{"version":3,"file":"static/js/main.e840899c.js","mappings":"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0rB,GACE5E,EACA7C,EACAkH,EACAC,EACA,KAAmC,MAA5BnH,EAAa1E,gBAEpB,KAARz/B,GACEirC,GACE9G,EAAapkC,UACbokC,GAEJ,MACF,KAAK,GACHiH,GACEpE,EACA7C,EACAkH,EACAC,GAEM,KAARtrC,GACEmrC,GAA8BhH,EAAapkC,UAAWokC,GACxD,MACF,QACEiH,GACEpE,EACA7C,EACAkH,EACAC,GAGR,CACA,SAASM,GACPb,EACA9B,EACA4C,EACAC,EACAd,GAIA,IAFAA,EACEA,GAAgC,KAAkC,MAA3B/B,EAAYxJ,cAChDwJ,EAAcA,EAAY1oC,MAAO,OAAS0oC,GAAe,CAC5D,IAAIjC,EAAe+D,EACjB5G,EAAe8E,EACfoC,EAAiBQ,EACjBP,EAAuBQ,EACvB9rC,EAAQmkC,EAAankC,MACvB,OAAQmkC,EAAax5C,KACnB,KAAK,EACL,KAAK,GACL,KAAK,GACHihD,GACE5E,EACA7C,EACAkH,EACAC,EACAN,GAEF9G,GAA0B,EAAGC,GAC7B,MACF,KAAK,GACH,MACF,KAAK,GACH,IAAIhiB,EAAWgiB,EAAan8B,UAC5B,OAASm8B,EAAahkC,cACK,EAAvBgiB,EAASjC,YACP0rB,GACE5E,EACA7C,EACAkH,EACAC,EACAN,GAEFW,GACE3E,EACA7C,IAEFhiB,EAASjC,aAAe,EAC1B0rB,GACE5E,EACA7C,EACAkH,EACAC,EACAN,IAENA,GACU,KAARhrC,GACAirC,GACE9G,EAAapkC,UACbokC,GAEJ,MACF,KAAK,GACHyH,GACE5E,EACA7C,EACAkH,EACAC,EACAN,GAEFA,GACU,KAARhrC,GACAmrC,GAA8BhH,EAAapkC,UAAWokC,GACxD,MACF,QACEyH,GACE5E,EACA7C,EACAkH,EACAC,EACAN,GAGN/B,EAAcA,EAAYzoC,OAC5B,CACF,CACA,SAASmrC,GACPZ,EACA9B,GAEA,GAA+B,MAA3BA,EAAYxJ,aACd,IAAKwJ,EAAcA,EAAY1oC,MAAO,OAAS0oC,GAAe,CAC5D,IAAIjC,EAAe+D,EACjB5G,EAAe8E,EACfjpC,EAAQmkC,EAAankC,MACvB,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AA,EACA7C,mBAAA,EACAz3M,QAAA,EACA06M,eAAA,IAIGroO,CAAA,CGlUT,ICIM+kI,GAAS,SAACnmI,GAAA,gBCCQA,EACtBa,EACAD,EACAg9E,GAAA,YAAAA,IAAAA,EAAkB78E,MAEb/E,EAAAA,GAAAA,oBAAmB4E,GAAA,OACf2gE,GAAiB,EAAG92D,OAAO7J,IAAA,IAK9B8+E,EAAmB,kBAAa7+E,EAAqBD,EAAKg9E,EAAS4lD,GAAAnuE,WAAA,EAAAj3D,WAAA,SAGzEshF,EAAiBiqJ,WAAa,SAAA3tO,GAAA,OAC5BgE,EAAqBa,EAAsBD,EAAAxG,GAAA,GAAUwjF,EAAA,GAAY5hF,GAAA,EAGnE0jF,EAAiB/nE,MAAQ,SAAA3b,GAAA,OACvBgE,EAAqBa,EAAsBD,EAAAxG,GAAA,GACtCwjF,EAAA,CACHjmE,MAAO/hB,MAAMqI,UAAU5I,OAAOuoF,EAAQjmE,MAAO3b,GAAOsd,OAAOo/E,WAAA,EAGxDhZ,CAAA,CDzBO,CAAqCwnD,GAAiBlnI,EAAA,EDJvD,CACb,IACA,OACA,UACA,OACA,UACA,QACA,QACA,IACA,OACA,MACA,MACA,MACA,aACA,OACA,KACA,SACA,SACA,UACA,OACA,OACA,MACA,WACA,OACA,WACA,KACA,MACA,UACA,MACA,SACA,MACA,KACA,KACA,KACA,QACA,WACA,aACA,SACA,SACA,OACA,KACA,KACA,KACA,KACA,KACA,KACA,OACA,SACA,SACA,KACA,OACA,IACA,SACA,MACA,QACA,MACA,MACA,SACA,QACA,SACA,KACA,OACA,OACA,MACA,OACA,UACA,OACA,WACA,OACA,QACA,MACA,WACA,SACA,KACA,WACA,SACA,SACA,IACA,QACA,UACA,MACA,WACA,IACA,KACA,KACA,OACA,IACA,OACA,SACA,UACA,SACA,QACA,SACA,OACA,SACA,QACA,MACA,UACA,MACA,QACA,QACA,KACA,WACA,QACA,KACA,QACA,OACA,QACA,KACA,QACA,IACA,KACA,MACA,QACA,MAGA,SACA,WACA,OACA,UACA,gBACA,IACA,QACA,OACA,iBA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","sources":["../node_modules/fast-diff/diff.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/hoist-non-react-statics/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/hoist-non-react-statics/node_modules/react-is/index.js","../node_modules/lodash.clonedeep/index.js","../node_modules/lodash.isequal/index.js","../node_modules/lodash/_DataView.js","../node_modules/lodash/_Hash.js","../node_modules/lodash/_ListCache.js","../node_modules/lodash/_Map.js","../node_modules/lodash/_MapCache.js","../node_modules/lodash/_Promise.js","../node_modules/lodash/_Set.js","../node_modules/lodash/_SetCache.js","../node_modules/lodash/_Stack.js","../node_modules/lodash/_Symbol.js","../node_modules/lodash/_Uint8Array.js","../node_modules/lodash/_WeakMap.js","../node_modules/lodash/_arrayFilter.js","../node_modules/lodash/_arrayLikeKeys.js","../node_modules/lodash/_arrayPush.js","../node_modules/lodash/_arraySome.js","../node_modules/lodash/_assocIndexOf.js","../node_modules/lodash/_baseGetAllKeys.js","../node_modules/lodash/_baseGetTag.js","../node_modules/lodash/_baseIsArguments.js","../node_modules/lodash/_baseIsEqual.js","../node_modules/lodash/_baseIsEqualDeep.js","../node_modules/lodash/_baseIsNative.js","../node_modules/lodash/_baseIsTypedArray.js","../node_modules/lodash/_baseKeys.js","../node_modules/lodash/_baseTimes.js","../node_modules/lodash/_baseUnary.js","../node_modules/lodash/_cacheHas.js","../node_modules/lodash/_coreJsData.js","../node_modules/lodash/_equalArrays.js","../node_modules/lodash/_equalByTag.js","../node_modules/lodash/_equalObjects.js","../node_modules/lodash/_freeGlobal.js","../node_modules/lodash/_getAllKeys.js","../node_modules/lodash/_getMapData.js","../node_modules/lodash/_getNative.js","../node_modules/lodash/_getRawTag.js","../node_modules/lodash/_getSymbols.js","../node_modules/lodash/_getTag.js","../node_modules/lodash/_getValue.js","../node_modules/lodash/_hashClear.js","../node_modules/lodash/_hashDelete.js","../node_modules/lodash/_hashGet.js","../node_modules/lodash/_hashHas.js","../node_modules/lodash/_hashSet.js","../node_modules/lodash/_isIndex.js","../node_modules/lodash/_isKeyable.js","../node_modules/lodash/_isMasked.js","../node_modules/lodash/_isPrototype.js","../node_modules/lodash/_listCacheClear.js","../node_modules/lodash/_listCacheDelete.js","../node_modules/lodash/_listCacheGet.js","../node_modules/lodash/_listCacheHas.js","../node_modules/lodash/_listCacheSet.js","../node_modules/lodash/_mapCacheClear.js","../node_modules/lodash/_mapCacheDelete.js","../node_modules/lodash/_mapCacheGet.js","../node_modules/lodash/_mapCacheHas.js","../node_modules/lodash/_mapCacheSet.js","../node_modules/lodash/_mapToArray.js","../node_modules/lodash/_nativeCreate.js","../node_modules/lodash/_nativeKeys.js","../node_modules/lodash/_nodeUtil.js","../node_modules/lodash/_objectToString.js","../node_modules/lodash/_overArg.js","../node_modules/lodash/_root.js","../node_modules/lodash/_setCacheAdd.js","../node_modules/lodash/_setCacheHas.js","../node_modules/lodash/_setToArray.js","../node_modules/lodash/_stackClear.js","../node_modules/lodash/_stackDelete.js","../node_modules/lodash/_stackGet.js","../node_modules/lodash/_stackHas.js","../node_modules/lodash/_stackSet.js","../node_modules/lodash/_toSource.js","../node_modules/lodash/eq.js","../node_modules/lodash/isArguments.js","../node_modules/lodash/isArray.js","../node_modules/lodash/isArrayLike.js","../node_modules/lodash/isBuffer.js","../node_modules/lodash/isEqual.js","../node_modules/lodash/isFunction.js","../node_modules/lodash/isLength.js","../node_modules/lodash/isObject.js","../node_modules/lodash/isObjectLike.js","../node_modules/lodash/isTypedArray.js","../node_modules/lodash/keys.js","../node_modules/lodash/stubArray.js","../node_modules/lodash/stubFalse.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/quill-delta/src/AttributeMap.ts","../node_modules/quill-delta/src/Delta.ts","../node_modules/quill-delta/src/Op.ts","../node_modules/quill-delta/src/OpIterator.ts","../node_modules/react-dom/cjs/react-dom-client.production.js","../node_modules/react-dom/cjs/react-dom.production.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/index.js","../node_modules/react-quill-new/node_modules/eventemitter3/index.js","../node_modules/react-router/node_modules/cookie/src/index.ts","../node_modules/react-swipeable-views-core/lib/checkIndexBounds.js","../node_modules/react-swipeable-views-core/lib/computeIndex.js","../node_modules/react-swipeable-views-core/lib/constant.js","../node_modules/react-swipeable-views-core/lib/getDisplaySameSlide.js","../node_modules/react-swipeable-views-core/lib/index.js","../node_modules/react-swipeable-views-core/lib/mod.js","../node_modules/react-swipeable-views/lib/SwipeableViews.js","../node_modules/react-swipeable-views/lib/index.js","../node_modules/react/cjs/react-jsx-runtime.production.js","../node_modules/react/cjs/react.production.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/scheduler/cjs/scheduler.production.js","../node_modules/scheduler/index.js","../node_modules/shallowequal/index.js","../node_modules/warning/warning.js","../node_modules/react-swipeable-views-core/node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/assertThisInitialized.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/classCallCheck.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/createClass.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/extends.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/getPrototypeOf.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/inherits.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/objectWithoutProperties.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/setPrototypeOf.js","../node_modules/react-swipeable-views/node_modules/@babel/runtime/helpers/typeof.js","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/node module decorator","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","../webpack/runtime/nonce","../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/react-router/dist/development/chunk-K6AXKMTT.mjs","../node_modules/@firebase/util/src/constants.ts","../node_modules/@firebase/util/src/crypt.ts","../node_modules/@firebase/util/src/defaults.ts","../node_modules/@firebase/util/src/global.ts","../node_modules/@firebase/util/src/deferred.ts","../node_modules/@firebase/util/src/emulator.ts","../node_modules/@firebase/util/src/environment.ts","../node_modules/@firebase/util/src/errors.ts","../node_modules/@firebase/util/src/obj.ts","../node_modules/@firebase/util/src/query.ts","../node_modules/@firebase/util/src/subscribe.ts","../node_modules/@firebase/util/src/compat.ts","../node_modules/@firebase/component/src/component.ts","../node_modules/@firebase/component/src/constants.ts","../node_modules/@firebase/component/src/provider.ts","../node_modules/@firebase/component/src/component_container.ts","../node_modules/@firebase/logger/src/logger.ts","../node_modules/idb/build/wrap-idb-value.js","../node_modules/idb/build/index.js","../node_modules/@firebase/app/src/platformLoggerService.ts","../node_modules/@firebase/app/src/logger.ts","../node_modules/@firebase/app/src/constants.ts","../node_modules/@firebase/app/src/internal.ts","../node_modules/@firebase/app/src/errors.ts","../node_modules/@firebase/app/src/firebaseApp.ts","../node_modules/@firebase/app/src/api.ts","../node_modules/@firebase/app/src/indexeddb.ts","../node_modules/@firebase/app/src/heartbeatService.ts","../node_modules/@firebase/app/src/registerCoreComponents.ts","../node_modules/@firebase/app/src/index.ts","../node_modules/firebase/app/index.ts","../node_modules/node_modules/closure-net/firebase/bloom_blob_es2018.js","../node_modules/node_modules/closure-net/firebase/webchannel_blob_es2018.js","../node_modules/@firebase/firestore/src/auth/user.ts","../node_modules/@firebase/firestore/src/core/version.ts","../node_modules/@firebase/firestore/src/util/log.ts","../node_modules/@firebase/firestore/src/platform/browser/format_json.ts","../node_modules/@firebase/firestore/src/util/assert.ts","../node_modules/@firebase/firestore/src/util/error.ts","../node_modules/@firebase/firestore/src/util/promise.ts","../node_modules/@firebase/firestore/src/api/credentials.ts","../node_modules/@firebase/firestore/src/platform/browser/random_bytes.ts","../node_modules/@firebase/firestore/src/util/misc.ts","../node_modules/@firebase/firestore/src/lite-api/timestamp.ts","../node_modules/@firebase/firestore/src/core/snapshot_version.ts","../node_modules/@firebase/firestore/src/model/path.ts","../node_modules/@firebase/firestore/src/model/document_key.ts","../node_modules/@firebase/firestore/src/model/field_index.ts","../node_modules/@firebase/firestore/src/local/persistence_transaction.ts","../node_modules/@firebase/firestore/src/local/local_store.ts","../node_modules/@firebase/firestore/src/local/persistence_promise.ts","../node_modules/@firebase/firestore/src/local/simple_db.ts","../node_modules/@firebase/firestore/src/core/listen_sequence.ts","../node_modules/@firebase/firestore/src/util/types.ts","../node_modules/@firebase/firestore/src/local/encoded_resource_path.ts","../node_modules/@firebase/firestore/src/local/indexeddb_sentinels.ts","../node_modules/@firebase/firestore/src/local/indexeddb_schema_legacy.ts","../node_modules/@firebase/firestore/src/util/obj.ts","../node_modules/@firebase/firestore/src/util/sorted_map.ts","../node_modules/@firebase/firestore/src/util/sorted_set.ts","../node_modules/@firebase/firestore/src/model/field_mask.ts","../node_modules/@firebase/firestore/src/util/base64_decode_error.ts","../node_modules/@firebase/firestore/src/util/byte_string.ts","../node_modules/@firebase/firestore/src/platform/browser/base64.ts","../node_modules/@firebase/firestore/src/model/normalize.ts","../node_modules/@firebase/firestore/src/model/server_timestamps.ts","../node_modules/@firebase/firestore/src/core/database_info.ts","../node_modules/@firebase/firestore/src/model/values.ts","../node_modules/@firebase/firestore/src/model/object_value.ts","../node_modules/@firebase/firestore/src/model/document.ts","../node_modules/@firebase/firestore/src/core/bound.ts","../node_modules/@firebase/firestore/src/core/order_by.ts","../node_modules/@firebase/firestore/src/core/filter.ts","../node_modules/@firebase/firestore/src/core/target.ts","../node_modules/@firebase/firestore/src/core/query.ts","../node_modules/@firebase/firestore/src/util/obj_map.ts","../node_modules/@firebase/firestore/src/model/collections.ts","../node_modules/@firebase/firestore/src/remote/number_serializer.ts","../node_modules/@firebase/firestore/src/model/transform_operation.ts","../node_modules/@firebase/firestore/src/model/mutation.ts","../node_modules/@firebase/firestore/src/model/mutation_batch.ts","../node_modules/@firebase/firestore/src/model/overlay.ts","../node_modules/@firebase/firestore/src/remote/existence_filter.ts","../node_modules/@firebase/firestore/src/remote/rpc_error.ts","../node_modules/@firebase/firestore/src/util/testing_hooks_spi.ts","../node_modules/@firebase/firestore/src/platform/browser/text_serializer.ts","../node_modules/@firebase/firestore/src/remote/bloom_filter.ts","../node_modules/@firebase/firestore/src/remote/remote_event.ts","../node_modules/@firebase/firestore/src/remote/watch_change.ts","../node_modules/@firebase/firestore/src/remote/serializer.ts","../node_modules/@firebase/firestore/src/local/target_data.ts","../node_modules/@firebase/firestore/src/local/local_serializer.ts","../node_modules/@firebase/firestore/src/index/firestore_index_value_writer.ts","../node_modules/@firebase/firestore/src/local/memory_index_manager.ts","../node_modules/@firebase/firestore/src/local/indexeddb_index_manager.ts","../node_modules/@firebase/firestore/src/local/lru_garbage_collector.ts","../node_modules/@firebase/firestore/src/core/target_id_generator.ts","../node_modules/@firebase/firestore/src/local/lru_garbage_collector_impl.ts","../node_modules/@firebase/firestore/src/local/remote_document_change_buffer.ts","../node_modules/@firebase/firestore/src/local/overlayed_document.ts","../node_modules/@firebase/firestore/src/local/local_documents_view.ts","../node_modules/@firebase/firestore/src/local/memory_bundle_cache.ts","../node_modules/@firebase/firestore/src/local/memory_document_overlay_cache.ts","../node_modules/@firebase/firestore/src/local/memory_globals_cache.ts","../node_modules/@firebase/firestore/src/local/reference_set.ts","../node_modules/@firebase/firestore/src/local/memory_mutation_queue.ts","../node_modules/@firebase/firestore/src/local/memory_remote_document_cache.ts","../node_modules/@firebase/firestore/src/local/memory_target_cache.ts","../node_modules/@firebase/firestore/src/local/memory_persistence.ts","../node_modules/@firebase/firestore/src/local/local_view_changes.ts","../node_modules/@firebase/firestore/src/local/query_context.ts","../node_modules/@firebase/firestore/src/local/query_engine.ts","../node_modules/@firebase/firestore/src/local/local_store_impl.ts","../node_modules/@firebase/firestore/src/local/shared_client_state.ts","../node_modules/@firebase/firestore/src/remote/connectivity_monitor_noop.ts","../node_modules/@firebase/firestore/src/platform/browser/connectivity_monitor.ts","../node_modules/@firebase/firestore/src/util/debug_uid.ts","../node_modules/@firebase/firestore/src/remote/rest_connection.ts","../node_modules/@firebase/firestore/src/remote/stream_bridge.ts","../node_modules/@firebase/firestore/src/platform/browser/webchannel_connection.ts","../node_modules/@firebase/firestore/src/platform/browser/dom.ts","../node_modules/@firebase/firestore/src/platform/browser/serializer.ts","../node_modules/@firebase/firestore/src/remote/backoff.ts","../node_modules/@firebase/firestore/src/remote/persistent_stream.ts","../node_modules/@firebase/firestore/src/remote/datastore.ts","../node_modules/@firebase/firestore/src/remote/online_state_tracker.ts","../node_modules/@firebase/firestore/src/remote/remote_store.ts","../node_modules/@firebase/firestore/src/util/async_queue.ts","../node_modules/@firebase/firestore/src/model/document_set.ts","../node_modules/@firebase/firestore/src/core/view_snapshot.ts","../node_modules/@firebase/firestore/src/core/event_manager.ts","../node_modules/@firebase/firestore/src/core/view.ts","../node_modules/@firebase/firestore/src/core/sync_engine_impl.ts","../node_modules/@firebase/firestore/src/core/component_provider.ts","../node_modules/@firebase/firestore/src/platform/browser/connection.ts","../node_modules/@firebase/firestore/src/util/async_observer.ts","../node_modules/@firebase/firestore/src/core/firestore_client.ts","../node_modules/@firebase/firestore/src/api/long_polling_options.ts","../node_modules/@firebase/firestore/src/lite-api/components.ts","../node_modules/@firebase/firestore/src/util/input_validation.ts","../node_modules/@firebase/firestore/src/lite-api/settings.ts","../node_modules/@firebase/firestore/src/lite-api/database.ts","../node_modules/@firebase/firestore/src/lite-api/reference.ts","../node_modules/@firebase/firestore/src/util/async_queue_impl.ts","../node_modules/@firebase/firestore/src/api/database.ts","../node_modules/@firebase/firestore/src/lite-api/bytes.ts","../node_modules/@firebase/firestore/src/lite-api/field_path.ts","../node_modules/@firebase/firestore/src/lite-api/field_value.ts","../node_modules/@firebase/firestore/src/lite-api/geo_point.ts","../node_modules/@firebase/firestore/src/lite-api/vector_value.ts","../node_modules/@firebase/firestore/src/util/array.ts","../node_modules/@firebase/firestore/src/lite-api/user_data_reader.ts","../node_modules/@firebase/firestore/src/lite-api/snapshot.ts","../node_modules/@firebase/firestore/src/lite-api/query.ts","../node_modules/@firebase/firestore/src/lite-api/user_data_writer.ts","../node_modules/@firebase/firestore/src/lite-api/reference_impl.ts","../node_modules/@firebase/firestore/src/api/snapshot.ts","../node_modules/@firebase/firestore/src/api/reference_impl.ts","../node_modules/@firebase/firestore/src/api/persistent_cache_index_manager.ts","../node_modules/@firebase/firestore/src/register.ts","../node_modules/@firebase/firestore/src/index.ts","firebaseConfig.js","../node_modules/@firebase/storage/src/implementation/constants.ts","../node_modules/@firebase/storage/src/implementation/error.ts","../node_modules/@firebase/storage/src/implementation/connection.ts","../node_modules/@firebase/storage/src/implementation/location.ts","../node_modules/@firebase/storage/src/implementation/failrequest.ts","../node_modules/@firebase/storage/src/implementation/type.ts","../node_modules/@firebase/storage/src/implementation/url.ts","../node_modules/@firebase/storage/src/implementation/utils.ts","../node_modules/@firebase/storage/src/implementation/request.ts","../node_modules/@firebase/storage/src/implementation/backoff.ts","../node_modules/@firebase/storage/src/implementation/fs.ts","../node_modules/@firebase/storage/src/platform/browser/base64.ts","../node_modules/@firebase/storage/src/implementation/string.ts","../node_modules/@firebase/storage/src/implementation/blob.ts","../node_modules/@firebase/storage/src/implementation/json.ts","../node_modules/@firebase/storage/src/implementation/path.ts","../node_modules/@firebase/storage/src/implementation/metadata.ts","../node_modules/@firebase/storage/src/implementation/requestinfo.ts","../node_modules/@firebase/storage/src/implementation/requests.ts","../node_modules/@firebase/storage/src/implementation/taskenums.ts","../node_modules/@firebase/storage/src/implementation/observer.ts","../node_modules/@firebase/storage/src/implementation/async.ts","../node_modules/@firebase/storage/src/platform/browser/connection.ts","../node_modules/@firebase/storage/src/task.ts","../node_modules/@firebase/storage/src/reference.ts","../node_modules/@firebase/storage/src/service.ts","../node_modules/@firebase/storage/src/constants.ts","../node_modules/@firebase/storage/src/api.ts","../node_modules/@firebase/storage/src/index.ts","../node_modules/lodash-es/_listCacheClear.js","../node_modules/lodash-es/eq.js","../node_modules/lodash-es/_assocIndexOf.js","../node_modules/lodash-es/_listCacheDelete.js","../node_modules/lodash-es/_listCacheGet.js","../node_modules/lodash-es/_listCacheHas.js","../node_modules/lodash-es/_listCacheSet.js","../node_modules/lodash-es/_ListCache.js","../node_modules/lodash-es/_stackClear.js","../node_modules/lodash-es/_stackDelete.js","../node_modules/lodash-es/_stackGet.js","../node_modules/lodash-es/_stackHas.js","../node_modules/lodash-es/_freeGlobal.js","../node_modules/lodash-es/_root.js","../node_modules/lodash-es/_Symbol.js","../node_modules/lodash-es/_getRawTag.js","../node_modules/lodash-es/_objectToString.js","../node_modules/lodash-es/_baseGetTag.js","../node_modules/lodash-es/isObject.js","../node_modules/lodash-es/isFunction.js","../node_modules/lodash-es/_coreJsData.js","../node_modules/lodash-es/_isMasked.js","../node_modules/lodash-es/_toSource.js","../node_modules/lodash-es/_baseIsNative.js","../node_modules/lodash-es/_getValue.js","../node_modules/lodash-es/_getNative.js","../node_modules/lodash-es/_Map.js","../node_modules/lodash-es/_nativeCreate.js","../node_modules/lodash-es/_hashClear.js","../node_modules/lodash-es/_hashDelete.js","../node_modules/lodash-es/_hashGet.js","../node_modules/lodash-es/_hashHas.js","../node_modules/lodash-es/_hashSet.js","../node_modules/lodash-es/_Hash.js","../node_modules/lodash-es/_mapCacheClear.js","../node_modules/lodash-es/_isKeyable.js","../node_modules/lodash-es/_getMapData.js","../node_modules/lodash-es/_mapCacheDelete.js","../node_modules/lodash-es/_mapCacheGet.js","../node_modules/lodash-es/_mapCacheHas.js","../node_modules/lodash-es/_mapCacheSet.js","../node_modules/lodash-es/_MapCache.js","../node_modules/lodash-es/_stackSet.js","../node_modules/lodash-es/_Stack.js","../node_modules/lodash-es/_defineProperty.js","../node_modules/lodash-es/_baseAssignValue.js","../node_modules/lodash-es/_assignMergeValue.js","../node_modules/lodash-es/_baseFor.js","../node_modules/lodash-es/_createBaseFor.js","../node_modules/lodash-es/_cloneBuffer.js","../node_modules/lodash-es/_Uint8Array.js","../node_modules/lodash-es/_cloneArrayBuffer.js","../node_modules/lodash-es/_cloneTypedArray.js","../node_modules/lodash-es/_copyArray.js","../node_modules/lodash-es/_baseCreate.js","../node_modules/lodash-es/_overArg.js","../node_modules/lodash-es/_getPrototype.js","../node_modules/lodash-es/_isPrototype.js","../node_modules/lodash-es/_initCloneObject.js","../node_modules/lodash-es/isObjectLike.js","../node_modules/lodash-es/_baseIsArguments.js","../node_modules/lodash-es/isArguments.js","../node_modules/lodash-es/isArray.js","../node_modules/lodash-es/isLength.js","../node_modules/lodash-es/isArrayLike.js","../node_modules/lodash-es/isArrayLikeObject.js","../node_modules/lodash-es/stubFalse.js","../node_modules/lodash-es/isBuffer.js","../node_modules/lodash-es/isPlainObject.js","../node_modules/lodash-es/_baseIsTypedArray.js","../node_modules/lodash-es/_baseUnary.js","../node_modules/lodash-es/_nodeUtil.js","../node_modules/lodash-es/isTypedArray.js","../node_modules/lodash-es/_safeGet.js","../node_modules/lodash-es/_assignValue.js","../node_modules/lodash-es/_copyObject.js","../node_modules/lodash-es/_baseTimes.js","../node_modules/lodash-es/_isIndex.js","../node_modules/lodash-es/_arrayLikeKeys.js","../node_modules/lodash-es/_nativeKeysIn.js","../node_modules/lodash-es/_baseKeysIn.js","../node_modules/lodash-es/keysIn.js","../node_modules/lodash-es/toPlainObject.js","../node_modules/lodash-es/_baseMergeDeep.js","../node_modules/lodash-es/_baseMerge.js","../node_modules/lodash-es/identity.js","../node_modules/lodash-es/_apply.js","../node_modules/lodash-es/_overRest.js","../node_modules/lodash-es/constant.js","../node_modules/lodash-es/_baseSetToString.js","../node_modules/lodash-es/_shortOut.js","../node_modules/lodash-es/_setToString.js","../node_modules/lodash-es/_baseRest.js","../node_modules/lodash-es/_isIterateeCall.js","../node_modules/lodash-es/merge.js","../node_modules/lodash-es/_createAssigner.js","../node_modules/react-quill-new/node_modules/parchment/src/scope.ts","../node_modules/react-quill-new/node_modules/parchment/src/attributor/attributor.ts","../node_modules/react-quill-new/node_modules/parchment/src/error.ts","../node_modules/react-quill-new/node_modules/parchment/src/registry.ts","../node_modules/react-quill-new/node_modules/parchment/src/attributor/class.ts","../node_modules/react-quill-new/node_modules/parchment/src/attributor/style.ts","../node_modules/react-quill-new/node_modules/parchment/src/attributor/store.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/abstract/shadow.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/abstract/leaf.ts","../node_modules/react-quill-new/node_modules/parchment/src/collection/linked-list.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/abstract/parent.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/inline.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/block.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/abstract/container.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/embed.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/scroll.ts","../node_modules/react-quill-new/node_modules/parchment/src/blot/text.ts","../node_modules/lodash-es/_arrayEach.js","../node_modules/lodash-es/_nativeKeys.js","../node_modules/lodash-es/_baseKeys.js","../node_modules/lodash-es/keys.js","../node_modules/lodash-es/_baseAssign.js","../node_modules/lodash-es/_baseAssignIn.js","../node_modules/lodash-es/_arrayFilter.js","../node_modules/lodash-es/stubArray.js","../node_modules/lodash-es/_getSymbols.js","../node_modules/lodash-es/_copySymbols.js","../node_modules/lodash-es/_arrayPush.js","../node_modules/lodash-es/_getSymbolsIn.js","../node_modules/lodash-es/_copySymbolsIn.js","../node_modules/lodash-es/_baseGetAllKeys.js","../node_modules/lodash-es/_getAllKeys.js","../node_modules/lodash-es/_getAllKeysIn.js","../node_modules/lodash-es/_DataView.js","../node_modules/lodash-es/_Promise.js","../node_modules/lodash-es/_Set.js","../node_modules/lodash-es/_WeakMap.js","../node_modules/lodash-es/_getTag.js","../node_modules/lodash-es/_initCloneArray.js","../node_modules/lodash-es/_cloneDataView.js","../node_modules/lodash-es/_cloneRegExp.js","../node_modules/lodash-es/_cloneSymbol.js","../node_modules/lodash-es/_initCloneByTag.js","../node_modules/lodash-es/_baseIsMap.js","../node_modules/lodash-es/isMap.js","../node_modules/lodash-es/_baseIsSet.js","../node_modules/lodash-es/isSet.js","../node_modules/lodash-es/_baseClone.js","../node_modules/lodash-es/cloneDeep.js","../node_modules/lodash-es/_setCacheAdd.js","../node_modules/lodash-es/_setCacheHas.js","../node_modules/lodash-es/_SetCache.js","../node_modules/lodash-es/_arraySome.js","../node_modules/lodash-es/_cacheHas.js","../node_modules/lodash-es/_equalArrays.js","../node_modules/lodash-es/_mapToArray.js","../node_modules/lodash-es/_setToArray.js","../node_modules/lodash-es/_equalByTag.js","../node_modules/lodash-es/_equalObjects.js","../node_modules/lodash-es/_baseIsEqualDeep.js","../node_modules/lodash-es/_baseIsEqual.js","../node_modules/lodash-es/isEqual.js","../node_modules/react-quill-new/node_modules/src/blots/break.ts","../node_modules/react-quill-new/node_modules/src/blots/text.ts","../node_modules/react-quill-new/node_modules/src/blots/inline.ts","../node_modules/react-quill-new/node_modules/src/blots/block.ts","../node_modules/react-quill-new/node_modules/src/blots/cursor.ts","../node_modules/react-quill-new/node_modules/eventemitter3/index.mjs","../node_modules/react-quill-new/node_modules/src/core/instances.ts","../node_modules/react-quill-new/node_modules/src/core/logger.ts","../node_modules/react-quill-new/node_modules/src/core/emitter.ts","../node_modules/react-quill-new/node_modules/src/core/selection.ts","../node_modules/react-quill-new/node_modules/src/core/editor.ts","../node_modules/react-quill-new/node_modules/src/core/module.ts","../node_modules/react-quill-new/node_modules/src/blots/embed.ts","../node_modules/react-quill-new/node_modules/src/core/composition.ts","../node_modules/react-quill-new/node_modules/src/core/theme.ts","../node_modules/react-quill-new/node_modules/src/core/utils/scrollRectIntoView.ts","../node_modules/react-quill-new/node_modules/src/core/utils/createRegistryWithFormats.ts","../node_modules/react-quill-new/node_modules/src/core/quill.ts","../node_modules/react-quill-new/node_modules/src/blots/container.ts","../node_modules/react-quill-new/node_modules/src/blots/scroll.ts","../node_modules/react-quill-new/node_modules/src/formats/align.ts","../node_modules/react-quill-new/node_modules/src/formats/color.ts","../node_modules/react-quill-new/node_modules/src/formats/background.ts","../node_modules/react-quill-new/node_modules/src/formats/code.ts","../node_modules/react-quill-new/node_modules/src/formats/direction.ts","../node_modules/react-quill-new/node_modules/src/formats/font.ts","../node_modules/react-quill-new/node_modules/src/formats/size.ts","../node_modules/react-quill-new/node_modules/src/modules/keyboard.ts","../node_modules/react-quill-new/node_modules/src/modules/normalizeExternalHTML/normalizers/googleDocs.ts","../node_modules/react-quill-new/node_modules/src/modules/normalizeExternalHTML/normalizers/msWord.ts","../node_modules/react-quill-new/node_modules/src/modules/normalizeExternalHTML/index.ts","../node_modules/react-quill-new/node_modules/src/modules/clipboard.ts","../node_modules/react-quill-new/node_modules/src/modules/history.ts","../node_modules/react-quill-new/node_modules/src/modules/uploader.ts","../node_modules/react-quill-new/node_modules/src/modules/input.ts","../node_modules/react-quill-new/node_modules/src/modules/uiNode.ts","../node_modules/react-quill-new/node_modules/src/core.ts","../node_modules/react-quill-new/node_modules/src/formats/indent.ts","../node_modules/react-quill-new/node_modules/src/formats/blockquote.ts","../node_modules/react-quill-new/node_modules/src/formats/header.ts","../node_modules/react-quill-new/node_modules/src/formats/list.ts","../node_modules/react-quill-new/node_modules/src/formats/bold.ts","../node_modules/react-quill-new/node_modules/src/formats/italic.ts","../node_modules/react-quill-new/node_modules/src/formats/link.ts","../node_modules/react-quill-new/node_modules/src/formats/script.ts","../node_modules/react-quill-new/node_modules/src/formats/strike.ts","../node_modules/react-quill-new/node_modules/src/formats/underline.ts","../node_modules/react-quill-new/node_modules/src/formats/formula.ts","../node_modules/react-quill-new/node_modules/src/formats/image.ts","../node_modules/react-quill-new/node_modules/src/formats/video.ts","../node_modules/react-quill-new/node_modules/src/modules/syntax.ts","../node_modules/react-quill-new/node_modules/src/formats/table.ts","../node_modules/react-quill-new/node_modules/src/modules/table.ts","../node_modules/react-quill-new/node_modules/src/modules/toolbar.ts","../node_modules/react-quill-new/node_modules/src/ui/icons.ts","../node_modules/react-quill-new/node_modules/src/ui/picker.ts","../node_modules/react-quill-new/node_modules/src/ui/color-picker.ts","../node_modules/react-quill-new/node_modules/src/ui/icon-picker.ts","../node_modules/react-quill-new/node_modules/src/ui/tooltip.ts","../node_modules/react-quill-new/node_modules/src/themes/base.ts","../node_modules/react-quill-new/node_modules/src/themes/bubble.ts","../node_modules/react-quill-new/node_modules/src/themes/snow.ts","../node_modules/react-quill-new/node_modules/src/quill.ts","../node_modules/react-quill-new/src/index.tsx","adminDashboard.js","../node_modules/tslib/tslib.es6.mjs","../node_modules/@firebase/auth/src/core/errors.ts","../node_modules/@firebase/auth/src/core/util/log.ts","../node_modules/@firebase/auth/src/core/util/assert.ts","../node_modules/@firebase/auth/src/core/util/location.ts","../node_modules/@firebase/auth/src/core/util/navigator.ts","../node_modules/@firebase/auth/src/core/util/delay.ts","../node_modules/@firebase/auth/src/core/util/emulator.ts","../node_modules/@firebase/auth/src/core/util/fetch_provider.ts","../node_modules/@firebase/auth/src/api/errors.ts","../node_modules/@firebase/auth/src/api/index.ts","../node_modules/@firebase/auth/src/platform_browser/recaptcha/recaptcha.ts","../node_modules/@firebase/auth/src/api/authentication/recaptcha.ts","../node_modules/@firebase/auth/src/api/account_management/account.ts","../node_modules/@firebase/auth/src/core/util/time.ts","../node_modules/@firebase/auth/src/core/user/id_token_result.ts","../node_modules/@firebase/auth/src/core/user/invalidation.ts","../node_modules/@firebase/auth/src/core/user/proactive_refresh.ts","../node_modules/@firebase/auth/src/core/user/user_metadata.ts","../node_modules/@firebase/auth/src/core/user/reload.ts","../node_modules/@firebase/auth/src/core/user/token_manager.ts","../node_modules/@firebase/auth/src/api/authentication/token.ts","../node_modules/@firebase/auth/src/core/user/user_impl.ts","../node_modules/@firebase/auth/src/core/util/instantiator.ts","../node_modules/@firebase/auth/src/core/persistence/in_memory.ts","../node_modules/@firebase/auth/src/core/persistence/persistence_user_manager.ts","../node_modules/@firebase/auth/src/core/util/browser.ts","../node_modules/@firebase/auth/src/core/util/version.ts","../node_modules/@firebase/auth/src/core/auth/middleware.ts","../node_modules/@firebase/auth/src/core/auth/password_policy_impl.ts","../node_modules/@firebase/auth/src/core/auth/auth_impl.ts","../node_modules/@firebase/auth/src/api/password_policy/get_password_policy.ts","../node_modules/@firebase/auth/src/platform_browser/load_js.ts","../node_modules/@firebase/auth/src/platform_browser/recaptcha/recaptcha_mock.ts","../node_modules/@firebase/auth/src/platform_browser/recaptcha/recaptcha_enterprise_verifier.ts","../node_modules/@firebase/auth/src/core/auth/emulator.ts","../node_modules/@firebase/auth/src/core/credentials/auth_credential.ts","../node_modules/@firebase/auth/src/api/account_management/email_and_password.ts","../node_modules/@firebase/auth/src/api/authentication/email_and_password.ts","../node_modules/@firebase/auth/src/core/credentials/email.ts","../node_modules/@firebase/auth/src/api/authentication/email_link.ts","../node_modules/@firebase/auth/src/api/authentication/idp.ts","../node_modules/@firebase/auth/src/core/credentials/oauth.ts","../node_modules/@firebase/auth/src/api/authentication/sms.ts","../node_modules/@firebase/auth/src/core/credentials/phone.ts","../node_modules/@firebase/auth/src/core/action_code_url.ts","../node_modules/@firebase/auth/src/core/providers/email.ts","../node_modules/@firebase/auth/src/core/providers/federated.ts","../node_modules/@firebase/auth/src/core/providers/oauth.ts","../node_modules/@firebase/auth/src/core/providers/facebook.ts","../node_modules/@firebase/auth/src/core/providers/google.ts","../node_modules/@firebase/auth/src/core/providers/github.ts","../node_modules/@firebase/auth/src/core/providers/twitter.ts","../node_modules/@firebase/auth/src/core/user/user_credential_impl.ts","../node_modules/@firebase/auth/src/mfa/mfa_error.ts","../node_modules/@firebase/auth/src/core/user/link_unlink.ts","../node_modules/@firebase/auth/src/core/user/reauthenticate.ts","../node_modules/@firebase/auth/src/core/strategies/credential.ts","../node_modules/@firebase/auth/src/api/account_management/mfa.ts","../node_modules/@firebase/auth/src/mfa/mfa_user.ts","../node_modules/@firebase/auth/src/core/persistence/index.ts","../node_modules/@firebase/auth/src/platform_browser/persistence/browser.ts","../node_modules/@firebase/auth/src/platform_browser/persistence/local_storage.ts","../node_modules/@firebase/auth/src/platform_browser/persistence/session_storage.ts","../node_modules/@firebase/auth/src/platform_browser/messagechannel/receiver.ts","../node_modules/@firebase/auth/src/platform_browser/messagechannel/promise.ts","../node_modules/@firebase/auth/src/core/util/event_id.ts","../node_modules/@firebase/auth/src/platform_browser/messagechannel/sender.ts","../node_modules/@firebase/auth/src/platform_browser/auth_window.ts","../node_modules/@firebase/auth/src/platform_browser/util/worker.ts","../node_modules/@firebase/auth/src/platform_browser/persistence/indexed_db.ts","../node_modules/@firebase/auth/src/api/authentication/mfa.ts","../node_modules/@firebase/auth/src/platform_browser/recaptcha/recaptcha_loader.ts","../node_modules/@firebase/auth/src/platform_browser/recaptcha/recaptcha_verifier.ts","../node_modules/@firebase/auth/src/platform_browser/strategies/phone.ts","../node_modules/@firebase/auth/src/platform_browser/providers/phone.ts","../node_modules/@firebase/auth/src/core/util/resolver.ts","../node_modules/@firebase/auth/src/core/strategies/idp.ts","../node_modules/@firebase/auth/src/core/strategies/abstract_popup_redirect_operation.ts","../node_modules/@firebase/auth/src/platform_browser/strategies/popup.ts","../node_modules/@firebase/auth/src/core/strategies/redirect.ts","../node_modules/@firebase/auth/src/platform_browser/strategies/redirect.ts","../node_modules/@firebase/auth/src/core/auth/auth_event_manager.ts","../node_modules/@firebase/auth/src/core/util/validate_origin.ts","../node_modules/@firebase/auth/src/api/project_config/get_project_config.ts","../node_modules/@firebase/auth/src/platform_browser/iframe/gapi.ts","../node_modules/@firebase/auth/src/platform_browser/iframe/iframe.ts","../node_modules/@firebase/auth/src/platform_browser/util/popup.ts","../node_modules/@firebase/auth/src/core/util/handler.ts","../node_modules/@firebase/auth/src/platform_browser/popup_redirect.ts","../node_modules/@firebase/auth/src/core/auth/firebase_internal.ts","../node_modules/@firebase/auth/src/platform_browser/index.ts","../node_modules/@firebase/auth/src/core/auth/initialize.ts","../node_modules/@firebase/auth/src/core/index.ts","../node_modules/@firebase/auth/src/core/auth/register.ts","components/AuthButton.js","components/Header.js","components/HeroSection.js","components/AboutSection.js","components/TeamsSection.js","components/ContactSection.js","components/PromoteAppSection.js","../node_modules/@emotion/stylis/dist/stylis.browser.esm.js","../node_modules/react-brackets/node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/interleave.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isPlainObject.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/empties.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isFunction.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/getComponentName.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isStyledComponent.js","../node_modules/react-brackets/node_modules/styled-components/src/constants.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/error.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/GroupedTag.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/GroupIDAllocator.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/Rehydration.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/nonce.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/dom.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/Tag.js","../node_modules/react-brackets/node_modules/styled-components/src/sheet/Sheet.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/generateAlphabeticName.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/hash.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isStaticRules.js","../node_modules/react-brackets/node_modules/styled-components/src/models/ComponentStyle.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/stylis.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/stylisPluginInsertRule.js","../node_modules/react-brackets/node_modules/styled-components/src/models/StyleSheetManager.js","../node_modules/react-brackets/node_modules/styled-components/src/models/Keyframes.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/hyphenateStyleName.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/flatten.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isStatelessFunction.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/addUnitIfNeeded.js","../node_modules/react-brackets/node_modules/styled-components/src/constructors/css.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/checkDynamicCreation.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/determineTheme.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/escape.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/generateComponentId.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/isTag.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/mixinDeep.js","../node_modules/react-brackets/node_modules/styled-components/src/models/ThemeProvider.js","../node_modules/react-brackets/node_modules/styled-components/src/models/StyledComponent.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/generateDisplayName.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/joinStrings.js","../node_modules/react-brackets/node_modules/styled-components/src/utils/domElements.js","../node_modules/react-brackets/node_modules/styled-components/src/constructors/styled.js","../node_modules/react-brackets/node_modules/styled-components/src/constructors/constructWithOptions.js","../node_modules/react-brackets/node_modules/styled-components/src/models/GlobalStyle.js","../node_modules/react-brackets/node_modules/styled-components/src/models/ServerStyleSheet.js","../node_modules/react-brackets/node_modules/styled-components/src/base.js","../node_modules/react-brackets/src/components/round.ts","../node_modules/react-brackets/src/components/seed.ts","../node_modules/react-brackets/src/utils/renders.tsx","../node_modules/react-brackets/src/brackets/index.tsx","../node_modules/react-brackets/src/hooks/useMedia.tsx","components/TournamentsSection.js","components/NoticiasSection.js","components/AffiliatesSection.js","components/Footer.js","HomePage.js","components/ProtectedRoutes.js","App.js","reportWebVitals.js","index.js"],"sourcesContent":["/**\n * This library modifies the diff-patch-match library by Neil Fraser\n * by removing the patch and match functionality and certain advanced\n * options in the diff function. The original license is as follows:\n *\n * ===\n *\n * Diff Match and Patch\n *\n * Copyright 2006 Google Inc.\n * http://code.google.com/p/google-diff-match-patch/\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 data structure representing a diff is an array of tuples:\n * [[DIFF_DELETE, 'Hello'], [DIFF_INSERT, 'Goodbye'], [DIFF_EQUAL, ' world.']]\n * which means: delete 'Hello', add 'Goodbye' and keep ' world.'\n */\nvar DIFF_DELETE = -1;\nvar DIFF_INSERT = 1;\nvar DIFF_EQUAL = 0;\n\n/**\n * Find the differences between two texts.  Simplifies the problem by stripping\n * any common prefix or suffix off the texts before diffing.\n * @param {string} text1 Old string to be diffed.\n * @param {string} text2 New string to be diffed.\n * @param {Int|Object} [cursor_pos] Edit position in text1 or object with more info\n * @param {boolean} [cleanup] Apply semantic cleanup before returning.\n * @return {Array} Array of diff tuples.\n */\nfunction diff_main(text1, text2, cursor_pos, cleanup, _fix_unicode) {\n  // Check for equality\n  if (text1 === text2) {\n    if (text1) {\n      return [[DIFF_EQUAL, text1]];\n    }\n    return [];\n  }\n\n  if (cursor_pos != null) {\n    var editdiff = find_cursor_edit_diff(text1, text2, cursor_pos);\n    if (editdiff) {\n      return editdiff;\n    }\n  }\n\n  // Trim off common prefix (speedup).\n  var commonlength = diff_commonPrefix(text1, text2);\n  var commonprefix = text1.substring(0, commonlength);\n  text1 = text1.substring(commonlength);\n  text2 = text2.substring(commonlength);\n\n  // Trim off common suffix (speedup).\n  commonlength = diff_commonSuffix(text1, text2);\n  var commonsuffix = text1.substring(text1.length - commonlength);\n  text1 = text1.substring(0, text1.length - commonlength);\n  text2 = text2.substring(0, text2.length - commonlength);\n\n  // Compute the diff on the middle block.\n  var diffs = diff_compute_(text1, text2);\n\n  // Restore the prefix and suffix.\n  if (commonprefix) {\n    diffs.unshift([DIFF_EQUAL, commonprefix]);\n  }\n  if (commonsuffix) {\n    diffs.push([DIFF_EQUAL, commonsuffix]);\n  }\n  diff_cleanupMerge(diffs, _fix_unicode);\n  if (cleanup) {\n    diff_cleanupSemantic(diffs);\n  }\n  return diffs;\n}\n\n/**\n * Find the differences between two texts.  Assumes that the texts do not\n * have any common prefix or suffix.\n * @param {string} text1 Old string to be diffed.\n * @param {string} text2 New string to be diffed.\n * @return {Array} Array of diff tuples.\n */\nfunction diff_compute_(text1, text2) {\n  var diffs;\n\n  if (!text1) {\n    // Just add some text (speedup).\n    return [[DIFF_INSERT, text2]];\n  }\n\n  if (!text2) {\n    // Just delete some text (speedup).\n    return [[DIFF_DELETE, text1]];\n  }\n\n  var longtext = text1.length > text2.length ? text1 : text2;\n  var shorttext = text1.length > text2.length ? text2 : text1;\n  var i = longtext.indexOf(shorttext);\n  if (i !== -1) {\n    // Shorter text is inside the longer text (speedup).\n    diffs = [\n      [DIFF_INSERT, longtext.substring(0, i)],\n      [DIFF_EQUAL, shorttext],\n      [DIFF_INSERT, longtext.substring(i + shorttext.length)],\n    ];\n    // Swap insertions for deletions if diff is reversed.\n    if (text1.length > text2.length) {\n      diffs[0][0] = diffs[2][0] = DIFF_DELETE;\n    }\n    return diffs;\n  }\n\n  if (shorttext.length === 1) {\n    // Single character string.\n    // After the previous speedup, the character can't be an equality.\n    return [\n      [DIFF_DELETE, text1],\n      [DIFF_INSERT, text2],\n    ];\n  }\n\n  // Check to see if the problem can be split in two.\n  var hm = diff_halfMatch_(text1, text2);\n  if (hm) {\n    // A half-match was found, sort out the return data.\n    var text1_a = hm[0];\n    var text1_b = hm[1];\n    var text2_a = hm[2];\n    var text2_b = hm[3];\n    var mid_common = hm[4];\n    // Send both pairs off for separate processing.\n    var diffs_a = diff_main(text1_a, text2_a);\n    var diffs_b = diff_main(text1_b, text2_b);\n    // Merge the results.\n    return diffs_a.concat([[DIFF_EQUAL, mid_common]], diffs_b);\n  }\n\n  return diff_bisect_(text1, text2);\n}\n\n/**\n * Find the 'middle snake' of a diff, split the problem in two\n * and return the recursively constructed diff.\n * See Myers 1986 paper: An O(ND) Difference Algorithm and Its Variations.\n * @param {string} text1 Old string to be diffed.\n * @param {string} text2 New string to be diffed.\n * @return {Array} Array of diff tuples.\n * @private\n */\nfunction diff_bisect_(text1, text2) {\n  // Cache the text lengths to prevent multiple calls.\n  var text1_length = text1.length;\n  var text2_length = text2.length;\n  var max_d = Math.ceil((text1_length + text2_length) / 2);\n  var v_offset = max_d;\n  var v_length = 2 * max_d;\n  var v1 = new Array(v_length);\n  var v2 = new Array(v_length);\n  // Setting all elements to -1 is faster in Chrome & Firefox than mixing\n  // integers and undefined.\n  for (var x = 0; x < v_length; x++) {\n    v1[x] = -1;\n    v2[x] = -1;\n  }\n  v1[v_offset + 1] = 0;\n  v2[v_offset + 1] = 0;\n  var delta = text1_length - text2_length;\n  // If the total number of characters is odd, then the front path will collide\n  // with the reverse path.\n  var front = delta % 2 !== 0;\n  // Offsets for start and end of k loop.\n  // Prevents mapping of space beyond the grid.\n  var k1start = 0;\n  var k1end = 0;\n  var k2start = 0;\n  var k2end = 0;\n  for (var d = 0; d < max_d; d++) {\n    // Walk the front path one step.\n    for (var k1 = -d + k1start; k1 <= d - k1end; k1 += 2) {\n      var k1_offset = v_offset + k1;\n      var x1;\n      if (k1 === -d || (k1 !== d && v1[k1_offset - 1] < v1[k1_offset + 1])) {\n        x1 = v1[k1_offset + 1];\n      } else {\n        x1 = v1[k1_offset - 1] + 1;\n      }\n      var y1 = x1 - k1;\n      while (\n        x1 < text1_length &&\n        y1 < text2_length &&\n        text1.charAt(x1) === text2.charAt(y1)\n      ) {\n        x1++;\n        y1++;\n      }\n      v1[k1_offset] = x1;\n      if (x1 > text1_length) {\n        // Ran off the right of the graph.\n        k1end += 2;\n      } else if (y1 > text2_length) {\n        // Ran off the bottom of the graph.\n        k1start += 2;\n      } else if (front) {\n        var k2_offset = v_offset + delta - k1;\n        if (k2_offset >= 0 && k2_offset < v_length && v2[k2_offset] !== -1) {\n          // Mirror x2 onto top-left coordinate system.\n          var x2 = text1_length - v2[k2_offset];\n          if (x1 >= x2) {\n            // Overlap detected.\n            return diff_bisectSplit_(text1, text2, x1, y1);\n          }\n        }\n      }\n    }\n\n    // Walk the reverse path one step.\n    for (var k2 = -d + k2start; k2 <= d - k2end; k2 += 2) {\n      var k2_offset = v_offset + k2;\n      var x2;\n      if (k2 === -d || (k2 !== d && v2[k2_offset - 1] < v2[k2_offset + 1])) {\n        x2 = v2[k2_offset + 1];\n      } else {\n        x2 = v2[k2_offset - 1] + 1;\n      }\n      var y2 = x2 - k2;\n      while (\n        x2 < text1_length &&\n        y2 < text2_length &&\n        text1.charAt(text1_length - x2 - 1) ===\n          text2.charAt(text2_length - y2 - 1)\n      ) {\n        x2++;\n        y2++;\n      }\n      v2[k2_offset] = x2;\n      if (x2 > text1_length) {\n        // Ran off the left of the graph.\n        k2end += 2;\n      } else if (y2 > text2_length) {\n        // Ran off the top of the graph.\n        k2start += 2;\n      } else if (!front) {\n        var k1_offset = v_offset + delta - k2;\n        if (k1_offset >= 0 && k1_offset < v_length && v1[k1_offset] !== -1) {\n          var x1 = v1[k1_offset];\n          var y1 = v_offset + x1 - k1_offset;\n          // Mirror x2 onto top-left coordinate system.\n          x2 = text1_length - x2;\n          if (x1 >= x2) {\n            // Overlap detected.\n            return diff_bisectSplit_(text1, text2, x1, y1);\n          }\n        }\n      }\n    }\n  }\n  // Diff took too long and hit the deadline or\n  // number of diffs equals number of characters, no commonality at all.\n  return [\n    [DIFF_DELETE, text1],\n    [DIFF_INSERT, text2],\n  ];\n}\n\n/**\n * Given the location of the 'middle snake', split the diff in two parts\n * and recurse.\n * @param {string} text1 Old string to be diffed.\n * @param {string} text2 New string to be diffed.\n * @param {number} x Index of split point in text1.\n * @param {number} y Index of split point in text2.\n * @return {Array} Array of diff tuples.\n */\nfunction diff_bisectSplit_(text1, text2, x, y) {\n  var text1a = text1.substring(0, x);\n  var text2a = text2.substring(0, y);\n  var text1b = text1.substring(x);\n  var text2b = text2.substring(y);\n\n  // Compute both diffs serially.\n  var diffs = diff_main(text1a, text2a);\n  var diffsb = diff_main(text1b, text2b);\n\n  return diffs.concat(diffsb);\n}\n\n/**\n * Determine the common prefix of two strings.\n * @param {string} text1 First string.\n * @param {string} text2 Second string.\n * @return {number} The number of characters common to the start of each\n *     string.\n */\nfunction diff_commonPrefix(text1, text2) {\n  // Quick check for common null cases.\n  if (!text1 || !text2 || text1.charAt(0) !== text2.charAt(0)) {\n    return 0;\n  }\n  // Binary search.\n  // Performance analysis: http://neil.fraser.name/news/2007/10/09/\n  var pointermin = 0;\n  var pointermax = Math.min(text1.length, text2.length);\n  var pointermid = pointermax;\n  var pointerstart = 0;\n  while (pointermin < pointermid) {\n    if (\n      text1.substring(pointerstart, pointermid) ==\n      text2.substring(pointerstart, pointermid)\n    ) {\n      pointermin = pointermid;\n      pointerstart = pointermin;\n    } else {\n      pointermax = pointermid;\n    }\n    pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin);\n  }\n\n  if (is_surrogate_pair_start(text1.charCodeAt(pointermid - 1))) {\n    pointermid--;\n  }\n\n  return pointermid;\n}\n\n/**\n * Determine if the suffix of one string is the prefix of another.\n * @param {string} text1 First string.\n * @param {string} text2 Second string.\n * @return {number} The number of characters common to the end of the first\n *     string and the start of the second string.\n * @private\n */\nfunction diff_commonOverlap_(text1, text2) {\n  // Cache the text lengths to prevent multiple calls.\n  var text1_length = text1.length;\n  var text2_length = text2.length;\n  // Eliminate the null case.\n  if (text1_length == 0 || text2_length == 0) {\n    return 0;\n  }\n  // Truncate the longer string.\n  if (text1_length > text2_length) {\n    text1 = text1.substring(text1_length - text2_length);\n  } else if (text1_length < text2_length) {\n    text2 = text2.substring(0, text1_length);\n  }\n  var text_length = Math.min(text1_length, text2_length);\n  // Quick check for the worst case.\n  if (text1 == text2) {\n    return text_length;\n  }\n\n  // Start by looking for a single character match\n  // and increase length until no match is found.\n  // Performance analysis: http://neil.fraser.name/news/2010/11/04/\n  var best = 0;\n  var length = 1;\n  while (true) {\n    var pattern = text1.substring(text_length - length);\n    var found = text2.indexOf(pattern);\n    if (found == -1) {\n      return best;\n    }\n    length += found;\n    if (\n      found == 0 ||\n      text1.substring(text_length - length) == text2.substring(0, length)\n    ) {\n      best = length;\n      length++;\n    }\n  }\n}\n\n/**\n * Determine the common suffix of two strings.\n * @param {string} text1 First string.\n * @param {string} text2 Second string.\n * @return {number} The number of characters common to the end of each string.\n */\nfunction diff_commonSuffix(text1, text2) {\n  // Quick check for common null cases.\n  if (!text1 || !text2 || text1.slice(-1) !== text2.slice(-1)) {\n    return 0;\n  }\n  // Binary search.\n  // Performance analysis: http://neil.fraser.name/news/2007/10/09/\n  var pointermin = 0;\n  var pointermax = Math.min(text1.length, text2.length);\n  var pointermid = pointermax;\n  var pointerend = 0;\n  while (pointermin < pointermid) {\n    if (\n      text1.substring(text1.length - pointermid, text1.length - pointerend) ==\n      text2.substring(text2.length - pointermid, text2.length - pointerend)\n    ) {\n      pointermin = pointermid;\n      pointerend = pointermin;\n    } else {\n      pointermax = pointermid;\n    }\n    pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin);\n  }\n\n  if (is_surrogate_pair_end(text1.charCodeAt(text1.length - pointermid))) {\n    pointermid--;\n  }\n\n  return pointermid;\n}\n\n/**\n * Do the two texts share a substring which is at least half the length of the\n * longer text?\n * This speedup can produce non-minimal diffs.\n * @param {string} text1 First string.\n * @param {string} text2 Second string.\n * @return {Array.<string>} Five element Array, containing the prefix of\n *     text1, the suffix of text1, the prefix of text2, the suffix of\n *     text2 and the common middle.  Or null if there was no match.\n */\nfunction diff_halfMatch_(text1, text2) {\n  var longtext = text1.length > text2.length ? text1 : text2;\n  var shorttext = text1.length > text2.length ? text2 : text1;\n  if (longtext.length < 4 || shorttext.length * 2 < longtext.length) {\n    return null; // Pointless.\n  }\n\n  /**\n   * Does a substring of shorttext exist within longtext such that the substring\n   * is at least half the length of longtext?\n   * Closure, but does not reference any external variables.\n   * @param {string} longtext Longer string.\n   * @param {string} shorttext Shorter string.\n   * @param {number} i Start index of quarter length substring within longtext.\n   * @return {Array.<string>} Five element Array, containing the prefix of\n   *     longtext, the suffix of longtext, the prefix of shorttext, the suffix\n   *     of shorttext and the common middle.  Or null if there was no match.\n   * @private\n   */\n  function diff_halfMatchI_(longtext, shorttext, i) {\n    // Start with a 1/4 length substring at position i as a seed.\n    var seed = longtext.substring(i, i + Math.floor(longtext.length / 4));\n    var j = -1;\n    var best_common = \"\";\n    var best_longtext_a, best_longtext_b, best_shorttext_a, best_shorttext_b;\n    while ((j = shorttext.indexOf(seed, j + 1)) !== -1) {\n      var prefixLength = diff_commonPrefix(\n        longtext.substring(i),\n        shorttext.substring(j)\n      );\n      var suffixLength = diff_commonSuffix(\n        longtext.substring(0, i),\n        shorttext.substring(0, j)\n      );\n      if (best_common.length < suffixLength + prefixLength) {\n        best_common =\n          shorttext.substring(j - suffixLength, j) +\n          shorttext.substring(j, j + prefixLength);\n        best_longtext_a = longtext.substring(0, i - suffixLength);\n        best_longtext_b = longtext.substring(i + prefixLength);\n        best_shorttext_a = shorttext.substring(0, j - suffixLength);\n        best_shorttext_b = shorttext.substring(j + prefixLength);\n      }\n    }\n    if (best_common.length * 2 >= longtext.length) {\n      return [\n        best_longtext_a,\n        best_longtext_b,\n        best_shorttext_a,\n        best_shorttext_b,\n        best_common,\n      ];\n    } else {\n      return null;\n    }\n  }\n\n  // First check if the second quarter is the seed for a half-match.\n  var hm1 = diff_halfMatchI_(\n    longtext,\n    shorttext,\n    Math.ceil(longtext.length / 4)\n  );\n  // Check again based on the third quarter.\n  var hm2 = diff_halfMatchI_(\n    longtext,\n    shorttext,\n    Math.ceil(longtext.length / 2)\n  );\n  var hm;\n  if (!hm1 && !hm2) {\n    return null;\n  } else if (!hm2) {\n    hm = hm1;\n  } else if (!hm1) {\n    hm = hm2;\n  } else {\n    // Both matched.  Select the longest.\n    hm = hm1[4].length > hm2[4].length ? hm1 : hm2;\n  }\n\n  // A half-match was found, sort out the return data.\n  var text1_a, text1_b, text2_a, text2_b;\n  if (text1.length > text2.length) {\n    text1_a = hm[0];\n    text1_b = hm[1];\n    text2_a = hm[2];\n    text2_b = hm[3];\n  } else {\n    text2_a = hm[0];\n    text2_b = hm[1];\n    text1_a = hm[2];\n    text1_b = hm[3];\n  }\n  var mid_common = hm[4];\n  return [text1_a, text1_b, text2_a, text2_b, mid_common];\n}\n\n/**\n * Reduce the number of edits by eliminating semantically trivial equalities.\n * @param {!Array.<!diff_match_patch.Diff>} diffs Array of diff tuples.\n */\nfunction diff_cleanupSemantic(diffs) {\n  var changes = false;\n  var equalities = []; // Stack of indices where equalities are found.\n  var equalitiesLength = 0; // Keeping our own length var is faster in JS.\n  /** @type {?string} */\n  var lastequality = null;\n  // Always equal to diffs[equalities[equalitiesLength - 1]][1]\n  var pointer = 0; // Index of current position.\n  // Number of characters that changed prior to the equality.\n  var length_insertions1 = 0;\n  var length_deletions1 = 0;\n  // Number of characters that changed after the equality.\n  var length_insertions2 = 0;\n  var length_deletions2 = 0;\n  while (pointer < diffs.length) {\n    if (diffs[pointer][0] == DIFF_EQUAL) {\n      // Equality found.\n      equalities[equalitiesLength++] = pointer;\n      length_insertions1 = length_insertions2;\n      length_deletions1 = length_deletions2;\n      length_insertions2 = 0;\n      length_deletions2 = 0;\n      lastequality = diffs[pointer][1];\n    } else {\n      // An insertion or deletion.\n      if (diffs[pointer][0] == DIFF_INSERT) {\n        length_insertions2 += diffs[pointer][1].length;\n      } else {\n        length_deletions2 += diffs[pointer][1].length;\n      }\n      // Eliminate an equality that is smaller or equal to the edits on both\n      // sides of it.\n      if (\n        lastequality &&\n        lastequality.length <=\n          Math.max(length_insertions1, length_deletions1) &&\n        lastequality.length <= Math.max(length_insertions2, length_deletions2)\n      ) {\n        // Duplicate record.\n        diffs.splice(equalities[equalitiesLength - 1], 0, [\n          DIFF_DELETE,\n          lastequality,\n        ]);\n        // Change second copy to insert.\n        diffs[equalities[equalitiesLength - 1] + 1][0] = DIFF_INSERT;\n        // Throw away the equality we just deleted.\n        equalitiesLength--;\n        // Throw away the previous equality (it needs to be reevaluated).\n        equalitiesLength--;\n        pointer = equalitiesLength > 0 ? equalities[equalitiesLength - 1] : -1;\n        length_insertions1 = 0; // Reset the counters.\n        length_deletions1 = 0;\n        length_insertions2 = 0;\n        length_deletions2 = 0;\n        lastequality = null;\n        changes = true;\n      }\n    }\n    pointer++;\n  }\n\n  // Normalize the diff.\n  if (changes) {\n    diff_cleanupMerge(diffs);\n  }\n  diff_cleanupSemanticLossless(diffs);\n\n  // Find any overlaps between deletions and insertions.\n  // e.g: <del>abcxxx</del><ins>xxxdef</ins>\n  //   -> <del>abc</del>xxx<ins>def</ins>\n  // e.g: <del>xxxabc</del><ins>defxxx</ins>\n  //   -> <ins>def</ins>xxx<del>abc</del>\n  // Only extract an overlap if it is as big as the edit ahead or behind it.\n  pointer = 1;\n  while (pointer < diffs.length) {\n    if (\n      diffs[pointer - 1][0] == DIFF_DELETE &&\n      diffs[pointer][0] == DIFF_INSERT\n    ) {\n      var deletion = diffs[pointer - 1][1];\n      var insertion = diffs[pointer][1];\n      var overlap_length1 = diff_commonOverlap_(deletion, insertion);\n      var overlap_length2 = diff_commonOverlap_(insertion, deletion);\n      if (overlap_length1 >= overlap_length2) {\n        if (\n          overlap_length1 >= deletion.length / 2 ||\n          overlap_length1 >= insertion.length / 2\n        ) {\n          // Overlap found.  Insert an equality and trim the surrounding edits.\n          diffs.splice(pointer, 0, [\n            DIFF_EQUAL,\n            insertion.substring(0, overlap_length1),\n          ]);\n          diffs[pointer - 1][1] = deletion.substring(\n            0,\n            deletion.length - overlap_length1\n          );\n          diffs[pointer + 1][1] = insertion.substring(overlap_length1);\n          pointer++;\n        }\n      } else {\n        if (\n          overlap_length2 >= deletion.length / 2 ||\n          overlap_length2 >= insertion.length / 2\n        ) {\n          // Reverse overlap found.\n          // Insert an equality and swap and trim the surrounding edits.\n          diffs.splice(pointer, 0, [\n            DIFF_EQUAL,\n            deletion.substring(0, overlap_length2),\n          ]);\n          diffs[pointer - 1][0] = DIFF_INSERT;\n          diffs[pointer - 1][1] = insertion.substring(\n            0,\n            insertion.length - overlap_length2\n          );\n          diffs[pointer + 1][0] = DIFF_DELETE;\n          diffs[pointer + 1][1] = deletion.substring(overlap_length2);\n          pointer++;\n        }\n      }\n      pointer++;\n    }\n    pointer++;\n  }\n}\n\nvar nonAlphaNumericRegex_ = /[^a-zA-Z0-9]/;\nvar whitespaceRegex_ = /\\s/;\nvar linebreakRegex_ = /[\\r\\n]/;\nvar blanklineEndRegex_ = /\\n\\r?\\n$/;\nvar blanklineStartRegex_ = /^\\r?\\n\\r?\\n/;\n\n/**\n * Look for single edits surrounded on both sides by equalities\n * which can be shifted sideways to align the edit to a word boundary.\n * e.g: The c<ins>at c</ins>ame. -> The <ins>cat </ins>came.\n * @param {!Array.<!diff_match_patch.Diff>} diffs Array of diff tuples.\n */\nfunction diff_cleanupSemanticLossless(diffs) {\n  /**\n   * Given two strings, compute a score representing whether the internal\n   * boundary falls on logical boundaries.\n   * Scores range from 6 (best) to 0 (worst).\n   * Closure, but does not reference any external variables.\n   * @param {string} one First string.\n   * @param {string} two Second string.\n   * @return {number} The score.\n   * @private\n   */\n  function diff_cleanupSemanticScore_(one, two) {\n    if (!one || !two) {\n      // Edges are the best.\n      return 6;\n    }\n\n    // Each port of this function behaves slightly differently due to\n    // subtle differences in each language's definition of things like\n    // 'whitespace'.  Since this function's purpose is largely cosmetic,\n    // the choice has been made to use each language's native features\n    // rather than force total conformity.\n    var char1 = one.charAt(one.length - 1);\n    var char2 = two.charAt(0);\n    var nonAlphaNumeric1 = char1.match(nonAlphaNumericRegex_);\n    var nonAlphaNumeric2 = char2.match(nonAlphaNumericRegex_);\n    var whitespace1 = nonAlphaNumeric1 && char1.match(whitespaceRegex_);\n    var whitespace2 = nonAlphaNumeric2 && char2.match(whitespaceRegex_);\n    var lineBreak1 = whitespace1 && char1.match(linebreakRegex_);\n    var lineBreak2 = whitespace2 && char2.match(linebreakRegex_);\n    var blankLine1 = lineBreak1 && one.match(blanklineEndRegex_);\n    var blankLine2 = lineBreak2 && two.match(blanklineStartRegex_);\n\n    if (blankLine1 || blankLine2) {\n      // Five points for blank lines.\n      return 5;\n    } else if (lineBreak1 || lineBreak2) {\n      // Four points for line breaks.\n      return 4;\n    } else if (nonAlphaNumeric1 && !whitespace1 && whitespace2) {\n      // Three points for end of sentences.\n      return 3;\n    } else if (whitespace1 || whitespace2) {\n      // Two points for whitespace.\n      return 2;\n    } else if (nonAlphaNumeric1 || nonAlphaNumeric2) {\n      // One point for non-alphanumeric.\n      return 1;\n    }\n    return 0;\n  }\n\n  var pointer = 1;\n  // Intentionally ignore the first and last element (don't need checking).\n  while (pointer < diffs.length - 1) {\n    if (\n      diffs[pointer - 1][0] == DIFF_EQUAL &&\n      diffs[pointer + 1][0] == DIFF_EQUAL\n    ) {\n      // This is a single edit surrounded by equalities.\n      var equality1 = diffs[pointer - 1][1];\n      var edit = diffs[pointer][1];\n      var equality2 = diffs[pointer + 1][1];\n\n      // First, shift the edit as far left as possible.\n      var commonOffset = diff_commonSuffix(equality1, edit);\n      if (commonOffset) {\n        var commonString = edit.substring(edit.length - commonOffset);\n        equality1 = equality1.substring(0, equality1.length - commonOffset);\n        edit = commonString + edit.substring(0, edit.length - commonOffset);\n        equality2 = commonString + equality2;\n      }\n\n      // Second, step character by character right, looking for the best fit.\n      var bestEquality1 = equality1;\n      var bestEdit = edit;\n      var bestEquality2 = equality2;\n      var bestScore =\n        diff_cleanupSemanticScore_(equality1, edit) +\n        diff_cleanupSemanticScore_(edit, equality2);\n      while (edit.charAt(0) === equality2.charAt(0)) {\n        equality1 += edit.charAt(0);\n        edit = edit.substring(1) + equality2.charAt(0);\n        equality2 = equality2.substring(1);\n        var score =\n          diff_cleanupSemanticScore_(equality1, edit) +\n          diff_cleanupSemanticScore_(edit, equality2);\n        // The >= encourages trailing rather than leading whitespace on edits.\n        if (score >= bestScore) {\n          bestScore = score;\n          bestEquality1 = equality1;\n          bestEdit = edit;\n          bestEquality2 = equality2;\n        }\n      }\n\n      if (diffs[pointer - 1][1] != bestEquality1) {\n        // We have an improvement, save it back to the diff.\n        if (bestEquality1) {\n          diffs[pointer - 1][1] = bestEquality1;\n        } else {\n          diffs.splice(pointer - 1, 1);\n          pointer--;\n        }\n        diffs[pointer][1] = bestEdit;\n        if (bestEquality2) {\n          diffs[pointer + 1][1] = bestEquality2;\n        } else {\n          diffs.splice(pointer + 1, 1);\n          pointer--;\n        }\n      }\n    }\n    pointer++;\n  }\n}\n\n/**\n * Reorder and merge like edit sections.  Merge equalities.\n * Any edit section can move as long as it doesn't cross an equality.\n * @param {Array} diffs Array of diff tuples.\n * @param {boolean} fix_unicode Whether to normalize to a unicode-correct diff\n */\nfunction diff_cleanupMerge(diffs, fix_unicode) {\n  diffs.push([DIFF_EQUAL, \"\"]); // Add a dummy entry at the end.\n  var pointer = 0;\n  var count_delete = 0;\n  var count_insert = 0;\n  var text_delete = \"\";\n  var text_insert = \"\";\n  var commonlength;\n  while (pointer < diffs.length) {\n    if (pointer < diffs.length - 1 && !diffs[pointer][1]) {\n      diffs.splice(pointer, 1);\n      continue;\n    }\n    switch (diffs[pointer][0]) {\n      case DIFF_INSERT:\n        count_insert++;\n        text_insert += diffs[pointer][1];\n        pointer++;\n        break;\n      case DIFF_DELETE:\n        count_delete++;\n        text_delete += diffs[pointer][1];\n        pointer++;\n        break;\n      case DIFF_EQUAL:\n        var previous_equality = pointer - count_insert - count_delete - 1;\n        if (fix_unicode) {\n          // prevent splitting of unicode surrogate pairs.  when fix_unicode is true,\n          // we assume that the old and new text in the diff are complete and correct\n          // unicode-encoded JS strings, but the tuple boundaries may fall between\n          // surrogate pairs.  we fix this by shaving off stray surrogates from the end\n          // of the previous equality and the beginning of this equality.  this may create\n          // empty equalities or a common prefix or suffix.  for example, if AB and AC are\n          // emojis, `[[0, 'A'], [-1, 'BA'], [0, 'C']]` would turn into deleting 'ABAC' and\n          // inserting 'AC', and then the common suffix 'AC' will be eliminated.  in this\n          // particular case, both equalities go away, we absorb any previous inequalities,\n          // and we keep scanning for the next equality before rewriting the tuples.\n          if (\n            previous_equality >= 0 &&\n            ends_with_pair_start(diffs[previous_equality][1])\n          ) {\n            var stray = diffs[previous_equality][1].slice(-1);\n            diffs[previous_equality][1] = diffs[previous_equality][1].slice(\n              0,\n              -1\n            );\n            text_delete = stray + text_delete;\n            text_insert = stray + text_insert;\n            if (!diffs[previous_equality][1]) {\n              // emptied out previous equality, so delete it and include previous delete/insert\n              diffs.splice(previous_equality, 1);\n              pointer--;\n              var k = previous_equality - 1;\n              if (diffs[k] && diffs[k][0] === DIFF_INSERT) {\n                count_insert++;\n                text_insert = diffs[k][1] + text_insert;\n                k--;\n              }\n              if (diffs[k] && diffs[k][0] === DIFF_DELETE) {\n                count_delete++;\n                text_delete = diffs[k][1] + text_delete;\n                k--;\n              }\n              previous_equality = k;\n            }\n          }\n          if (starts_with_pair_end(diffs[pointer][1])) {\n            var stray = diffs[pointer][1].charAt(0);\n            diffs[pointer][1] = diffs[pointer][1].slice(1);\n            text_delete += stray;\n            text_insert += stray;\n          }\n        }\n        if (pointer < diffs.length - 1 && !diffs[pointer][1]) {\n          // for empty equality not at end, wait for next equality\n          diffs.splice(pointer, 1);\n          break;\n        }\n        if (text_delete.length > 0 || text_insert.length > 0) {\n          // note that diff_commonPrefix and diff_commonSuffix are unicode-aware\n          if (text_delete.length > 0 && text_insert.length > 0) {\n            // Factor out any common prefixes.\n            commonlength = diff_commonPrefix(text_insert, text_delete);\n            if (commonlength !== 0) {\n              if (previous_equality >= 0) {\n                diffs[previous_equality][1] += text_insert.substring(\n                  0,\n                  commonlength\n                );\n              } else {\n                diffs.splice(0, 0, [\n                  DIFF_EQUAL,\n                  text_insert.substring(0, commonlength),\n                ]);\n                pointer++;\n              }\n              text_insert = text_insert.substring(commonlength);\n              text_delete = text_delete.substring(commonlength);\n            }\n            // Factor out any common suffixes.\n            commonlength = diff_commonSuffix(text_insert, text_delete);\n            if (commonlength !== 0) {\n              diffs[pointer][1] =\n                text_insert.substring(text_insert.length - commonlength) +\n                diffs[pointer][1];\n              text_insert = text_insert.substring(\n                0,\n                text_insert.length - commonlength\n              );\n              text_delete = text_delete.substring(\n                0,\n                text_delete.length - commonlength\n              );\n            }\n          }\n          // Delete the offending records and add the merged ones.\n          var n = count_insert + count_delete;\n          if (text_delete.length === 0 && text_insert.length === 0) {\n            diffs.splice(pointer - n, n);\n            pointer = pointer - n;\n          } else if (text_delete.length === 0) {\n            diffs.splice(pointer - n, n, [DIFF_INSERT, text_insert]);\n            pointer = pointer - n + 1;\n          } else if (text_insert.length === 0) {\n            diffs.splice(pointer - n, n, [DIFF_DELETE, text_delete]);\n            pointer = pointer - n + 1;\n          } else {\n            diffs.splice(\n              pointer - n,\n              n,\n              [DIFF_DELETE, text_delete],\n              [DIFF_INSERT, text_insert]\n            );\n            pointer = pointer - n + 2;\n          }\n        }\n        if (pointer !== 0 && diffs[pointer - 1][0] === DIFF_EQUAL) {\n          // Merge this equality with the previous one.\n          diffs[pointer - 1][1] += diffs[pointer][1];\n          diffs.splice(pointer, 1);\n        } else {\n          pointer++;\n        }\n        count_insert = 0;\n        count_delete = 0;\n        text_delete = \"\";\n        text_insert = \"\";\n        break;\n    }\n  }\n  if (diffs[diffs.length - 1][1] === \"\") {\n    diffs.pop(); // Remove the dummy entry at the end.\n  }\n\n  // Second pass: look for single edits surrounded on both sides by equalities\n  // which can be shifted sideways to eliminate an equality.\n  // e.g: A<ins>BA</ins>C -> <ins>AB</ins>AC\n  var changes = false;\n  pointer = 1;\n  // Intentionally ignore the first and last element (don't need checking).\n  while (pointer < diffs.length - 1) {\n    if (\n      diffs[pointer - 1][0] === DIFF_EQUAL &&\n      diffs[pointer + 1][0] === DIFF_EQUAL\n    ) {\n      // This is a single edit surrounded by equalities.\n      if (\n        diffs[pointer][1].substring(\n          diffs[pointer][1].length - diffs[pointer - 1][1].length\n        ) === diffs[pointer - 1][1]\n      ) {\n        // Shift the edit over the previous equality.\n        diffs[pointer][1] =\n          diffs[pointer - 1][1] +\n          diffs[pointer][1].substring(\n            0,\n            diffs[pointer][1].length - diffs[pointer - 1][1].length\n          );\n        diffs[pointer + 1][1] = diffs[pointer - 1][1] + diffs[pointer + 1][1];\n        diffs.splice(pointer - 1, 1);\n        changes = true;\n      } else if (\n        diffs[pointer][1].substring(0, diffs[pointer + 1][1].length) ==\n        diffs[pointer + 1][1]\n      ) {\n        // Shift the edit over the next equality.\n        diffs[pointer - 1][1] += diffs[pointer + 1][1];\n        diffs[pointer][1] =\n          diffs[pointer][1].substring(diffs[pointer + 1][1].length) +\n          diffs[pointer + 1][1];\n        diffs.splice(pointer + 1, 1);\n        changes = true;\n      }\n    }\n    pointer++;\n  }\n  // If shifts were made, the diff needs reordering and another shift sweep.\n  if (changes) {\n    diff_cleanupMerge(diffs, fix_unicode);\n  }\n}\n\nfunction is_surrogate_pair_start(charCode) {\n  return charCode >= 0xd800 && charCode <= 0xdbff;\n}\n\nfunction is_surrogate_pair_end(charCode) {\n  return charCode >= 0xdc00 && charCode <= 0xdfff;\n}\n\nfunction starts_with_pair_end(str) {\n  return is_surrogate_pair_end(str.charCodeAt(0));\n}\n\nfunction ends_with_pair_start(str) {\n  return is_surrogate_pair_start(str.charCodeAt(str.length - 1));\n}\n\nfunction remove_empty_tuples(tuples) {\n  var ret = [];\n  for (var i = 0; i < tuples.length; i++) {\n    if (tuples[i][1].length > 0) {\n      ret.push(tuples[i]);\n    }\n  }\n  return ret;\n}\n\nfunction make_edit_splice(before, oldMiddle, newMiddle, after) {\n  if (ends_with_pair_start(before) || starts_with_pair_end(after)) {\n    return null;\n  }\n  return remove_empty_tuples([\n    [DIFF_EQUAL, before],\n    [DIFF_DELETE, oldMiddle],\n    [DIFF_INSERT, newMiddle],\n    [DIFF_EQUAL, after],\n  ]);\n}\n\nfunction find_cursor_edit_diff(oldText, newText, cursor_pos) {\n  // note: this runs after equality check has ruled out exact equality\n  var oldRange =\n    typeof cursor_pos === \"number\"\n      ? { index: cursor_pos, length: 0 }\n      : cursor_pos.oldRange;\n  var newRange = typeof cursor_pos === \"number\" ? null : cursor_pos.newRange;\n  // take into account the old and new selection to generate the best diff\n  // possible for a text edit.  for example, a text change from \"xxx\" to \"xx\"\n  // could be a delete or forwards-delete of any one of the x's, or the\n  // result of selecting two of the x's and typing \"x\".\n  var oldLength = oldText.length;\n  var newLength = newText.length;\n  if (oldRange.length === 0 && (newRange === null || newRange.length === 0)) {\n    // see if we have an insert or delete before or after cursor\n    var oldCursor = oldRange.index;\n    var oldBefore = oldText.slice(0, oldCursor);\n    var oldAfter = oldText.slice(oldCursor);\n    var maybeNewCursor = newRange ? newRange.index : null;\n    editBefore: {\n      // is this an insert or delete right before oldCursor?\n      var newCursor = oldCursor + newLength - oldLength;\n      if (maybeNewCursor !== null && maybeNewCursor !== newCursor) {\n        break editBefore;\n      }\n      if (newCursor < 0 || newCursor > newLength) {\n        break editBefore;\n      }\n      var newBefore = newText.slice(0, newCursor);\n      var newAfter = newText.slice(newCursor);\n      if (newAfter !== oldAfter) {\n        break editBefore;\n      }\n      var prefixLength = Math.min(oldCursor, newCursor);\n      var oldPrefix = oldBefore.slice(0, prefixLength);\n      var newPrefix = newBefore.slice(0, prefixLength);\n      if (oldPrefix !== newPrefix) {\n        break editBefore;\n      }\n      var oldMiddle = oldBefore.slice(prefixLength);\n      var newMiddle = newBefore.slice(prefixLength);\n      return make_edit_splice(oldPrefix, oldMiddle, newMiddle, oldAfter);\n    }\n    editAfter: {\n      // is this an insert or delete right after oldCursor?\n      if (maybeNewCursor !== null && maybeNewCursor !== oldCursor) {\n        break editAfter;\n      }\n      var cursor = oldCursor;\n      var newBefore = newText.slice(0, cursor);\n      var newAfter = newText.slice(cursor);\n      if (newBefore !== oldBefore) {\n        break editAfter;\n      }\n      var suffixLength = Math.min(oldLength - cursor, newLength - cursor);\n      var oldSuffix = oldAfter.slice(oldAfter.length - suffixLength);\n      var newSuffix = newAfter.slice(newAfter.length - suffixLength);\n      if (oldSuffix !== newSuffix) {\n        break editAfter;\n      }\n      var oldMiddle = oldAfter.slice(0, oldAfter.length - suffixLength);\n      var newMiddle = newAfter.slice(0, newAfter.length - suffixLength);\n      return make_edit_splice(oldBefore, oldMiddle, newMiddle, oldSuffix);\n    }\n  }\n  if (oldRange.length > 0 && newRange && newRange.length === 0) {\n    replaceRange: {\n      // see if diff could be a splice of the old selection range\n      var oldPrefix = oldText.slice(0, oldRange.index);\n      var oldSuffix = oldText.slice(oldRange.index + oldRange.length);\n      var prefixLength = oldPrefix.length;\n      var suffixLength = oldSuffix.length;\n      if (newLength < prefixLength + suffixLength) {\n        break replaceRange;\n      }\n      var newPrefix = newText.slice(0, prefixLength);\n      var newSuffix = newText.slice(newLength - suffixLength);\n      if (oldPrefix !== newPrefix || oldSuffix !== newSuffix) {\n        break replaceRange;\n      }\n      var oldMiddle = oldText.slice(prefixLength, oldLength - suffixLength);\n      var newMiddle = newText.slice(prefixLength, newLength - suffixLength);\n      return make_edit_splice(oldPrefix, oldMiddle, newMiddle, oldSuffix);\n    }\n  }\n\n  return null;\n}\n\nfunction diff(text1, text2, cursor_pos, cleanup) {\n  // only pass fix_unicode=true at the top level, not when diff_main is\n  // recursively invoked\n  return diff_main(text1, text2, cursor_pos, cleanup, true);\n}\n\ndiff.INSERT = DIFF_INSERT;\ndiff.DELETE = DIFF_DELETE;\ndiff.EQUAL = DIFF_EQUAL;\n\nmodule.exports = diff;\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","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./cjs/react-is.production.min.js');\n} else {\n  module.exports = require('./cjs/react-is.development.js');\n}\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.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\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    promiseTag = '[object Promise]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]',\n    weakMapTag = '[object WeakMap]';\n\nvar 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/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/**\n * Adds the key-value `pair` to `map`.\n *\n * @private\n * @param {Object} map The map to modify.\n * @param {Array} pair The key-value pair to add.\n * @returns {Object} Returns `map`.\n */\nfunction addMapEntry(map, pair) {\n  // Don't return `map.set` because it's not chainable in IE 11.\n  map.set(pair[0], pair[1]);\n  return map;\n}\n\n/**\n * Adds `value` to `set`.\n *\n * @private\n * @param {Object} set The set to modify.\n * @param {*} value The value to add.\n * @returns {Object} Returns `set`.\n */\nfunction addSetEntry(set, value) {\n  // Don't return `set.add` because it's not chainable in IE 11.\n  set.add(value);\n  return set;\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 */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array ? array.length : 0;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\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 */\nfunction 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 */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n  var index = -1,\n      length = array ? array.length : 0;\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 * 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 */\nfunction 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 * 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 */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\n/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n  // Many host objects are `Object` objects that can coerce to strings\n  // despite having improperly defined `toString` methods.\n  var result = false;\n  if (value != null && typeof value.toString != 'function') {\n    try {\n      result = !!(value + '');\n    } catch (e) {}\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 */\nfunction 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 */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\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 */\nfunction 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/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n    funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nvar objectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    Symbol = root.Symbol,\n    Uint8Array = root.Uint8Array,\n    getPrototype = overArg(Object.getPrototypeOf, Object),\n    objectCreate = Object.create,\n    propertyIsEnumerable = objectProto.propertyIsEnumerable,\n    splice = arrayProto.splice;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n    nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n    nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n    Map = getNative(root, 'Map'),\n    Promise = getNative(root, 'Promise'),\n    Set = getNative(root, 'Set'),\n    WeakMap = getNative(root, 'WeakMap'),\n    nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar 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. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n      length = entries ? entries.length : 0;\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 */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\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 */\nfunction hashDelete(key) {\n  return this.has(key) && delete this.__data__[key];\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 */\nfunction 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 */\nfunction 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 */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n      length = entries ? entries.length : 0;\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 */\nfunction listCacheClear() {\n  this.__data__ = [];\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 */\nfunction 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  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 */\nfunction 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 */\nfunction 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 */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\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 */\nfunction MapCache(entries) {\n  var index = -1,\n      length = entries ? entries.length : 0;\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 */\nfunction mapCacheClear() {\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 */\nfunction mapCacheDelete(key) {\n  return getMapData(this, key)['delete'](key);\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 */\nfunction 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 */\nfunction 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 */\nfunction mapCacheSet(key, value) {\n  getMapData(this, key).set(key, value);\n  return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\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 */\nfunction Stack(entries) {\n  this.__data__ = new ListCache(entries);\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\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 */\nfunction stackDelete(key) {\n  return this.__data__['delete'](key);\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 */\nfunction 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 */\nfunction 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 */\nfunction stackSet(key, value) {\n  var cache = this.__data__;\n  if (cache instanceof ListCache) {\n    var pairs = cache.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      return this;\n    }\n    cache = this.__data__ = new MapCache(pairs);\n  }\n  cache.set(key, value);\n  return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\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 */\nfunction arrayLikeKeys(value, inherited) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  // Safari 9 makes `arguments.length` enumerable in strict mode.\n  var result = (isArray(value) || isArguments(value))\n    ? baseTimes(value.length, String)\n    : [];\n\n  var length = result.length,\n      skipIndexes = !!length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (key == 'length' || isIndex(key, length)))) {\n      result.push(key);\n    }\n  }\n  return result;\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 */\nfunction 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    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 */\nfunction 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 * 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 */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\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} [isDeep] Specify a deep clone.\n * @param {boolean} [isFull] Specify a clone including 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 */\nfunction baseClone(value, isDeep, isFull, customizer, key, object, stack) {\n  var result;\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      if (isHostObject(value)) {\n        return object ? value : {};\n      }\n      result = initCloneObject(isFunc ? {} : value);\n      if (!isDeep) {\n        return copySymbols(value, baseAssign(result, value));\n      }\n    } else {\n      if (!cloneableTags[tag]) {\n        return object ? value : {};\n      }\n      result = initCloneByTag(value, tag, baseClone, 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 (!isArr) {\n    var props = isFull ? getAllKeys(value) : keys(value);\n  }\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, isDeep, isFull, customizer, key, value, stack));\n  });\n  return result;\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} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nfunction baseCreate(proto) {\n  return isObject(proto) ? objectCreate(proto) : {};\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 */\nfunction 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`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  return objectToString.call(value);\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 */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(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 */\nfunction 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 * 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 */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var result = new buffer.constructor(buffer.length);\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 */\nfunction 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 */\nfunction 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 `map`.\n *\n * @private\n * @param {Object} map The map to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned map.\n */\nfunction cloneMap(map, isDeep, cloneFunc) {\n  var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map);\n  return arrayReduce(array, addMapEntry, new map.constructor);\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 */\nfunction 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 `set`.\n *\n * @private\n * @param {Object} set The set to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned set.\n */\nfunction cloneSet(set, isDeep, cloneFunc) {\n  var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set);\n  return arrayReduce(array, addSetEntry, new set.constructor);\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 */\nfunction 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 */\nfunction 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 * 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 */\nfunction 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 */\nfunction copyObject(source, props, object, customizer) {\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    assignValue(object, key, newValue === undefined ? source[key] : newValue);\n  }\n  return object;\n}\n\n/**\n * Copies own symbol properties 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 */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\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 */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\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 */\nfunction 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 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 */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * Creates an array of the own enumerable symbol properties of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray;\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 */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11,\n// for data views in Edge < 14, and promises in Node.js.\nif ((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 = objectToString.call(value),\n        Ctor = result == objectTag ? value.constructor : undefined,\n        ctorString = Ctor ? toSource(Ctor) : undefined;\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 * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n      result = 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 */\nfunction 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`, `Number`, `RegExp`, 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 {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, cloneFunc, 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 cloneMap(object, isDeep, cloneFunc);\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 cloneSet(object, isDeep, cloneFunc);\n\n    case symbolTag:\n      return cloneSymbol(object);\n  }\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 */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\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 */\nfunction 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 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 */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\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 */\nfunction 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 * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to process.\n * @returns {string} Returns the source code.\n */\nfunction 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 * 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 */\nfunction cloneDeep(value) {\n  return baseClone(value, true, true);\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 */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== 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 */\nfunction isArguments(value) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n    (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\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 */\nvar isArray = Array.isArray;\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 */\nfunction 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 */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\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 */\nvar isBuffer = nativeIsBuffer || stubFalse;\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 */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 8-9 which returns 'object' for typed array and other constructors.\n  var tag = isObject(value) ? objectToString.call(value) : '';\n  return tag == funcTag || tag == genTag;\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 */\nfunction 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 */\nfunction isObject(value) {\n  var type = typeof value;\n  return !!value && (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 */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\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 */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\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 */\nfunction 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 */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = cloneDeep;\n","/**\n * Lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors <https://js.foundation/>\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\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    asyncTag = '[object AsyncFunction]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\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\nvar 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/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n  try {\n    return freeProcess && freeProcess.binding && freeProcess.binding('util');\n  } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\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 */\nfunction 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 * 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 */\nfunction 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 `_.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 */\nfunction 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 * 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 */\nfunction 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 `_.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 */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\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 */\nfunction cacheHas(cache, key) {\n  return cache.has(key);\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 */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\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 */\nfunction 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 */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\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 */\nfunction 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/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n    funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar 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 */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    Symbol = root.Symbol,\n    Uint8Array = root.Uint8Array,\n    propertyIsEnumerable = objectProto.propertyIsEnumerable,\n    splice = arrayProto.splice,\n    symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n    nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n    nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n    Map = getNative(root, 'Map'),\n    Promise = getNative(root, 'Promise'),\n    Set = getNative(root, 'Set'),\n    WeakMap = getNative(root, 'WeakMap'),\n    nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar 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. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\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 */\nfunction 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 */\nfunction 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 */\nfunction setCacheHas(value) {\n  return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 */\nfunction 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`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\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 */\nfunction 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 * 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 */\nfunction 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 * 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 */\nfunction 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 */\nfunction 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 `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\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 */\nfunction 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 */\nfunction 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 `_.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 */\nfunction 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 `_.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 */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(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 */\nfunction 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 * 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 */\nfunction 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 */\nfunction 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 */\nfunction 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 * 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 */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\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 */\nfunction 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 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 */\nfunction 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 */\nfunction 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 */\nvar 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 * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((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 * 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 */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\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 */\nfunction 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 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 */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\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 */\nfunction 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 * 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 */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\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 */\nfunction 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 * 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 */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== 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 */\nvar 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 */\nvar isArray = Array.isArray;\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 */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\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 */\nvar isBuffer = nativeIsBuffer || stubFalse;\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 */\nfunction isEqual(value, other) {\n  return baseIsEqual(value, other);\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 */\nfunction 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 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 */\nfunction 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 */\nfunction 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 */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\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 */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\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 */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\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 */\nfunction 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 */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = isEqual;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var hashClear = require('./_hashClear'),\n    hashDelete = require('./_hashDelete'),\n    hashGet = require('./_hashGet'),\n    hashHas = require('./_hashHas'),\n    hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var listCacheClear = require('./_listCacheClear'),\n    listCacheDelete = require('./_listCacheDelete'),\n    listCacheGet = require('./_listCacheGet'),\n    listCacheHas = require('./_listCacheHas'),\n    listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var mapCacheClear = require('./_mapCacheClear'),\n    mapCacheDelete = require('./_mapCacheDelete'),\n    mapCacheGet = require('./_mapCacheGet'),\n    mapCacheHas = require('./_mapCacheHas'),\n    mapCacheSet = require('./_mapCacheSet');\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 */\nfunction 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// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var MapCache = require('./_MapCache'),\n    setCacheAdd = require('./_setCacheAdd'),\n    setCacheHas = require('./_setCacheHas');\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 */\nfunction 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// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","var ListCache = require('./_ListCache'),\n    stackClear = require('./_stackClear'),\n    stackDelete = require('./_stackDelete'),\n    stackGet = require('./_stackGet'),\n    stackHas = require('./_stackHas'),\n    stackSet = require('./_stackSet');\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 */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var getNative = require('./_getNative'),\n    root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\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 */\nfunction 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\nmodule.exports = arrayFilter;\n","var baseTimes = require('./_baseTimes'),\n    isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isIndex = require('./_isIndex'),\n    isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nmodule.exports = arrayLikeKeys;\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 */\nfunction 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\nmodule.exports = arrayPush;\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 */\nfunction 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\nmodule.exports = arraySome;\n","var eq = require('./eq');\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 */\nfunction 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\nmodule.exports = assocIndexOf;\n","var arrayPush = require('./_arrayPush'),\n    isArray = require('./isArray');\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 */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n  var result = keysFunc(object);\n  return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","var Symbol = require('./_Symbol'),\n    getRawTag = require('./_getRawTag'),\n    objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\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 */\nfunction 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\nmodule.exports = baseGetTag;\n","var baseGetTag = require('./_baseGetTag'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\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 */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n    isObjectLike = require('./isObjectLike');\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 */\nfunction 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\nmodule.exports = baseIsEqual;\n","var Stack = require('./_Stack'),\n    equalArrays = require('./_equalArrays'),\n    equalByTag = require('./_equalByTag'),\n    equalObjects = require('./_equalObjects'),\n    getTag = require('./_getTag'),\n    isArray = require('./isArray'),\n    isBuffer = require('./isBuffer'),\n    isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nmodule.exports = baseIsEqualDeep;\n","var isFunction = require('./isFunction'),\n    isMasked = require('./_isMasked'),\n    isObject = require('./isObject'),\n    toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\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 */\nfunction 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\nmodule.exports = baseIsNative;\n","var baseGetTag = require('./_baseGetTag'),\n    isLength = require('./isLength'),\n    isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar 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 identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\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 */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var isPrototype = require('./_isPrototype'),\n    nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nmodule.exports = baseKeys;\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 */\nfunction 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\nmodule.exports = baseTimes;\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 */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nmodule.exports = baseUnary;\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 */\nfunction cacheHas(cache, key) {\n  return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","var SetCache = require('./_SetCache'),\n    arraySome = require('./_arraySome'),\n    cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\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 */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      arrLength = array.length,\n      othLength = other.length;\n\n  if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n    return false;\n  }\n  // Check that cyclic values are equal.\n  var arrStacked = stack.get(array);\n  var othStacked = stack.get(other);\n  if (arrStacked && othStacked) {\n    return arrStacked == other && othStacked == array;\n  }\n  var index = -1,\n      result = true,\n      seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n  stack.set(array, other);\n  stack.set(other, array);\n\n  // Ignore non-index properties.\n  while (++index < arrLength) {\n    var arrValue = array[index],\n        othValue = other[index];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, arrValue, index, other, array, stack)\n        : customizer(arrValue, othValue, index, array, other, stack);\n    }\n    if (compared !== undefined) {\n      if (compared) {\n        continue;\n      }\n      result = false;\n      break;\n    }\n    // Recursively compare arrays (susceptible to call stack limits).\n    if (seen) {\n      if (!arraySome(other, function(othValue, othIndex) {\n            if (!cacheHas(seen, othIndex) &&\n                (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n              return seen.push(othIndex);\n            }\n          })) {\n        result = false;\n        break;\n      }\n    } else if (!(\n          arrValue === othValue ||\n            equalFunc(arrValue, othValue, bitmask, customizer, stack)\n        )) {\n      result = false;\n      break;\n    }\n  }\n  stack['delete'](array);\n  stack['delete'](other);\n  return result;\n}\n\nmodule.exports = equalArrays;\n","var Symbol = require('./_Symbol'),\n    Uint8Array = require('./_Uint8Array'),\n    eq = require('./eq'),\n    equalArrays = require('./_equalArrays'),\n    mapToArray = require('./_mapToArray'),\n    setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\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 */\nfunction 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\nmodule.exports = equalByTag;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      objProps = getAllKeys(object),\n      objLength = objProps.length,\n      othProps = getAllKeys(other),\n      othLength = othProps.length;\n\n  if (objLength != othLength && !isPartial) {\n    return false;\n  }\n  var index = objLength;\n  while (index--) {\n    var key = objProps[index];\n    if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n      return false;\n    }\n  }\n  // Check that cyclic values are equal.\n  var objStacked = stack.get(object);\n  var othStacked = stack.get(other);\n  if (objStacked && othStacked) {\n    return objStacked == other && othStacked == object;\n  }\n  var result = true;\n  stack.set(object, other);\n  stack.set(other, object);\n\n  var skipCtor = isPartial;\n  while (++index < objLength) {\n    key = objProps[index];\n    var objValue = object[key],\n        othValue = other[key];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, objValue, key, other, object, stack)\n        : customizer(objValue, othValue, key, object, other, stack);\n    }\n    // Recursively compare objects (susceptible to call stack limits).\n    if (!(compared === undefined\n          ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n          : compared\n        )) {\n      result = false;\n      break;\n    }\n    skipCtor || (skipCtor = key == 'constructor');\n  }\n  if (result && !skipCtor) {\n    var objCtor = object.constructor,\n        othCtor = other.constructor;\n\n    // Non `Object` object instances with different constructors are not equal.\n    if (objCtor != othCtor &&\n        ('constructor' in object && 'constructor' in other) &&\n        !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n          typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n      result = false;\n    }\n  }\n  stack['delete'](object);\n  stack['delete'](other);\n  return result;\n}\n\nmodule.exports = equalObjects;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n    getSymbols = require('./_getSymbols'),\n    keys = require('./keys');\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 */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var isKeyable = require('./_isKeyable');\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 */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nmodule.exports = getMapData;\n","var baseIsNative = require('./_baseIsNative'),\n    getValue = require('./_getValue');\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 */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\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 */\nfunction 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\nmodule.exports = getRawTag;\n","var arrayFilter = require('./_arrayFilter'),\n    stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\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 */\nvar 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\nmodule.exports = getSymbols;\n","var DataView = require('./_DataView'),\n    Map = require('./_Map'),\n    Promise = require('./_Promise'),\n    Set = require('./_Set'),\n    WeakMap = require('./_WeakMap'),\n    baseGetTag = require('./_baseGetTag'),\n    toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    objectTag = '[object Object]',\n    promiseTag = '[object Promise]',\n    setTag = '[object Set]',\n    weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n    mapCtorString = toSource(Map),\n    promiseCtorString = toSource(Promise),\n    setCtorString = toSource(Set),\n    weakMapCtorString = toSource(WeakMap);\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 */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((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\nmodule.exports = getTag;\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 */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nmodule.exports = hashClear;\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 */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\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 */\nfunction 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\nmodule.exports = hashSet;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\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 */\nfunction 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\nmodule.exports = isIndex;\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 */\nfunction 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\nmodule.exports = isKeyable;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\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 */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\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 */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nmodule.exports = isPrototype;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\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 */\nfunction 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\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\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 */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\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 */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\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 */\nfunction 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\nmodule.exports = listCacheSet;\n","var Hash = require('./_Hash'),\n    ListCache = require('./_ListCache'),\n    Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nmodule.exports = mapCacheClear;\n","var getMapData = require('./_getMapData');\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 */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var getMapData = require('./_getMapData');\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 */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\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 */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\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 */\nfunction 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\nmodule.exports = mapCacheSet;\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 */\nfunction 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\nmodule.exports = mapToArray;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar 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\nmodule.exports = nodeUtil;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\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 */\nvar nativeObjectToString = objectProto.toString;\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 */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\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 */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nmodule.exports = overArg;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\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 */\nfunction setCacheAdd(value) {\n  this.__data__.set(value, HASH_UNDEFINED);\n  return this;\n}\n\nmodule.exports = setCacheAdd;\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 */\nfunction setCacheHas(value) {\n  return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\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 */\nfunction 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\nmodule.exports = setToArray;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nmodule.exports = stackClear;\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 */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nmodule.exports = stackDelete;\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 */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\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 */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n    Map = require('./_Map'),\n    MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\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 */\nfunction 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\nmodule.exports = stackSet;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\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 */\nfunction 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\nmodule.exports = toSource;\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 */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var baseIsArguments = require('./_baseIsArguments'),\n    isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\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 */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\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 */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var isFunction = require('./isFunction'),\n    isLength = require('./isLength');\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 */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var root = require('./_root'),\n    stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\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 */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var baseIsEqual = require('./_baseIsEqual');\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 */\nfunction isEqual(value, other) {\n  return baseIsEqual(value, other);\n}\n\nmodule.exports = isEqual;\n","var baseGetTag = require('./_baseGetTag'),\n    isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\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 */\nfunction 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\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\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 */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\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 */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\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 */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n    baseUnary = require('./_baseUnary'),\n    nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\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 */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n    baseKeys = require('./_baseKeys'),\n    isArrayLike = require('./isArrayLike');\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 */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\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 */\nfunction stubArray() {\n  return [];\n}\n\nmodule.exports = stubArray;\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 */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = stubFalse;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n  function shim(props, propName, componentName, location, propFullName, secret) {\n    if (secret === ReactPropTypesSecret) {\n      // It is still safe when called from React.\n      return;\n    }\n    var err = new Error(\n      'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n      'Use PropTypes.checkPropTypes() to call them. ' +\n      'Read more at http://fb.me/use-check-prop-types'\n    );\n    err.name = 'Invariant Violation';\n    throw err;\n  };\n  shim.isRequired = shim;\n  function getShim() {\n    return shim;\n  };\n  // Important!\n  // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n  var ReactPropTypes = {\n    array: shim,\n    bigint: shim,\n    bool: shim,\n    func: shim,\n    number: shim,\n    object: shim,\n    string: shim,\n    symbol: shim,\n\n    any: shim,\n    arrayOf: getShim,\n    element: shim,\n    elementType: shim,\n    instanceOf: getShim,\n    node: shim,\n    objectOf: getShim,\n    oneOf: getShim,\n    oneOfType: getShim,\n    shape: getShim,\n    exact: getShim,\n\n    checkPropTypes: emptyFunctionWithReset,\n    resetWarningCache: emptyFunction\n  };\n\n  ReactPropTypes.PropTypes = ReactPropTypes;\n\n  return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n  var ReactIs = require('react-is');\n\n  // By explicitly using `prop-types` you are opting into new development behavior.\n  // http://fb.me/prop-types-in-prod\n  var throwOnDirectAccess = true;\n  module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n  // By explicitly using `prop-types` you are opting into new production behavior.\n  // http://fb.me/prop-types-in-prod\n  module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","import cloneDeep = require('lodash.clonedeep');\nimport isEqual = require('lodash.isequal');\n\ninterface AttributeMap {\n  [key: string]: unknown;\n}\n\nnamespace AttributeMap {\n  export function compose(\n    a: AttributeMap = {},\n    b: AttributeMap = {},\n    keepNull = false,\n  ): AttributeMap | undefined {\n    if (typeof a !== 'object') {\n      a = {};\n    }\n    if (typeof b !== 'object') {\n      b = {};\n    }\n    let attributes = cloneDeep(b);\n    if (!keepNull) {\n      attributes = Object.keys(attributes).reduce<AttributeMap>((copy, key) => {\n        if (attributes[key] != null) {\n          copy[key] = attributes[key];\n        }\n        return copy;\n      }, {});\n    }\n    for (const key in a) {\n      if (a[key] !== undefined && b[key] === undefined) {\n        attributes[key] = a[key];\n      }\n    }\n    return Object.keys(attributes).length > 0 ? attributes : undefined;\n  }\n\n  export function diff(\n    a: AttributeMap = {},\n    b: AttributeMap = {},\n  ): AttributeMap | undefined {\n    if (typeof a !== 'object') {\n      a = {};\n    }\n    if (typeof b !== 'object') {\n      b = {};\n    }\n    const attributes = Object.keys(a)\n      .concat(Object.keys(b))\n      .reduce<AttributeMap>((attrs, key) => {\n        if (!isEqual(a[key], b[key])) {\n          attrs[key] = b[key] === undefined ? null : b[key];\n        }\n        return attrs;\n      }, {});\n    return Object.keys(attributes).length > 0 ? attributes : undefined;\n  }\n\n  export function invert(\n    attr: AttributeMap = {},\n    base: AttributeMap = {},\n  ): AttributeMap {\n    attr = attr || {};\n    const baseInverted = Object.keys(base).reduce<AttributeMap>((memo, key) => {\n      if (base[key] !== attr[key] && attr[key] !== undefined) {\n        memo[key] = base[key];\n      }\n      return memo;\n    }, {});\n    return Object.keys(attr).reduce<AttributeMap>((memo, key) => {\n      if (attr[key] !== base[key] && base[key] === undefined) {\n        memo[key] = null;\n      }\n      return memo;\n    }, baseInverted);\n  }\n\n  export function transform(\n    a: AttributeMap | undefined,\n    b: AttributeMap | undefined,\n    priority = false,\n  ): AttributeMap | undefined {\n    if (typeof a !== 'object') {\n      return b;\n    }\n    if (typeof b !== 'object') {\n      return undefined;\n    }\n    if (!priority) {\n      return b; // b simply overwrites us without priority\n    }\n    const attributes = Object.keys(b).reduce<AttributeMap>((attrs, key) => {\n      if (a[key] === undefined) {\n        attrs[key] = b[key]; // null is a valid value\n      }\n      return attrs;\n    }, {});\n    return Object.keys(attributes).length > 0 ? attributes : undefined;\n  }\n}\n\nexport default AttributeMap;\n","import * as diff from 'fast-diff';\nimport cloneDeep = require('lodash.clonedeep');\nimport isEqual = require('lodash.isequal');\nimport AttributeMap from './AttributeMap';\nimport Op from './Op';\nimport OpIterator from './OpIterator';\n\nconst NULL_CHARACTER = String.fromCharCode(0); // Placeholder char for embed in diff()\n\ninterface EmbedHandler<T> {\n  compose(a: T, b: T, keepNull: boolean): T;\n  invert(a: T, b: T): T;\n  transform(a: T, b: T, priority: boolean): T;\n}\n\nconst getEmbedTypeAndData = (\n  a: Op['insert'] | Op['retain'],\n  b: Op['insert'],\n): [string, unknown, unknown] => {\n  if (typeof a !== 'object' || a === null) {\n    throw new Error(`cannot retain a ${typeof a}`);\n  }\n  if (typeof b !== 'object' || b === null) {\n    throw new Error(`cannot retain a ${typeof b}`);\n  }\n  const embedType = Object.keys(a)[0];\n  if (!embedType || embedType !== Object.keys(b)[0]) {\n    throw new Error(\n      `embed types not matched: ${embedType} != ${Object.keys(b)[0]}`,\n    );\n  }\n  return [embedType, a[embedType], b[embedType]];\n};\n\nclass Delta {\n  static Op = Op;\n  static OpIterator = OpIterator;\n  static AttributeMap = AttributeMap;\n  private static handlers: { [embedType: string]: EmbedHandler<unknown> } = {};\n\n  static registerEmbed<T>(embedType: string, handler: EmbedHandler<T>): void {\n    this.handlers[embedType] = handler;\n  }\n\n  static unregisterEmbed(embedType: string): void {\n    delete this.handlers[embedType];\n  }\n\n  private static getHandler(embedType: string): EmbedHandler<unknown> {\n    const handler = this.handlers[embedType];\n    if (!handler) {\n      throw new Error(`no handlers for embed type \"${embedType}\"`);\n    }\n    return handler;\n  }\n\n  ops: Op[];\n  constructor(ops?: Op[] | { ops: Op[] }) {\n    // Assume we are given a well formed ops\n    if (Array.isArray(ops)) {\n      this.ops = ops;\n    } else if (ops != null && Array.isArray(ops.ops)) {\n      this.ops = ops.ops;\n    } else {\n      this.ops = [];\n    }\n  }\n\n  insert(\n    arg: string | Record<string, unknown>,\n    attributes?: AttributeMap | null,\n  ): this {\n    const newOp: Op = {};\n    if (typeof arg === 'string' && arg.length === 0) {\n      return this;\n    }\n    newOp.insert = arg;\n    if (\n      attributes != null &&\n      typeof attributes === 'object' &&\n      Object.keys(attributes).length > 0\n    ) {\n      newOp.attributes = attributes;\n    }\n    return this.push(newOp);\n  }\n\n  delete(length: number): this {\n    if (length <= 0) {\n      return this;\n    }\n    return this.push({ delete: length });\n  }\n\n  retain(\n    length: number | Record<string, unknown>,\n    attributes?: AttributeMap | null,\n  ): this {\n    if (typeof length === 'number' && length <= 0) {\n      return this;\n    }\n    const newOp: Op = { retain: length };\n    if (\n      attributes != null &&\n      typeof attributes === 'object' &&\n      Object.keys(attributes).length > 0\n    ) {\n      newOp.attributes = attributes;\n    }\n    return this.push(newOp);\n  }\n\n  push(newOp: Op): this {\n    let index = this.ops.length;\n    let lastOp = this.ops[index - 1];\n    newOp = cloneDeep(newOp);\n    if (typeof lastOp === 'object') {\n      if (\n        typeof newOp.delete === 'number' &&\n        typeof lastOp.delete === 'number'\n      ) {\n        this.ops[index - 1] = { delete: lastOp.delete + newOp.delete };\n        return this;\n      }\n      // Since it does not matter if we insert before or after deleting at the same index,\n      // always prefer to insert first\n      if (typeof lastOp.delete === 'number' && newOp.insert != null) {\n        index -= 1;\n        lastOp = this.ops[index - 1];\n        if (typeof lastOp !== 'object') {\n          this.ops.unshift(newOp);\n          return this;\n        }\n      }\n      if (isEqual(newOp.attributes, lastOp.attributes)) {\n        if (\n          typeof newOp.insert === 'string' &&\n          typeof lastOp.insert === 'string'\n        ) {\n          this.ops[index - 1] = { insert: lastOp.insert + newOp.insert };\n          if (typeof newOp.attributes === 'object') {\n            this.ops[index - 1].attributes = newOp.attributes;\n          }\n          return this;\n        } else if (\n          typeof newOp.retain === 'number' &&\n          typeof lastOp.retain === 'number'\n        ) {\n          this.ops[index - 1] = { retain: lastOp.retain + newOp.retain };\n          if (typeof newOp.attributes === 'object') {\n            this.ops[index - 1].attributes = newOp.attributes;\n          }\n          return this;\n        }\n      }\n    }\n    if (index === this.ops.length) {\n      this.ops.push(newOp);\n    } else {\n      this.ops.splice(index, 0, newOp);\n    }\n    return this;\n  }\n\n  chop(): this {\n    const lastOp = this.ops[this.ops.length - 1];\n    if (lastOp && typeof lastOp.retain === 'number' && !lastOp.attributes) {\n      this.ops.pop();\n    }\n    return this;\n  }\n\n  filter(predicate: (op: Op, index: number) => boolean): Op[] {\n    return this.ops.filter(predicate);\n  }\n\n  forEach(predicate: (op: Op, index: number) => void): void {\n    this.ops.forEach(predicate);\n  }\n\n  map<T>(predicate: (op: Op, index: number) => T): T[] {\n    return this.ops.map(predicate);\n  }\n\n  partition(predicate: (op: Op) => boolean): [Op[], Op[]] {\n    const passed: Op[] = [];\n    const failed: Op[] = [];\n    this.forEach((op) => {\n      const target = predicate(op) ? passed : failed;\n      target.push(op);\n    });\n    return [passed, failed];\n  }\n\n  reduce<T>(\n    predicate: (accum: T, curr: Op, index: number) => T,\n    initialValue: T,\n  ): T {\n    return this.ops.reduce(predicate, initialValue);\n  }\n\n  changeLength(): number {\n    return this.reduce((length, elem) => {\n      if (elem.insert) {\n        return length + Op.length(elem);\n      } else if (elem.delete) {\n        return length - elem.delete;\n      }\n      return length;\n    }, 0);\n  }\n\n  length(): number {\n    return this.reduce((length, elem) => {\n      return length + Op.length(elem);\n    }, 0);\n  }\n\n  slice(start = 0, end = Infinity): Delta {\n    const ops = [];\n    const iter = new OpIterator(this.ops);\n    let index = 0;\n    while (index < end && iter.hasNext()) {\n      let nextOp;\n      if (index < start) {\n        nextOp = iter.next(start - index);\n      } else {\n        nextOp = iter.next(end - index);\n        ops.push(nextOp);\n      }\n      index += Op.length(nextOp);\n    }\n    return new Delta(ops);\n  }\n\n  compose(other: Delta): Delta {\n    const thisIter = new OpIterator(this.ops);\n    const otherIter = new OpIterator(other.ops);\n    const ops = [];\n    const firstOther = otherIter.peek();\n    if (\n      firstOther != null &&\n      typeof firstOther.retain === 'number' &&\n      firstOther.attributes == null\n    ) {\n      let firstLeft = firstOther.retain;\n      while (\n        thisIter.peekType() === 'insert' &&\n        thisIter.peekLength() <= firstLeft\n      ) {\n        firstLeft -= thisIter.peekLength();\n        ops.push(thisIter.next());\n      }\n      if (firstOther.retain - firstLeft > 0) {\n        otherIter.next(firstOther.retain - firstLeft);\n      }\n    }\n    const delta = new Delta(ops);\n    while (thisIter.hasNext() || otherIter.hasNext()) {\n      if (otherIter.peekType() === 'insert') {\n        delta.push(otherIter.next());\n      } else if (thisIter.peekType() === 'delete') {\n        delta.push(thisIter.next());\n      } else {\n        const length = Math.min(thisIter.peekLength(), otherIter.peekLength());\n        const thisOp = thisIter.next(length);\n        const otherOp = otherIter.next(length);\n        if (otherOp.retain) {\n          const newOp: Op = {};\n          if (typeof thisOp.retain === 'number') {\n            newOp.retain =\n              typeof otherOp.retain === 'number' ? length : otherOp.retain;\n          } else {\n            if (typeof otherOp.retain === 'number') {\n              if (thisOp.retain == null) {\n                newOp.insert = thisOp.insert;\n              } else {\n                newOp.retain = thisOp.retain;\n              }\n            } else {\n              const action = thisOp.retain == null ? 'insert' : 'retain';\n              const [embedType, thisData, otherData] = getEmbedTypeAndData(\n                thisOp[action],\n                otherOp.retain,\n              );\n              const handler = Delta.getHandler(embedType);\n              newOp[action] = {\n                [embedType]: handler.compose(\n                  thisData,\n                  otherData,\n                  action === 'retain',\n                ),\n              };\n            }\n          }\n          // Preserve null when composing with a retain, otherwise remove it for inserts\n          const attributes = AttributeMap.compose(\n            thisOp.attributes,\n            otherOp.attributes,\n            typeof thisOp.retain === 'number',\n          );\n          if (attributes) {\n            newOp.attributes = attributes;\n          }\n          delta.push(newOp);\n\n          // Optimization if rest of other is just retain\n          if (\n            !otherIter.hasNext() &&\n            isEqual(delta.ops[delta.ops.length - 1], newOp)\n          ) {\n            const rest = new Delta(thisIter.rest());\n            return delta.concat(rest).chop();\n          }\n\n          // Other op should be delete, we could be an insert or retain\n          // Insert + delete cancels out\n        } else if (\n          typeof otherOp.delete === 'number' &&\n          (typeof thisOp.retain === 'number' ||\n            (typeof thisOp.retain === 'object' && thisOp.retain !== null))\n        ) {\n          delta.push(otherOp);\n        }\n      }\n    }\n    return delta.chop();\n  }\n\n  concat(other: Delta): Delta {\n    const delta = new Delta(this.ops.slice());\n    if (other.ops.length > 0) {\n      delta.push(other.ops[0]);\n      delta.ops = delta.ops.concat(other.ops.slice(1));\n    }\n    return delta;\n  }\n\n  diff(other: Delta, cursor?: number | diff.CursorInfo): Delta {\n    if (this.ops === other.ops) {\n      return new Delta();\n    }\n    const strings = [this, other].map((delta) => {\n      return delta\n        .map((op) => {\n          if (op.insert != null) {\n            return typeof op.insert === 'string' ? op.insert : NULL_CHARACTER;\n          }\n          const prep = delta === other ? 'on' : 'with';\n          throw new Error('diff() called ' + prep + ' non-document');\n        })\n        .join('');\n    });\n    const retDelta = new Delta();\n    const diffResult = diff(strings[0], strings[1], cursor, true);\n    const thisIter = new OpIterator(this.ops);\n    const otherIter = new OpIterator(other.ops);\n    diffResult.forEach((component: diff.Diff) => {\n      let length = component[1].length;\n      while (length > 0) {\n        let opLength = 0;\n        switch (component[0]) {\n          case diff.INSERT:\n            opLength = Math.min(otherIter.peekLength(), length);\n            retDelta.push(otherIter.next(opLength));\n            break;\n          case diff.DELETE:\n            opLength = Math.min(length, thisIter.peekLength());\n            thisIter.next(opLength);\n            retDelta.delete(opLength);\n            break;\n          case diff.EQUAL:\n            opLength = Math.min(\n              thisIter.peekLength(),\n              otherIter.peekLength(),\n              length,\n            );\n            const thisOp = thisIter.next(opLength);\n            const otherOp = otherIter.next(opLength);\n            if (isEqual(thisOp.insert, otherOp.insert)) {\n              retDelta.retain(\n                opLength,\n                AttributeMap.diff(thisOp.attributes, otherOp.attributes),\n              );\n            } else {\n              retDelta.push(otherOp).delete(opLength);\n            }\n            break;\n        }\n        length -= opLength;\n      }\n    });\n    return retDelta.chop();\n  }\n\n  eachLine(\n    predicate: (\n      line: Delta,\n      attributes: AttributeMap,\n      index: number,\n    ) => boolean | void,\n    newline = '\\n',\n  ): void {\n    const iter = new OpIterator(this.ops);\n    let line = new Delta();\n    let i = 0;\n    while (iter.hasNext()) {\n      if (iter.peekType() !== 'insert') {\n        return;\n      }\n      const thisOp = iter.peek();\n      const start = Op.length(thisOp) - iter.peekLength();\n      const index =\n        typeof thisOp.insert === 'string'\n          ? thisOp.insert.indexOf(newline, start) - start\n          : -1;\n      if (index < 0) {\n        line.push(iter.next());\n      } else if (index > 0) {\n        line.push(iter.next(index));\n      } else {\n        if (predicate(line, iter.next(1).attributes || {}, i) === false) {\n          return;\n        }\n        i += 1;\n        line = new Delta();\n      }\n    }\n    if (line.length() > 0) {\n      predicate(line, {}, i);\n    }\n  }\n\n  invert(base: Delta): Delta {\n    const inverted = new Delta();\n    this.reduce((baseIndex, op) => {\n      if (op.insert) {\n        inverted.delete(Op.length(op));\n      } else if (typeof op.retain === 'number' && op.attributes == null) {\n        inverted.retain(op.retain);\n        return baseIndex + op.retain;\n      } else if (op.delete || typeof op.retain === 'number') {\n        const length = (op.delete || op.retain) as number;\n        const slice = base.slice(baseIndex, baseIndex + length);\n        slice.forEach((baseOp) => {\n          if (op.delete) {\n            inverted.push(baseOp);\n          } else if (op.retain && op.attributes) {\n            inverted.retain(\n              Op.length(baseOp),\n              AttributeMap.invert(op.attributes, baseOp.attributes),\n            );\n          }\n        });\n        return baseIndex + length;\n      } else if (typeof op.retain === 'object' && op.retain !== null) {\n        const slice = base.slice(baseIndex, baseIndex + 1);\n        const baseOp = new OpIterator(slice.ops).next();\n        const [embedType, opData, baseOpData] = getEmbedTypeAndData(\n          op.retain,\n          baseOp.insert,\n        );\n        const handler = Delta.getHandler(embedType);\n        inverted.retain(\n          { [embedType]: handler.invert(opData, baseOpData) },\n          AttributeMap.invert(op.attributes, baseOp.attributes),\n        );\n        return baseIndex + 1;\n      }\n      return baseIndex;\n    }, 0);\n    return inverted.chop();\n  }\n\n  transform(index: number, priority?: boolean): number;\n  transform(other: Delta, priority?: boolean): Delta;\n  transform(arg: number | Delta, priority = false): typeof arg {\n    priority = !!priority;\n    if (typeof arg === 'number') {\n      return this.transformPosition(arg, priority);\n    }\n    const other: Delta = arg;\n    const thisIter = new OpIterator(this.ops);\n    const otherIter = new OpIterator(other.ops);\n    const delta = new Delta();\n    while (thisIter.hasNext() || otherIter.hasNext()) {\n      if (\n        thisIter.peekType() === 'insert' &&\n        (priority || otherIter.peekType() !== 'insert')\n      ) {\n        delta.retain(Op.length(thisIter.next()));\n      } else if (otherIter.peekType() === 'insert') {\n        delta.push(otherIter.next());\n      } else {\n        const length = Math.min(thisIter.peekLength(), otherIter.peekLength());\n        const thisOp = thisIter.next(length);\n        const otherOp = otherIter.next(length);\n        if (thisOp.delete) {\n          // Our delete either makes their delete redundant or removes their retain\n          continue;\n        } else if (otherOp.delete) {\n          delta.push(otherOp);\n        } else {\n          const thisData = thisOp.retain;\n          const otherData = otherOp.retain;\n          let transformedData: Op['retain'] =\n            typeof otherData === 'object' && otherData !== null\n              ? otherData\n              : length;\n          if (\n            typeof thisData === 'object' &&\n            thisData !== null &&\n            typeof otherData === 'object' &&\n            otherData !== null\n          ) {\n            const embedType = Object.keys(thisData)[0];\n            if (embedType === Object.keys(otherData)[0]) {\n              const handler = Delta.getHandler(embedType);\n              if (handler) {\n                transformedData = {\n                  [embedType]: handler.transform(\n                    thisData[embedType],\n                    otherData[embedType],\n                    priority,\n                  ),\n                };\n              }\n            }\n          }\n\n          // We retain either their retain or insert\n          delta.retain(\n            transformedData,\n            AttributeMap.transform(\n              thisOp.attributes,\n              otherOp.attributes,\n              priority,\n            ),\n          );\n        }\n      }\n    }\n    return delta.chop();\n  }\n\n  transformPosition(index: number, priority = false): number {\n    priority = !!priority;\n    const thisIter = new OpIterator(this.ops);\n    let offset = 0;\n    while (thisIter.hasNext() && offset <= index) {\n      const length = thisIter.peekLength();\n      const nextType = thisIter.peekType();\n      thisIter.next();\n      if (nextType === 'delete') {\n        index -= Math.min(length, index - offset);\n        continue;\n      } else if (nextType === 'insert' && (offset < index || !priority)) {\n        index += length;\n      }\n      offset += length;\n    }\n    return index;\n  }\n}\n\nexport default Delta;\n\nexport { Op, OpIterator, AttributeMap };\n\nif (typeof module === 'object') {\n  module.exports = Delta;\n  module.exports.default = Delta;\n}\n","import AttributeMap from './AttributeMap';\n\ninterface Op {\n  // only one property out of {insert, delete, retain} will be present\n  insert?: string | Record<string, unknown>;\n  delete?: number;\n  retain?: number | Record<string, unknown>;\n\n  attributes?: AttributeMap;\n}\n\nnamespace Op {\n  export function length(op: Op): number {\n    if (typeof op.delete === 'number') {\n      return op.delete;\n    } else if (typeof op.retain === 'number') {\n      return op.retain;\n    } else if (typeof op.retain === 'object' && op.retain !== null) {\n      return 1;\n    } else {\n      return typeof op.insert === 'string' ? op.insert.length : 1;\n    }\n  }\n}\n\nexport default Op;\n","import Op from './Op';\n\nexport default class Iterator {\n  ops: Op[];\n  index: number;\n  offset: number;\n\n  constructor(ops: Op[]) {\n    this.ops = ops;\n    this.index = 0;\n    this.offset = 0;\n  }\n\n  hasNext(): boolean {\n    return this.peekLength() < Infinity;\n  }\n\n  next(length?: number): Op {\n    if (!length) {\n      length = Infinity;\n    }\n    const nextOp = this.ops[this.index];\n    if (nextOp) {\n      const offset = this.offset;\n      const opLength = Op.length(nextOp);\n      if (length >= opLength - offset) {\n        length = opLength - offset;\n        this.index += 1;\n        this.offset = 0;\n      } else {\n        this.offset += length;\n      }\n      if (typeof nextOp.delete === 'number') {\n        return { delete: length };\n      } else {\n        const retOp: Op = {};\n        if (nextOp.attributes) {\n          retOp.attributes = nextOp.attributes;\n        }\n        if (typeof nextOp.retain === 'number') {\n          retOp.retain = length;\n        } else if (\n          typeof nextOp.retain === 'object' &&\n          nextOp.retain !== null\n        ) {\n          // offset should === 0, length should === 1\n          retOp.retain = nextOp.retain;\n        } else if (typeof nextOp.insert === 'string') {\n          retOp.insert = nextOp.insert.substr(offset, length);\n        } else {\n          // offset should === 0, length should === 1\n          retOp.insert = nextOp.insert;\n        }\n        return retOp;\n      }\n    } else {\n      return { retain: Infinity };\n    }\n  }\n\n  peek(): Op {\n    return this.ops[this.index];\n  }\n\n  peekLength(): number {\n    if (this.ops[this.index]) {\n      // Should never return 0 if our index is being managed correctly\n      return Op.length(this.ops[this.index]) - this.offset;\n    } else {\n      return Infinity;\n    }\n  }\n\n  peekType(): string {\n    const op = this.ops[this.index];\n    if (op) {\n      if (typeof op.delete === 'number') {\n        return 'delete';\n      } else if (\n        typeof op.retain === 'number' ||\n        (typeof op.retain === 'object' && op.retain !== null)\n      ) {\n        return 'retain';\n      } else {\n        return 'insert';\n      }\n    }\n    return 'retain';\n  }\n\n  rest(): Op[] {\n    if (!this.hasNext()) {\n      return [];\n    } else if (this.offset === 0) {\n      return this.ops.slice(this.index);\n    } else {\n      const offset = this.offset;\n      const index = this.index;\n      const next = this.next();\n      const rest = this.ops.slice(this.index);\n      this.offset = offset;\n      this.index = index;\n      return [next].concat(rest);\n    }\n  }\n}\n","/**\n * @license React\n * react-dom-client.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n\"use strict\";\nvar Scheduler = require(\"scheduler\"),\n  React = require(\"react\"),\n  ReactDOM = require(\"react-dom\");\nfunction formatProdErrorMessage(code) {\n  var url = \"https://react.dev/errors/\" + code;\n  if (1 < arguments.length) {\n    url += \"?args[]=\" + encodeURIComponent(arguments[1]);\n    for (var i = 2; i < arguments.length; i++)\n      url += \"&args[]=\" + encodeURIComponent(arguments[i]);\n  }\n  return (\n    \"Minified React error #\" +\n    code +\n    \"; visit \" +\n    url +\n    \" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"\n  );\n}\nfunction isValidContainer(node) {\n  return !(\n    !node ||\n    (1 !== node.nodeType && 9 !== node.nodeType && 11 !== node.nodeType)\n  );\n}\nvar REACT_LEGACY_ELEMENT_TYPE = Symbol.for(\"react.element\"),\n  REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n  REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n  REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n  REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n  REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n  REACT_PROVIDER_TYPE = Symbol.for(\"react.provider\"),\n  REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n  REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n  REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n  REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n  REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n  REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n  REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nSymbol.for(\"react.scope\");\nSymbol.for(\"react.debug_trace_mode\");\nvar REACT_OFFSCREEN_TYPE = Symbol.for(\"react.offscreen\");\nSymbol.for(\"react.legacy_hidden\");\nSymbol.for(\"react.tracing_marker\");\nvar REACT_MEMO_CACHE_SENTINEL = Symbol.for(\"react.memo_cache_sentinel\"),\n  MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nfunction getIteratorFn(maybeIterable) {\n  if (null === maybeIterable || \"object\" !== typeof maybeIterable) return null;\n  maybeIterable =\n    (MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||\n    maybeIterable[\"@@iterator\"];\n  return \"function\" === typeof maybeIterable ? maybeIterable : null;\n}\nvar REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nfunction getComponentNameFromType(type) {\n  if (null == type) return null;\n  if (\"function\" === typeof type)\n    return type.$$typeof === REACT_CLIENT_REFERENCE\n      ? null\n      : type.displayName || type.name || null;\n  if (\"string\" === typeof type) return type;\n  switch (type) {\n    case REACT_FRAGMENT_TYPE:\n      return \"Fragment\";\n    case REACT_PORTAL_TYPE:\n      return \"Portal\";\n    case REACT_PROFILER_TYPE:\n      return \"Profiler\";\n    case REACT_STRICT_MODE_TYPE:\n      return \"StrictMode\";\n    case REACT_SUSPENSE_TYPE:\n      return \"Suspense\";\n    case REACT_SUSPENSE_LIST_TYPE:\n      return \"SuspenseList\";\n  }\n  if (\"object\" === typeof type)\n    switch (type.$$typeof) {\n      case REACT_CONTEXT_TYPE:\n        return (type.displayName || \"Context\") + \".Provider\";\n      case REACT_CONSUMER_TYPE:\n        return (type._context.displayName || \"Context\") + \".Consumer\";\n      case REACT_FORWARD_REF_TYPE:\n        var innerType = type.render;\n        type = type.displayName;\n        type ||\n          ((type = innerType.displayName || innerType.name || \"\"),\n          (type = \"\" !== type ? \"ForwardRef(\" + type + \")\" : \"ForwardRef\"));\n        return type;\n      case REACT_MEMO_TYPE:\n        return (\n          (innerType = type.displayName || null),\n          null !== innerType\n            ? innerType\n            : getComponentNameFromType(type.type) || \"Memo\"\n        );\n      case REACT_LAZY_TYPE:\n        innerType = type._payload;\n        type = type._init;\n        try {\n          return getComponentNameFromType(type(innerType));\n        } catch (x) {}\n    }\n  return null;\n}\nvar ReactSharedInternals =\n    React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,\n  assign = Object.assign,\n  prefix,\n  suffix;\nfunction describeBuiltInComponentFrame(name) {\n  if (void 0 === prefix)\n    try {\n      throw Error();\n    } catch (x) {\n      var match = x.stack.trim().match(/\\n( *(at )?)/);\n      prefix = (match && match[1]) || \"\";\n      suffix =\n        -1 < x.stack.indexOf(\"\\n    at\")\n          ? \" (<anonymous>)\"\n          : -1 < x.stack.indexOf(\"@\")\n            ? \"@unknown:0:0\"\n            : \"\";\n    }\n  return \"\\n\" + prefix + name + suffix;\n}\nvar reentry = !1;\nfunction describeNativeComponentFrame(fn, construct) {\n  if (!fn || reentry) return \"\";\n  reentry = !0;\n  var previousPrepareStackTrace = Error.prepareStackTrace;\n  Error.prepareStackTrace = void 0;\n  try {\n    var RunInRootFrame = {\n      DetermineComponentFrameRoot: function () {\n        try {\n          if (construct) {\n            var Fake = function () {\n              throw Error();\n            };\n            Object.defineProperty(Fake.prototype, \"props\", {\n              set: function () {\n                throw Error();\n              }\n            });\n            if (\"object\" === typeof Reflect && Reflect.construct) {\n              try {\n                Reflect.construct(Fake, []);\n              } catch (x) {\n                var control = x;\n              }\n              Reflect.construct(fn, [], Fake);\n            } else {\n              try {\n                Fake.call();\n              } catch (x$0) {\n                control = x$0;\n              }\n              fn.call(Fake.prototype);\n            }\n          } else {\n            try {\n              throw Error();\n            } catch (x$1) {\n              control = x$1;\n            }\n            (Fake = fn()) &&\n              \"function\" === typeof Fake.catch &&\n              Fake.catch(function () {});\n          }\n        } catch (sample) {\n          if (sample && control && \"string\" === typeof sample.stack)\n            return [sample.stack, control.stack];\n        }\n        return [null, null];\n      }\n    };\n    RunInRootFrame.DetermineComponentFrameRoot.displayName =\n      \"DetermineComponentFrameRoot\";\n    var namePropDescriptor = Object.getOwnPropertyDescriptor(\n      RunInRootFrame.DetermineComponentFrameRoot,\n      \"name\"\n    );\n    namePropDescriptor &&\n      namePropDescriptor.configurable &&\n      Object.defineProperty(\n        RunInRootFrame.DetermineComponentFrameRoot,\n        \"name\",\n        { value: \"DetermineComponentFrameRoot\" }\n      );\n    var _RunInRootFrame$Deter = RunInRootFrame.DetermineComponentFrameRoot(),\n      sampleStack = _RunInRootFrame$Deter[0],\n      controlStack = _RunInRootFrame$Deter[1];\n    if (sampleStack && controlStack) {\n      var sampleLines = sampleStack.split(\"\\n\"),\n        controlLines = controlStack.split(\"\\n\");\n      for (\n        namePropDescriptor = RunInRootFrame = 0;\n        RunInRootFrame < sampleLines.length &&\n        !sampleLines[RunInRootFrame].includes(\"DetermineComponentFrameRoot\");\n\n      )\n        RunInRootFrame++;\n      for (\n        ;\n        namePropDescriptor < controlLines.length &&\n        !controlLines[namePropDescriptor].includes(\n          \"DetermineComponentFrameRoot\"\n        );\n\n      )\n        namePropDescriptor++;\n      if (\n        RunInRootFrame === sampleLines.length ||\n        namePropDescriptor === controlLines.length\n      )\n        for (\n          RunInRootFrame = sampleLines.length - 1,\n            namePropDescriptor = controlLines.length - 1;\n          1 <= RunInRootFrame &&\n          0 <= namePropDescriptor &&\n          sampleLines[RunInRootFrame] !== controlLines[namePropDescriptor];\n\n        )\n          namePropDescriptor--;\n      for (\n        ;\n        1 <= RunInRootFrame && 0 <= namePropDescriptor;\n        RunInRootFrame--, namePropDescriptor--\n      )\n        if (sampleLines[RunInRootFrame] !== controlLines[namePropDescriptor]) {\n          if (1 !== RunInRootFrame || 1 !== namePropDescriptor) {\n            do\n              if (\n                (RunInRootFrame--,\n                namePropDescriptor--,\n                0 > namePropDescriptor ||\n                  sampleLines[RunInRootFrame] !==\n                    controlLines[namePropDescriptor])\n              ) {\n                var frame =\n                  \"\\n\" +\n                  sampleLines[RunInRootFrame].replace(\" at new \", \" at \");\n                fn.displayName &&\n                  frame.includes(\"<anonymous>\") &&\n                  (frame = frame.replace(\"<anonymous>\", fn.displayName));\n                return frame;\n              }\n            while (1 <= RunInRootFrame && 0 <= namePropDescriptor);\n          }\n          break;\n        }\n    }\n  } finally {\n    (reentry = !1), (Error.prepareStackTrace = previousPrepareStackTrace);\n  }\n  return (previousPrepareStackTrace = fn ? fn.displayName || fn.name : \"\")\n    ? describeBuiltInComponentFrame(previousPrepareStackTrace)\n    : \"\";\n}\nfunction describeFiber(fiber) {\n  switch (fiber.tag) {\n    case 26:\n    case 27:\n    case 5:\n      return describeBuiltInComponentFrame(fiber.type);\n    case 16:\n      return describeBuiltInComponentFrame(\"Lazy\");\n    case 13:\n      return describeBuiltInComponentFrame(\"Suspense\");\n    case 19:\n      return describeBuiltInComponentFrame(\"SuspenseList\");\n    case 0:\n    case 15:\n      return (fiber = describeNativeComponentFrame(fiber.type, !1)), fiber;\n    case 11:\n      return (\n        (fiber = describeNativeComponentFrame(fiber.type.render, !1)), fiber\n      );\n    case 1:\n      return (fiber = describeNativeComponentFrame(fiber.type, !0)), fiber;\n    default:\n      return \"\";\n  }\n}\nfunction getStackByFiberInDevAndProd(workInProgress) {\n  try {\n    var info = \"\";\n    do\n      (info += describeFiber(workInProgress)),\n        (workInProgress = workInProgress.return);\n    while (workInProgress);\n    return info;\n  } catch (x) {\n    return \"\\nError generating stack: \" + x.message + \"\\n\" + x.stack;\n  }\n}\nfunction getNearestMountedFiber(fiber) {\n  var node = fiber,\n    nearestMounted = fiber;\n  if (fiber.alternate) for (; node.return; ) node = node.return;\n  else {\n    fiber = node;\n    do\n      (node = fiber),\n        0 !== (node.flags & 4098) && (nearestMounted = node.return),\n        (fiber = node.return);\n    while (fiber);\n  }\n  return 3 === node.tag ? nearestMounted : null;\n}\nfunction getSuspenseInstanceFromFiber(fiber) {\n  if (13 === fiber.tag) {\n    var suspenseState = fiber.memoizedState;\n    null === suspenseState &&\n      ((fiber = fiber.alternate),\n      null !== fiber && (suspenseState = fiber.memoizedState));\n    if (null !== suspenseState) return suspenseState.dehydrated;\n  }\n  return null;\n}\nfunction assertIsMounted(fiber) {\n  if (getNearestMountedFiber(fiber) !== fiber)\n    throw Error(formatProdErrorMessage(188));\n}\nfunction findCurrentFiberUsingSlowPath(fiber) {\n  var alternate = fiber.alternate;\n  if (!alternate) {\n    alternate = getNearestMountedFiber(fiber);\n    if (null === alternate) throw Error(formatProdErrorMessage(188));\n    return alternate !== fiber ? null : fiber;\n  }\n  for (var a = fiber, b = alternate; ; ) {\n    var parentA = a.return;\n    if (null === parentA) break;\n    var parentB = parentA.alternate;\n    if (null === parentB) {\n      b = parentA.return;\n      if (null !== b) {\n        a = b;\n        continue;\n      }\n      break;\n    }\n    if (parentA.child === parentB.child) {\n      for (parentB = parentA.child; parentB; ) {\n        if (parentB === a) return assertIsMounted(parentA), fiber;\n        if (parentB === b) return assertIsMounted(parentA), alternate;\n        parentB = parentB.sibling;\n      }\n      throw Error(formatProdErrorMessage(188));\n    }\n    if (a.return !== b.return) (a = parentA), (b = parentB);\n    else {\n      for (var didFindChild = !1, child$2 = parentA.child; child$2; ) {\n        if (child$2 === a) {\n          didFindChild = !0;\n          a = parentA;\n          b = parentB;\n          break;\n        }\n        if (child$2 === b) {\n          didFindChild = !0;\n          b = parentA;\n          a = parentB;\n          break;\n        }\n        child$2 = child$2.sibling;\n      }\n      if (!didFindChild) {\n        for (child$2 = parentB.child; child$2; ) {\n          if (child$2 === a) {\n            didFindChild = !0;\n            a = parentB;\n            b = parentA;\n            break;\n          }\n          if (child$2 === b) {\n            didFindChild = !0;\n            b = parentB;\n            a = parentA;\n            break;\n          }\n          child$2 = child$2.sibling;\n        }\n        if (!didFindChild) throw Error(formatProdErrorMessage(189));\n      }\n    }\n    if (a.alternate !== b) throw Error(formatProdErrorMessage(190));\n  }\n  if (3 !== a.tag) throw Error(formatProdErrorMessage(188));\n  return a.stateNode.current === a ? fiber : alternate;\n}\nfunction findCurrentHostFiberImpl(node) {\n  var tag = node.tag;\n  if (5 === tag || 26 === tag || 27 === tag || 6 === tag) return node;\n  for (node = node.child; null !== node; ) {\n    tag = findCurrentHostFiberImpl(node);\n    if (null !== tag) return tag;\n    node = node.sibling;\n  }\n  return null;\n}\nvar isArrayImpl = Array.isArray,\n  ReactDOMSharedInternals =\n    ReactDOM.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,\n  sharedNotPendingObject = {\n    pending: !1,\n    data: null,\n    method: null,\n    action: null\n  },\n  valueStack = [],\n  index = -1;\nfunction createCursor(defaultValue) {\n  return { current: defaultValue };\n}\nfunction pop(cursor) {\n  0 > index ||\n    ((cursor.current = valueStack[index]), (valueStack[index] = null), index--);\n}\nfunction push(cursor, value) {\n  index++;\n  valueStack[index] = cursor.current;\n  cursor.current = value;\n}\nvar contextStackCursor = createCursor(null),\n  contextFiberStackCursor = createCursor(null),\n  rootInstanceStackCursor = createCursor(null),\n  hostTransitionProviderCursor = createCursor(null);\nfunction pushHostContainer(fiber, nextRootInstance) {\n  push(rootInstanceStackCursor, nextRootInstance);\n  push(contextFiberStackCursor, fiber);\n  push(contextStackCursor, null);\n  fiber = nextRootInstance.nodeType;\n  switch (fiber) {\n    case 9:\n    case 11:\n      nextRootInstance = (nextRootInstance = nextRootInstance.documentElement)\n        ? (nextRootInstance = nextRootInstance.namespaceURI)\n          ? getOwnHostContext(nextRootInstance)\n          : 0\n        : 0;\n      break;\n    default:\n      if (\n        ((fiber = 8 === fiber ? nextRootInstance.parentNode : nextRootInstance),\n        (nextRootInstance = fiber.tagName),\n        (fiber = fiber.namespaceURI))\n      )\n        (fiber = getOwnHostContext(fiber)),\n          (nextRootInstance = getChildHostContextProd(fiber, nextRootInstance));\n      else\n        switch (nextRootInstance) {\n          case \"svg\":\n            nextRootInstance = 1;\n            break;\n          case \"math\":\n            nextRootInstance = 2;\n            break;\n          default:\n            nextRootInstance = 0;\n        }\n  }\n  pop(contextStackCursor);\n  push(contextStackCursor, nextRootInstance);\n}\nfunction popHostContainer() {\n  pop(contextStackCursor);\n  pop(contextFiberStackCursor);\n  pop(rootInstanceStackCursor);\n}\nfunction pushHostContext(fiber) {\n  null !== fiber.memoizedState && push(hostTransitionProviderCursor, fiber);\n  var context = contextStackCursor.current;\n  var JSCompiler_inline_result = getChildHostContextProd(context, fiber.type);\n  context !== JSCompiler_inline_result &&\n    (push(contextFiberStackCursor, fiber),\n    push(contextStackCursor, JSCompiler_inline_result));\n}\nfunction popHostContext(fiber) {\n  contextFiberStackCursor.current === fiber &&\n    (pop(contextStackCursor), pop(contextFiberStackCursor));\n  hostTransitionProviderCursor.current === fiber &&\n    (pop(hostTransitionProviderCursor),\n    (HostTransitionContext._currentValue = sharedNotPendingObject));\n}\nvar hasOwnProperty = Object.prototype.hasOwnProperty,\n  scheduleCallback$3 = Scheduler.unstable_scheduleCallback,\n  cancelCallback$1 = Scheduler.unstable_cancelCallback,\n  shouldYield = Scheduler.unstable_shouldYield,\n  requestPaint = Scheduler.unstable_requestPaint,\n  now = Scheduler.unstable_now,\n  getCurrentPriorityLevel = Scheduler.unstable_getCurrentPriorityLevel,\n  ImmediatePriority = Scheduler.unstable_ImmediatePriority,\n  UserBlockingPriority = Scheduler.unstable_UserBlockingPriority,\n  NormalPriority$1 = Scheduler.unstable_NormalPriority,\n  LowPriority = Scheduler.unstable_LowPriority,\n  IdlePriority = Scheduler.unstable_IdlePriority,\n  log$1 = Scheduler.log,\n  unstable_setDisableYieldValue = Scheduler.unstable_setDisableYieldValue,\n  rendererID = null,\n  injectedHook = null;\nfunction onCommitRoot(root) {\n  if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberRoot)\n    try {\n      injectedHook.onCommitFiberRoot(\n        rendererID,\n        root,\n        void 0,\n        128 === (root.current.flags & 128)\n      );\n    } catch (err) {}\n}\nfunction setIsStrictModeForDevtools(newIsStrictMode) {\n  \"function\" === typeof log$1 && unstable_setDisableYieldValue(newIsStrictMode);\n  if (injectedHook && \"function\" === typeof injectedHook.setStrictMode)\n    try {\n      injectedHook.setStrictMode(rendererID, newIsStrictMode);\n    } catch (err) {}\n}\nvar clz32 = Math.clz32 ? Math.clz32 : clz32Fallback,\n  log = Math.log,\n  LN2 = Math.LN2;\nfunction clz32Fallback(x) {\n  x >>>= 0;\n  return 0 === x ? 32 : (31 - ((log(x) / LN2) | 0)) | 0;\n}\nvar nextTransitionLane = 128,\n  nextRetryLane = 4194304;\nfunction getHighestPriorityLanes(lanes) {\n  var pendingSyncLanes = lanes & 42;\n  if (0 !== pendingSyncLanes) return pendingSyncLanes;\n  switch (lanes & -lanes) {\n    case 1:\n      return 1;\n    case 2:\n      return 2;\n    case 4:\n      return 4;\n    case 8:\n      return 8;\n    case 16:\n      return 16;\n    case 32:\n      return 32;\n    case 64:\n      return 64;\n    case 128:\n    case 256:\n    case 512:\n    case 1024:\n    case 2048:\n    case 4096:\n    case 8192:\n    case 16384:\n    case 32768:\n    case 65536:\n    case 131072:\n    case 262144:\n    case 524288:\n    case 1048576:\n    case 2097152:\n      return lanes & 4194176;\n    case 4194304:\n    case 8388608:\n    case 16777216:\n    case 33554432:\n      return lanes & 62914560;\n    case 67108864:\n      return 67108864;\n    case 134217728:\n      return 134217728;\n    case 268435456:\n      return 268435456;\n    case 536870912:\n      return 536870912;\n    case 1073741824:\n      return 0;\n    default:\n      return lanes;\n  }\n}\nfunction getNextLanes(root, wipLanes) {\n  var pendingLanes = root.pendingLanes;\n  if (0 === pendingLanes) return 0;\n  var nextLanes = 0,\n    suspendedLanes = root.suspendedLanes,\n    pingedLanes = root.pingedLanes,\n    warmLanes = root.warmLanes;\n  root = 0 !== root.finishedLanes;\n  var nonIdlePendingLanes = pendingLanes & 134217727;\n  0 !== nonIdlePendingLanes\n    ? ((pendingLanes = nonIdlePendingLanes & ~suspendedLanes),\n      0 !== pendingLanes\n        ? (nextLanes = getHighestPriorityLanes(pendingLanes))\n        : ((pingedLanes &= nonIdlePendingLanes),\n          0 !== pingedLanes\n            ? (nextLanes = getHighestPriorityLanes(pingedLanes))\n            : root ||\n              ((warmLanes = nonIdlePendingLanes & ~warmLanes),\n              0 !== warmLanes &&\n                (nextLanes = getHighestPriorityLanes(warmLanes)))))\n    : ((nonIdlePendingLanes = pendingLanes & ~suspendedLanes),\n      0 !== nonIdlePendingLanes\n        ? (nextLanes = getHighestPriorityLanes(nonIdlePendingLanes))\n        : 0 !== pingedLanes\n          ? (nextLanes = getHighestPriorityLanes(pingedLanes))\n          : root ||\n            ((warmLanes = pendingLanes & ~warmLanes),\n            0 !== warmLanes &&\n              (nextLanes = getHighestPriorityLanes(warmLanes))));\n  return 0 === nextLanes\n    ? 0\n    : 0 !== wipLanes &&\n        wipLanes !== nextLanes &&\n        0 === (wipLanes & suspendedLanes) &&\n        ((suspendedLanes = nextLanes & -nextLanes),\n        (warmLanes = wipLanes & -wipLanes),\n        suspendedLanes >= warmLanes ||\n          (32 === suspendedLanes && 0 !== (warmLanes & 4194176)))\n      ? wipLanes\n      : nextLanes;\n}\nfunction checkIfRootIsPrerendering(root, renderLanes) {\n  return (\n    0 ===\n    (root.pendingLanes &\n      ~(root.suspendedLanes & ~root.pingedLanes) &\n      renderLanes)\n  );\n}\nfunction computeExpirationTime(lane, currentTime) {\n  switch (lane) {\n    case 1:\n    case 2:\n    case 4:\n    case 8:\n      return currentTime + 250;\n    case 16:\n    case 32:\n    case 64:\n    case 128:\n    case 256:\n    case 512:\n    case 1024:\n    case 2048:\n    case 4096:\n    case 8192:\n    case 16384:\n    case 32768:\n    case 65536:\n    case 131072:\n    case 262144:\n    case 524288:\n    case 1048576:\n    case 2097152:\n      return currentTime + 5e3;\n    case 4194304:\n    case 8388608:\n    case 16777216:\n    case 33554432:\n      return -1;\n    case 67108864:\n    case 134217728:\n    case 268435456:\n    case 536870912:\n    case 1073741824:\n      return -1;\n    default:\n      return -1;\n  }\n}\nfunction claimNextTransitionLane() {\n  var lane = nextTransitionLane;\n  nextTransitionLane <<= 1;\n  0 === (nextTransitionLane & 4194176) && (nextTransitionLane = 128);\n  return lane;\n}\nfunction claimNextRetryLane() {\n  var lane = nextRetryLane;\n  nextRetryLane <<= 1;\n  0 === (nextRetryLane & 62914560) && (nextRetryLane = 4194304);\n  return lane;\n}\nfunction createLaneMap(initial) {\n  for (var laneMap = [], i = 0; 31 > i; i++) laneMap.push(initial);\n  return laneMap;\n}\nfunction markRootUpdated$1(root, updateLane) {\n  root.pendingLanes |= updateLane;\n  268435456 !== updateLane &&\n    ((root.suspendedLanes = 0), (root.pingedLanes = 0), (root.warmLanes = 0));\n}\nfunction markRootFinished(\n  root,\n  finishedLanes,\n  remainingLanes,\n  spawnedLane,\n  updatedLanes,\n  suspendedRetryLanes\n) {\n  var previouslyPendingLanes = root.pendingLanes;\n  root.pendingLanes = remainingLanes;\n  root.suspendedLanes = 0;\n  root.pingedLanes = 0;\n  root.warmLanes = 0;\n  root.expiredLanes &= remainingLanes;\n  root.entangledLanes &= remainingLanes;\n  root.errorRecoveryDisabledLanes &= remainingLanes;\n  root.shellSuspendCounter = 0;\n  var entanglements = root.entanglements,\n    expirationTimes = root.expirationTimes,\n    hiddenUpdates = root.hiddenUpdates;\n  for (\n    remainingLanes = previouslyPendingLanes & ~remainingLanes;\n    0 < remainingLanes;\n\n  ) {\n    var index$7 = 31 - clz32(remainingLanes),\n      lane = 1 << index$7;\n    entanglements[index$7] = 0;\n    expirationTimes[index$7] = -1;\n    var hiddenUpdatesForLane = hiddenUpdates[index$7];\n    if (null !== hiddenUpdatesForLane)\n      for (\n        hiddenUpdates[index$7] = null, index$7 = 0;\n        index$7 < hiddenUpdatesForLane.length;\n        index$7++\n      ) {\n        var update = hiddenUpdatesForLane[index$7];\n        null !== update && (update.lane &= -536870913);\n      }\n    remainingLanes &= ~lane;\n  }\n  0 !== spawnedLane && markSpawnedDeferredLane(root, spawnedLane, 0);\n  0 !== suspendedRetryLanes &&\n    0 === updatedLanes &&\n    0 !== root.tag &&\n    (root.suspendedLanes |=\n      suspendedRetryLanes & ~(previouslyPendingLanes & ~finishedLanes));\n}\nfunction markSpawnedDeferredLane(root, spawnedLane, entangledLanes) {\n  root.pendingLanes |= spawnedLane;\n  root.suspendedLanes &= ~spawnedLane;\n  var spawnedLaneIndex = 31 - clz32(spawnedLane);\n  root.entangledLanes |= spawnedLane;\n  root.entanglements[spawnedLaneIndex] =\n    root.entanglements[spawnedLaneIndex] |\n    1073741824 |\n    (entangledLanes & 4194218);\n}\nfunction markRootEntangled(root, entangledLanes) {\n  var rootEntangledLanes = (root.entangledLanes |= entangledLanes);\n  for (root = root.entanglements; rootEntangledLanes; ) {\n    var index$8 = 31 - clz32(rootEntangledLanes),\n      lane = 1 << index$8;\n    (lane & entangledLanes) | (root[index$8] & entangledLanes) &&\n      (root[index$8] |= entangledLanes);\n    rootEntangledLanes &= ~lane;\n  }\n}\nfunction lanesToEventPriority(lanes) {\n  lanes &= -lanes;\n  return 2 < lanes\n    ? 8 < lanes\n      ? 0 !== (lanes & 134217727)\n        ? 32\n        : 268435456\n      : 8\n    : 2;\n}\nfunction resolveUpdatePriority() {\n  var updatePriority = ReactDOMSharedInternals.p;\n  if (0 !== updatePriority) return updatePriority;\n  updatePriority = window.event;\n  return void 0 === updatePriority ? 32 : getEventPriority(updatePriority.type);\n}\nfunction runWithPriority(priority, fn) {\n  var previousPriority = ReactDOMSharedInternals.p;\n  try {\n    return (ReactDOMSharedInternals.p = priority), fn();\n  } finally {\n    ReactDOMSharedInternals.p = previousPriority;\n  }\n}\nvar randomKey = Math.random().toString(36).slice(2),\n  internalInstanceKey = \"__reactFiber$\" + randomKey,\n  internalPropsKey = \"__reactProps$\" + randomKey,\n  internalContainerInstanceKey = \"__reactContainer$\" + randomKey,\n  internalEventHandlersKey = \"__reactEvents$\" + randomKey,\n  internalEventHandlerListenersKey = \"__reactListeners$\" + randomKey,\n  internalEventHandlesSetKey = \"__reactHandles$\" + randomKey,\n  internalRootNodeResourcesKey = \"__reactResources$\" + randomKey,\n  internalHoistableMarker = \"__reactMarker$\" + randomKey;\nfunction detachDeletedInstance(node) {\n  delete node[internalInstanceKey];\n  delete node[internalPropsKey];\n  delete node[internalEventHandlersKey];\n  delete node[internalEventHandlerListenersKey];\n  delete node[internalEventHandlesSetKey];\n}\nfunction getClosestInstanceFromNode(targetNode) {\n  var targetInst = targetNode[internalInstanceKey];\n  if (targetInst) return targetInst;\n  for (var parentNode = targetNode.parentNode; parentNode; ) {\n    if (\n      (targetInst =\n        parentNode[internalContainerInstanceKey] ||\n        parentNode[internalInstanceKey])\n    ) {\n      parentNode = targetInst.alternate;\n      if (\n        null !== targetInst.child ||\n        (null !== parentNode && null !== parentNode.child)\n      )\n        for (\n          targetNode = getParentSuspenseInstance(targetNode);\n          null !== targetNode;\n\n        ) {\n          if ((parentNode = targetNode[internalInstanceKey])) return parentNode;\n          targetNode = getParentSuspenseInstance(targetNode);\n        }\n      return targetInst;\n    }\n    targetNode = parentNode;\n    parentNode = targetNode.parentNode;\n  }\n  return null;\n}\nfunction getInstanceFromNode(node) {\n  if (\n    (node = node[internalInstanceKey] || node[internalContainerInstanceKey])\n  ) {\n    var tag = node.tag;\n    if (\n      5 === tag ||\n      6 === tag ||\n      13 === tag ||\n      26 === tag ||\n      27 === tag ||\n      3 === tag\n    )\n      return node;\n  }\n  return null;\n}\nfunction getNodeFromInstance(inst) {\n  var tag = inst.tag;\n  if (5 === tag || 26 === tag || 27 === tag || 6 === tag) return inst.stateNode;\n  throw Error(formatProdErrorMessage(33));\n}\nfunction getResourcesFromRoot(root) {\n  var resources = root[internalRootNodeResourcesKey];\n  resources ||\n    (resources = root[internalRootNodeResourcesKey] =\n      { hoistableStyles: new Map(), hoistableScripts: new Map() });\n  return resources;\n}\nfunction markNodeAsHoistable(node) {\n  node[internalHoistableMarker] = !0;\n}\nvar allNativeEvents = new Set(),\n  registrationNameDependencies = {};\nfunction registerTwoPhaseEvent(registrationName, dependencies) {\n  registerDirectEvent(registrationName, dependencies);\n  registerDirectEvent(registrationName + \"Capture\", dependencies);\n}\nfunction registerDirectEvent(registrationName, dependencies) {\n  registrationNameDependencies[registrationName] = dependencies;\n  for (\n    registrationName = 0;\n    registrationName < dependencies.length;\n    registrationName++\n  )\n    allNativeEvents.add(dependencies[registrationName]);\n}\nvar canUseDOM = !(\n    \"undefined\" === typeof window ||\n    \"undefined\" === typeof window.document ||\n    \"undefined\" === typeof window.document.createElement\n  ),\n  VALID_ATTRIBUTE_NAME_REGEX = RegExp(\n    \"^[: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]*$\"\n  ),\n  illegalAttributeNameCache = {},\n  validatedAttributeNameCache = {};\nfunction isAttributeNameSafe(attributeName) {\n  if (hasOwnProperty.call(validatedAttributeNameCache, attributeName))\n    return !0;\n  if (hasOwnProperty.call(illegalAttributeNameCache, attributeName)) return !1;\n  if (VALID_ATTRIBUTE_NAME_REGEX.test(attributeName))\n    return (validatedAttributeNameCache[attributeName] = !0);\n  illegalAttributeNameCache[attributeName] = !0;\n  return !1;\n}\nfunction setValueForAttribute(node, name, value) {\n  if (isAttributeNameSafe(name))\n    if (null === value) node.removeAttribute(name);\n    else {\n      switch (typeof value) {\n        case \"undefined\":\n        case \"function\":\n        case \"symbol\":\n          node.removeAttribute(name);\n          return;\n        case \"boolean\":\n          var prefix$10 = name.toLowerCase().slice(0, 5);\n          if (\"data-\" !== prefix$10 && \"aria-\" !== prefix$10) {\n            node.removeAttribute(name);\n            return;\n          }\n      }\n      node.setAttribute(name, \"\" + value);\n    }\n}\nfunction setValueForKnownAttribute(node, name, value) {\n  if (null === value) node.removeAttribute(name);\n  else {\n    switch (typeof value) {\n      case \"undefined\":\n      case \"function\":\n      case \"symbol\":\n      case \"boolean\":\n        node.removeAttribute(name);\n        return;\n    }\n    node.setAttribute(name, \"\" + value);\n  }\n}\nfunction setValueForNamespacedAttribute(node, namespace, name, value) {\n  if (null === value) node.removeAttribute(name);\n  else {\n    switch (typeof value) {\n      case \"undefined\":\n      case \"function\":\n      case \"symbol\":\n      case \"boolean\":\n        node.removeAttribute(name);\n        return;\n    }\n    node.setAttributeNS(namespace, name, \"\" + value);\n  }\n}\nfunction getToStringValue(value) {\n  switch (typeof value) {\n    case \"bigint\":\n    case \"boolean\":\n    case \"number\":\n    case \"string\":\n    case \"undefined\":\n      return value;\n    case \"object\":\n      return value;\n    default:\n      return \"\";\n  }\n}\nfunction isCheckable(elem) {\n  var type = elem.type;\n  return (\n    (elem = elem.nodeName) &&\n    \"input\" === elem.toLowerCase() &&\n    (\"checkbox\" === type || \"radio\" === type)\n  );\n}\nfunction trackValueOnNode(node) {\n  var valueField = isCheckable(node) ? \"checked\" : \"value\",\n    descriptor = Object.getOwnPropertyDescriptor(\n      node.constructor.prototype,\n      valueField\n    ),\n    currentValue = \"\" + node[valueField];\n  if (\n    !node.hasOwnProperty(valueField) &&\n    \"undefined\" !== typeof descriptor &&\n    \"function\" === typeof descriptor.get &&\n    \"function\" === typeof descriptor.set\n  ) {\n    var get = descriptor.get,\n      set = descriptor.set;\n    Object.defineProperty(node, valueField, {\n      configurable: !0,\n      get: function () {\n        return get.call(this);\n      },\n      set: function (value) {\n        currentValue = \"\" + value;\n        set.call(this, value);\n      }\n    });\n    Object.defineProperty(node, valueField, {\n      enumerable: descriptor.enumerable\n    });\n    return {\n      getValue: function () {\n        return currentValue;\n      },\n      setValue: function (value) {\n        currentValue = \"\" + value;\n      },\n      stopTracking: function () {\n        node._valueTracker = null;\n        delete node[valueField];\n      }\n    };\n  }\n}\nfunction track(node) {\n  node._valueTracker || (node._valueTracker = trackValueOnNode(node));\n}\nfunction updateValueIfChanged(node) {\n  if (!node) return !1;\n  var tracker = node._valueTracker;\n  if (!tracker) return !0;\n  var lastValue = tracker.getValue();\n  var value = \"\";\n  node &&\n    (value = isCheckable(node)\n      ? node.checked\n        ? \"true\"\n        : \"false\"\n      : node.value);\n  node = value;\n  return node !== lastValue ? (tracker.setValue(node), !0) : !1;\n}\nfunction getActiveElement(doc) {\n  doc = doc || (\"undefined\" !== typeof document ? document : void 0);\n  if (\"undefined\" === typeof doc) return null;\n  try {\n    return doc.activeElement || doc.body;\n  } catch (e) {\n    return doc.body;\n  }\n}\nvar escapeSelectorAttributeValueInsideDoubleQuotesRegex = /[\\n\"\\\\]/g;\nfunction escapeSelectorAttributeValueInsideDoubleQuotes(value) {\n  return value.replace(\n    escapeSelectorAttributeValueInsideDoubleQuotesRegex,\n    function (ch) {\n      return \"\\\\\" + ch.charCodeAt(0).toString(16) + \" \";\n    }\n  );\n}\nfunction updateInput(\n  element,\n  value,\n  defaultValue,\n  lastDefaultValue,\n  checked,\n  defaultChecked,\n  type,\n  name\n) {\n  element.name = \"\";\n  null != type &&\n  \"function\" !== typeof type &&\n  \"symbol\" !== typeof type &&\n  \"boolean\" !== typeof type\n    ? (element.type = type)\n    : element.removeAttribute(\"type\");\n  if (null != value)\n    if (\"number\" === type) {\n      if ((0 === value && \"\" === element.value) || element.value != value)\n        element.value = \"\" + getToStringValue(value);\n    } else\n      element.value !== \"\" + getToStringValue(value) &&\n        (element.value = \"\" + getToStringValue(value));\n  else\n    (\"submit\" !== type && \"reset\" !== type) || element.removeAttribute(\"value\");\n  null != value\n    ? setDefaultValue(element, type, getToStringValue(value))\n    : null != defaultValue\n      ? setDefaultValue(element, type, getToStringValue(defaultValue))\n      : null != lastDefaultValue && element.removeAttribute(\"value\");\n  null == checked &&\n    null != defaultChecked &&\n    (element.defaultChecked = !!defaultChecked);\n  null != checked &&\n    (element.checked =\n      checked && \"function\" !== typeof checked && \"symbol\" !== typeof checked);\n  null != name &&\n  \"function\" !== typeof name &&\n  \"symbol\" !== typeof name &&\n  \"boolean\" !== typeof name\n    ? (element.name = \"\" + getToStringValue(name))\n    : element.removeAttribute(\"name\");\n}\nfunction initInput(\n  element,\n  value,\n  defaultValue,\n  checked,\n  defaultChecked,\n  type,\n  name,\n  isHydrating\n) {\n  null != type &&\n    \"function\" !== typeof type &&\n    \"symbol\" !== typeof type &&\n    \"boolean\" !== typeof type &&\n    (element.type = type);\n  if (null != value || null != defaultValue) {\n    if (\n      !(\n        (\"submit\" !== type && \"reset\" !== type) ||\n        (void 0 !== value && null !== value)\n      )\n    )\n      return;\n    defaultValue =\n      null != defaultValue ? \"\" + getToStringValue(defaultValue) : \"\";\n    value = null != value ? \"\" + getToStringValue(value) : defaultValue;\n    isHydrating || value === element.value || (element.value = value);\n    element.defaultValue = value;\n  }\n  checked = null != checked ? checked : defaultChecked;\n  checked =\n    \"function\" !== typeof checked && \"symbol\" !== typeof checked && !!checked;\n  element.checked = isHydrating ? element.checked : !!checked;\n  element.defaultChecked = !!checked;\n  null != name &&\n    \"function\" !== typeof name &&\n    \"symbol\" !== typeof name &&\n    \"boolean\" !== typeof name &&\n    (element.name = name);\n}\nfunction setDefaultValue(node, type, value) {\n  (\"number\" === type && getActiveElement(node.ownerDocument) === node) ||\n    node.defaultValue === \"\" + value ||\n    (node.defaultValue = \"\" + value);\n}\nfunction updateOptions(node, multiple, propValue, setDefaultSelected) {\n  node = node.options;\n  if (multiple) {\n    multiple = {};\n    for (var i = 0; i < propValue.length; i++)\n      multiple[\"$\" + propValue[i]] = !0;\n    for (propValue = 0; propValue < node.length; propValue++)\n      (i = multiple.hasOwnProperty(\"$\" + node[propValue].value)),\n        node[propValue].selected !== i && (node[propValue].selected = i),\n        i && setDefaultSelected && (node[propValue].defaultSelected = !0);\n  } else {\n    propValue = \"\" + getToStringValue(propValue);\n    multiple = null;\n    for (i = 0; i < node.length; i++) {\n      if (node[i].value === propValue) {\n        node[i].selected = !0;\n        setDefaultSelected && (node[i].defaultSelected = !0);\n        return;\n      }\n      null !== multiple || node[i].disabled || (multiple = node[i]);\n    }\n    null !== multiple && (multiple.selected = !0);\n  }\n}\nfunction updateTextarea(element, value, defaultValue) {\n  if (\n    null != value &&\n    ((value = \"\" + getToStringValue(value)),\n    value !== element.value && (element.value = value),\n    null == defaultValue)\n  ) {\n    element.defaultValue !== value && (element.defaultValue = value);\n    return;\n  }\n  element.defaultValue =\n    null != defaultValue ? \"\" + getToStringValue(defaultValue) : \"\";\n}\nfunction initTextarea(element, value, defaultValue, children) {\n  if (null == value) {\n    if (null != children) {\n      if (null != defaultValue) throw Error(formatProdErrorMessage(92));\n      if (isArrayImpl(children)) {\n        if (1 < children.length) throw Error(formatProdErrorMessage(93));\n        children = children[0];\n      }\n      defaultValue = children;\n    }\n    null == defaultValue && (defaultValue = \"\");\n    value = defaultValue;\n  }\n  defaultValue = getToStringValue(value);\n  element.defaultValue = defaultValue;\n  children = element.textContent;\n  children === defaultValue &&\n    \"\" !== children &&\n    null !== children &&\n    (element.value = children);\n}\nfunction setTextContent(node, text) {\n  if (text) {\n    var firstChild = node.firstChild;\n    if (\n      firstChild &&\n      firstChild === node.lastChild &&\n      3 === firstChild.nodeType\n    ) {\n      firstChild.nodeValue = text;\n      return;\n    }\n  }\n  node.textContent = text;\n}\nvar unitlessNumbers = new Set(\n  \"animationIterationCount aspectRatio borderImageOutset borderImageSlice borderImageWidth boxFlex boxFlexGroup boxOrdinalGroup columnCount columns flex flexGrow flexPositive flexShrink flexNegative flexOrder gridArea gridRow gridRowEnd gridRowSpan gridRowStart gridColumn gridColumnEnd gridColumnSpan gridColumnStart fontWeight lineClamp lineHeight opacity order orphans scale tabSize widows zIndex zoom fillOpacity floodOpacity stopOpacity strokeDasharray strokeDashoffset strokeMiterlimit strokeOpacity strokeWidth MozAnimationIterationCount MozBoxFlex MozBoxFlexGroup MozLineClamp msAnimationIterationCount msFlex msZoom msFlexGrow msFlexNegative msFlexOrder msFlexPositive msFlexShrink msGridColumn msGridColumnSpan msGridRow msGridRowSpan WebkitAnimationIterationCount WebkitBoxFlex WebKitBoxFlexGroup WebkitBoxOrdinalGroup WebkitColumnCount WebkitColumns WebkitFlex WebkitFlexGrow WebkitFlexPositive WebkitFlexShrink WebkitLineClamp\".split(\n    \" \"\n  )\n);\nfunction setValueForStyle(style, styleName, value) {\n  var isCustomProperty = 0 === styleName.indexOf(\"--\");\n  null == value || \"boolean\" === typeof value || \"\" === value\n    ? isCustomProperty\n      ? style.setProperty(styleName, \"\")\n      : \"float\" === styleName\n        ? (style.cssFloat = \"\")\n        : (style[styleName] = \"\")\n    : isCustomProperty\n      ? style.setProperty(styleName, value)\n      : \"number\" !== typeof value ||\n          0 === value ||\n          unitlessNumbers.has(styleName)\n        ? \"float\" === styleName\n          ? (style.cssFloat = value)\n          : (style[styleName] = (\"\" + value).trim())\n        : (style[styleName] = value + \"px\");\n}\nfunction setValueForStyles(node, styles, prevStyles) {\n  if (null != styles && \"object\" !== typeof styles)\n    throw Error(formatProdErrorMessage(62));\n  node = node.style;\n  if (null != prevStyles) {\n    for (var styleName in prevStyles)\n      !prevStyles.hasOwnProperty(styleName) ||\n        (null != styles && styles.hasOwnProperty(styleName)) ||\n        (0 === styleName.indexOf(\"--\")\n          ? node.setProperty(styleName, \"\")\n          : \"float\" === styleName\n            ? (node.cssFloat = \"\")\n            : (node[styleName] = \"\"));\n    for (var styleName$16 in styles)\n      (styleName = styles[styleName$16]),\n        styles.hasOwnProperty(styleName$16) &&\n          prevStyles[styleName$16] !== styleName &&\n          setValueForStyle(node, styleName$16, styleName);\n  } else\n    for (var styleName$17 in styles)\n      styles.hasOwnProperty(styleName$17) &&\n        setValueForStyle(node, styleName$17, styles[styleName$17]);\n}\nfunction isCustomElement(tagName) {\n  if (-1 === tagName.indexOf(\"-\")) return !1;\n  switch (tagName) {\n    case \"annotation-xml\":\n    case \"color-profile\":\n    case \"font-face\":\n    case \"font-face-src\":\n    case \"font-face-uri\":\n    case \"font-face-format\":\n    case \"font-face-name\":\n    case \"missing-glyph\":\n      return !1;\n    default:\n      return !0;\n  }\n}\nvar aliases = new Map([\n    [\"acceptCharset\", \"accept-charset\"],\n    [\"htmlFor\", \"for\"],\n    [\"httpEquiv\", \"http-equiv\"],\n    [\"crossOrigin\", \"crossorigin\"],\n    [\"accentHeight\", \"accent-height\"],\n    [\"alignmentBaseline\", \"alignment-baseline\"],\n    [\"arabicForm\", \"arabic-form\"],\n    [\"baselineShift\", \"baseline-shift\"],\n    [\"capHeight\", \"cap-height\"],\n    [\"clipPath\", \"clip-path\"],\n    [\"clipRule\", \"clip-rule\"],\n    [\"colorInterpolation\", \"color-interpolation\"],\n    [\"colorInterpolationFilters\", \"color-interpolation-filters\"],\n    [\"colorProfile\", \"color-profile\"],\n    [\"colorRendering\", \"color-rendering\"],\n    [\"dominantBaseline\", \"dominant-baseline\"],\n    [\"enableBackground\", \"enable-background\"],\n    [\"fillOpacity\", \"fill-opacity\"],\n    [\"fillRule\", \"fill-rule\"],\n    [\"floodColor\", \"flood-color\"],\n    [\"floodOpacity\", \"flood-opacity\"],\n    [\"fontFamily\", \"font-family\"],\n    [\"fontSize\", \"font-size\"],\n    [\"fontSizeAdjust\", \"font-size-adjust\"],\n    [\"fontStretch\", \"font-stretch\"],\n    [\"fontStyle\", \"font-style\"],\n    [\"fontVariant\", \"font-variant\"],\n    [\"fontWeight\", \"font-weight\"],\n    [\"glyphName\", \"glyph-name\"],\n    [\"glyphOrientationHorizontal\", \"glyph-orientation-horizontal\"],\n    [\"glyphOrientationVertical\", \"glyph-orientation-vertical\"],\n    [\"horizAdvX\", \"horiz-adv-x\"],\n    [\"horizOriginX\", \"horiz-origin-x\"],\n    [\"imageRendering\", \"image-rendering\"],\n    [\"letterSpacing\", \"letter-spacing\"],\n    [\"lightingColor\", \"lighting-color\"],\n    [\"markerEnd\", \"marker-end\"],\n    [\"markerMid\", \"marker-mid\"],\n    [\"markerStart\", \"marker-start\"],\n    [\"overlinePosition\", \"overline-position\"],\n    [\"overlineThickness\", \"overline-thickness\"],\n    [\"paintOrder\", \"paint-order\"],\n    [\"panose-1\", \"panose-1\"],\n    [\"pointerEvents\", \"pointer-events\"],\n    [\"renderingIntent\", \"rendering-intent\"],\n    [\"shapeRendering\", \"shape-rendering\"],\n    [\"stopColor\", \"stop-color\"],\n    [\"stopOpacity\", \"stop-opacity\"],\n    [\"strikethroughPosition\", \"strikethrough-position\"],\n    [\"strikethroughThickness\", \"strikethrough-thickness\"],\n    [\"strokeDasharray\", \"stroke-dasharray\"],\n    [\"strokeDashoffset\", \"stroke-dashoffset\"],\n    [\"strokeLinecap\", \"stroke-linecap\"],\n    [\"strokeLinejoin\", \"stroke-linejoin\"],\n    [\"strokeMiterlimit\", \"stroke-miterlimit\"],\n    [\"strokeOpacity\", \"stroke-opacity\"],\n    [\"strokeWidth\", \"stroke-width\"],\n    [\"textAnchor\", \"text-anchor\"],\n    [\"textDecoration\", \"text-decoration\"],\n    [\"textRendering\", \"text-rendering\"],\n    [\"transformOrigin\", \"transform-origin\"],\n    [\"underlinePosition\", \"underline-position\"],\n    [\"underlineThickness\", \"underline-thickness\"],\n    [\"unicodeBidi\", \"unicode-bidi\"],\n    [\"unicodeRange\", \"unicode-range\"],\n    [\"unitsPerEm\", \"units-per-em\"],\n    [\"vAlphabetic\", \"v-alphabetic\"],\n    [\"vHanging\", \"v-hanging\"],\n    [\"vIdeographic\", \"v-ideographic\"],\n    [\"vMathematical\", \"v-mathematical\"],\n    [\"vectorEffect\", \"vector-effect\"],\n    [\"vertAdvY\", \"vert-adv-y\"],\n    [\"vertOriginX\", \"vert-origin-x\"],\n    [\"vertOriginY\", \"vert-origin-y\"],\n    [\"wordSpacing\", \"word-spacing\"],\n    [\"writingMode\", \"writing-mode\"],\n    [\"xmlnsXlink\", \"xmlns:xlink\"],\n    [\"xHeight\", \"x-height\"]\n  ]),\n  isJavaScriptProtocol =\n    /^[\\u0000-\\u001F ]*j[\\r\\n\\t]*a[\\r\\n\\t]*v[\\r\\n\\t]*a[\\r\\n\\t]*s[\\r\\n\\t]*c[\\r\\n\\t]*r[\\r\\n\\t]*i[\\r\\n\\t]*p[\\r\\n\\t]*t[\\r\\n\\t]*:/i;\nfunction sanitizeURL(url) {\n  return isJavaScriptProtocol.test(\"\" + url)\n    ? \"javascript:throw new Error('React has blocked a javascript: URL as a security precaution.')\"\n    : url;\n}\nvar currentReplayingEvent = null;\nfunction getEventTarget(nativeEvent) {\n  nativeEvent = nativeEvent.target || nativeEvent.srcElement || window;\n  nativeEvent.correspondingUseElement &&\n    (nativeEvent = nativeEvent.correspondingUseElement);\n  return 3 === nativeEvent.nodeType ? nativeEvent.parentNode : nativeEvent;\n}\nvar restoreTarget = null,\n  restoreQueue = null;\nfunction restoreStateOfTarget(target) {\n  var internalInstance = getInstanceFromNode(target);\n  if (internalInstance && (target = internalInstance.stateNode)) {\n    var props = target[internalPropsKey] || null;\n    a: switch (((target = internalInstance.stateNode), internalInstance.type)) {\n      case \"input\":\n        updateInput(\n          target,\n          props.value,\n          props.defaultValue,\n          props.defaultValue,\n          props.checked,\n          props.defaultChecked,\n          props.type,\n          props.name\n        );\n        internalInstance = props.name;\n        if (\"radio\" === props.type && null != internalInstance) {\n          for (props = target; props.parentNode; ) props = props.parentNode;\n          props = props.querySelectorAll(\n            'input[name=\"' +\n              escapeSelectorAttributeValueInsideDoubleQuotes(\n                \"\" + internalInstance\n              ) +\n              '\"][type=\"radio\"]'\n          );\n          for (\n            internalInstance = 0;\n            internalInstance < props.length;\n            internalInstance++\n          ) {\n            var otherNode = props[internalInstance];\n            if (otherNode !== target && otherNode.form === target.form) {\n              var otherProps = otherNode[internalPropsKey] || null;\n              if (!otherProps) throw Error(formatProdErrorMessage(90));\n              updateInput(\n                otherNode,\n                otherProps.value,\n                otherProps.defaultValue,\n                otherProps.defaultValue,\n                otherProps.checked,\n                otherProps.defaultChecked,\n                otherProps.type,\n                otherProps.name\n              );\n            }\n          }\n          for (\n            internalInstance = 0;\n            internalInstance < props.length;\n            internalInstance++\n          )\n            (otherNode = props[internalInstance]),\n              otherNode.form === target.form && updateValueIfChanged(otherNode);\n        }\n        break a;\n      case \"textarea\":\n        updateTextarea(target, props.value, props.defaultValue);\n        break a;\n      case \"select\":\n        (internalInstance = props.value),\n          null != internalInstance &&\n            updateOptions(target, !!props.multiple, internalInstance, !1);\n    }\n  }\n}\nvar isInsideEventHandler = !1;\nfunction batchedUpdates$1(fn, a, b) {\n  if (isInsideEventHandler) return fn(a, b);\n  isInsideEventHandler = !0;\n  try {\n    var JSCompiler_inline_result = fn(a);\n    return JSCompiler_inline_result;\n  } finally {\n    if (\n      ((isInsideEventHandler = !1),\n      null !== restoreTarget || null !== restoreQueue)\n    )\n      if (\n        (flushSyncWork$1(),\n        restoreTarget &&\n          ((a = restoreTarget),\n          (fn = restoreQueue),\n          (restoreQueue = restoreTarget = null),\n          restoreStateOfTarget(a),\n          fn))\n      )\n        for (a = 0; a < fn.length; a++) restoreStateOfTarget(fn[a]);\n  }\n}\nfunction getListener(inst, registrationName) {\n  var stateNode = inst.stateNode;\n  if (null === stateNode) return null;\n  var props = stateNode[internalPropsKey] || null;\n  if (null === props) return null;\n  stateNode = props[registrationName];\n  a: switch (registrationName) {\n    case \"onClick\":\n    case \"onClickCapture\":\n    case \"onDoubleClick\":\n    case \"onDoubleClickCapture\":\n    case \"onMouseDown\":\n    case \"onMouseDownCapture\":\n    case \"onMouseMove\":\n    case \"onMouseMoveCapture\":\n    case \"onMouseUp\":\n    case \"onMouseUpCapture\":\n    case \"onMouseEnter\":\n      (props = !props.disabled) ||\n        ((inst = inst.type),\n        (props = !(\n          \"button\" === inst ||\n          \"input\" === inst ||\n          \"select\" === inst ||\n          \"textarea\" === inst\n        )));\n      inst = !props;\n      break a;\n    default:\n      inst = !1;\n  }\n  if (inst) return null;\n  if (stateNode && \"function\" !== typeof stateNode)\n    throw Error(\n      formatProdErrorMessage(231, registrationName, typeof stateNode)\n    );\n  return stateNode;\n}\nvar passiveBrowserEventsSupported = !1;\nif (canUseDOM)\n  try {\n    var options = {};\n    Object.defineProperty(options, \"passive\", {\n      get: function () {\n        passiveBrowserEventsSupported = !0;\n      }\n    });\n    window.addEventListener(\"test\", options, options);\n    window.removeEventListener(\"test\", options, options);\n  } catch (e) {\n    passiveBrowserEventsSupported = !1;\n  }\nvar root = null,\n  startText = null,\n  fallbackText = null;\nfunction getData() {\n  if (fallbackText) return fallbackText;\n  var start,\n    startValue = startText,\n    startLength = startValue.length,\n    end,\n    endValue = \"value\" in root ? root.value : root.textContent,\n    endLength = endValue.length;\n  for (\n    start = 0;\n    start < startLength && startValue[start] === endValue[start];\n    start++\n  );\n  var minEnd = startLength - start;\n  for (\n    end = 1;\n    end <= minEnd &&\n    startValue[startLength - end] === endValue[endLength - end];\n    end++\n  );\n  return (fallbackText = endValue.slice(start, 1 < end ? 1 - end : void 0));\n}\nfunction getEventCharCode(nativeEvent) {\n  var keyCode = nativeEvent.keyCode;\n  \"charCode\" in nativeEvent\n    ? ((nativeEvent = nativeEvent.charCode),\n      0 === nativeEvent && 13 === keyCode && (nativeEvent = 13))\n    : (nativeEvent = keyCode);\n  10 === nativeEvent && (nativeEvent = 13);\n  return 32 <= nativeEvent || 13 === nativeEvent ? nativeEvent : 0;\n}\nfunction functionThatReturnsTrue() {\n  return !0;\n}\nfunction functionThatReturnsFalse() {\n  return !1;\n}\nfunction createSyntheticEvent(Interface) {\n  function SyntheticBaseEvent(\n    reactName,\n    reactEventType,\n    targetInst,\n    nativeEvent,\n    nativeEventTarget\n  ) {\n    this._reactName = reactName;\n    this._targetInst = targetInst;\n    this.type = reactEventType;\n    this.nativeEvent = nativeEvent;\n    this.target = nativeEventTarget;\n    this.currentTarget = null;\n    for (var propName in Interface)\n      Interface.hasOwnProperty(propName) &&\n        ((reactName = Interface[propName]),\n        (this[propName] = reactName\n          ? reactName(nativeEvent)\n          : nativeEvent[propName]));\n    this.isDefaultPrevented = (\n      null != nativeEvent.defaultPrevented\n        ? nativeEvent.defaultPrevented\n        : !1 === nativeEvent.returnValue\n    )\n      ? functionThatReturnsTrue\n      : functionThatReturnsFalse;\n    this.isPropagationStopped = functionThatReturnsFalse;\n    return this;\n  }\n  assign(SyntheticBaseEvent.prototype, {\n    preventDefault: function () {\n      this.defaultPrevented = !0;\n      var event = this.nativeEvent;\n      event &&\n        (event.preventDefault\n          ? event.preventDefault()\n          : \"unknown\" !== typeof event.returnValue && (event.returnValue = !1),\n        (this.isDefaultPrevented = functionThatReturnsTrue));\n    },\n    stopPropagation: function () {\n      var event = this.nativeEvent;\n      event &&\n        (event.stopPropagation\n          ? event.stopPropagation()\n          : \"unknown\" !== typeof event.cancelBubble &&\n            (event.cancelBubble = !0),\n        (this.isPropagationStopped = functionThatReturnsTrue));\n    },\n    persist: function () {},\n    isPersistent: functionThatReturnsTrue\n  });\n  return SyntheticBaseEvent;\n}\nvar EventInterface = {\n    eventPhase: 0,\n    bubbles: 0,\n    cancelable: 0,\n    timeStamp: function (event) {\n      return event.timeStamp || Date.now();\n    },\n    defaultPrevented: 0,\n    isTrusted: 0\n  },\n  SyntheticEvent = createSyntheticEvent(EventInterface),\n  UIEventInterface = assign({}, EventInterface, { view: 0, detail: 0 }),\n  SyntheticUIEvent = createSyntheticEvent(UIEventInterface),\n  lastMovementX,\n  lastMovementY,\n  lastMouseEvent,\n  MouseEventInterface = assign({}, UIEventInterface, {\n    screenX: 0,\n    screenY: 0,\n    clientX: 0,\n    clientY: 0,\n    pageX: 0,\n    pageY: 0,\n    ctrlKey: 0,\n    shiftKey: 0,\n    altKey: 0,\n    metaKey: 0,\n    getModifierState: getEventModifierState,\n    button: 0,\n    buttons: 0,\n    relatedTarget: function (event) {\n      return void 0 === event.relatedTarget\n        ? event.fromElement === event.srcElement\n          ? event.toElement\n          : event.fromElement\n        : event.relatedTarget;\n    },\n    movementX: function (event) {\n      if (\"movementX\" in event) return event.movementX;\n      event !== lastMouseEvent &&\n        (lastMouseEvent && \"mousemove\" === event.type\n          ? ((lastMovementX = event.screenX - lastMouseEvent.screenX),\n            (lastMovementY = event.screenY - lastMouseEvent.screenY))\n          : (lastMovementY = lastMovementX = 0),\n        (lastMouseEvent = event));\n      return lastMovementX;\n    },\n    movementY: function (event) {\n      return \"movementY\" in event ? event.movementY : lastMovementY;\n    }\n  }),\n  SyntheticMouseEvent = createSyntheticEvent(MouseEventInterface),\n  DragEventInterface = assign({}, MouseEventInterface, { dataTransfer: 0 }),\n  SyntheticDragEvent = createSyntheticEvent(DragEventInterface),\n  FocusEventInterface = assign({}, UIEventInterface, { relatedTarget: 0 }),\n  SyntheticFocusEvent = createSyntheticEvent(FocusEventInterface),\n  AnimationEventInterface = assign({}, EventInterface, {\n    animationName: 0,\n    elapsedTime: 0,\n    pseudoElement: 0\n  }),\n  SyntheticAnimationEvent = createSyntheticEvent(AnimationEventInterface),\n  ClipboardEventInterface = assign({}, EventInterface, {\n    clipboardData: function (event) {\n      return \"clipboardData\" in event\n        ? event.clipboardData\n        : window.clipboardData;\n    }\n  }),\n  SyntheticClipboardEvent = createSyntheticEvent(ClipboardEventInterface),\n  CompositionEventInterface = assign({}, EventInterface, { data: 0 }),\n  SyntheticCompositionEvent = createSyntheticEvent(CompositionEventInterface),\n  normalizeKey = {\n    Esc: \"Escape\",\n    Spacebar: \" \",\n    Left: \"ArrowLeft\",\n    Up: \"ArrowUp\",\n    Right: \"ArrowRight\",\n    Down: \"ArrowDown\",\n    Del: \"Delete\",\n    Win: \"OS\",\n    Menu: \"ContextMenu\",\n    Apps: \"ContextMenu\",\n    Scroll: \"ScrollLock\",\n    MozPrintableKey: \"Unidentified\"\n  },\n  translateToKey = {\n    8: \"Backspace\",\n    9: \"Tab\",\n    12: \"Clear\",\n    13: \"Enter\",\n    16: \"Shift\",\n    17: \"Control\",\n    18: \"Alt\",\n    19: \"Pause\",\n    20: \"CapsLock\",\n    27: \"Escape\",\n    32: \" \",\n    33: \"PageUp\",\n    34: \"PageDown\",\n    35: \"End\",\n    36: \"Home\",\n    37: \"ArrowLeft\",\n    38: \"ArrowUp\",\n    39: \"ArrowRight\",\n    40: \"ArrowDown\",\n    45: \"Insert\",\n    46: \"Delete\",\n    112: \"F1\",\n    113: \"F2\",\n    114: \"F3\",\n    115: \"F4\",\n    116: \"F5\",\n    117: \"F6\",\n    118: \"F7\",\n    119: \"F8\",\n    120: \"F9\",\n    121: \"F10\",\n    122: \"F11\",\n    123: \"F12\",\n    144: \"NumLock\",\n    145: \"ScrollLock\",\n    224: \"Meta\"\n  },\n  modifierKeyToProp = {\n    Alt: \"altKey\",\n    Control: \"ctrlKey\",\n    Meta: \"metaKey\",\n    Shift: \"shiftKey\"\n  };\nfunction modifierStateGetter(keyArg) {\n  var nativeEvent = this.nativeEvent;\n  return nativeEvent.getModifierState\n    ? nativeEvent.getModifierState(keyArg)\n    : (keyArg = modifierKeyToProp[keyArg])\n      ? !!nativeEvent[keyArg]\n      : !1;\n}\nfunction getEventModifierState() {\n  return modifierStateGetter;\n}\nvar KeyboardEventInterface = assign({}, UIEventInterface, {\n    key: function (nativeEvent) {\n      if (nativeEvent.key) {\n        var key = normalizeKey[nativeEvent.key] || nativeEvent.key;\n        if (\"Unidentified\" !== key) return key;\n      }\n      return \"keypress\" === nativeEvent.type\n        ? ((nativeEvent = getEventCharCode(nativeEvent)),\n          13 === nativeEvent ? \"Enter\" : String.fromCharCode(nativeEvent))\n        : \"keydown\" === nativeEvent.type || \"keyup\" === nativeEvent.type\n          ? translateToKey[nativeEvent.keyCode] || \"Unidentified\"\n          : \"\";\n    },\n    code: 0,\n    location: 0,\n    ctrlKey: 0,\n    shiftKey: 0,\n    altKey: 0,\n    metaKey: 0,\n    repeat: 0,\n    locale: 0,\n    getModifierState: getEventModifierState,\n    charCode: function (event) {\n      return \"keypress\" === event.type ? getEventCharCode(event) : 0;\n    },\n    keyCode: function (event) {\n      return \"keydown\" === event.type || \"keyup\" === event.type\n        ? event.keyCode\n        : 0;\n    },\n    which: function (event) {\n      return \"keypress\" === event.type\n        ? getEventCharCode(event)\n        : \"keydown\" === event.type || \"keyup\" === event.type\n          ? event.keyCode\n          : 0;\n    }\n  }),\n  SyntheticKeyboardEvent = createSyntheticEvent(KeyboardEventInterface),\n  PointerEventInterface = assign({}, MouseEventInterface, {\n    pointerId: 0,\n    width: 0,\n    height: 0,\n    pressure: 0,\n    tangentialPressure: 0,\n    tiltX: 0,\n    tiltY: 0,\n    twist: 0,\n    pointerType: 0,\n    isPrimary: 0\n  }),\n  SyntheticPointerEvent = createSyntheticEvent(PointerEventInterface),\n  TouchEventInterface = assign({}, UIEventInterface, {\n    touches: 0,\n    targetTouches: 0,\n    changedTouches: 0,\n    altKey: 0,\n    metaKey: 0,\n    ctrlKey: 0,\n    shiftKey: 0,\n    getModifierState: getEventModifierState\n  }),\n  SyntheticTouchEvent = createSyntheticEvent(TouchEventInterface),\n  TransitionEventInterface = assign({}, EventInterface, {\n    propertyName: 0,\n    elapsedTime: 0,\n    pseudoElement: 0\n  }),\n  SyntheticTransitionEvent = createSyntheticEvent(TransitionEventInterface),\n  WheelEventInterface = assign({}, MouseEventInterface, {\n    deltaX: function (event) {\n      return \"deltaX\" in event\n        ? event.deltaX\n        : \"wheelDeltaX\" in event\n          ? -event.wheelDeltaX\n          : 0;\n    },\n    deltaY: function (event) {\n      return \"deltaY\" in event\n        ? event.deltaY\n        : \"wheelDeltaY\" in event\n          ? -event.wheelDeltaY\n          : \"wheelDelta\" in event\n            ? -event.wheelDelta\n            : 0;\n    },\n    deltaZ: 0,\n    deltaMode: 0\n  }),\n  SyntheticWheelEvent = createSyntheticEvent(WheelEventInterface),\n  ToggleEventInterface = assign({}, EventInterface, {\n    newState: 0,\n    oldState: 0\n  }),\n  SyntheticToggleEvent = createSyntheticEvent(ToggleEventInterface),\n  END_KEYCODES = [9, 13, 27, 32],\n  canUseCompositionEvent = canUseDOM && \"CompositionEvent\" in window,\n  documentMode = null;\ncanUseDOM &&\n  \"documentMode\" in document &&\n  (documentMode = document.documentMode);\nvar canUseTextInputEvent = canUseDOM && \"TextEvent\" in window && !documentMode,\n  useFallbackCompositionData =\n    canUseDOM &&\n    (!canUseCompositionEvent ||\n      (documentMode && 8 < documentMode && 11 >= documentMode)),\n  SPACEBAR_CHAR = String.fromCharCode(32),\n  hasSpaceKeypress = !1;\nfunction isFallbackCompositionEnd(domEventName, nativeEvent) {\n  switch (domEventName) {\n    case \"keyup\":\n      return -1 !== END_KEYCODES.indexOf(nativeEvent.keyCode);\n    case \"keydown\":\n      return 229 !== nativeEvent.keyCode;\n    case \"keypress\":\n    case \"mousedown\":\n    case \"focusout\":\n      return !0;\n    default:\n      return !1;\n  }\n}\nfunction getDataFromCustomEvent(nativeEvent) {\n  nativeEvent = nativeEvent.detail;\n  return \"object\" === typeof nativeEvent && \"data\" in nativeEvent\n    ? nativeEvent.data\n    : null;\n}\nvar isComposing = !1;\nfunction getNativeBeforeInputChars(domEventName, nativeEvent) {\n  switch (domEventName) {\n    case \"compositionend\":\n      return getDataFromCustomEvent(nativeEvent);\n    case \"keypress\":\n      if (32 !== nativeEvent.which) return null;\n      hasSpaceKeypress = !0;\n      return SPACEBAR_CHAR;\n    case \"textInput\":\n      return (\n        (domEventName = nativeEvent.data),\n        domEventName === SPACEBAR_CHAR && hasSpaceKeypress ? null : domEventName\n      );\n    default:\n      return null;\n  }\n}\nfunction getFallbackBeforeInputChars(domEventName, nativeEvent) {\n  if (isComposing)\n    return \"compositionend\" === domEventName ||\n      (!canUseCompositionEvent &&\n        isFallbackCompositionEnd(domEventName, nativeEvent))\n      ? ((domEventName = getData()),\n        (fallbackText = startText = root = null),\n        (isComposing = !1),\n        domEventName)\n      : null;\n  switch (domEventName) {\n    case \"paste\":\n      return null;\n    case \"keypress\":\n      if (\n        !(nativeEvent.ctrlKey || nativeEvent.altKey || nativeEvent.metaKey) ||\n        (nativeEvent.ctrlKey && nativeEvent.altKey)\n      ) {\n        if (nativeEvent.char && 1 < nativeEvent.char.length)\n          return nativeEvent.char;\n        if (nativeEvent.which) return String.fromCharCode(nativeEvent.which);\n      }\n      return null;\n    case \"compositionend\":\n      return useFallbackCompositionData && \"ko\" !== nativeEvent.locale\n        ? null\n        : nativeEvent.data;\n    default:\n      return null;\n  }\n}\nvar supportedInputTypes = {\n  color: !0,\n  date: !0,\n  datetime: !0,\n  \"datetime-local\": !0,\n  email: !0,\n  month: !0,\n  number: !0,\n  password: !0,\n  range: !0,\n  search: !0,\n  tel: !0,\n  text: !0,\n  time: !0,\n  url: !0,\n  week: !0\n};\nfunction isTextInputElement(elem) {\n  var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase();\n  return \"input\" === nodeName\n    ? !!supportedInputTypes[elem.type]\n    : \"textarea\" === nodeName\n      ? !0\n      : !1;\n}\nfunction createAndAccumulateChangeEvent(\n  dispatchQueue,\n  inst,\n  nativeEvent,\n  target\n) {\n  restoreTarget\n    ? restoreQueue\n      ? restoreQueue.push(target)\n      : (restoreQueue = [target])\n    : (restoreTarget = target);\n  inst = accumulateTwoPhaseListeners(inst, \"onChange\");\n  0 < inst.length &&\n    ((nativeEvent = new SyntheticEvent(\n      \"onChange\",\n      \"change\",\n      null,\n      nativeEvent,\n      target\n    )),\n    dispatchQueue.push({ event: nativeEvent, listeners: inst }));\n}\nvar activeElement$1 = null,\n  activeElementInst$1 = null;\nfunction runEventInBatch(dispatchQueue) {\n  processDispatchQueue(dispatchQueue, 0);\n}\nfunction getInstIfValueChanged(targetInst) {\n  var targetNode = getNodeFromInstance(targetInst);\n  if (updateValueIfChanged(targetNode)) return targetInst;\n}\nfunction getTargetInstForChangeEvent(domEventName, targetInst) {\n  if (\"change\" === domEventName) return targetInst;\n}\nvar isInputEventSupported = !1;\nif (canUseDOM) {\n  var JSCompiler_inline_result$jscomp$283;\n  if (canUseDOM) {\n    var isSupported$jscomp$inline_418 = \"oninput\" in document;\n    if (!isSupported$jscomp$inline_418) {\n      var element$jscomp$inline_419 = document.createElement(\"div\");\n      element$jscomp$inline_419.setAttribute(\"oninput\", \"return;\");\n      isSupported$jscomp$inline_418 =\n        \"function\" === typeof element$jscomp$inline_419.oninput;\n    }\n    JSCompiler_inline_result$jscomp$283 = isSupported$jscomp$inline_418;\n  } else JSCompiler_inline_result$jscomp$283 = !1;\n  isInputEventSupported =\n    JSCompiler_inline_result$jscomp$283 &&\n    (!document.documentMode || 9 < document.documentMode);\n}\nfunction stopWatchingForValueChange() {\n  activeElement$1 &&\n    (activeElement$1.detachEvent(\"onpropertychange\", handlePropertyChange),\n    (activeElementInst$1 = activeElement$1 = null));\n}\nfunction handlePropertyChange(nativeEvent) {\n  if (\n    \"value\" === nativeEvent.propertyName &&\n    getInstIfValueChanged(activeElementInst$1)\n  ) {\n    var dispatchQueue = [];\n    createAndAccumulateChangeEvent(\n      dispatchQueue,\n      activeElementInst$1,\n      nativeEvent,\n      getEventTarget(nativeEvent)\n    );\n    batchedUpdates$1(runEventInBatch, dispatchQueue);\n  }\n}\nfunction handleEventsForInputEventPolyfill(domEventName, target, targetInst) {\n  \"focusin\" === domEventName\n    ? (stopWatchingForValueChange(),\n      (activeElement$1 = target),\n      (activeElementInst$1 = targetInst),\n      activeElement$1.attachEvent(\"onpropertychange\", handlePropertyChange))\n    : \"focusout\" === domEventName && stopWatchingForValueChange();\n}\nfunction getTargetInstForInputEventPolyfill(domEventName) {\n  if (\n    \"selectionchange\" === domEventName ||\n    \"keyup\" === domEventName ||\n    \"keydown\" === domEventName\n  )\n    return getInstIfValueChanged(activeElementInst$1);\n}\nfunction getTargetInstForClickEvent(domEventName, targetInst) {\n  if (\"click\" === domEventName) return getInstIfValueChanged(targetInst);\n}\nfunction getTargetInstForInputOrChangeEvent(domEventName, targetInst) {\n  if (\"input\" === domEventName || \"change\" === domEventName)\n    return getInstIfValueChanged(targetInst);\n}\nfunction is(x, y) {\n  return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is;\nfunction shallowEqual(objA, objB) {\n  if (objectIs(objA, objB)) return !0;\n  if (\n    \"object\" !== typeof objA ||\n    null === objA ||\n    \"object\" !== typeof objB ||\n    null === objB\n  )\n    return !1;\n  var keysA = Object.keys(objA),\n    keysB = Object.keys(objB);\n  if (keysA.length !== keysB.length) return !1;\n  for (keysB = 0; keysB < keysA.length; keysB++) {\n    var currentKey = keysA[keysB];\n    if (\n      !hasOwnProperty.call(objB, currentKey) ||\n      !objectIs(objA[currentKey], objB[currentKey])\n    )\n      return !1;\n  }\n  return !0;\n}\nfunction getLeafNode(node) {\n  for (; node && node.firstChild; ) node = node.firstChild;\n  return node;\n}\nfunction getNodeForCharacterOffset(root, offset) {\n  var node = getLeafNode(root);\n  root = 0;\n  for (var nodeEnd; node; ) {\n    if (3 === node.nodeType) {\n      nodeEnd = root + node.textContent.length;\n      if (root <= offset && nodeEnd >= offset)\n        return { node: node, offset: offset - root };\n      root = nodeEnd;\n    }\n    a: {\n      for (; node; ) {\n        if (node.nextSibling) {\n          node = node.nextSibling;\n          break a;\n        }\n        node = node.parentNode;\n      }\n      node = void 0;\n    }\n    node = getLeafNode(node);\n  }\n}\nfunction containsNode(outerNode, innerNode) {\n  return outerNode && innerNode\n    ? outerNode === innerNode\n      ? !0\n      : outerNode && 3 === outerNode.nodeType\n        ? !1\n        : innerNode && 3 === innerNode.nodeType\n          ? containsNode(outerNode, innerNode.parentNode)\n          : \"contains\" in outerNode\n            ? outerNode.contains(innerNode)\n            : outerNode.compareDocumentPosition\n              ? !!(outerNode.compareDocumentPosition(innerNode) & 16)\n              : !1\n    : !1;\n}\nfunction getActiveElementDeep(containerInfo) {\n  containerInfo =\n    null != containerInfo &&\n    null != containerInfo.ownerDocument &&\n    null != containerInfo.ownerDocument.defaultView\n      ? containerInfo.ownerDocument.defaultView\n      : window;\n  for (\n    var element = getActiveElement(containerInfo.document);\n    element instanceof containerInfo.HTMLIFrameElement;\n\n  ) {\n    try {\n      var JSCompiler_inline_result =\n        \"string\" === typeof element.contentWindow.location.href;\n    } catch (err) {\n      JSCompiler_inline_result = !1;\n    }\n    if (JSCompiler_inline_result) containerInfo = element.contentWindow;\n    else break;\n    element = getActiveElement(containerInfo.document);\n  }\n  return element;\n}\nfunction hasSelectionCapabilities(elem) {\n  var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase();\n  return (\n    nodeName &&\n    ((\"input\" === nodeName &&\n      (\"text\" === elem.type ||\n        \"search\" === elem.type ||\n        \"tel\" === elem.type ||\n        \"url\" === elem.type ||\n        \"password\" === elem.type)) ||\n      \"textarea\" === nodeName ||\n      \"true\" === elem.contentEditable)\n  );\n}\nfunction restoreSelection(priorSelectionInformation, containerInfo) {\n  var curFocusedElem = getActiveElementDeep(containerInfo);\n  containerInfo = priorSelectionInformation.focusedElem;\n  var priorSelectionRange = priorSelectionInformation.selectionRange;\n  if (\n    curFocusedElem !== containerInfo &&\n    containerInfo &&\n    containerInfo.ownerDocument &&\n    containsNode(containerInfo.ownerDocument.documentElement, containerInfo)\n  ) {\n    if (null !== priorSelectionRange && hasSelectionCapabilities(containerInfo))\n      if (\n        ((priorSelectionInformation = priorSelectionRange.start),\n        (curFocusedElem = priorSelectionRange.end),\n        void 0 === curFocusedElem &&\n          (curFocusedElem = priorSelectionInformation),\n        \"selectionStart\" in containerInfo)\n      )\n        (containerInfo.selectionStart = priorSelectionInformation),\n          (containerInfo.selectionEnd = Math.min(\n            curFocusedElem,\n            containerInfo.value.length\n          ));\n      else if (\n        ((curFocusedElem =\n          ((priorSelectionInformation =\n            containerInfo.ownerDocument || document) &&\n            priorSelectionInformation.defaultView) ||\n          window),\n        curFocusedElem.getSelection)\n      ) {\n        curFocusedElem = curFocusedElem.getSelection();\n        var length = containerInfo.textContent.length,\n          start = Math.min(priorSelectionRange.start, length);\n        priorSelectionRange =\n          void 0 === priorSelectionRange.end\n            ? start\n            : Math.min(priorSelectionRange.end, length);\n        !curFocusedElem.extend &&\n          start > priorSelectionRange &&\n          ((length = priorSelectionRange),\n          (priorSelectionRange = start),\n          (start = length));\n        length = getNodeForCharacterOffset(containerInfo, start);\n        var endMarker = getNodeForCharacterOffset(\n          containerInfo,\n          priorSelectionRange\n        );\n        length &&\n          endMarker &&\n          (1 !== curFocusedElem.rangeCount ||\n            curFocusedElem.anchorNode !== length.node ||\n            curFocusedElem.anchorOffset !== length.offset ||\n            curFocusedElem.focusNode !== endMarker.node ||\n            curFocusedElem.focusOffset !== endMarker.offset) &&\n          ((priorSelectionInformation =\n            priorSelectionInformation.createRange()),\n          priorSelectionInformation.setStart(length.node, length.offset),\n          curFocusedElem.removeAllRanges(),\n          start > priorSelectionRange\n            ? (curFocusedElem.addRange(priorSelectionInformation),\n              curFocusedElem.extend(endMarker.node, endMarker.offset))\n            : (priorSelectionInformation.setEnd(\n                endMarker.node,\n                endMarker.offset\n              ),\n              curFocusedElem.addRange(priorSelectionInformation)));\n      }\n    priorSelectionInformation = [];\n    for (\n      curFocusedElem = containerInfo;\n      (curFocusedElem = curFocusedElem.parentNode);\n\n    )\n      1 === curFocusedElem.nodeType &&\n        priorSelectionInformation.push({\n          element: curFocusedElem,\n          left: curFocusedElem.scrollLeft,\n          top: curFocusedElem.scrollTop\n        });\n    \"function\" === typeof containerInfo.focus && containerInfo.focus();\n    for (\n      containerInfo = 0;\n      containerInfo < priorSelectionInformation.length;\n      containerInfo++\n    )\n      (curFocusedElem = priorSelectionInformation[containerInfo]),\n        (curFocusedElem.element.scrollLeft = curFocusedElem.left),\n        (curFocusedElem.element.scrollTop = curFocusedElem.top);\n  }\n}\nvar skipSelectionChangeEvent =\n    canUseDOM && \"documentMode\" in document && 11 >= document.documentMode,\n  activeElement = null,\n  activeElementInst = null,\n  lastSelection = null,\n  mouseDown = !1;\nfunction constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget) {\n  var doc =\n    nativeEventTarget.window === nativeEventTarget\n      ? nativeEventTarget.document\n      : 9 === nativeEventTarget.nodeType\n        ? nativeEventTarget\n        : nativeEventTarget.ownerDocument;\n  mouseDown ||\n    null == activeElement ||\n    activeElement !== getActiveElement(doc) ||\n    ((doc = activeElement),\n    \"selectionStart\" in doc && hasSelectionCapabilities(doc)\n      ? (doc = { start: doc.selectionStart, end: doc.selectionEnd })\n      : ((doc = (\n          (doc.ownerDocument && doc.ownerDocument.defaultView) ||\n          window\n        ).getSelection()),\n        (doc = {\n          anchorNode: doc.anchorNode,\n          anchorOffset: doc.anchorOffset,\n          focusNode: doc.focusNode,\n          focusOffset: doc.focusOffset\n        })),\n    (lastSelection && shallowEqual(lastSelection, doc)) ||\n      ((lastSelection = doc),\n      (doc = accumulateTwoPhaseListeners(activeElementInst, \"onSelect\")),\n      0 < doc.length &&\n        ((nativeEvent = new SyntheticEvent(\n          \"onSelect\",\n          \"select\",\n          null,\n          nativeEvent,\n          nativeEventTarget\n        )),\n        dispatchQueue.push({ event: nativeEvent, listeners: doc }),\n        (nativeEvent.target = activeElement))));\n}\nfunction makePrefixMap(styleProp, eventName) {\n  var prefixes = {};\n  prefixes[styleProp.toLowerCase()] = eventName.toLowerCase();\n  prefixes[\"Webkit\" + styleProp] = \"webkit\" + eventName;\n  prefixes[\"Moz\" + styleProp] = \"moz\" + eventName;\n  return prefixes;\n}\nvar vendorPrefixes = {\n    animationend: makePrefixMap(\"Animation\", \"AnimationEnd\"),\n    animationiteration: makePrefixMap(\"Animation\", \"AnimationIteration\"),\n    animationstart: makePrefixMap(\"Animation\", \"AnimationStart\"),\n    transitionrun: makePrefixMap(\"Transition\", \"TransitionRun\"),\n    transitionstart: makePrefixMap(\"Transition\", \"TransitionStart\"),\n    transitioncancel: makePrefixMap(\"Transition\", \"TransitionCancel\"),\n    transitionend: makePrefixMap(\"Transition\", \"TransitionEnd\")\n  },\n  prefixedEventNames = {},\n  style = {};\ncanUseDOM &&\n  ((style = document.createElement(\"div\").style),\n  \"AnimationEvent\" in window ||\n    (delete vendorPrefixes.animationend.animation,\n    delete vendorPrefixes.animationiteration.animation,\n    delete vendorPrefixes.animationstart.animation),\n  \"TransitionEvent\" in window ||\n    delete vendorPrefixes.transitionend.transition);\nfunction getVendorPrefixedEventName(eventName) {\n  if (prefixedEventNames[eventName]) return prefixedEventNames[eventName];\n  if (!vendorPrefixes[eventName]) return eventName;\n  var prefixMap = vendorPrefixes[eventName],\n    styleProp;\n  for (styleProp in prefixMap)\n    if (prefixMap.hasOwnProperty(styleProp) && styleProp in style)\n      return (prefixedEventNames[eventName] = prefixMap[styleProp]);\n  return eventName;\n}\nvar ANIMATION_END = getVendorPrefixedEventName(\"animationend\"),\n  ANIMATION_ITERATION = getVendorPrefixedEventName(\"animationiteration\"),\n  ANIMATION_START = getVendorPrefixedEventName(\"animationstart\"),\n  TRANSITION_RUN = getVendorPrefixedEventName(\"transitionrun\"),\n  TRANSITION_START = getVendorPrefixedEventName(\"transitionstart\"),\n  TRANSITION_CANCEL = getVendorPrefixedEventName(\"transitioncancel\"),\n  TRANSITION_END = getVendorPrefixedEventName(\"transitionend\"),\n  topLevelEventsToReactNames = new Map(),\n  simpleEventPluginEvents =\n    \"abort auxClick beforeToggle cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll scrollEnd toggle touchMove waiting wheel\".split(\n      \" \"\n    );\nfunction registerSimpleEvent(domEventName, reactName) {\n  topLevelEventsToReactNames.set(domEventName, reactName);\n  registerTwoPhaseEvent(reactName, [domEventName]);\n}\nvar concurrentQueues = [],\n  concurrentQueuesIndex = 0,\n  concurrentlyUpdatedLanes = 0;\nfunction finishQueueingConcurrentUpdates() {\n  for (\n    var endIndex = concurrentQueuesIndex,\n      i = (concurrentlyUpdatedLanes = concurrentQueuesIndex = 0);\n    i < endIndex;\n\n  ) {\n    var fiber = concurrentQueues[i];\n    concurrentQueues[i++] = null;\n    var queue = concurrentQueues[i];\n    concurrentQueues[i++] = null;\n    var update = concurrentQueues[i];\n    concurrentQueues[i++] = null;\n    var lane = concurrentQueues[i];\n    concurrentQueues[i++] = null;\n    if (null !== queue && null !== update) {\n      var pending = queue.pending;\n      null === pending\n        ? (update.next = update)\n        : ((update.next = pending.next), (pending.next = update));\n      queue.pending = update;\n    }\n    0 !== lane && markUpdateLaneFromFiberToRoot(fiber, update, lane);\n  }\n}\nfunction enqueueUpdate$1(fiber, queue, update, lane) {\n  concurrentQueues[concurrentQueuesIndex++] = fiber;\n  concurrentQueues[concurrentQueuesIndex++] = queue;\n  concurrentQueues[concurrentQueuesIndex++] = update;\n  concurrentQueues[concurrentQueuesIndex++] = lane;\n  concurrentlyUpdatedLanes |= lane;\n  fiber.lanes |= lane;\n  fiber = fiber.alternate;\n  null !== fiber && (fiber.lanes |= lane);\n}\nfunction enqueueConcurrentHookUpdate(fiber, queue, update, lane) {\n  enqueueUpdate$1(fiber, queue, update, lane);\n  return getRootForUpdatedFiber(fiber);\n}\nfunction enqueueConcurrentRenderForLane(fiber, lane) {\n  enqueueUpdate$1(fiber, null, null, lane);\n  return getRootForUpdatedFiber(fiber);\n}\nfunction markUpdateLaneFromFiberToRoot(sourceFiber, update, lane) {\n  sourceFiber.lanes |= lane;\n  var alternate = sourceFiber.alternate;\n  null !== alternate && (alternate.lanes |= lane);\n  for (var isHidden = !1, parent = sourceFiber.return; null !== parent; )\n    (parent.childLanes |= lane),\n      (alternate = parent.alternate),\n      null !== alternate && (alternate.childLanes |= lane),\n      22 === parent.tag &&\n        ((sourceFiber = parent.stateNode),\n        null === sourceFiber || sourceFiber._visibility & 1 || (isHidden = !0)),\n      (sourceFiber = parent),\n      (parent = parent.return);\n  isHidden &&\n    null !== update &&\n    3 === sourceFiber.tag &&\n    ((parent = sourceFiber.stateNode),\n    (isHidden = 31 - clz32(lane)),\n    (parent = parent.hiddenUpdates),\n    (sourceFiber = parent[isHidden]),\n    null === sourceFiber\n      ? (parent[isHidden] = [update])\n      : sourceFiber.push(update),\n    (update.lane = lane | 536870912));\n}\nfunction getRootForUpdatedFiber(sourceFiber) {\n  if (50 < nestedUpdateCount)\n    throw (\n      ((nestedUpdateCount = 0),\n      (rootWithNestedUpdates = null),\n      Error(formatProdErrorMessage(185)))\n    );\n  for (var parent = sourceFiber.return; null !== parent; )\n    (sourceFiber = parent), (parent = sourceFiber.return);\n  return 3 === sourceFiber.tag ? sourceFiber.stateNode : null;\n}\nvar emptyContextObject = {},\n  CapturedStacks = new WeakMap();\nfunction createCapturedValueAtFiber(value, source) {\n  if (\"object\" === typeof value && null !== value) {\n    var existing = CapturedStacks.get(value);\n    if (void 0 !== existing) return existing;\n    source = {\n      value: value,\n      source: source,\n      stack: getStackByFiberInDevAndProd(source)\n    };\n    CapturedStacks.set(value, source);\n    return source;\n  }\n  return {\n    value: value,\n    source: source,\n    stack: getStackByFiberInDevAndProd(source)\n  };\n}\nvar forkStack = [],\n  forkStackIndex = 0,\n  treeForkProvider = null,\n  treeForkCount = 0,\n  idStack = [],\n  idStackIndex = 0,\n  treeContextProvider = null,\n  treeContextId = 1,\n  treeContextOverflow = \"\";\nfunction pushTreeFork(workInProgress, totalChildren) {\n  forkStack[forkStackIndex++] = treeForkCount;\n  forkStack[forkStackIndex++] = treeForkProvider;\n  treeForkProvider = workInProgress;\n  treeForkCount = totalChildren;\n}\nfunction pushTreeId(workInProgress, totalChildren, index) {\n  idStack[idStackIndex++] = treeContextId;\n  idStack[idStackIndex++] = treeContextOverflow;\n  idStack[idStackIndex++] = treeContextProvider;\n  treeContextProvider = workInProgress;\n  var baseIdWithLeadingBit = treeContextId;\n  workInProgress = treeContextOverflow;\n  var baseLength = 32 - clz32(baseIdWithLeadingBit) - 1;\n  baseIdWithLeadingBit &= ~(1 << baseLength);\n  index += 1;\n  var length = 32 - clz32(totalChildren) + baseLength;\n  if (30 < length) {\n    var numberOfOverflowBits = baseLength - (baseLength % 5);\n    length = (\n      baseIdWithLeadingBit &\n      ((1 << numberOfOverflowBits) - 1)\n    ).toString(32);\n    baseIdWithLeadingBit >>= numberOfOverflowBits;\n    baseLength -= numberOfOverflowBits;\n    treeContextId =\n      (1 << (32 - clz32(totalChildren) + baseLength)) |\n      (index << baseLength) |\n      baseIdWithLeadingBit;\n    treeContextOverflow = length + workInProgress;\n  } else\n    (treeContextId =\n      (1 << length) | (index << baseLength) | baseIdWithLeadingBit),\n      (treeContextOverflow = workInProgress);\n}\nfunction pushMaterializedTreeId(workInProgress) {\n  null !== workInProgress.return &&\n    (pushTreeFork(workInProgress, 1), pushTreeId(workInProgress, 1, 0));\n}\nfunction popTreeContext(workInProgress) {\n  for (; workInProgress === treeForkProvider; )\n    (treeForkProvider = forkStack[--forkStackIndex]),\n      (forkStack[forkStackIndex] = null),\n      (treeForkCount = forkStack[--forkStackIndex]),\n      (forkStack[forkStackIndex] = null);\n  for (; workInProgress === treeContextProvider; )\n    (treeContextProvider = idStack[--idStackIndex]),\n      (idStack[idStackIndex] = null),\n      (treeContextOverflow = idStack[--idStackIndex]),\n      (idStack[idStackIndex] = null),\n      (treeContextId = idStack[--idStackIndex]),\n      (idStack[idStackIndex] = null);\n}\nvar hydrationParentFiber = null,\n  nextHydratableInstance = null,\n  isHydrating = !1,\n  hydrationErrors = null,\n  rootOrSingletonContext = !1,\n  HydrationMismatchException = Error(formatProdErrorMessage(519));\nfunction throwOnHydrationMismatch(fiber) {\n  var error = Error(formatProdErrorMessage(418, \"\"));\n  queueHydrationError(createCapturedValueAtFiber(error, fiber));\n  throw HydrationMismatchException;\n}\nfunction prepareToHydrateHostInstance(fiber) {\n  var instance = fiber.stateNode,\n    type = fiber.type,\n    props = fiber.memoizedProps;\n  instance[internalInstanceKey] = fiber;\n  instance[internalPropsKey] = props;\n  switch (type) {\n    case \"dialog\":\n      listenToNonDelegatedEvent(\"cancel\", instance);\n      listenToNonDelegatedEvent(\"close\", instance);\n      break;\n    case \"iframe\":\n    case \"object\":\n    case \"embed\":\n      listenToNonDelegatedEvent(\"load\", instance);\n      break;\n    case \"video\":\n    case \"audio\":\n      for (type = 0; type < mediaEventTypes.length; type++)\n        listenToNonDelegatedEvent(mediaEventTypes[type], instance);\n      break;\n    case \"source\":\n      listenToNonDelegatedEvent(\"error\", instance);\n      break;\n    case \"img\":\n    case \"image\":\n    case \"link\":\n      listenToNonDelegatedEvent(\"error\", instance);\n      listenToNonDelegatedEvent(\"load\", instance);\n      break;\n    case \"details\":\n      listenToNonDelegatedEvent(\"toggle\", instance);\n      break;\n    case \"input\":\n      listenToNonDelegatedEvent(\"invalid\", instance);\n      initInput(\n        instance,\n        props.value,\n        props.defaultValue,\n        props.checked,\n        props.defaultChecked,\n        props.type,\n        props.name,\n        !0\n      );\n      track(instance);\n      break;\n    case \"select\":\n      listenToNonDelegatedEvent(\"invalid\", instance);\n      break;\n    case \"textarea\":\n      listenToNonDelegatedEvent(\"invalid\", instance),\n        initTextarea(instance, props.value, props.defaultValue, props.children),\n        track(instance);\n  }\n  type = props.children;\n  (\"string\" !== typeof type &&\n    \"number\" !== typeof type &&\n    \"bigint\" !== typeof type) ||\n  instance.textContent === \"\" + type ||\n  !0 === props.suppressHydrationWarning ||\n  checkForUnmatchedText(instance.textContent, type)\n    ? (null != props.popover &&\n        (listenToNonDelegatedEvent(\"beforetoggle\", instance),\n        listenToNonDelegatedEvent(\"toggle\", instance)),\n      null != props.onScroll && listenToNonDelegatedEvent(\"scroll\", instance),\n      null != props.onScrollEnd &&\n        listenToNonDelegatedEvent(\"scrollend\", instance),\n      null != props.onClick && (instance.onclick = noop$1),\n      (instance = !0))\n    : (instance = !1);\n  instance || throwOnHydrationMismatch(fiber);\n}\nfunction popToNextHostParent(fiber) {\n  for (hydrationParentFiber = fiber.return; hydrationParentFiber; )\n    switch (hydrationParentFiber.tag) {\n      case 3:\n      case 27:\n        rootOrSingletonContext = !0;\n        return;\n      case 5:\n      case 13:\n        rootOrSingletonContext = !1;\n        return;\n      default:\n        hydrationParentFiber = hydrationParentFiber.return;\n    }\n}\nfunction popHydrationState(fiber) {\n  if (fiber !== hydrationParentFiber) return !1;\n  if (!isHydrating) return popToNextHostParent(fiber), (isHydrating = !0), !1;\n  var shouldClear = !1,\n    JSCompiler_temp;\n  if ((JSCompiler_temp = 3 !== fiber.tag && 27 !== fiber.tag)) {\n    if ((JSCompiler_temp = 5 === fiber.tag))\n      (JSCompiler_temp = fiber.type),\n        (JSCompiler_temp =\n          !(\"form\" !== JSCompiler_temp && \"button\" !== JSCompiler_temp) ||\n          shouldSetTextContent(fiber.type, fiber.memoizedProps));\n    JSCompiler_temp = !JSCompiler_temp;\n  }\n  JSCompiler_temp && (shouldClear = !0);\n  shouldClear && nextHydratableInstance && throwOnHydrationMismatch(fiber);\n  popToNextHostParent(fiber);\n  if (13 === fiber.tag) {\n    fiber = fiber.memoizedState;\n    fiber = null !== fiber ? fiber.dehydrated : null;\n    if (!fiber) throw Error(formatProdErrorMessage(317));\n    a: {\n      fiber = fiber.nextSibling;\n      for (shouldClear = 0; fiber; ) {\n        if (8 === fiber.nodeType)\n          if (((JSCompiler_temp = fiber.data), \"/$\" === JSCompiler_temp)) {\n            if (0 === shouldClear) {\n              nextHydratableInstance = getNextHydratable(fiber.nextSibling);\n              break a;\n            }\n            shouldClear--;\n          } else\n            (\"$\" !== JSCompiler_temp &&\n              \"$!\" !== JSCompiler_temp &&\n              \"$?\" !== JSCompiler_temp) ||\n              shouldClear++;\n        fiber = fiber.nextSibling;\n      }\n      nextHydratableInstance = null;\n    }\n  } else\n    nextHydratableInstance = hydrationParentFiber\n      ? getNextHydratable(fiber.stateNode.nextSibling)\n      : null;\n  return !0;\n}\nfunction resetHydrationState() {\n  nextHydratableInstance = hydrationParentFiber = null;\n  isHydrating = !1;\n}\nfunction queueHydrationError(error) {\n  null === hydrationErrors\n    ? (hydrationErrors = [error])\n    : hydrationErrors.push(error);\n}\nvar SuspenseException = Error(formatProdErrorMessage(460)),\n  SuspenseyCommitException = Error(formatProdErrorMessage(474)),\n  noopSuspenseyCommitThenable = { then: function () {} };\nfunction isThenableResolved(thenable) {\n  thenable = thenable.status;\n  return \"fulfilled\" === thenable || \"rejected\" === thenable;\n}\nfunction noop$3() {}\nfunction trackUsedThenable(thenableState, thenable, index) {\n  index = thenableState[index];\n  void 0 === index\n    ? thenableState.push(thenable)\n    : index !== thenable && (thenable.then(noop$3, noop$3), (thenable = index));\n  switch (thenable.status) {\n    case \"fulfilled\":\n      return thenable.value;\n    case \"rejected\":\n      thenableState = thenable.reason;\n      if (thenableState === SuspenseException)\n        throw Error(formatProdErrorMessage(483));\n      throw thenableState;\n    default:\n      if (\"string\" === typeof thenable.status) thenable.then(noop$3, noop$3);\n      else {\n        thenableState = workInProgressRoot;\n        if (null !== thenableState && 100 < thenableState.shellSuspendCounter)\n          throw Error(formatProdErrorMessage(482));\n        thenableState = thenable;\n        thenableState.status = \"pending\";\n        thenableState.then(\n          function (fulfilledValue) {\n            if (\"pending\" === thenable.status) {\n              var fulfilledThenable = thenable;\n              fulfilledThenable.status = \"fulfilled\";\n              fulfilledThenable.value = fulfilledValue;\n            }\n          },\n          function (error) {\n            if (\"pending\" === thenable.status) {\n              var rejectedThenable = thenable;\n              rejectedThenable.status = \"rejected\";\n              rejectedThenable.reason = error;\n            }\n          }\n        );\n      }\n      switch (thenable.status) {\n        case \"fulfilled\":\n          return thenable.value;\n        case \"rejected\":\n          thenableState = thenable.reason;\n          if (thenableState === SuspenseException)\n            throw Error(formatProdErrorMessage(483));\n          throw thenableState;\n      }\n      suspendedThenable = thenable;\n      throw SuspenseException;\n  }\n}\nvar suspendedThenable = null;\nfunction getSuspendedThenable() {\n  if (null === suspendedThenable) throw Error(formatProdErrorMessage(459));\n  var thenable = suspendedThenable;\n  suspendedThenable = null;\n  return thenable;\n}\nvar thenableState$1 = null,\n  thenableIndexCounter$1 = 0;\nfunction unwrapThenable(thenable) {\n  var index = thenableIndexCounter$1;\n  thenableIndexCounter$1 += 1;\n  null === thenableState$1 && (thenableState$1 = []);\n  return trackUsedThenable(thenableState$1, thenable, index);\n}\nfunction coerceRef(workInProgress, element) {\n  element = element.props.ref;\n  workInProgress.ref = void 0 !== element ? element : null;\n}\nfunction throwOnInvalidObjectType(returnFiber, newChild) {\n  if (newChild.$$typeof === REACT_LEGACY_ELEMENT_TYPE)\n    throw Error(formatProdErrorMessage(525));\n  returnFiber = Object.prototype.toString.call(newChild);\n  throw Error(\n    formatProdErrorMessage(\n      31,\n      \"[object Object]\" === returnFiber\n        ? \"object with keys {\" + Object.keys(newChild).join(\", \") + \"}\"\n        : returnFiber\n    )\n  );\n}\nfunction resolveLazy(lazyType) {\n  var init = lazyType._init;\n  return init(lazyType._payload);\n}\nfunction createChildReconciler(shouldTrackSideEffects) {\n  function deleteChild(returnFiber, childToDelete) {\n    if (shouldTrackSideEffects) {\n      var deletions = returnFiber.deletions;\n      null === deletions\n        ? ((returnFiber.deletions = [childToDelete]), (returnFiber.flags |= 16))\n        : deletions.push(childToDelete);\n    }\n  }\n  function deleteRemainingChildren(returnFiber, currentFirstChild) {\n    if (!shouldTrackSideEffects) return null;\n    for (; null !== currentFirstChild; )\n      deleteChild(returnFiber, currentFirstChild),\n        (currentFirstChild = currentFirstChild.sibling);\n    return null;\n  }\n  function mapRemainingChildren(currentFirstChild) {\n    for (var existingChildren = new Map(); null !== currentFirstChild; )\n      null !== currentFirstChild.key\n        ? existingChildren.set(currentFirstChild.key, currentFirstChild)\n        : existingChildren.set(currentFirstChild.index, currentFirstChild),\n        (currentFirstChild = currentFirstChild.sibling);\n    return existingChildren;\n  }\n  function useFiber(fiber, pendingProps) {\n    fiber = createWorkInProgress(fiber, pendingProps);\n    fiber.index = 0;\n    fiber.sibling = null;\n    return fiber;\n  }\n  function placeChild(newFiber, lastPlacedIndex, newIndex) {\n    newFiber.index = newIndex;\n    if (!shouldTrackSideEffects)\n      return (newFiber.flags |= 1048576), lastPlacedIndex;\n    newIndex = newFiber.alternate;\n    if (null !== newIndex)\n      return (\n        (newIndex = newIndex.index),\n        newIndex < lastPlacedIndex\n          ? ((newFiber.flags |= 33554434), lastPlacedIndex)\n          : newIndex\n      );\n    newFiber.flags |= 33554434;\n    return lastPlacedIndex;\n  }\n  function placeSingleChild(newFiber) {\n    shouldTrackSideEffects &&\n      null === newFiber.alternate &&\n      (newFiber.flags |= 33554434);\n    return newFiber;\n  }\n  function updateTextNode(returnFiber, current, textContent, lanes) {\n    if (null === current || 6 !== current.tag)\n      return (\n        (current = createFiberFromText(textContent, returnFiber.mode, lanes)),\n        (current.return = returnFiber),\n        current\n      );\n    current = useFiber(current, textContent);\n    current.return = returnFiber;\n    return current;\n  }\n  function updateElement(returnFiber, current, element, lanes) {\n    var elementType = element.type;\n    if (elementType === REACT_FRAGMENT_TYPE)\n      return updateFragment(\n        returnFiber,\n        current,\n        element.props.children,\n        lanes,\n        element.key\n      );\n    if (\n      null !== current &&\n      (current.elementType === elementType ||\n        (\"object\" === typeof elementType &&\n          null !== elementType &&\n          elementType.$$typeof === REACT_LAZY_TYPE &&\n          resolveLazy(elementType) === current.type))\n    )\n      return (\n        (current = useFiber(current, element.props)),\n        coerceRef(current, element),\n        (current.return = returnFiber),\n        current\n      );\n    current = createFiberFromTypeAndProps(\n      element.type,\n      element.key,\n      element.props,\n      null,\n      returnFiber.mode,\n      lanes\n    );\n    coerceRef(current, element);\n    current.return = returnFiber;\n    return current;\n  }\n  function updatePortal(returnFiber, current, portal, lanes) {\n    if (\n      null === current ||\n      4 !== current.tag ||\n      current.stateNode.containerInfo !== portal.containerInfo ||\n      current.stateNode.implementation !== portal.implementation\n    )\n      return (\n        (current = createFiberFromPortal(portal, returnFiber.mode, lanes)),\n        (current.return = returnFiber),\n        current\n      );\n    current = useFiber(current, portal.children || []);\n    current.return = returnFiber;\n    return current;\n  }\n  function updateFragment(returnFiber, current, fragment, lanes, key) {\n    if (null === current || 7 !== current.tag)\n      return (\n        (current = createFiberFromFragment(\n          fragment,\n          returnFiber.mode,\n          lanes,\n          key\n        )),\n        (current.return = returnFiber),\n        current\n      );\n    current = useFiber(current, fragment);\n    current.return = returnFiber;\n    return current;\n  }\n  function createChild(returnFiber, newChild, lanes) {\n    if (\n      (\"string\" === typeof newChild && \"\" !== newChild) ||\n      \"number\" === typeof newChild ||\n      \"bigint\" === typeof newChild\n    )\n      return (\n        (newChild = createFiberFromText(\n          \"\" + newChild,\n          returnFiber.mode,\n          lanes\n        )),\n        (newChild.return = returnFiber),\n        newChild\n      );\n    if (\"object\" === typeof newChild && null !== newChild) {\n      switch (newChild.$$typeof) {\n        case REACT_ELEMENT_TYPE:\n          return (\n            (lanes = createFiberFromTypeAndProps(\n              newChild.type,\n              newChild.key,\n              newChild.props,\n              null,\n              returnFiber.mode,\n              lanes\n            )),\n            coerceRef(lanes, newChild),\n            (lanes.return = returnFiber),\n            lanes\n          );\n        case REACT_PORTAL_TYPE:\n          return (\n            (newChild = createFiberFromPortal(\n              newChild,\n              returnFiber.mode,\n              lanes\n            )),\n            (newChild.return = returnFiber),\n            newChild\n          );\n        case REACT_LAZY_TYPE:\n          var init = newChild._init;\n          newChild = init(newChild._payload);\n          return createChild(returnFiber, newChild, lanes);\n      }\n      if (isArrayImpl(newChild) || getIteratorFn(newChild))\n        return (\n          (newChild = createFiberFromFragment(\n            newChild,\n            returnFiber.mode,\n            lanes,\n            null\n          )),\n          (newChild.return = returnFiber),\n          newChild\n        );\n      if (\"function\" === typeof newChild.then)\n        return createChild(returnFiber, unwrapThenable(newChild), lanes);\n      if (newChild.$$typeof === REACT_CONTEXT_TYPE)\n        return createChild(\n          returnFiber,\n          readContextDuringReconciliation(returnFiber, newChild),\n          lanes\n        );\n      throwOnInvalidObjectType(returnFiber, newChild);\n    }\n    return null;\n  }\n  function updateSlot(returnFiber, oldFiber, newChild, lanes) {\n    var key = null !== oldFiber ? oldFiber.key : null;\n    if (\n      (\"string\" === typeof newChild && \"\" !== newChild) ||\n      \"number\" === typeof newChild ||\n      \"bigint\" === typeof newChild\n    )\n      return null !== key\n        ? null\n        : updateTextNode(returnFiber, oldFiber, \"\" + newChild, lanes);\n    if (\"object\" === typeof newChild && null !== newChild) {\n      switch (newChild.$$typeof) {\n        case REACT_ELEMENT_TYPE:\n          return newChild.key === key\n            ? updateElement(returnFiber, oldFiber, newChild, lanes)\n            : null;\n        case REACT_PORTAL_TYPE:\n          return newChild.key === key\n            ? updatePortal(returnFiber, oldFiber, newChild, lanes)\n            : null;\n        case REACT_LAZY_TYPE:\n          return (\n            (key = newChild._init),\n            (newChild = key(newChild._payload)),\n            updateSlot(returnFiber, oldFiber, newChild, lanes)\n          );\n      }\n      if (isArrayImpl(newChild) || getIteratorFn(newChild))\n        return null !== key\n          ? null\n          : updateFragment(returnFiber, oldFiber, newChild, lanes, null);\n      if (\"function\" === typeof newChild.then)\n        return updateSlot(\n          returnFiber,\n          oldFiber,\n          unwrapThenable(newChild),\n          lanes\n        );\n      if (newChild.$$typeof === REACT_CONTEXT_TYPE)\n        return updateSlot(\n          returnFiber,\n          oldFiber,\n          readContextDuringReconciliation(returnFiber, newChild),\n          lanes\n        );\n      throwOnInvalidObjectType(returnFiber, newChild);\n    }\n    return null;\n  }\n  function updateFromMap(\n    existingChildren,\n    returnFiber,\n    newIdx,\n    newChild,\n    lanes\n  ) {\n    if (\n      (\"string\" === typeof newChild && \"\" !== newChild) ||\n      \"number\" === typeof newChild ||\n      \"bigint\" === typeof newChild\n    )\n      return (\n        (existingChildren = existingChildren.get(newIdx) || null),\n        updateTextNode(returnFiber, existingChildren, \"\" + newChild, lanes)\n      );\n    if (\"object\" === typeof newChild && null !== newChild) {\n      switch (newChild.$$typeof) {\n        case REACT_ELEMENT_TYPE:\n          return (\n            (existingChildren =\n              existingChildren.get(\n                null === newChild.key ? newIdx : newChild.key\n              ) || null),\n            updateElement(returnFiber, existingChildren, newChild, lanes)\n          );\n        case REACT_PORTAL_TYPE:\n          return (\n            (existingChildren =\n              existingChildren.get(\n                null === newChild.key ? newIdx : newChild.key\n              ) || null),\n            updatePortal(returnFiber, existingChildren, newChild, lanes)\n          );\n        case REACT_LAZY_TYPE:\n          var init = newChild._init;\n          newChild = init(newChild._payload);\n          return updateFromMap(\n            existingChildren,\n            returnFiber,\n            newIdx,\n            newChild,\n            lanes\n          );\n      }\n      if (isArrayImpl(newChild) || getIteratorFn(newChild))\n        return (\n          (existingChildren = existingChildren.get(newIdx) || null),\n          updateFragment(returnFiber, existingChildren, newChild, lanes, null)\n        );\n      if (\"function\" === typeof newChild.then)\n        return updateFromMap(\n          existingChildren,\n          returnFiber,\n          newIdx,\n          unwrapThenable(newChild),\n          lanes\n        );\n      if (newChild.$$typeof === REACT_CONTEXT_TYPE)\n        return updateFromMap(\n          existingChildren,\n          returnFiber,\n          newIdx,\n          readContextDuringReconciliation(returnFiber, newChild),\n          lanes\n        );\n      throwOnInvalidObjectType(returnFiber, newChild);\n    }\n    return null;\n  }\n  function reconcileChildrenArray(\n    returnFiber,\n    currentFirstChild,\n    newChildren,\n    lanes\n  ) {\n    for (\n      var resultingFirstChild = null,\n        previousNewFiber = null,\n        oldFiber = currentFirstChild,\n        newIdx = (currentFirstChild = 0),\n        nextOldFiber = null;\n      null !== oldFiber && newIdx < newChildren.length;\n      newIdx++\n    ) {\n      oldFiber.index > newIdx\n        ? ((nextOldFiber = oldFiber), (oldFiber = null))\n        : (nextOldFiber = oldFiber.sibling);\n      var newFiber = updateSlot(\n        returnFiber,\n        oldFiber,\n        newChildren[newIdx],\n        lanes\n      );\n      if (null === newFiber) {\n        null === oldFiber && (oldFiber = nextOldFiber);\n        break;\n      }\n      shouldTrackSideEffects &&\n        oldFiber &&\n        null === newFiber.alternate &&\n        deleteChild(returnFiber, oldFiber);\n      currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n      null === previousNewFiber\n        ? (resultingFirstChild = newFiber)\n        : (previousNewFiber.sibling = newFiber);\n      previousNewFiber = newFiber;\n      oldFiber = nextOldFiber;\n    }\n    if (newIdx === newChildren.length)\n      return (\n        deleteRemainingChildren(returnFiber, oldFiber),\n        isHydrating && pushTreeFork(returnFiber, newIdx),\n        resultingFirstChild\n      );\n    if (null === oldFiber) {\n      for (; newIdx < newChildren.length; newIdx++)\n        (oldFiber = createChild(returnFiber, newChildren[newIdx], lanes)),\n          null !== oldFiber &&\n            ((currentFirstChild = placeChild(\n              oldFiber,\n              currentFirstChild,\n              newIdx\n            )),\n            null === previousNewFiber\n              ? (resultingFirstChild = oldFiber)\n              : (previousNewFiber.sibling = oldFiber),\n            (previousNewFiber = oldFiber));\n      isHydrating && pushTreeFork(returnFiber, newIdx);\n      return resultingFirstChild;\n    }\n    for (\n      oldFiber = mapRemainingChildren(oldFiber);\n      newIdx < newChildren.length;\n      newIdx++\n    )\n      (nextOldFiber = updateFromMap(\n        oldFiber,\n        returnFiber,\n        newIdx,\n        newChildren[newIdx],\n        lanes\n      )),\n        null !== nextOldFiber &&\n          (shouldTrackSideEffects &&\n            null !== nextOldFiber.alternate &&\n            oldFiber.delete(\n              null === nextOldFiber.key ? newIdx : nextOldFiber.key\n            ),\n          (currentFirstChild = placeChild(\n            nextOldFiber,\n            currentFirstChild,\n            newIdx\n          )),\n          null === previousNewFiber\n            ? (resultingFirstChild = nextOldFiber)\n            : (previousNewFiber.sibling = nextOldFiber),\n          (previousNewFiber = nextOldFiber));\n    shouldTrackSideEffects &&\n      oldFiber.forEach(function (child) {\n        return deleteChild(returnFiber, child);\n      });\n    isHydrating && pushTreeFork(returnFiber, newIdx);\n    return resultingFirstChild;\n  }\n  function reconcileChildrenIterator(\n    returnFiber,\n    currentFirstChild,\n    newChildren,\n    lanes\n  ) {\n    if (null == newChildren) throw Error(formatProdErrorMessage(151));\n    for (\n      var resultingFirstChild = null,\n        previousNewFiber = null,\n        oldFiber = currentFirstChild,\n        newIdx = (currentFirstChild = 0),\n        nextOldFiber = null,\n        step = newChildren.next();\n      null !== oldFiber && !step.done;\n      newIdx++, step = newChildren.next()\n    ) {\n      oldFiber.index > newIdx\n        ? ((nextOldFiber = oldFiber), (oldFiber = null))\n        : (nextOldFiber = oldFiber.sibling);\n      var newFiber = updateSlot(returnFiber, oldFiber, step.value, lanes);\n      if (null === newFiber) {\n        null === oldFiber && (oldFiber = nextOldFiber);\n        break;\n      }\n      shouldTrackSideEffects &&\n        oldFiber &&\n        null === newFiber.alternate &&\n        deleteChild(returnFiber, oldFiber);\n      currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n      null === previousNewFiber\n        ? (resultingFirstChild = newFiber)\n        : (previousNewFiber.sibling = newFiber);\n      previousNewFiber = newFiber;\n      oldFiber = nextOldFiber;\n    }\n    if (step.done)\n      return (\n        deleteRemainingChildren(returnFiber, oldFiber),\n        isHydrating && pushTreeFork(returnFiber, newIdx),\n        resultingFirstChild\n      );\n    if (null === oldFiber) {\n      for (; !step.done; newIdx++, step = newChildren.next())\n        (step = createChild(returnFiber, step.value, lanes)),\n          null !== step &&\n            ((currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n            null === previousNewFiber\n              ? (resultingFirstChild = step)\n              : (previousNewFiber.sibling = step),\n            (previousNewFiber = step));\n      isHydrating && pushTreeFork(returnFiber, newIdx);\n      return resultingFirstChild;\n    }\n    for (\n      oldFiber = mapRemainingChildren(oldFiber);\n      !step.done;\n      newIdx++, step = newChildren.next()\n    )\n      (step = updateFromMap(oldFiber, returnFiber, newIdx, step.value, lanes)),\n        null !== step &&\n          (shouldTrackSideEffects &&\n            null !== step.alternate &&\n            oldFiber.delete(null === step.key ? newIdx : step.key),\n          (currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n          null === previousNewFiber\n            ? (resultingFirstChild = step)\n            : (previousNewFiber.sibling = step),\n          (previousNewFiber = step));\n    shouldTrackSideEffects &&\n      oldFiber.forEach(function (child) {\n        return deleteChild(returnFiber, child);\n      });\n    isHydrating && pushTreeFork(returnFiber, newIdx);\n    return resultingFirstChild;\n  }\n  function reconcileChildFibersImpl(\n    returnFiber,\n    currentFirstChild,\n    newChild,\n    lanes\n  ) {\n    \"object\" === typeof newChild &&\n      null !== newChild &&\n      newChild.type === REACT_FRAGMENT_TYPE &&\n      null === newChild.key &&\n      (newChild = newChild.props.children);\n    if (\"object\" === typeof newChild && null !== newChild) {\n      switch (newChild.$$typeof) {\n        case REACT_ELEMENT_TYPE:\n          a: {\n            for (var key = newChild.key; null !== currentFirstChild; ) {\n              if (currentFirstChild.key === key) {\n                key = newChild.type;\n                if (key === REACT_FRAGMENT_TYPE) {\n                  if (7 === currentFirstChild.tag) {\n                    deleteRemainingChildren(\n                      returnFiber,\n                      currentFirstChild.sibling\n                    );\n                    lanes = useFiber(\n                      currentFirstChild,\n                      newChild.props.children\n                    );\n                    lanes.return = returnFiber;\n                    returnFiber = lanes;\n                    break a;\n                  }\n                } else if (\n                  currentFirstChild.elementType === key ||\n                  (\"object\" === typeof key &&\n                    null !== key &&\n                    key.$$typeof === REACT_LAZY_TYPE &&\n                    resolveLazy(key) === currentFirstChild.type)\n                ) {\n                  deleteRemainingChildren(\n                    returnFiber,\n                    currentFirstChild.sibling\n                  );\n                  lanes = useFiber(currentFirstChild, newChild.props);\n                  coerceRef(lanes, newChild);\n                  lanes.return = returnFiber;\n                  returnFiber = lanes;\n                  break a;\n                }\n                deleteRemainingChildren(returnFiber, currentFirstChild);\n                break;\n              } else deleteChild(returnFiber, currentFirstChild);\n              currentFirstChild = currentFirstChild.sibling;\n            }\n            newChild.type === REACT_FRAGMENT_TYPE\n              ? ((lanes = createFiberFromFragment(\n                  newChild.props.children,\n                  returnFiber.mode,\n                  lanes,\n                  newChild.key\n                )),\n                (lanes.return = returnFiber),\n                (returnFiber = lanes))\n              : ((lanes = createFiberFromTypeAndProps(\n                  newChild.type,\n                  newChild.key,\n                  newChild.props,\n                  null,\n                  returnFiber.mode,\n                  lanes\n                )),\n                coerceRef(lanes, newChild),\n                (lanes.return = returnFiber),\n                (returnFiber = lanes));\n          }\n          return placeSingleChild(returnFiber);\n        case REACT_PORTAL_TYPE:\n          a: {\n            for (key = newChild.key; null !== currentFirstChild; ) {\n              if (currentFirstChild.key === key)\n                if (\n                  4 === currentFirstChild.tag &&\n                  currentFirstChild.stateNode.containerInfo ===\n                    newChild.containerInfo &&\n                  currentFirstChild.stateNode.implementation ===\n                    newChild.implementation\n                ) {\n                  deleteRemainingChildren(\n                    returnFiber,\n                    currentFirstChild.sibling\n                  );\n                  lanes = useFiber(currentFirstChild, newChild.children || []);\n                  lanes.return = returnFiber;\n                  returnFiber = lanes;\n                  break a;\n                } else {\n                  deleteRemainingChildren(returnFiber, currentFirstChild);\n                  break;\n                }\n              else deleteChild(returnFiber, currentFirstChild);\n              currentFirstChild = currentFirstChild.sibling;\n            }\n            lanes = createFiberFromPortal(newChild, returnFiber.mode, lanes);\n            lanes.return = returnFiber;\n            returnFiber = lanes;\n          }\n          return placeSingleChild(returnFiber);\n        case REACT_LAZY_TYPE:\n          return (\n            (key = newChild._init),\n            (newChild = key(newChild._payload)),\n            reconcileChildFibersImpl(\n              returnFiber,\n              currentFirstChild,\n              newChild,\n              lanes\n            )\n          );\n      }\n      if (isArrayImpl(newChild))\n        return reconcileChildrenArray(\n          returnFiber,\n          currentFirstChild,\n          newChild,\n          lanes\n        );\n      if (getIteratorFn(newChild)) {\n        key = getIteratorFn(newChild);\n        if (\"function\" !== typeof key) throw Error(formatProdErrorMessage(150));\n        newChild = key.call(newChild);\n        return reconcileChildrenIterator(\n          returnFiber,\n          currentFirstChild,\n          newChild,\n          lanes\n        );\n      }\n      if (\"function\" === typeof newChild.then)\n        return reconcileChildFibersImpl(\n          returnFiber,\n          currentFirstChild,\n          unwrapThenable(newChild),\n          lanes\n        );\n      if (newChild.$$typeof === REACT_CONTEXT_TYPE)\n        return reconcileChildFibersImpl(\n          returnFiber,\n          currentFirstChild,\n          readContextDuringReconciliation(returnFiber, newChild),\n          lanes\n        );\n      throwOnInvalidObjectType(returnFiber, newChild);\n    }\n    return (\"string\" === typeof newChild && \"\" !== newChild) ||\n      \"number\" === typeof newChild ||\n      \"bigint\" === typeof newChild\n      ? ((newChild = \"\" + newChild),\n        null !== currentFirstChild && 6 === currentFirstChild.tag\n          ? (deleteRemainingChildren(returnFiber, currentFirstChild.sibling),\n            (lanes = useFiber(currentFirstChild, newChild)),\n            (lanes.return = returnFiber),\n            (returnFiber = lanes))\n          : (deleteRemainingChildren(returnFiber, currentFirstChild),\n            (lanes = createFiberFromText(newChild, returnFiber.mode, lanes)),\n            (lanes.return = returnFiber),\n            (returnFiber = lanes)),\n        placeSingleChild(returnFiber))\n      : deleteRemainingChildren(returnFiber, currentFirstChild);\n  }\n  return function (returnFiber, currentFirstChild, newChild, lanes) {\n    try {\n      thenableIndexCounter$1 = 0;\n      var firstChildFiber = reconcileChildFibersImpl(\n        returnFiber,\n        currentFirstChild,\n        newChild,\n        lanes\n      );\n      thenableState$1 = null;\n      return firstChildFiber;\n    } catch (x) {\n      if (x === SuspenseException) throw x;\n      var fiber = createFiberImplClass(29, x, null, returnFiber.mode);\n      fiber.lanes = lanes;\n      fiber.return = returnFiber;\n      return fiber;\n    } finally {\n    }\n  };\n}\nvar reconcileChildFibers = createChildReconciler(!0),\n  mountChildFibers = createChildReconciler(!1),\n  currentTreeHiddenStackCursor = createCursor(null),\n  prevEntangledRenderLanesCursor = createCursor(0);\nfunction pushHiddenContext(fiber, context) {\n  fiber = entangledRenderLanes;\n  push(prevEntangledRenderLanesCursor, fiber);\n  push(currentTreeHiddenStackCursor, context);\n  entangledRenderLanes = fiber | context.baseLanes;\n}\nfunction reuseHiddenContextOnStack() {\n  push(prevEntangledRenderLanesCursor, entangledRenderLanes);\n  push(currentTreeHiddenStackCursor, currentTreeHiddenStackCursor.current);\n}\nfunction popHiddenContext() {\n  entangledRenderLanes = prevEntangledRenderLanesCursor.current;\n  pop(currentTreeHiddenStackCursor);\n  pop(prevEntangledRenderLanesCursor);\n}\nvar suspenseHandlerStackCursor = createCursor(null),\n  shellBoundary = null;\nfunction pushPrimaryTreeSuspenseHandler(handler) {\n  var current = handler.alternate;\n  push(suspenseStackCursor, suspenseStackCursor.current & 1);\n  push(suspenseHandlerStackCursor, handler);\n  null === shellBoundary &&\n    (null === current || null !== currentTreeHiddenStackCursor.current\n      ? (shellBoundary = handler)\n      : null !== current.memoizedState && (shellBoundary = handler));\n}\nfunction pushOffscreenSuspenseHandler(fiber) {\n  if (22 === fiber.tag) {\n    if (\n      (push(suspenseStackCursor, suspenseStackCursor.current),\n      push(suspenseHandlerStackCursor, fiber),\n      null === shellBoundary)\n    ) {\n      var current = fiber.alternate;\n      null !== current &&\n        null !== current.memoizedState &&\n        (shellBoundary = fiber);\n    }\n  } else reuseSuspenseHandlerOnStack(fiber);\n}\nfunction reuseSuspenseHandlerOnStack() {\n  push(suspenseStackCursor, suspenseStackCursor.current);\n  push(suspenseHandlerStackCursor, suspenseHandlerStackCursor.current);\n}\nfunction popSuspenseHandler(fiber) {\n  pop(suspenseHandlerStackCursor);\n  shellBoundary === fiber && (shellBoundary = null);\n  pop(suspenseStackCursor);\n}\nvar suspenseStackCursor = createCursor(0);\nfunction findFirstSuspended(row) {\n  for (var node = row; null !== node; ) {\n    if (13 === node.tag) {\n      var state = node.memoizedState;\n      if (\n        null !== state &&\n        ((state = state.dehydrated),\n        null === state || \"$?\" === state.data || \"$!\" === state.data)\n      )\n        return node;\n    } else if (19 === node.tag && void 0 !== node.memoizedProps.revealOrder) {\n      if (0 !== (node.flags & 128)) return node;\n    } else if (null !== node.child) {\n      node.child.return = node;\n      node = node.child;\n      continue;\n    }\n    if (node === row) break;\n    for (; null === node.sibling; ) {\n      if (null === node.return || node.return === row) return null;\n      node = node.return;\n    }\n    node.sibling.return = node.return;\n    node = node.sibling;\n  }\n  return null;\n}\nvar AbortControllerLocal =\n    \"undefined\" !== typeof AbortController\n      ? AbortController\n      : function () {\n          var listeners = [],\n            signal = (this.signal = {\n              aborted: !1,\n              addEventListener: function (type, listener) {\n                listeners.push(listener);\n              }\n            });\n          this.abort = function () {\n            signal.aborted = !0;\n            listeners.forEach(function (listener) {\n              return listener();\n            });\n          };\n        },\n  scheduleCallback$2 = Scheduler.unstable_scheduleCallback,\n  NormalPriority = Scheduler.unstable_NormalPriority,\n  CacheContext = {\n    $$typeof: REACT_CONTEXT_TYPE,\n    Consumer: null,\n    Provider: null,\n    _currentValue: null,\n    _currentValue2: null,\n    _threadCount: 0\n  };\nfunction createCache() {\n  return {\n    controller: new AbortControllerLocal(),\n    data: new Map(),\n    refCount: 0\n  };\n}\nfunction releaseCache(cache) {\n  cache.refCount--;\n  0 === cache.refCount &&\n    scheduleCallback$2(NormalPriority, function () {\n      cache.controller.abort();\n    });\n}\nvar currentEntangledListeners = null,\n  currentEntangledPendingCount = 0,\n  currentEntangledLane = 0,\n  currentEntangledActionThenable = null;\nfunction entangleAsyncAction(transition, thenable) {\n  if (null === currentEntangledListeners) {\n    var entangledListeners = (currentEntangledListeners = []);\n    currentEntangledPendingCount = 0;\n    currentEntangledLane = requestTransitionLane();\n    currentEntangledActionThenable = {\n      status: \"pending\",\n      value: void 0,\n      then: function (resolve) {\n        entangledListeners.push(resolve);\n      }\n    };\n  }\n  currentEntangledPendingCount++;\n  thenable.then(pingEngtangledActionScope, pingEngtangledActionScope);\n  return thenable;\n}\nfunction pingEngtangledActionScope() {\n  if (\n    0 === --currentEntangledPendingCount &&\n    null !== currentEntangledListeners\n  ) {\n    null !== currentEntangledActionThenable &&\n      (currentEntangledActionThenable.status = \"fulfilled\");\n    var listeners = currentEntangledListeners;\n    currentEntangledListeners = null;\n    currentEntangledLane = 0;\n    currentEntangledActionThenable = null;\n    for (var i = 0; i < listeners.length; i++) (0, listeners[i])();\n  }\n}\nfunction chainThenableValue(thenable, result) {\n  var listeners = [],\n    thenableWithOverride = {\n      status: \"pending\",\n      value: null,\n      reason: null,\n      then: function (resolve) {\n        listeners.push(resolve);\n      }\n    };\n  thenable.then(\n    function () {\n      thenableWithOverride.status = \"fulfilled\";\n      thenableWithOverride.value = result;\n      for (var i = 0; i < listeners.length; i++) (0, listeners[i])(result);\n    },\n    function (error) {\n      thenableWithOverride.status = \"rejected\";\n      thenableWithOverride.reason = error;\n      for (error = 0; error < listeners.length; error++)\n        (0, listeners[error])(void 0);\n    }\n  );\n  return thenableWithOverride;\n}\nvar prevOnStartTransitionFinish = ReactSharedInternals.S;\nReactSharedInternals.S = function (transition, returnValue) {\n  \"object\" === typeof returnValue &&\n    null !== returnValue &&\n    \"function\" === typeof returnValue.then &&\n    entangleAsyncAction(transition, returnValue);\n  null !== prevOnStartTransitionFinish &&\n    prevOnStartTransitionFinish(transition, returnValue);\n};\nvar resumedCache = createCursor(null);\nfunction peekCacheFromPool() {\n  var cacheResumedFromPreviousRender = resumedCache.current;\n  return null !== cacheResumedFromPreviousRender\n    ? cacheResumedFromPreviousRender\n    : workInProgressRoot.pooledCache;\n}\nfunction pushTransition(offscreenWorkInProgress, prevCachePool) {\n  null === prevCachePool\n    ? push(resumedCache, resumedCache.current)\n    : push(resumedCache, prevCachePool.pool);\n}\nfunction getSuspendedCache() {\n  var cacheFromPool = peekCacheFromPool();\n  return null === cacheFromPool\n    ? null\n    : { parent: CacheContext._currentValue, pool: cacheFromPool };\n}\nvar renderLanes = 0,\n  currentlyRenderingFiber$1 = null,\n  currentHook = null,\n  workInProgressHook = null,\n  didScheduleRenderPhaseUpdate = !1,\n  didScheduleRenderPhaseUpdateDuringThisPass = !1,\n  shouldDoubleInvokeUserFnsInHooksDEV = !1,\n  localIdCounter = 0,\n  thenableIndexCounter = 0,\n  thenableState = null,\n  globalClientIdCounter = 0;\nfunction throwInvalidHookError() {\n  throw Error(formatProdErrorMessage(321));\n}\nfunction areHookInputsEqual(nextDeps, prevDeps) {\n  if (null === prevDeps) return !1;\n  for (var i = 0; i < prevDeps.length && i < nextDeps.length; i++)\n    if (!objectIs(nextDeps[i], prevDeps[i])) return !1;\n  return !0;\n}\nfunction renderWithHooks(\n  current,\n  workInProgress,\n  Component,\n  props,\n  secondArg,\n  nextRenderLanes\n) {\n  renderLanes = nextRenderLanes;\n  currentlyRenderingFiber$1 = workInProgress;\n  workInProgress.memoizedState = null;\n  workInProgress.updateQueue = null;\n  workInProgress.lanes = 0;\n  ReactSharedInternals.H =\n    null === current || null === current.memoizedState\n      ? HooksDispatcherOnMount\n      : HooksDispatcherOnUpdate;\n  shouldDoubleInvokeUserFnsInHooksDEV = !1;\n  nextRenderLanes = Component(props, secondArg);\n  shouldDoubleInvokeUserFnsInHooksDEV = !1;\n  didScheduleRenderPhaseUpdateDuringThisPass &&\n    (nextRenderLanes = renderWithHooksAgain(\n      workInProgress,\n      Component,\n      props,\n      secondArg\n    ));\n  finishRenderingHooks(current);\n  return nextRenderLanes;\n}\nfunction finishRenderingHooks(current) {\n  ReactSharedInternals.H = ContextOnlyDispatcher;\n  var didRenderTooFewHooks = null !== currentHook && null !== currentHook.next;\n  renderLanes = 0;\n  workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n  didScheduleRenderPhaseUpdate = !1;\n  thenableIndexCounter = 0;\n  thenableState = null;\n  if (didRenderTooFewHooks) throw Error(formatProdErrorMessage(300));\n  null === current ||\n    didReceiveUpdate ||\n    ((current = current.dependencies),\n    null !== current &&\n      checkIfContextChanged(current) &&\n      (didReceiveUpdate = !0));\n}\nfunction renderWithHooksAgain(workInProgress, Component, props, secondArg) {\n  currentlyRenderingFiber$1 = workInProgress;\n  var numberOfReRenders = 0;\n  do {\n    didScheduleRenderPhaseUpdateDuringThisPass && (thenableState = null);\n    thenableIndexCounter = 0;\n    didScheduleRenderPhaseUpdateDuringThisPass = !1;\n    if (25 <= numberOfReRenders) throw Error(formatProdErrorMessage(301));\n    numberOfReRenders += 1;\n    workInProgressHook = currentHook = null;\n    if (null != workInProgress.updateQueue) {\n      var children = workInProgress.updateQueue;\n      children.lastEffect = null;\n      children.events = null;\n      children.stores = null;\n      null != children.memoCache && (children.memoCache.index = 0);\n    }\n    ReactSharedInternals.H = HooksDispatcherOnRerender;\n    children = Component(props, secondArg);\n  } while (didScheduleRenderPhaseUpdateDuringThisPass);\n  return children;\n}\nfunction TransitionAwareHostComponent() {\n  var dispatcher = ReactSharedInternals.H,\n    maybeThenable = dispatcher.useState()[0];\n  maybeThenable =\n    \"function\" === typeof maybeThenable.then\n      ? useThenable(maybeThenable)\n      : maybeThenable;\n  dispatcher = dispatcher.useState()[0];\n  (null !== currentHook ? currentHook.memoizedState : null) !== dispatcher &&\n    (currentlyRenderingFiber$1.flags |= 1024);\n  return maybeThenable;\n}\nfunction checkDidRenderIdHook() {\n  var didRenderIdHook = 0 !== localIdCounter;\n  localIdCounter = 0;\n  return didRenderIdHook;\n}\nfunction bailoutHooks(current, workInProgress, lanes) {\n  workInProgress.updateQueue = current.updateQueue;\n  workInProgress.flags &= -2053;\n  current.lanes &= ~lanes;\n}\nfunction resetHooksOnUnwind(workInProgress) {\n  if (didScheduleRenderPhaseUpdate) {\n    for (\n      workInProgress = workInProgress.memoizedState;\n      null !== workInProgress;\n\n    ) {\n      var queue = workInProgress.queue;\n      null !== queue && (queue.pending = null);\n      workInProgress = workInProgress.next;\n    }\n    didScheduleRenderPhaseUpdate = !1;\n  }\n  renderLanes = 0;\n  workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n  didScheduleRenderPhaseUpdateDuringThisPass = !1;\n  thenableIndexCounter = localIdCounter = 0;\n  thenableState = null;\n}\nfunction mountWorkInProgressHook() {\n  var hook = {\n    memoizedState: null,\n    baseState: null,\n    baseQueue: null,\n    queue: null,\n    next: null\n  };\n  null === workInProgressHook\n    ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook = hook)\n    : (workInProgressHook = workInProgressHook.next = hook);\n  return workInProgressHook;\n}\nfunction updateWorkInProgressHook() {\n  if (null === currentHook) {\n    var nextCurrentHook = currentlyRenderingFiber$1.alternate;\n    nextCurrentHook =\n      null !== nextCurrentHook ? nextCurrentHook.memoizedState : null;\n  } else nextCurrentHook = currentHook.next;\n  var nextWorkInProgressHook =\n    null === workInProgressHook\n      ? currentlyRenderingFiber$1.memoizedState\n      : workInProgressHook.next;\n  if (null !== nextWorkInProgressHook)\n    (workInProgressHook = nextWorkInProgressHook),\n      (currentHook = nextCurrentHook);\n  else {\n    if (null === nextCurrentHook) {\n      if (null === currentlyRenderingFiber$1.alternate)\n        throw Error(formatProdErrorMessage(467));\n      throw Error(formatProdErrorMessage(310));\n    }\n    currentHook = nextCurrentHook;\n    nextCurrentHook = {\n      memoizedState: currentHook.memoizedState,\n      baseState: currentHook.baseState,\n      baseQueue: currentHook.baseQueue,\n      queue: currentHook.queue,\n      next: null\n    };\n    null === workInProgressHook\n      ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook =\n          nextCurrentHook)\n      : (workInProgressHook = workInProgressHook.next = nextCurrentHook);\n  }\n  return workInProgressHook;\n}\nvar createFunctionComponentUpdateQueue;\ncreateFunctionComponentUpdateQueue = function () {\n  return { lastEffect: null, events: null, stores: null, memoCache: null };\n};\nfunction useThenable(thenable) {\n  var index = thenableIndexCounter;\n  thenableIndexCounter += 1;\n  null === thenableState && (thenableState = []);\n  thenable = trackUsedThenable(thenableState, thenable, index);\n  index = currentlyRenderingFiber$1;\n  null ===\n    (null === workInProgressHook\n      ? index.memoizedState\n      : workInProgressHook.next) &&\n    ((index = index.alternate),\n    (ReactSharedInternals.H =\n      null === index || null === index.memoizedState\n        ? HooksDispatcherOnMount\n        : HooksDispatcherOnUpdate));\n  return thenable;\n}\nfunction use(usable) {\n  if (null !== usable && \"object\" === typeof usable) {\n    if (\"function\" === typeof usable.then) return useThenable(usable);\n    if (usable.$$typeof === REACT_CONTEXT_TYPE) return readContext(usable);\n  }\n  throw Error(formatProdErrorMessage(438, String(usable)));\n}\nfunction useMemoCache(size) {\n  var memoCache = null,\n    updateQueue = currentlyRenderingFiber$1.updateQueue;\n  null !== updateQueue && (memoCache = updateQueue.memoCache);\n  if (null == memoCache) {\n    var current = currentlyRenderingFiber$1.alternate;\n    null !== current &&\n      ((current = current.updateQueue),\n      null !== current &&\n        ((current = current.memoCache),\n        null != current &&\n          (memoCache = {\n            data: current.data.map(function (array) {\n              return array.slice();\n            }),\n            index: 0\n          })));\n  }\n  null == memoCache && (memoCache = { data: [], index: 0 });\n  null === updateQueue &&\n    ((updateQueue = createFunctionComponentUpdateQueue()),\n    (currentlyRenderingFiber$1.updateQueue = updateQueue));\n  updateQueue.memoCache = memoCache;\n  updateQueue = memoCache.data[memoCache.index];\n  if (void 0 === updateQueue)\n    for (\n      updateQueue = memoCache.data[memoCache.index] = Array(size), current = 0;\n      current < size;\n      current++\n    )\n      updateQueue[current] = REACT_MEMO_CACHE_SENTINEL;\n  memoCache.index++;\n  return updateQueue;\n}\nfunction basicStateReducer(state, action) {\n  return \"function\" === typeof action ? action(state) : action;\n}\nfunction updateReducer(reducer) {\n  var hook = updateWorkInProgressHook();\n  return updateReducerImpl(hook, currentHook, reducer);\n}\nfunction updateReducerImpl(hook, current, reducer) {\n  var queue = hook.queue;\n  if (null === queue) throw Error(formatProdErrorMessage(311));\n  queue.lastRenderedReducer = reducer;\n  var baseQueue = hook.baseQueue,\n    pendingQueue = queue.pending;\n  if (null !== pendingQueue) {\n    if (null !== baseQueue) {\n      var baseFirst = baseQueue.next;\n      baseQueue.next = pendingQueue.next;\n      pendingQueue.next = baseFirst;\n    }\n    current.baseQueue = baseQueue = pendingQueue;\n    queue.pending = null;\n  }\n  pendingQueue = hook.baseState;\n  if (null === baseQueue) hook.memoizedState = pendingQueue;\n  else {\n    current = baseQueue.next;\n    var newBaseQueueFirst = (baseFirst = null),\n      newBaseQueueLast = null,\n      update = current,\n      didReadFromEntangledAsyncAction$54 = !1;\n    do {\n      var updateLane = update.lane & -536870913;\n      if (\n        updateLane !== update.lane\n          ? (workInProgressRootRenderLanes & updateLane) === updateLane\n          : (renderLanes & updateLane) === updateLane\n      ) {\n        var revertLane = update.revertLane;\n        if (0 === revertLane)\n          null !== newBaseQueueLast &&\n            (newBaseQueueLast = newBaseQueueLast.next =\n              {\n                lane: 0,\n                revertLane: 0,\n                action: update.action,\n                hasEagerState: update.hasEagerState,\n                eagerState: update.eagerState,\n                next: null\n              }),\n            updateLane === currentEntangledLane &&\n              (didReadFromEntangledAsyncAction$54 = !0);\n        else if ((renderLanes & revertLane) === revertLane) {\n          update = update.next;\n          revertLane === currentEntangledLane &&\n            (didReadFromEntangledAsyncAction$54 = !0);\n          continue;\n        } else\n          (updateLane = {\n            lane: 0,\n            revertLane: update.revertLane,\n            action: update.action,\n            hasEagerState: update.hasEagerState,\n            eagerState: update.eagerState,\n            next: null\n          }),\n            null === newBaseQueueLast\n              ? ((newBaseQueueFirst = newBaseQueueLast = updateLane),\n                (baseFirst = pendingQueue))\n              : (newBaseQueueLast = newBaseQueueLast.next = updateLane),\n            (currentlyRenderingFiber$1.lanes |= revertLane),\n            (workInProgressRootSkippedLanes |= revertLane);\n        updateLane = update.action;\n        shouldDoubleInvokeUserFnsInHooksDEV &&\n          reducer(pendingQueue, updateLane);\n        pendingQueue = update.hasEagerState\n          ? update.eagerState\n          : reducer(pendingQueue, updateLane);\n      } else\n        (revertLane = {\n          lane: updateLane,\n          revertLane: update.revertLane,\n          action: update.action,\n          hasEagerState: update.hasEagerState,\n          eagerState: update.eagerState,\n          next: null\n        }),\n          null === newBaseQueueLast\n            ? ((newBaseQueueFirst = newBaseQueueLast = revertLane),\n              (baseFirst = pendingQueue))\n            : (newBaseQueueLast = newBaseQueueLast.next = revertLane),\n          (currentlyRenderingFiber$1.lanes |= updateLane),\n          (workInProgressRootSkippedLanes |= updateLane);\n      update = update.next;\n    } while (null !== update && update !== current);\n    null === newBaseQueueLast\n      ? (baseFirst = pendingQueue)\n      : (newBaseQueueLast.next = newBaseQueueFirst);\n    if (\n      !objectIs(pendingQueue, hook.memoizedState) &&\n      ((didReceiveUpdate = !0),\n      didReadFromEntangledAsyncAction$54 &&\n        ((reducer = currentEntangledActionThenable), null !== reducer))\n    )\n      throw reducer;\n    hook.memoizedState = pendingQueue;\n    hook.baseState = baseFirst;\n    hook.baseQueue = newBaseQueueLast;\n    queue.lastRenderedState = pendingQueue;\n  }\n  null === baseQueue && (queue.lanes = 0);\n  return [hook.memoizedState, queue.dispatch];\n}\nfunction rerenderReducer(reducer) {\n  var hook = updateWorkInProgressHook(),\n    queue = hook.queue;\n  if (null === queue) throw Error(formatProdErrorMessage(311));\n  queue.lastRenderedReducer = reducer;\n  var dispatch = queue.dispatch,\n    lastRenderPhaseUpdate = queue.pending,\n    newState = hook.memoizedState;\n  if (null !== lastRenderPhaseUpdate) {\n    queue.pending = null;\n    var update = (lastRenderPhaseUpdate = lastRenderPhaseUpdate.next);\n    do (newState = reducer(newState, update.action)), (update = update.next);\n    while (update !== lastRenderPhaseUpdate);\n    objectIs(newState, hook.memoizedState) || (didReceiveUpdate = !0);\n    hook.memoizedState = newState;\n    null === hook.baseQueue && (hook.baseState = newState);\n    queue.lastRenderedState = newState;\n  }\n  return [newState, dispatch];\n}\nfunction updateSyncExternalStore(subscribe, getSnapshot, getServerSnapshot) {\n  var fiber = currentlyRenderingFiber$1,\n    hook = updateWorkInProgressHook(),\n    isHydrating$jscomp$0 = isHydrating;\n  if (isHydrating$jscomp$0) {\n    if (void 0 === getServerSnapshot) throw Error(formatProdErrorMessage(407));\n    getServerSnapshot = getServerSnapshot();\n  } else getServerSnapshot = getSnapshot();\n  var snapshotChanged = !objectIs(\n    (currentHook || hook).memoizedState,\n    getServerSnapshot\n  );\n  snapshotChanged &&\n    ((hook.memoizedState = getServerSnapshot), (didReceiveUpdate = !0));\n  hook = hook.queue;\n  updateEffect(subscribeToStore.bind(null, fiber, hook, subscribe), [\n    subscribe\n  ]);\n  if (\n    hook.getSnapshot !== getSnapshot ||\n    snapshotChanged ||\n    (null !== workInProgressHook && workInProgressHook.memoizedState.tag & 1)\n  ) {\n    fiber.flags |= 2048;\n    pushEffect(\n      9,\n      updateStoreInstance.bind(\n        null,\n        fiber,\n        hook,\n        getServerSnapshot,\n        getSnapshot\n      ),\n      { destroy: void 0 },\n      null\n    );\n    if (null === workInProgressRoot) throw Error(formatProdErrorMessage(349));\n    isHydrating$jscomp$0 ||\n      0 !== (renderLanes & 60) ||\n      pushStoreConsistencyCheck(fiber, getSnapshot, getServerSnapshot);\n  }\n  return getServerSnapshot;\n}\nfunction pushStoreConsistencyCheck(fiber, getSnapshot, renderedSnapshot) {\n  fiber.flags |= 16384;\n  fiber = { getSnapshot: getSnapshot, value: renderedSnapshot };\n  getSnapshot = currentlyRenderingFiber$1.updateQueue;\n  null === getSnapshot\n    ? ((getSnapshot = createFunctionComponentUpdateQueue()),\n      (currentlyRenderingFiber$1.updateQueue = getSnapshot),\n      (getSnapshot.stores = [fiber]))\n    : ((renderedSnapshot = getSnapshot.stores),\n      null === renderedSnapshot\n        ? (getSnapshot.stores = [fiber])\n        : renderedSnapshot.push(fiber));\n}\nfunction updateStoreInstance(fiber, inst, nextSnapshot, getSnapshot) {\n  inst.value = nextSnapshot;\n  inst.getSnapshot = getSnapshot;\n  checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n}\nfunction subscribeToStore(fiber, inst, subscribe) {\n  return subscribe(function () {\n    checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n  });\n}\nfunction checkIfSnapshotChanged(inst) {\n  var latestGetSnapshot = inst.getSnapshot;\n  inst = inst.value;\n  try {\n    var nextValue = latestGetSnapshot();\n    return !objectIs(inst, nextValue);\n  } catch (error) {\n    return !0;\n  }\n}\nfunction forceStoreRerender(fiber) {\n  var root = enqueueConcurrentRenderForLane(fiber, 2);\n  null !== root && scheduleUpdateOnFiber(root, fiber, 2);\n}\nfunction mountStateImpl(initialState) {\n  var hook = mountWorkInProgressHook();\n  if (\"function\" === typeof initialState) {\n    var initialStateInitializer = initialState;\n    initialState = initialStateInitializer();\n    if (shouldDoubleInvokeUserFnsInHooksDEV) {\n      setIsStrictModeForDevtools(!0);\n      try {\n        initialStateInitializer();\n      } finally {\n        setIsStrictModeForDevtools(!1);\n      }\n    }\n  }\n  hook.memoizedState = hook.baseState = initialState;\n  hook.queue = {\n    pending: null,\n    lanes: 0,\n    dispatch: null,\n    lastRenderedReducer: basicStateReducer,\n    lastRenderedState: initialState\n  };\n  return hook;\n}\nfunction updateOptimisticImpl(hook, current, passthrough, reducer) {\n  hook.baseState = passthrough;\n  return updateReducerImpl(\n    hook,\n    currentHook,\n    \"function\" === typeof reducer ? reducer : basicStateReducer\n  );\n}\nfunction dispatchActionState(\n  fiber,\n  actionQueue,\n  setPendingState,\n  setState,\n  payload\n) {\n  if (isRenderPhaseUpdate(fiber)) throw Error(formatProdErrorMessage(485));\n  fiber = actionQueue.action;\n  if (null !== fiber) {\n    var actionNode = {\n      payload: payload,\n      action: fiber,\n      next: null,\n      isTransition: !0,\n      status: \"pending\",\n      value: null,\n      reason: null,\n      listeners: [],\n      then: function (listener) {\n        actionNode.listeners.push(listener);\n      }\n    };\n    null !== ReactSharedInternals.T\n      ? setPendingState(!0)\n      : (actionNode.isTransition = !1);\n    setState(actionNode);\n    setPendingState = actionQueue.pending;\n    null === setPendingState\n      ? ((actionNode.next = actionQueue.pending = actionNode),\n        runActionStateAction(actionQueue, actionNode))\n      : ((actionNode.next = setPendingState.next),\n        (actionQueue.pending = setPendingState.next = actionNode));\n  }\n}\nfunction runActionStateAction(actionQueue, node) {\n  var action = node.action,\n    payload = node.payload,\n    prevState = actionQueue.state;\n  if (node.isTransition) {\n    var prevTransition = ReactSharedInternals.T,\n      currentTransition = {};\n    ReactSharedInternals.T = currentTransition;\n    try {\n      var returnValue = action(prevState, payload),\n        onStartTransitionFinish = ReactSharedInternals.S;\n      null !== onStartTransitionFinish &&\n        onStartTransitionFinish(currentTransition, returnValue);\n      handleActionReturnValue(actionQueue, node, returnValue);\n    } catch (error) {\n      onActionError(actionQueue, node, error);\n    } finally {\n      ReactSharedInternals.T = prevTransition;\n    }\n  } else\n    try {\n      (prevTransition = action(prevState, payload)),\n        handleActionReturnValue(actionQueue, node, prevTransition);\n    } catch (error$60) {\n      onActionError(actionQueue, node, error$60);\n    }\n}\nfunction handleActionReturnValue(actionQueue, node, returnValue) {\n  null !== returnValue &&\n  \"object\" === typeof returnValue &&\n  \"function\" === typeof returnValue.then\n    ? returnValue.then(\n        function (nextState) {\n          onActionSuccess(actionQueue, node, nextState);\n        },\n        function (error) {\n          return onActionError(actionQueue, node, error);\n        }\n      )\n    : onActionSuccess(actionQueue, node, returnValue);\n}\nfunction onActionSuccess(actionQueue, actionNode, nextState) {\n  actionNode.status = \"fulfilled\";\n  actionNode.value = nextState;\n  notifyActionListeners(actionNode);\n  actionQueue.state = nextState;\n  actionNode = actionQueue.pending;\n  null !== actionNode &&\n    ((nextState = actionNode.next),\n    nextState === actionNode\n      ? (actionQueue.pending = null)\n      : ((nextState = nextState.next),\n        (actionNode.next = nextState),\n        runActionStateAction(actionQueue, nextState)));\n}\nfunction onActionError(actionQueue, actionNode, error) {\n  var last = actionQueue.pending;\n  actionQueue.pending = null;\n  if (null !== last) {\n    last = last.next;\n    do\n      (actionNode.status = \"rejected\"),\n        (actionNode.reason = error),\n        notifyActionListeners(actionNode),\n        (actionNode = actionNode.next);\n    while (actionNode !== last);\n  }\n  actionQueue.action = null;\n}\nfunction notifyActionListeners(actionNode) {\n  actionNode = actionNode.listeners;\n  for (var i = 0; i < actionNode.length; i++) (0, actionNode[i])();\n}\nfunction actionStateReducer(oldState, newState) {\n  return newState;\n}\nfunction mountActionState(action, initialStateProp) {\n  if (isHydrating) {\n    var ssrFormState = workInProgressRoot.formState;\n    if (null !== ssrFormState) {\n      a: {\n        var JSCompiler_inline_result = currentlyRenderingFiber$1;\n        if (isHydrating) {\n          if (nextHydratableInstance) {\n            b: {\n              var JSCompiler_inline_result$jscomp$0 = nextHydratableInstance;\n              for (\n                var inRootOrSingleton = rootOrSingletonContext;\n                8 !== JSCompiler_inline_result$jscomp$0.nodeType;\n\n              ) {\n                if (!inRootOrSingleton) {\n                  JSCompiler_inline_result$jscomp$0 = null;\n                  break b;\n                }\n                JSCompiler_inline_result$jscomp$0 = getNextHydratable(\n                  JSCompiler_inline_result$jscomp$0.nextSibling\n                );\n                if (null === JSCompiler_inline_result$jscomp$0) {\n                  JSCompiler_inline_result$jscomp$0 = null;\n                  break b;\n                }\n              }\n              inRootOrSingleton = JSCompiler_inline_result$jscomp$0.data;\n              JSCompiler_inline_result$jscomp$0 =\n                \"F!\" === inRootOrSingleton || \"F\" === inRootOrSingleton\n                  ? JSCompiler_inline_result$jscomp$0\n                  : null;\n            }\n            if (JSCompiler_inline_result$jscomp$0) {\n              nextHydratableInstance = getNextHydratable(\n                JSCompiler_inline_result$jscomp$0.nextSibling\n              );\n              JSCompiler_inline_result =\n                \"F!\" === JSCompiler_inline_result$jscomp$0.data;\n              break a;\n            }\n          }\n          throwOnHydrationMismatch(JSCompiler_inline_result);\n        }\n        JSCompiler_inline_result = !1;\n      }\n      JSCompiler_inline_result && (initialStateProp = ssrFormState[0]);\n    }\n  }\n  ssrFormState = mountWorkInProgressHook();\n  ssrFormState.memoizedState = ssrFormState.baseState = initialStateProp;\n  JSCompiler_inline_result = {\n    pending: null,\n    lanes: 0,\n    dispatch: null,\n    lastRenderedReducer: actionStateReducer,\n    lastRenderedState: initialStateProp\n  };\n  ssrFormState.queue = JSCompiler_inline_result;\n  ssrFormState = dispatchSetState.bind(\n    null,\n    currentlyRenderingFiber$1,\n    JSCompiler_inline_result\n  );\n  JSCompiler_inline_result.dispatch = ssrFormState;\n  JSCompiler_inline_result = mountStateImpl(!1);\n  inRootOrSingleton = dispatchOptimisticSetState.bind(\n    null,\n    currentlyRenderingFiber$1,\n    !1,\n    JSCompiler_inline_result.queue\n  );\n  JSCompiler_inline_result = mountWorkInProgressHook();\n  JSCompiler_inline_result$jscomp$0 = {\n    state: initialStateProp,\n    dispatch: null,\n    action: action,\n    pending: null\n  };\n  JSCompiler_inline_result.queue = JSCompiler_inline_result$jscomp$0;\n  ssrFormState = dispatchActionState.bind(\n    null,\n    currentlyRenderingFiber$1,\n    JSCompiler_inline_result$jscomp$0,\n    inRootOrSingleton,\n    ssrFormState\n  );\n  JSCompiler_inline_result$jscomp$0.dispatch = ssrFormState;\n  JSCompiler_inline_result.memoizedState = action;\n  return [initialStateProp, ssrFormState, !1];\n}\nfunction updateActionState(action) {\n  var stateHook = updateWorkInProgressHook();\n  return updateActionStateImpl(stateHook, currentHook, action);\n}\nfunction updateActionStateImpl(stateHook, currentStateHook, action) {\n  currentStateHook = updateReducerImpl(\n    stateHook,\n    currentStateHook,\n    actionStateReducer\n  )[0];\n  stateHook = updateReducer(basicStateReducer)[0];\n  currentStateHook =\n    \"object\" === typeof currentStateHook &&\n    null !== currentStateHook &&\n    \"function\" === typeof currentStateHook.then\n      ? useThenable(currentStateHook)\n      : currentStateHook;\n  var actionQueueHook = updateWorkInProgressHook(),\n    actionQueue = actionQueueHook.queue,\n    dispatch = actionQueue.dispatch;\n  action !== actionQueueHook.memoizedState &&\n    ((currentlyRenderingFiber$1.flags |= 2048),\n    pushEffect(\n      9,\n      actionStateActionEffect.bind(null, actionQueue, action),\n      { destroy: void 0 },\n      null\n    ));\n  return [currentStateHook, dispatch, stateHook];\n}\nfunction actionStateActionEffect(actionQueue, action) {\n  actionQueue.action = action;\n}\nfunction rerenderActionState(action) {\n  var stateHook = updateWorkInProgressHook(),\n    currentStateHook = currentHook;\n  if (null !== currentStateHook)\n    return updateActionStateImpl(stateHook, currentStateHook, action);\n  updateWorkInProgressHook();\n  stateHook = stateHook.memoizedState;\n  currentStateHook = updateWorkInProgressHook();\n  var dispatch = currentStateHook.queue.dispatch;\n  currentStateHook.memoizedState = action;\n  return [stateHook, dispatch, !1];\n}\nfunction pushEffect(tag, create, inst, deps) {\n  tag = { tag: tag, create: create, inst: inst, deps: deps, next: null };\n  create = currentlyRenderingFiber$1.updateQueue;\n  null === create &&\n    ((create = createFunctionComponentUpdateQueue()),\n    (currentlyRenderingFiber$1.updateQueue = create));\n  inst = create.lastEffect;\n  null === inst\n    ? (create.lastEffect = tag.next = tag)\n    : ((deps = inst.next),\n      (inst.next = tag),\n      (tag.next = deps),\n      (create.lastEffect = tag));\n  return tag;\n}\nfunction updateRef() {\n  return updateWorkInProgressHook().memoizedState;\n}\nfunction mountEffectImpl(fiberFlags, hookFlags, create, deps) {\n  var hook = mountWorkInProgressHook();\n  currentlyRenderingFiber$1.flags |= fiberFlags;\n  hook.memoizedState = pushEffect(\n    1 | hookFlags,\n    create,\n    { destroy: void 0 },\n    void 0 === deps ? null : deps\n  );\n}\nfunction updateEffectImpl(fiberFlags, hookFlags, create, deps) {\n  var hook = updateWorkInProgressHook();\n  deps = void 0 === deps ? null : deps;\n  var inst = hook.memoizedState.inst;\n  null !== currentHook &&\n  null !== deps &&\n  areHookInputsEqual(deps, currentHook.memoizedState.deps)\n    ? (hook.memoizedState = pushEffect(hookFlags, create, inst, deps))\n    : ((currentlyRenderingFiber$1.flags |= fiberFlags),\n      (hook.memoizedState = pushEffect(1 | hookFlags, create, inst, deps)));\n}\nfunction mountEffect(create, deps) {\n  mountEffectImpl(8390656, 8, create, deps);\n}\nfunction updateEffect(create, deps) {\n  updateEffectImpl(2048, 8, create, deps);\n}\nfunction updateInsertionEffect(create, deps) {\n  return updateEffectImpl(4, 2, create, deps);\n}\nfunction updateLayoutEffect(create, deps) {\n  return updateEffectImpl(4, 4, create, deps);\n}\nfunction imperativeHandleEffect(create, ref) {\n  if (\"function\" === typeof ref) {\n    create = create();\n    var refCleanup = ref(create);\n    return function () {\n      \"function\" === typeof refCleanup ? refCleanup() : ref(null);\n    };\n  }\n  if (null !== ref && void 0 !== ref)\n    return (\n      (create = create()),\n      (ref.current = create),\n      function () {\n        ref.current = null;\n      }\n    );\n}\nfunction updateImperativeHandle(ref, create, deps) {\n  deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n  updateEffectImpl(4, 4, imperativeHandleEffect.bind(null, create, ref), deps);\n}\nfunction mountDebugValue() {}\nfunction updateCallback(callback, deps) {\n  var hook = updateWorkInProgressHook();\n  deps = void 0 === deps ? null : deps;\n  var prevState = hook.memoizedState;\n  if (null !== deps && areHookInputsEqual(deps, prevState[1]))\n    return prevState[0];\n  hook.memoizedState = [callback, deps];\n  return callback;\n}\nfunction updateMemo(nextCreate, deps) {\n  var hook = updateWorkInProgressHook();\n  deps = void 0 === deps ? null : deps;\n  var prevState = hook.memoizedState;\n  if (null !== deps && areHookInputsEqual(deps, prevState[1]))\n    return prevState[0];\n  prevState = nextCreate();\n  if (shouldDoubleInvokeUserFnsInHooksDEV) {\n    setIsStrictModeForDevtools(!0);\n    try {\n      nextCreate();\n    } finally {\n      setIsStrictModeForDevtools(!1);\n    }\n  }\n  hook.memoizedState = [prevState, deps];\n  return prevState;\n}\nfunction mountDeferredValueImpl(hook, value, initialValue) {\n  if (void 0 === initialValue || 0 !== (renderLanes & 1073741824))\n    return (hook.memoizedState = value);\n  hook.memoizedState = initialValue;\n  hook = requestDeferredLane();\n  currentlyRenderingFiber$1.lanes |= hook;\n  workInProgressRootSkippedLanes |= hook;\n  return initialValue;\n}\nfunction updateDeferredValueImpl(hook, prevValue, value, initialValue) {\n  if (objectIs(value, prevValue)) return value;\n  if (null !== currentTreeHiddenStackCursor.current)\n    return (\n      (hook = mountDeferredValueImpl(hook, value, initialValue)),\n      objectIs(hook, prevValue) || (didReceiveUpdate = !0),\n      hook\n    );\n  if (0 === (renderLanes & 42))\n    return (didReceiveUpdate = !0), (hook.memoizedState = value);\n  hook = requestDeferredLane();\n  currentlyRenderingFiber$1.lanes |= hook;\n  workInProgressRootSkippedLanes |= hook;\n  return prevValue;\n}\nfunction startTransition(fiber, queue, pendingState, finishedState, callback) {\n  var previousPriority = ReactDOMSharedInternals.p;\n  ReactDOMSharedInternals.p =\n    0 !== previousPriority && 8 > previousPriority ? previousPriority : 8;\n  var prevTransition = ReactSharedInternals.T,\n    currentTransition = {};\n  ReactSharedInternals.T = currentTransition;\n  dispatchOptimisticSetState(fiber, !1, queue, pendingState);\n  try {\n    var returnValue = callback(),\n      onStartTransitionFinish = ReactSharedInternals.S;\n    null !== onStartTransitionFinish &&\n      onStartTransitionFinish(currentTransition, returnValue);\n    if (\n      null !== returnValue &&\n      \"object\" === typeof returnValue &&\n      \"function\" === typeof returnValue.then\n    ) {\n      var thenableForFinishedState = chainThenableValue(\n        returnValue,\n        finishedState\n      );\n      dispatchSetStateInternal(\n        fiber,\n        queue,\n        thenableForFinishedState,\n        requestUpdateLane(fiber)\n      );\n    } else\n      dispatchSetStateInternal(\n        fiber,\n        queue,\n        finishedState,\n        requestUpdateLane(fiber)\n      );\n  } catch (error) {\n    dispatchSetStateInternal(\n      fiber,\n      queue,\n      { then: function () {}, status: \"rejected\", reason: error },\n      requestUpdateLane()\n    );\n  } finally {\n    (ReactDOMSharedInternals.p = previousPriority),\n      (ReactSharedInternals.T = prevTransition);\n  }\n}\nfunction noop$2() {}\nfunction startHostTransition(formFiber, pendingState, action, formData) {\n  if (5 !== formFiber.tag) throw Error(formatProdErrorMessage(476));\n  var queue = ensureFormComponentIsStateful(formFiber).queue;\n  startTransition(\n    formFiber,\n    queue,\n    pendingState,\n    sharedNotPendingObject,\n    null === action\n      ? noop$2\n      : function () {\n          requestFormReset$1(formFiber);\n          return action(formData);\n        }\n  );\n}\nfunction ensureFormComponentIsStateful(formFiber) {\n  var existingStateHook = formFiber.memoizedState;\n  if (null !== existingStateHook) return existingStateHook;\n  existingStateHook = {\n    memoizedState: sharedNotPendingObject,\n    baseState: sharedNotPendingObject,\n    baseQueue: null,\n    queue: {\n      pending: null,\n      lanes: 0,\n      dispatch: null,\n      lastRenderedReducer: basicStateReducer,\n      lastRenderedState: sharedNotPendingObject\n    },\n    next: null\n  };\n  var initialResetState = {};\n  existingStateHook.next = {\n    memoizedState: initialResetState,\n    baseState: initialResetState,\n    baseQueue: null,\n    queue: {\n      pending: null,\n      lanes: 0,\n      dispatch: null,\n      lastRenderedReducer: basicStateReducer,\n      lastRenderedState: initialResetState\n    },\n    next: null\n  };\n  formFiber.memoizedState = existingStateHook;\n  formFiber = formFiber.alternate;\n  null !== formFiber && (formFiber.memoizedState = existingStateHook);\n  return existingStateHook;\n}\nfunction requestFormReset$1(formFiber) {\n  var resetStateQueue = ensureFormComponentIsStateful(formFiber).next.queue;\n  dispatchSetStateInternal(formFiber, resetStateQueue, {}, requestUpdateLane());\n}\nfunction useHostTransitionStatus() {\n  return readContext(HostTransitionContext);\n}\nfunction updateId() {\n  return updateWorkInProgressHook().memoizedState;\n}\nfunction updateRefresh() {\n  return updateWorkInProgressHook().memoizedState;\n}\nfunction refreshCache(fiber) {\n  for (var provider = fiber.return; null !== provider; ) {\n    switch (provider.tag) {\n      case 24:\n      case 3:\n        var lane = requestUpdateLane();\n        fiber = createUpdate(lane);\n        var root$63 = enqueueUpdate(provider, fiber, lane);\n        null !== root$63 &&\n          (scheduleUpdateOnFiber(root$63, provider, lane),\n          entangleTransitions(root$63, provider, lane));\n        provider = { cache: createCache() };\n        fiber.payload = provider;\n        return;\n    }\n    provider = provider.return;\n  }\n}\nfunction dispatchReducerAction(fiber, queue, action) {\n  var lane = requestUpdateLane();\n  action = {\n    lane: lane,\n    revertLane: 0,\n    action: action,\n    hasEagerState: !1,\n    eagerState: null,\n    next: null\n  };\n  isRenderPhaseUpdate(fiber)\n    ? enqueueRenderPhaseUpdate(queue, action)\n    : ((action = enqueueConcurrentHookUpdate(fiber, queue, action, lane)),\n      null !== action &&\n        (scheduleUpdateOnFiber(action, fiber, lane),\n        entangleTransitionUpdate(action, queue, lane)));\n}\nfunction dispatchSetState(fiber, queue, action) {\n  var lane = requestUpdateLane();\n  dispatchSetStateInternal(fiber, queue, action, lane);\n}\nfunction dispatchSetStateInternal(fiber, queue, action, lane) {\n  var update = {\n    lane: lane,\n    revertLane: 0,\n    action: action,\n    hasEagerState: !1,\n    eagerState: null,\n    next: null\n  };\n  if (isRenderPhaseUpdate(fiber)) enqueueRenderPhaseUpdate(queue, update);\n  else {\n    var alternate = fiber.alternate;\n    if (\n      0 === fiber.lanes &&\n      (null === alternate || 0 === alternate.lanes) &&\n      ((alternate = queue.lastRenderedReducer), null !== alternate)\n    )\n      try {\n        var currentState = queue.lastRenderedState,\n          eagerState = alternate(currentState, action);\n        update.hasEagerState = !0;\n        update.eagerState = eagerState;\n        if (objectIs(eagerState, currentState))\n          return (\n            enqueueUpdate$1(fiber, queue, update, 0),\n            null === workInProgressRoot && finishQueueingConcurrentUpdates(),\n            !1\n          );\n      } catch (error) {\n      } finally {\n      }\n    action = enqueueConcurrentHookUpdate(fiber, queue, update, lane);\n    if (null !== action)\n      return (\n        scheduleUpdateOnFiber(action, fiber, lane),\n        entangleTransitionUpdate(action, queue, lane),\n        !0\n      );\n  }\n  return !1;\n}\nfunction dispatchOptimisticSetState(fiber, throwIfDuringRender, queue, action) {\n  action = {\n    lane: 2,\n    revertLane: requestTransitionLane(),\n    action: action,\n    hasEagerState: !1,\n    eagerState: null,\n    next: null\n  };\n  if (isRenderPhaseUpdate(fiber)) {\n    if (throwIfDuringRender) throw Error(formatProdErrorMessage(479));\n  } else\n    (throwIfDuringRender = enqueueConcurrentHookUpdate(\n      fiber,\n      queue,\n      action,\n      2\n    )),\n      null !== throwIfDuringRender &&\n        scheduleUpdateOnFiber(throwIfDuringRender, fiber, 2);\n}\nfunction isRenderPhaseUpdate(fiber) {\n  var alternate = fiber.alternate;\n  return (\n    fiber === currentlyRenderingFiber$1 ||\n    (null !== alternate && alternate === currentlyRenderingFiber$1)\n  );\n}\nfunction enqueueRenderPhaseUpdate(queue, update) {\n  didScheduleRenderPhaseUpdateDuringThisPass = didScheduleRenderPhaseUpdate =\n    !0;\n  var pending = queue.pending;\n  null === pending\n    ? (update.next = update)\n    : ((update.next = pending.next), (pending.next = update));\n  queue.pending = update;\n}\nfunction entangleTransitionUpdate(root, queue, lane) {\n  if (0 !== (lane & 4194176)) {\n    var queueLanes = queue.lanes;\n    queueLanes &= root.pendingLanes;\n    lane |= queueLanes;\n    queue.lanes = lane;\n    markRootEntangled(root, lane);\n  }\n}\nvar ContextOnlyDispatcher = {\n  readContext: readContext,\n  use: use,\n  useCallback: throwInvalidHookError,\n  useContext: throwInvalidHookError,\n  useEffect: throwInvalidHookError,\n  useImperativeHandle: throwInvalidHookError,\n  useLayoutEffect: throwInvalidHookError,\n  useInsertionEffect: throwInvalidHookError,\n  useMemo: throwInvalidHookError,\n  useReducer: throwInvalidHookError,\n  useRef: throwInvalidHookError,\n  useState: throwInvalidHookError,\n  useDebugValue: throwInvalidHookError,\n  useDeferredValue: throwInvalidHookError,\n  useTransition: throwInvalidHookError,\n  useSyncExternalStore: throwInvalidHookError,\n  useId: throwInvalidHookError\n};\nContextOnlyDispatcher.useCacheRefresh = throwInvalidHookError;\nContextOnlyDispatcher.useMemoCache = throwInvalidHookError;\nContextOnlyDispatcher.useHostTransitionStatus = throwInvalidHookError;\nContextOnlyDispatcher.useFormState = throwInvalidHookError;\nContextOnlyDispatcher.useActionState = throwInvalidHookError;\nContextOnlyDispatcher.useOptimistic = throwInvalidHookError;\nvar HooksDispatcherOnMount = {\n  readContext: readContext,\n  use: use,\n  useCallback: function (callback, deps) {\n    mountWorkInProgressHook().memoizedState = [\n      callback,\n      void 0 === deps ? null : deps\n    ];\n    return callback;\n  },\n  useContext: readContext,\n  useEffect: mountEffect,\n  useImperativeHandle: function (ref, create, deps) {\n    deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n    mountEffectImpl(\n      4194308,\n      4,\n      imperativeHandleEffect.bind(null, create, ref),\n      deps\n    );\n  },\n  useLayoutEffect: function (create, deps) {\n    return mountEffectImpl(4194308, 4, create, deps);\n  },\n  useInsertionEffect: function (create, deps) {\n    mountEffectImpl(4, 2, create, deps);\n  },\n  useMemo: function (nextCreate, deps) {\n    var hook = mountWorkInProgressHook();\n    deps = void 0 === deps ? null : deps;\n    var nextValue = nextCreate();\n    if (shouldDoubleInvokeUserFnsInHooksDEV) {\n      setIsStrictModeForDevtools(!0);\n      try {\n        nextCreate();\n      } finally {\n        setIsStrictModeForDevtools(!1);\n      }\n    }\n    hook.memoizedState = [nextValue, deps];\n    return nextValue;\n  },\n  useReducer: function (reducer, initialArg, init) {\n    var hook = mountWorkInProgressHook();\n    if (void 0 !== init) {\n      var initialState = init(initialArg);\n      if (shouldDoubleInvokeUserFnsInHooksDEV) {\n        setIsStrictModeForDevtools(!0);\n        try {\n          init(initialArg);\n        } finally {\n          setIsStrictModeForDevtools(!1);\n        }\n      }\n    } else initialState = initialArg;\n    hook.memoizedState = hook.baseState = initialState;\n    reducer = {\n      pending: null,\n      lanes: 0,\n      dispatch: null,\n      lastRenderedReducer: reducer,\n      lastRenderedState: initialState\n    };\n    hook.queue = reducer;\n    reducer = reducer.dispatch = dispatchReducerAction.bind(\n      null,\n      currentlyRenderingFiber$1,\n      reducer\n    );\n    return [hook.memoizedState, reducer];\n  },\n  useRef: function (initialValue) {\n    var hook = mountWorkInProgressHook();\n    initialValue = { current: initialValue };\n    return (hook.memoizedState = initialValue);\n  },\n  useState: function (initialState) {\n    initialState = mountStateImpl(initialState);\n    var queue = initialState.queue,\n      dispatch = dispatchSetState.bind(null, currentlyRenderingFiber$1, queue);\n    queue.dispatch = dispatch;\n    return [initialState.memoizedState, dispatch];\n  },\n  useDebugValue: mountDebugValue,\n  useDeferredValue: function (value, initialValue) {\n    var hook = mountWorkInProgressHook();\n    return mountDeferredValueImpl(hook, value, initialValue);\n  },\n  useTransition: function () {\n    var stateHook = mountStateImpl(!1);\n    stateHook = startTransition.bind(\n      null,\n      currentlyRenderingFiber$1,\n      stateHook.queue,\n      !0,\n      !1\n    );\n    mountWorkInProgressHook().memoizedState = stateHook;\n    return [!1, stateHook];\n  },\n  useSyncExternalStore: function (subscribe, getSnapshot, getServerSnapshot) {\n    var fiber = currentlyRenderingFiber$1,\n      hook = mountWorkInProgressHook();\n    if (isHydrating) {\n      if (void 0 === getServerSnapshot)\n        throw Error(formatProdErrorMessage(407));\n      getServerSnapshot = getServerSnapshot();\n    } else {\n      getServerSnapshot = getSnapshot();\n      if (null === workInProgressRoot) throw Error(formatProdErrorMessage(349));\n      0 !== (workInProgressRootRenderLanes & 60) ||\n        pushStoreConsistencyCheck(fiber, getSnapshot, getServerSnapshot);\n    }\n    hook.memoizedState = getServerSnapshot;\n    var inst = { value: getServerSnapshot, getSnapshot: getSnapshot };\n    hook.queue = inst;\n    mountEffect(subscribeToStore.bind(null, fiber, inst, subscribe), [\n      subscribe\n    ]);\n    fiber.flags |= 2048;\n    pushEffect(\n      9,\n      updateStoreInstance.bind(\n        null,\n        fiber,\n        inst,\n        getServerSnapshot,\n        getSnapshot\n      ),\n      { destroy: void 0 },\n      null\n    );\n    return getServerSnapshot;\n  },\n  useId: function () {\n    var hook = mountWorkInProgressHook(),\n      identifierPrefix = workInProgressRoot.identifierPrefix;\n    if (isHydrating) {\n      var JSCompiler_inline_result = treeContextOverflow;\n      var idWithLeadingBit = treeContextId;\n      JSCompiler_inline_result =\n        (\n          idWithLeadingBit & ~(1 << (32 - clz32(idWithLeadingBit) - 1))\n        ).toString(32) + JSCompiler_inline_result;\n      identifierPrefix =\n        \":\" + identifierPrefix + \"R\" + JSCompiler_inline_result;\n      JSCompiler_inline_result = localIdCounter++;\n      0 < JSCompiler_inline_result &&\n        (identifierPrefix += \"H\" + JSCompiler_inline_result.toString(32));\n      identifierPrefix += \":\";\n    } else\n      (JSCompiler_inline_result = globalClientIdCounter++),\n        (identifierPrefix =\n          \":\" +\n          identifierPrefix +\n          \"r\" +\n          JSCompiler_inline_result.toString(32) +\n          \":\");\n    return (hook.memoizedState = identifierPrefix);\n  },\n  useCacheRefresh: function () {\n    return (mountWorkInProgressHook().memoizedState = refreshCache.bind(\n      null,\n      currentlyRenderingFiber$1\n    ));\n  }\n};\nHooksDispatcherOnMount.useMemoCache = useMemoCache;\nHooksDispatcherOnMount.useHostTransitionStatus = useHostTransitionStatus;\nHooksDispatcherOnMount.useFormState = mountActionState;\nHooksDispatcherOnMount.useActionState = mountActionState;\nHooksDispatcherOnMount.useOptimistic = function (passthrough) {\n  var hook = mountWorkInProgressHook();\n  hook.memoizedState = hook.baseState = passthrough;\n  var queue = {\n    pending: null,\n    lanes: 0,\n    dispatch: null,\n    lastRenderedReducer: null,\n    lastRenderedState: null\n  };\n  hook.queue = queue;\n  hook = dispatchOptimisticSetState.bind(\n    null,\n    currentlyRenderingFiber$1,\n    !0,\n    queue\n  );\n  queue.dispatch = hook;\n  return [passthrough, hook];\n};\nvar HooksDispatcherOnUpdate = {\n  readContext: readContext,\n  use: use,\n  useCallback: updateCallback,\n  useContext: readContext,\n  useEffect: updateEffect,\n  useImperativeHandle: updateImperativeHandle,\n  useInsertionEffect: updateInsertionEffect,\n  useLayoutEffect: updateLayoutEffect,\n  useMemo: updateMemo,\n  useReducer: updateReducer,\n  useRef: updateRef,\n  useState: function () {\n    return updateReducer(basicStateReducer);\n  },\n  useDebugValue: mountDebugValue,\n  useDeferredValue: function (value, initialValue) {\n    var hook = updateWorkInProgressHook();\n    return updateDeferredValueImpl(\n      hook,\n      currentHook.memoizedState,\n      value,\n      initialValue\n    );\n  },\n  useTransition: function () {\n    var booleanOrThenable = updateReducer(basicStateReducer)[0],\n      start = updateWorkInProgressHook().memoizedState;\n    return [\n      \"boolean\" === typeof booleanOrThenable\n        ? booleanOrThenable\n        : useThenable(booleanOrThenable),\n      start\n    ];\n  },\n  useSyncExternalStore: updateSyncExternalStore,\n  useId: updateId\n};\nHooksDispatcherOnUpdate.useCacheRefresh = updateRefresh;\nHooksDispatcherOnUpdate.useMemoCache = useMemoCache;\nHooksDispatcherOnUpdate.useHostTransitionStatus = useHostTransitionStatus;\nHooksDispatcherOnUpdate.useFormState = updateActionState;\nHooksDispatcherOnUpdate.useActionState = updateActionState;\nHooksDispatcherOnUpdate.useOptimistic = function (passthrough, reducer) {\n  var hook = updateWorkInProgressHook();\n  return updateOptimisticImpl(hook, currentHook, passthrough, reducer);\n};\nvar HooksDispatcherOnRerender = {\n  readContext: readContext,\n  use: use,\n  useCallback: updateCallback,\n  useContext: readContext,\n  useEffect: updateEffect,\n  useImperativeHandle: updateImperativeHandle,\n  useInsertionEffect: updateInsertionEffect,\n  useLayoutEffect: updateLayoutEffect,\n  useMemo: updateMemo,\n  useReducer: rerenderReducer,\n  useRef: updateRef,\n  useState: function () {\n    return rerenderReducer(basicStateReducer);\n  },\n  useDebugValue: mountDebugValue,\n  useDeferredValue: function (value, initialValue) {\n    var hook = updateWorkInProgressHook();\n    return null === currentHook\n      ? mountDeferredValueImpl(hook, value, initialValue)\n      : updateDeferredValueImpl(\n          hook,\n          currentHook.memoizedState,\n          value,\n          initialValue\n        );\n  },\n  useTransition: function () {\n    var booleanOrThenable = rerenderReducer(basicStateReducer)[0],\n      start = updateWorkInProgressHook().memoizedState;\n    return [\n      \"boolean\" === typeof booleanOrThenable\n        ? booleanOrThenable\n        : useThenable(booleanOrThenable),\n      start\n    ];\n  },\n  useSyncExternalStore: updateSyncExternalStore,\n  useId: updateId\n};\nHooksDispatcherOnRerender.useCacheRefresh = updateRefresh;\nHooksDispatcherOnRerender.useMemoCache = useMemoCache;\nHooksDispatcherOnRerender.useHostTransitionStatus = useHostTransitionStatus;\nHooksDispatcherOnRerender.useFormState = rerenderActionState;\nHooksDispatcherOnRerender.useActionState = rerenderActionState;\nHooksDispatcherOnRerender.useOptimistic = function (passthrough, reducer) {\n  var hook = updateWorkInProgressHook();\n  if (null !== currentHook)\n    return updateOptimisticImpl(hook, currentHook, passthrough, reducer);\n  hook.baseState = passthrough;\n  return [passthrough, hook.queue.dispatch];\n};\nfunction applyDerivedStateFromProps(\n  workInProgress,\n  ctor,\n  getDerivedStateFromProps,\n  nextProps\n) {\n  ctor = workInProgress.memoizedState;\n  getDerivedStateFromProps = getDerivedStateFromProps(nextProps, ctor);\n  getDerivedStateFromProps =\n    null === getDerivedStateFromProps || void 0 === getDerivedStateFromProps\n      ? ctor\n      : assign({}, ctor, getDerivedStateFromProps);\n  workInProgress.memoizedState = getDerivedStateFromProps;\n  0 === workInProgress.lanes &&\n    (workInProgress.updateQueue.baseState = getDerivedStateFromProps);\n}\nvar classComponentUpdater = {\n  isMounted: function (component) {\n    return (component = component._reactInternals)\n      ? getNearestMountedFiber(component) === component\n      : !1;\n  },\n  enqueueSetState: function (inst, payload, callback) {\n    inst = inst._reactInternals;\n    var lane = requestUpdateLane(),\n      update = createUpdate(lane);\n    update.payload = payload;\n    void 0 !== callback && null !== callback && (update.callback = callback);\n    payload = enqueueUpdate(inst, update, lane);\n    null !== payload &&\n      (scheduleUpdateOnFiber(payload, inst, lane),\n      entangleTransitions(payload, inst, lane));\n  },\n  enqueueReplaceState: function (inst, payload, callback) {\n    inst = inst._reactInternals;\n    var lane = requestUpdateLane(),\n      update = createUpdate(lane);\n    update.tag = 1;\n    update.payload = payload;\n    void 0 !== callback && null !== callback && (update.callback = callback);\n    payload = enqueueUpdate(inst, update, lane);\n    null !== payload &&\n      (scheduleUpdateOnFiber(payload, inst, lane),\n      entangleTransitions(payload, inst, lane));\n  },\n  enqueueForceUpdate: function (inst, callback) {\n    inst = inst._reactInternals;\n    var lane = requestUpdateLane(),\n      update = createUpdate(lane);\n    update.tag = 2;\n    void 0 !== callback && null !== callback && (update.callback = callback);\n    callback = enqueueUpdate(inst, update, lane);\n    null !== callback &&\n      (scheduleUpdateOnFiber(callback, inst, lane),\n      entangleTransitions(callback, inst, lane));\n  }\n};\nfunction checkShouldComponentUpdate(\n  workInProgress,\n  ctor,\n  oldProps,\n  newProps,\n  oldState,\n  newState,\n  nextContext\n) {\n  workInProgress = workInProgress.stateNode;\n  return \"function\" === typeof workInProgress.shouldComponentUpdate\n    ? workInProgress.shouldComponentUpdate(newProps, newState, nextContext)\n    : ctor.prototype && ctor.prototype.isPureReactComponent\n      ? !shallowEqual(oldProps, newProps) || !shallowEqual(oldState, newState)\n      : !0;\n}\nfunction callComponentWillReceiveProps(\n  workInProgress,\n  instance,\n  newProps,\n  nextContext\n) {\n  workInProgress = instance.state;\n  \"function\" === typeof instance.componentWillReceiveProps &&\n    instance.componentWillReceiveProps(newProps, nextContext);\n  \"function\" === typeof instance.UNSAFE_componentWillReceiveProps &&\n    instance.UNSAFE_componentWillReceiveProps(newProps, nextContext);\n  instance.state !== workInProgress &&\n    classComponentUpdater.enqueueReplaceState(instance, instance.state, null);\n}\nfunction resolveClassComponentProps(Component, baseProps) {\n  var newProps = baseProps;\n  if (\"ref\" in baseProps) {\n    newProps = {};\n    for (var propName in baseProps)\n      \"ref\" !== propName && (newProps[propName] = baseProps[propName]);\n  }\n  if ((Component = Component.defaultProps)) {\n    newProps === baseProps && (newProps = assign({}, newProps));\n    for (var propName$67 in Component)\n      void 0 === newProps[propName$67] &&\n        (newProps[propName$67] = Component[propName$67]);\n  }\n  return newProps;\n}\nvar reportGlobalError =\n  \"function\" === typeof reportError\n    ? reportError\n    : function (error) {\n        if (\n          \"object\" === typeof window &&\n          \"function\" === typeof window.ErrorEvent\n        ) {\n          var event = new window.ErrorEvent(\"error\", {\n            bubbles: !0,\n            cancelable: !0,\n            message:\n              \"object\" === typeof error &&\n              null !== error &&\n              \"string\" === typeof error.message\n                ? String(error.message)\n                : String(error),\n            error: error\n          });\n          if (!window.dispatchEvent(event)) return;\n        } else if (\n          \"object\" === typeof process &&\n          \"function\" === typeof process.emit\n        ) {\n          process.emit(\"uncaughtException\", error);\n          return;\n        }\n        console.error(error);\n      };\nfunction defaultOnUncaughtError(error) {\n  reportGlobalError(error);\n}\nfunction defaultOnCaughtError(error) {\n  console.error(error);\n}\nfunction defaultOnRecoverableError(error) {\n  reportGlobalError(error);\n}\nfunction logUncaughtError(root, errorInfo) {\n  try {\n    var onUncaughtError = root.onUncaughtError;\n    onUncaughtError(errorInfo.value, { componentStack: errorInfo.stack });\n  } catch (e$68) {\n    setTimeout(function () {\n      throw e$68;\n    });\n  }\n}\nfunction logCaughtError(root, boundary, errorInfo) {\n  try {\n    var onCaughtError = root.onCaughtError;\n    onCaughtError(errorInfo.value, {\n      componentStack: errorInfo.stack,\n      errorBoundary: 1 === boundary.tag ? boundary.stateNode : null\n    });\n  } catch (e$69) {\n    setTimeout(function () {\n      throw e$69;\n    });\n  }\n}\nfunction createRootErrorUpdate(root, errorInfo, lane) {\n  lane = createUpdate(lane);\n  lane.tag = 3;\n  lane.payload = { element: null };\n  lane.callback = function () {\n    logUncaughtError(root, errorInfo);\n  };\n  return lane;\n}\nfunction createClassErrorUpdate(lane) {\n  lane = createUpdate(lane);\n  lane.tag = 3;\n  return lane;\n}\nfunction initializeClassErrorUpdate(update, root, fiber, errorInfo) {\n  var getDerivedStateFromError = fiber.type.getDerivedStateFromError;\n  if (\"function\" === typeof getDerivedStateFromError) {\n    var error = errorInfo.value;\n    update.payload = function () {\n      return getDerivedStateFromError(error);\n    };\n    update.callback = function () {\n      logCaughtError(root, fiber, errorInfo);\n    };\n  }\n  var inst = fiber.stateNode;\n  null !== inst &&\n    \"function\" === typeof inst.componentDidCatch &&\n    (update.callback = function () {\n      logCaughtError(root, fiber, errorInfo);\n      \"function\" !== typeof getDerivedStateFromError &&\n        (null === legacyErrorBoundariesThatAlreadyFailed\n          ? (legacyErrorBoundariesThatAlreadyFailed = new Set([this]))\n          : legacyErrorBoundariesThatAlreadyFailed.add(this));\n      var stack = errorInfo.stack;\n      this.componentDidCatch(errorInfo.value, {\n        componentStack: null !== stack ? stack : \"\"\n      });\n    });\n}\nfunction throwException(\n  root,\n  returnFiber,\n  sourceFiber,\n  value,\n  rootRenderLanes\n) {\n  sourceFiber.flags |= 32768;\n  if (\n    null !== value &&\n    \"object\" === typeof value &&\n    \"function\" === typeof value.then\n  ) {\n    returnFiber = sourceFiber.alternate;\n    null !== returnFiber &&\n      propagateParentContextChanges(\n        returnFiber,\n        sourceFiber,\n        rootRenderLanes,\n        !0\n      );\n    sourceFiber = suspenseHandlerStackCursor.current;\n    if (null !== sourceFiber) {\n      switch (sourceFiber.tag) {\n        case 13:\n          return (\n            null === shellBoundary\n              ? renderDidSuspendDelayIfPossible()\n              : null === sourceFiber.alternate &&\n                0 === workInProgressRootExitStatus &&\n                (workInProgressRootExitStatus = 3),\n            (sourceFiber.flags &= -257),\n            (sourceFiber.flags |= 65536),\n            (sourceFiber.lanes = rootRenderLanes),\n            value === noopSuspenseyCommitThenable\n              ? (sourceFiber.flags |= 16384)\n              : ((returnFiber = sourceFiber.updateQueue),\n                null === returnFiber\n                  ? (sourceFiber.updateQueue = new Set([value]))\n                  : returnFiber.add(value),\n                attachPingListener(root, value, rootRenderLanes)),\n            !1\n          );\n        case 22:\n          return (\n            (sourceFiber.flags |= 65536),\n            value === noopSuspenseyCommitThenable\n              ? (sourceFiber.flags |= 16384)\n              : ((returnFiber = sourceFiber.updateQueue),\n                null === returnFiber\n                  ? ((returnFiber = {\n                      transitions: null,\n                      markerInstances: null,\n                      retryQueue: new Set([value])\n                    }),\n                    (sourceFiber.updateQueue = returnFiber))\n                  : ((sourceFiber = returnFiber.retryQueue),\n                    null === sourceFiber\n                      ? (returnFiber.retryQueue = new Set([value]))\n                      : sourceFiber.add(value)),\n                attachPingListener(root, value, rootRenderLanes)),\n            !1\n          );\n      }\n      throw Error(formatProdErrorMessage(435, sourceFiber.tag));\n    }\n    attachPingListener(root, value, rootRenderLanes);\n    renderDidSuspendDelayIfPossible();\n    return !1;\n  }\n  if (isHydrating)\n    return (\n      (returnFiber = suspenseHandlerStackCursor.current),\n      null !== returnFiber\n        ? (0 === (returnFiber.flags & 65536) && (returnFiber.flags |= 256),\n          (returnFiber.flags |= 65536),\n          (returnFiber.lanes = rootRenderLanes),\n          value !== HydrationMismatchException &&\n            ((root = Error(formatProdErrorMessage(422), { cause: value })),\n            queueHydrationError(createCapturedValueAtFiber(root, sourceFiber))))\n        : (value !== HydrationMismatchException &&\n            ((returnFiber = Error(formatProdErrorMessage(423), {\n              cause: value\n            })),\n            queueHydrationError(\n              createCapturedValueAtFiber(returnFiber, sourceFiber)\n            )),\n          (root = root.current.alternate),\n          (root.flags |= 65536),\n          (rootRenderLanes &= -rootRenderLanes),\n          (root.lanes |= rootRenderLanes),\n          (value = createCapturedValueAtFiber(value, sourceFiber)),\n          (rootRenderLanes = createRootErrorUpdate(\n            root.stateNode,\n            value,\n            rootRenderLanes\n          )),\n          enqueueCapturedUpdate(root, rootRenderLanes),\n          4 !== workInProgressRootExitStatus &&\n            (workInProgressRootExitStatus = 2)),\n      !1\n    );\n  var wrapperError = Error(formatProdErrorMessage(520), { cause: value });\n  wrapperError = createCapturedValueAtFiber(wrapperError, sourceFiber);\n  null === workInProgressRootConcurrentErrors\n    ? (workInProgressRootConcurrentErrors = [wrapperError])\n    : workInProgressRootConcurrentErrors.push(wrapperError);\n  4 !== workInProgressRootExitStatus && (workInProgressRootExitStatus = 2);\n  if (null === returnFiber) return !0;\n  value = createCapturedValueAtFiber(value, sourceFiber);\n  sourceFiber = returnFiber;\n  do {\n    switch (sourceFiber.tag) {\n      case 3:\n        return (\n          (sourceFiber.flags |= 65536),\n          (root = rootRenderLanes & -rootRenderLanes),\n          (sourceFiber.lanes |= root),\n          (root = createRootErrorUpdate(sourceFiber.stateNode, value, root)),\n          enqueueCapturedUpdate(sourceFiber, root),\n          !1\n        );\n      case 1:\n        if (\n          ((returnFiber = sourceFiber.type),\n          (wrapperError = sourceFiber.stateNode),\n          0 === (sourceFiber.flags & 128) &&\n            (\"function\" === typeof returnFiber.getDerivedStateFromError ||\n              (null !== wrapperError &&\n                \"function\" === typeof wrapperError.componentDidCatch &&\n                (null === legacyErrorBoundariesThatAlreadyFailed ||\n                  !legacyErrorBoundariesThatAlreadyFailed.has(wrapperError)))))\n        )\n          return (\n            (sourceFiber.flags |= 65536),\n            (rootRenderLanes &= -rootRenderLanes),\n            (sourceFiber.lanes |= rootRenderLanes),\n            (rootRenderLanes = createClassErrorUpdate(rootRenderLanes)),\n            initializeClassErrorUpdate(\n              rootRenderLanes,\n              root,\n              sourceFiber,\n              value\n            ),\n            enqueueCapturedUpdate(sourceFiber, rootRenderLanes),\n            !1\n          );\n    }\n    sourceFiber = sourceFiber.return;\n  } while (null !== sourceFiber);\n  return !1;\n}\nvar SelectiveHydrationException = Error(formatProdErrorMessage(461)),\n  didReceiveUpdate = !1;\nfunction reconcileChildren(current, workInProgress, nextChildren, renderLanes) {\n  workInProgress.child =\n    null === current\n      ? mountChildFibers(workInProgress, null, nextChildren, renderLanes)\n      : reconcileChildFibers(\n          workInProgress,\n          current.child,\n          nextChildren,\n          renderLanes\n        );\n}\nfunction updateForwardRef(\n  current,\n  workInProgress,\n  Component,\n  nextProps,\n  renderLanes\n) {\n  Component = Component.render;\n  var ref = workInProgress.ref;\n  if (\"ref\" in nextProps) {\n    var propsWithoutRef = {};\n    for (var key in nextProps)\n      \"ref\" !== key && (propsWithoutRef[key] = nextProps[key]);\n  } else propsWithoutRef = nextProps;\n  prepareToReadContext(workInProgress);\n  nextProps = renderWithHooks(\n    current,\n    workInProgress,\n    Component,\n    propsWithoutRef,\n    ref,\n    renderLanes\n  );\n  key = checkDidRenderIdHook();\n  if (null !== current && !didReceiveUpdate)\n    return (\n      bailoutHooks(current, workInProgress, renderLanes),\n      bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n    );\n  isHydrating && key && pushMaterializedTreeId(workInProgress);\n  workInProgress.flags |= 1;\n  reconcileChildren(current, workInProgress, nextProps, renderLanes);\n  return workInProgress.child;\n}\nfunction updateMemoComponent(\n  current,\n  workInProgress,\n  Component,\n  nextProps,\n  renderLanes\n) {\n  if (null === current) {\n    var type = Component.type;\n    if (\n      \"function\" === typeof type &&\n      !shouldConstruct(type) &&\n      void 0 === type.defaultProps &&\n      null === Component.compare\n    )\n      return (\n        (workInProgress.tag = 15),\n        (workInProgress.type = type),\n        updateSimpleMemoComponent(\n          current,\n          workInProgress,\n          type,\n          nextProps,\n          renderLanes\n        )\n      );\n    current = createFiberFromTypeAndProps(\n      Component.type,\n      null,\n      nextProps,\n      workInProgress,\n      workInProgress.mode,\n      renderLanes\n    );\n    current.ref = workInProgress.ref;\n    current.return = workInProgress;\n    return (workInProgress.child = current);\n  }\n  type = current.child;\n  if (!checkScheduledUpdateOrContext(current, renderLanes)) {\n    var prevProps = type.memoizedProps;\n    Component = Component.compare;\n    Component = null !== Component ? Component : shallowEqual;\n    if (Component(prevProps, nextProps) && current.ref === workInProgress.ref)\n      return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n  }\n  workInProgress.flags |= 1;\n  current = createWorkInProgress(type, nextProps);\n  current.ref = workInProgress.ref;\n  current.return = workInProgress;\n  return (workInProgress.child = current);\n}\nfunction updateSimpleMemoComponent(\n  current,\n  workInProgress,\n  Component,\n  nextProps,\n  renderLanes\n) {\n  if (null !== current) {\n    var prevProps = current.memoizedProps;\n    if (\n      shallowEqual(prevProps, nextProps) &&\n      current.ref === workInProgress.ref\n    )\n      if (\n        ((didReceiveUpdate = !1),\n        (workInProgress.pendingProps = nextProps = prevProps),\n        checkScheduledUpdateOrContext(current, renderLanes))\n      )\n        0 !== (current.flags & 131072) && (didReceiveUpdate = !0);\n      else\n        return (\n          (workInProgress.lanes = current.lanes),\n          bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n        );\n  }\n  return updateFunctionComponent(\n    current,\n    workInProgress,\n    Component,\n    nextProps,\n    renderLanes\n  );\n}\nfunction updateOffscreenComponent(current, workInProgress, renderLanes) {\n  var nextProps = workInProgress.pendingProps,\n    nextChildren = nextProps.children,\n    nextIsDetached = 0 !== (workInProgress.stateNode._pendingVisibility & 2),\n    prevState = null !== current ? current.memoizedState : null;\n  markRef(current, workInProgress);\n  if (\"hidden\" === nextProps.mode || nextIsDetached) {\n    if (0 !== (workInProgress.flags & 128)) {\n      nextProps =\n        null !== prevState ? prevState.baseLanes | renderLanes : renderLanes;\n      if (null !== current) {\n        nextChildren = workInProgress.child = current.child;\n        for (nextIsDetached = 0; null !== nextChildren; )\n          (nextIsDetached =\n            nextIsDetached | nextChildren.lanes | nextChildren.childLanes),\n            (nextChildren = nextChildren.sibling);\n        workInProgress.childLanes = nextIsDetached & ~nextProps;\n      } else (workInProgress.childLanes = 0), (workInProgress.child = null);\n      return deferHiddenOffscreenComponent(\n        current,\n        workInProgress,\n        nextProps,\n        renderLanes\n      );\n    }\n    if (0 !== (renderLanes & 536870912))\n      (workInProgress.memoizedState = { baseLanes: 0, cachePool: null }),\n        null !== current &&\n          pushTransition(\n            workInProgress,\n            null !== prevState ? prevState.cachePool : null\n          ),\n        null !== prevState\n          ? pushHiddenContext(workInProgress, prevState)\n          : reuseHiddenContextOnStack(),\n        pushOffscreenSuspenseHandler(workInProgress);\n    else\n      return (\n        (workInProgress.lanes = workInProgress.childLanes = 536870912),\n        deferHiddenOffscreenComponent(\n          current,\n          workInProgress,\n          null !== prevState ? prevState.baseLanes | renderLanes : renderLanes,\n          renderLanes\n        )\n      );\n  } else\n    null !== prevState\n      ? (pushTransition(workInProgress, prevState.cachePool),\n        pushHiddenContext(workInProgress, prevState),\n        reuseSuspenseHandlerOnStack(workInProgress),\n        (workInProgress.memoizedState = null))\n      : (null !== current && pushTransition(workInProgress, null),\n        reuseHiddenContextOnStack(),\n        reuseSuspenseHandlerOnStack(workInProgress));\n  reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n  return workInProgress.child;\n}\nfunction deferHiddenOffscreenComponent(\n  current,\n  workInProgress,\n  nextBaseLanes,\n  renderLanes\n) {\n  var JSCompiler_inline_result = peekCacheFromPool();\n  JSCompiler_inline_result =\n    null === JSCompiler_inline_result\n      ? null\n      : { parent: CacheContext._currentValue, pool: JSCompiler_inline_result };\n  workInProgress.memoizedState = {\n    baseLanes: nextBaseLanes,\n    cachePool: JSCompiler_inline_result\n  };\n  null !== current && pushTransition(workInProgress, null);\n  reuseHiddenContextOnStack();\n  pushOffscreenSuspenseHandler(workInProgress);\n  null !== current &&\n    propagateParentContextChanges(current, workInProgress, renderLanes, !0);\n  return null;\n}\nfunction markRef(current, workInProgress) {\n  var ref = workInProgress.ref;\n  if (null === ref)\n    null !== current &&\n      null !== current.ref &&\n      (workInProgress.flags |= 2097664);\n  else {\n    if (\"function\" !== typeof ref && \"object\" !== typeof ref)\n      throw Error(formatProdErrorMessage(284));\n    if (null === current || current.ref !== ref)\n      workInProgress.flags |= 2097664;\n  }\n}\nfunction updateFunctionComponent(\n  current,\n  workInProgress,\n  Component,\n  nextProps,\n  renderLanes\n) {\n  prepareToReadContext(workInProgress);\n  Component = renderWithHooks(\n    current,\n    workInProgress,\n    Component,\n    nextProps,\n    void 0,\n    renderLanes\n  );\n  nextProps = checkDidRenderIdHook();\n  if (null !== current && !didReceiveUpdate)\n    return (\n      bailoutHooks(current, workInProgress, renderLanes),\n      bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n    );\n  isHydrating && nextProps && pushMaterializedTreeId(workInProgress);\n  workInProgress.flags |= 1;\n  reconcileChildren(current, workInProgress, Component, renderLanes);\n  return workInProgress.child;\n}\nfunction replayFunctionComponent(\n  current,\n  workInProgress,\n  nextProps,\n  Component,\n  secondArg,\n  renderLanes\n) {\n  prepareToReadContext(workInProgress);\n  workInProgress.updateQueue = null;\n  nextProps = renderWithHooksAgain(\n    workInProgress,\n    Component,\n    nextProps,\n    secondArg\n  );\n  finishRenderingHooks(current);\n  Component = checkDidRenderIdHook();\n  if (null !== current && !didReceiveUpdate)\n    return (\n      bailoutHooks(current, workInProgress, renderLanes),\n      bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n    );\n  isHydrating && Component && pushMaterializedTreeId(workInProgress);\n  workInProgress.flags |= 1;\n  reconcileChildren(current, workInProgress, nextProps, renderLanes);\n  return workInProgress.child;\n}\nfunction updateClassComponent(\n  current,\n  workInProgress,\n  Component,\n  nextProps,\n  renderLanes\n) {\n  prepareToReadContext(workInProgress);\n  if (null === workInProgress.stateNode) {\n    var context = emptyContextObject,\n      contextType = Component.contextType;\n    \"object\" === typeof contextType &&\n      null !== contextType &&\n      (context = readContext(contextType));\n    context = new Component(nextProps, context);\n    workInProgress.memoizedState =\n      null !== context.state && void 0 !== context.state ? context.state : null;\n    context.updater = classComponentUpdater;\n    workInProgress.stateNode = context;\n    context._reactInternals = workInProgress;\n    context = workInProgress.stateNode;\n    context.props = nextProps;\n    context.state = workInProgress.memoizedState;\n    context.refs = {};\n    initializeUpdateQueue(workInProgress);\n    contextType = Component.contextType;\n    context.context =\n      \"object\" === typeof contextType && null !== contextType\n        ? readContext(contextType)\n        : emptyContextObject;\n    context.state = workInProgress.memoizedState;\n    contextType = Component.getDerivedStateFromProps;\n    \"function\" === typeof contextType &&\n      (applyDerivedStateFromProps(\n        workInProgress,\n        Component,\n        contextType,\n        nextProps\n      ),\n      (context.state = workInProgress.memoizedState));\n    \"function\" === typeof Component.getDerivedStateFromProps ||\n      \"function\" === typeof context.getSnapshotBeforeUpdate ||\n      (\"function\" !== typeof context.UNSAFE_componentWillMount &&\n        \"function\" !== typeof context.componentWillMount) ||\n      ((contextType = context.state),\n      \"function\" === typeof context.componentWillMount &&\n        context.componentWillMount(),\n      \"function\" === typeof context.UNSAFE_componentWillMount &&\n        context.UNSAFE_componentWillMount(),\n      contextType !== context.state &&\n        classComponentUpdater.enqueueReplaceState(context, context.state, null),\n      processUpdateQueue(workInProgress, nextProps, context, renderLanes),\n      suspendIfUpdateReadFromEntangledAsyncAction(),\n      (context.state = workInProgress.memoizedState));\n    \"function\" === typeof context.componentDidMount &&\n      (workInProgress.flags |= 4194308);\n    nextProps = !0;\n  } else if (null === current) {\n    context = workInProgress.stateNode;\n    var unresolvedOldProps = workInProgress.memoizedProps,\n      oldProps = resolveClassComponentProps(Component, unresolvedOldProps);\n    context.props = oldProps;\n    var oldContext = context.context,\n      contextType$jscomp$0 = Component.contextType;\n    contextType = emptyContextObject;\n    \"object\" === typeof contextType$jscomp$0 &&\n      null !== contextType$jscomp$0 &&\n      (contextType = readContext(contextType$jscomp$0));\n    var getDerivedStateFromProps = Component.getDerivedStateFromProps;\n    contextType$jscomp$0 =\n      \"function\" === typeof getDerivedStateFromProps ||\n      \"function\" === typeof context.getSnapshotBeforeUpdate;\n    unresolvedOldProps = workInProgress.pendingProps !== unresolvedOldProps;\n    contextType$jscomp$0 ||\n      (\"function\" !== typeof context.UNSAFE_componentWillReceiveProps &&\n        \"function\" !== typeof context.componentWillReceiveProps) ||\n      ((unresolvedOldProps || oldContext !== contextType) &&\n        callComponentWillReceiveProps(\n          workInProgress,\n          context,\n          nextProps,\n          contextType\n        ));\n    hasForceUpdate = !1;\n    var oldState = workInProgress.memoizedState;\n    context.state = oldState;\n    processUpdateQueue(workInProgress, nextProps, context, renderLanes);\n    suspendIfUpdateReadFromEntangledAsyncAction();\n    oldContext = workInProgress.memoizedState;\n    unresolvedOldProps || oldState !== oldContext || hasForceUpdate\n      ? (\"function\" === typeof getDerivedStateFromProps &&\n          (applyDerivedStateFromProps(\n            workInProgress,\n            Component,\n            getDerivedStateFromProps,\n            nextProps\n          ),\n          (oldContext = workInProgress.memoizedState)),\n        (oldProps =\n          hasForceUpdate ||\n          checkShouldComponentUpdate(\n            workInProgress,\n            Component,\n            oldProps,\n            nextProps,\n            oldState,\n            oldContext,\n            contextType\n          ))\n          ? (contextType$jscomp$0 ||\n              (\"function\" !== typeof context.UNSAFE_componentWillMount &&\n                \"function\" !== typeof context.componentWillMount) ||\n              (\"function\" === typeof context.componentWillMount &&\n                context.componentWillMount(),\n              \"function\" === typeof context.UNSAFE_componentWillMount &&\n                context.UNSAFE_componentWillMount()),\n            \"function\" === typeof context.componentDidMount &&\n              (workInProgress.flags |= 4194308))\n          : (\"function\" === typeof context.componentDidMount &&\n              (workInProgress.flags |= 4194308),\n            (workInProgress.memoizedProps = nextProps),\n            (workInProgress.memoizedState = oldContext)),\n        (context.props = nextProps),\n        (context.state = oldContext),\n        (context.context = contextType),\n        (nextProps = oldProps))\n      : (\"function\" === typeof context.componentDidMount &&\n          (workInProgress.flags |= 4194308),\n        (nextProps = !1));\n  } else {\n    context = workInProgress.stateNode;\n    cloneUpdateQueue(current, workInProgress);\n    contextType = workInProgress.memoizedProps;\n    contextType$jscomp$0 = resolveClassComponentProps(Component, contextType);\n    context.props = contextType$jscomp$0;\n    getDerivedStateFromProps = workInProgress.pendingProps;\n    oldState = context.context;\n    oldContext = Component.contextType;\n    oldProps = emptyContextObject;\n    \"object\" === typeof oldContext &&\n      null !== oldContext &&\n      (oldProps = readContext(oldContext));\n    unresolvedOldProps = Component.getDerivedStateFromProps;\n    (oldContext =\n      \"function\" === typeof unresolvedOldProps ||\n      \"function\" === typeof context.getSnapshotBeforeUpdate) ||\n      (\"function\" !== typeof context.UNSAFE_componentWillReceiveProps &&\n        \"function\" !== typeof context.componentWillReceiveProps) ||\n      ((contextType !== getDerivedStateFromProps || oldState !== oldProps) &&\n        callComponentWillReceiveProps(\n          workInProgress,\n          context,\n          nextProps,\n          oldProps\n        ));\n    hasForceUpdate = !1;\n    oldState = workInProgress.memoizedState;\n    context.state = oldState;\n    processUpdateQueue(workInProgress, nextProps, context, renderLanes);\n    suspendIfUpdateReadFromEntangledAsyncAction();\n    var newState = workInProgress.memoizedState;\n    contextType !== getDerivedStateFromProps ||\n    oldState !== newState ||\n    hasForceUpdate ||\n    (null !== current &&\n      null !== current.dependencies &&\n      checkIfContextChanged(current.dependencies))\n      ? (\"function\" === typeof unresolvedOldProps &&\n          (applyDerivedStateFromProps(\n            workInProgress,\n            Component,\n            unresolvedOldProps,\n            nextProps\n          ),\n          (newState = workInProgress.memoizedState)),\n        (contextType$jscomp$0 =\n          hasForceUpdate ||\n          checkShouldComponentUpdate(\n            workInProgress,\n            Component,\n            contextType$jscomp$0,\n            nextProps,\n            oldState,\n            newState,\n            oldProps\n          ) ||\n          (null !== current &&\n            null !== current.dependencies &&\n            checkIfContextChanged(current.dependencies)))\n          ? (oldContext ||\n              (\"function\" !== typeof context.UNSAFE_componentWillUpdate &&\n                \"function\" !== typeof context.componentWillUpdate) ||\n              (\"function\" === typeof context.componentWillUpdate &&\n                context.componentWillUpdate(nextProps, newState, oldProps),\n              \"function\" === typeof context.UNSAFE_componentWillUpdate &&\n                context.UNSAFE_componentWillUpdate(\n                  nextProps,\n                  newState,\n                  oldProps\n                )),\n            \"function\" === typeof context.componentDidUpdate &&\n              (workInProgress.flags |= 4),\n            \"function\" === typeof context.getSnapshotBeforeUpdate &&\n              (workInProgress.flags |= 1024))\n          : (\"function\" !== typeof context.componentDidUpdate ||\n              (contextType === current.memoizedProps &&\n                oldState === current.memoizedState) ||\n              (workInProgress.flags |= 4),\n            \"function\" !== typeof context.getSnapshotBeforeUpdate ||\n              (contextType === current.memoizedProps &&\n                oldState === current.memoizedState) ||\n              (workInProgress.flags |= 1024),\n            (workInProgress.memoizedProps = nextProps),\n            (workInProgress.memoizedState = newState)),\n        (context.props = nextProps),\n        (context.state = newState),\n        (context.context = oldProps),\n        (nextProps = contextType$jscomp$0))\n      : (\"function\" !== typeof context.componentDidUpdate ||\n          (contextType === current.memoizedProps &&\n            oldState === current.memoizedState) ||\n          (workInProgress.flags |= 4),\n        \"function\" !== typeof context.getSnapshotBeforeUpdate ||\n          (contextType === current.memoizedProps &&\n            oldState === current.memoizedState) ||\n          (workInProgress.flags |= 1024),\n        (nextProps = !1));\n  }\n  context = nextProps;\n  markRef(current, workInProgress);\n  nextProps = 0 !== (workInProgress.flags & 128);\n  context || nextProps\n    ? ((context = workInProgress.stateNode),\n      (Component =\n        nextProps && \"function\" !== typeof Component.getDerivedStateFromError\n          ? null\n          : context.render()),\n      (workInProgress.flags |= 1),\n      null !== current && nextProps\n        ? ((workInProgress.child = reconcileChildFibers(\n            workInProgress,\n            current.child,\n            null,\n            renderLanes\n          )),\n          (workInProgress.child = reconcileChildFibers(\n            workInProgress,\n            null,\n            Component,\n            renderLanes\n          )))\n        : reconcileChildren(current, workInProgress, Component, renderLanes),\n      (workInProgress.memoizedState = context.state),\n      (current = workInProgress.child))\n    : (current = bailoutOnAlreadyFinishedWork(\n        current,\n        workInProgress,\n        renderLanes\n      ));\n  return current;\n}\nfunction mountHostRootWithoutHydrating(\n  current,\n  workInProgress,\n  nextChildren,\n  renderLanes\n) {\n  resetHydrationState();\n  workInProgress.flags |= 256;\n  reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n  return workInProgress.child;\n}\nvar SUSPENDED_MARKER = { dehydrated: null, treeContext: null, retryLane: 0 };\nfunction mountSuspenseOffscreenState(renderLanes) {\n  return { baseLanes: renderLanes, cachePool: getSuspendedCache() };\n}\nfunction getRemainingWorkInPrimaryTree(\n  current,\n  primaryTreeDidDefer,\n  renderLanes\n) {\n  current = null !== current ? current.childLanes & ~renderLanes : 0;\n  primaryTreeDidDefer && (current |= workInProgressDeferredLane);\n  return current;\n}\nfunction updateSuspenseComponent(current, workInProgress, renderLanes) {\n  var nextProps = workInProgress.pendingProps,\n    showFallback = !1,\n    didSuspend = 0 !== (workInProgress.flags & 128),\n    JSCompiler_temp;\n  (JSCompiler_temp = didSuspend) ||\n    (JSCompiler_temp =\n      null !== current && null === current.memoizedState\n        ? !1\n        : 0 !== (suspenseStackCursor.current & 2));\n  JSCompiler_temp && ((showFallback = !0), (workInProgress.flags &= -129));\n  JSCompiler_temp = 0 !== (workInProgress.flags & 32);\n  workInProgress.flags &= -33;\n  if (null === current) {\n    if (isHydrating) {\n      showFallback\n        ? pushPrimaryTreeSuspenseHandler(workInProgress)\n        : reuseSuspenseHandlerOnStack(workInProgress);\n      if (isHydrating) {\n        var nextInstance = nextHydratableInstance,\n          JSCompiler_temp$jscomp$0;\n        if ((JSCompiler_temp$jscomp$0 = nextInstance)) {\n          c: {\n            JSCompiler_temp$jscomp$0 = nextInstance;\n            for (\n              nextInstance = rootOrSingletonContext;\n              8 !== JSCompiler_temp$jscomp$0.nodeType;\n\n            ) {\n              if (!nextInstance) {\n                nextInstance = null;\n                break c;\n              }\n              JSCompiler_temp$jscomp$0 = getNextHydratable(\n                JSCompiler_temp$jscomp$0.nextSibling\n              );\n              if (null === JSCompiler_temp$jscomp$0) {\n                nextInstance = null;\n                break c;\n              }\n            }\n            nextInstance = JSCompiler_temp$jscomp$0;\n          }\n          null !== nextInstance\n            ? ((workInProgress.memoizedState = {\n                dehydrated: nextInstance,\n                treeContext:\n                  null !== treeContextProvider\n                    ? { id: treeContextId, overflow: treeContextOverflow }\n                    : null,\n                retryLane: 536870912\n              }),\n              (JSCompiler_temp$jscomp$0 = createFiberImplClass(\n                18,\n                null,\n                null,\n                0\n              )),\n              (JSCompiler_temp$jscomp$0.stateNode = nextInstance),\n              (JSCompiler_temp$jscomp$0.return = workInProgress),\n              (workInProgress.child = JSCompiler_temp$jscomp$0),\n              (hydrationParentFiber = workInProgress),\n              (nextHydratableInstance = null),\n              (JSCompiler_temp$jscomp$0 = !0))\n            : (JSCompiler_temp$jscomp$0 = !1);\n        }\n        JSCompiler_temp$jscomp$0 || throwOnHydrationMismatch(workInProgress);\n      }\n      nextInstance = workInProgress.memoizedState;\n      if (\n        null !== nextInstance &&\n        ((nextInstance = nextInstance.dehydrated), null !== nextInstance)\n      )\n        return (\n          \"$!\" === nextInstance.data\n            ? (workInProgress.lanes = 16)\n            : (workInProgress.lanes = 536870912),\n          null\n        );\n      popSuspenseHandler(workInProgress);\n    }\n    nextInstance = nextProps.children;\n    nextProps = nextProps.fallback;\n    if (showFallback)\n      return (\n        reuseSuspenseHandlerOnStack(workInProgress),\n        (showFallback = workInProgress.mode),\n        (nextInstance = mountWorkInProgressOffscreenFiber(\n          { mode: \"hidden\", children: nextInstance },\n          showFallback\n        )),\n        (nextProps = createFiberFromFragment(\n          nextProps,\n          showFallback,\n          renderLanes,\n          null\n        )),\n        (nextInstance.return = workInProgress),\n        (nextProps.return = workInProgress),\n        (nextInstance.sibling = nextProps),\n        (workInProgress.child = nextInstance),\n        (showFallback = workInProgress.child),\n        (showFallback.memoizedState = mountSuspenseOffscreenState(renderLanes)),\n        (showFallback.childLanes = getRemainingWorkInPrimaryTree(\n          current,\n          JSCompiler_temp,\n          renderLanes\n        )),\n        (workInProgress.memoizedState = SUSPENDED_MARKER),\n        nextProps\n      );\n    pushPrimaryTreeSuspenseHandler(workInProgress);\n    return mountSuspensePrimaryChildren(workInProgress, nextInstance);\n  }\n  JSCompiler_temp$jscomp$0 = current.memoizedState;\n  if (\n    null !== JSCompiler_temp$jscomp$0 &&\n    ((nextInstance = JSCompiler_temp$jscomp$0.dehydrated),\n    null !== nextInstance)\n  ) {\n    if (didSuspend)\n      workInProgress.flags & 256\n        ? (pushPrimaryTreeSuspenseHandler(workInProgress),\n          (workInProgress.flags &= -257),\n          (workInProgress = retrySuspenseComponentWithoutHydrating(\n            current,\n            workInProgress,\n            renderLanes\n          )))\n        : null !== workInProgress.memoizedState\n          ? (reuseSuspenseHandlerOnStack(workInProgress),\n            (workInProgress.child = current.child),\n            (workInProgress.flags |= 128),\n            (workInProgress = null))\n          : (reuseSuspenseHandlerOnStack(workInProgress),\n            (showFallback = nextProps.fallback),\n            (nextInstance = workInProgress.mode),\n            (nextProps = mountWorkInProgressOffscreenFiber(\n              { mode: \"visible\", children: nextProps.children },\n              nextInstance\n            )),\n            (showFallback = createFiberFromFragment(\n              showFallback,\n              nextInstance,\n              renderLanes,\n              null\n            )),\n            (showFallback.flags |= 2),\n            (nextProps.return = workInProgress),\n            (showFallback.return = workInProgress),\n            (nextProps.sibling = showFallback),\n            (workInProgress.child = nextProps),\n            reconcileChildFibers(\n              workInProgress,\n              current.child,\n              null,\n              renderLanes\n            ),\n            (nextProps = workInProgress.child),\n            (nextProps.memoizedState =\n              mountSuspenseOffscreenState(renderLanes)),\n            (nextProps.childLanes = getRemainingWorkInPrimaryTree(\n              current,\n              JSCompiler_temp,\n              renderLanes\n            )),\n            (workInProgress.memoizedState = SUSPENDED_MARKER),\n            (workInProgress = showFallback));\n    else if (\n      (pushPrimaryTreeSuspenseHandler(workInProgress),\n      \"$!\" === nextInstance.data)\n    ) {\n      JSCompiler_temp =\n        nextInstance.nextSibling && nextInstance.nextSibling.dataset;\n      if (JSCompiler_temp) var digest = JSCompiler_temp.dgst;\n      JSCompiler_temp = digest;\n      nextProps = Error(formatProdErrorMessage(419));\n      nextProps.stack = \"\";\n      nextProps.digest = JSCompiler_temp;\n      queueHydrationError({ value: nextProps, source: null, stack: null });\n      workInProgress = retrySuspenseComponentWithoutHydrating(\n        current,\n        workInProgress,\n        renderLanes\n      );\n    } else if (\n      (didReceiveUpdate ||\n        propagateParentContextChanges(current, workInProgress, renderLanes, !1),\n      (JSCompiler_temp = 0 !== (renderLanes & current.childLanes)),\n      didReceiveUpdate || JSCompiler_temp)\n    ) {\n      JSCompiler_temp = workInProgressRoot;\n      if (null !== JSCompiler_temp) {\n        nextProps = renderLanes & -renderLanes;\n        if (0 !== (nextProps & 42)) nextProps = 1;\n        else\n          switch (nextProps) {\n            case 2:\n              nextProps = 1;\n              break;\n            case 8:\n              nextProps = 4;\n              break;\n            case 32:\n              nextProps = 16;\n              break;\n            case 128:\n            case 256:\n            case 512:\n            case 1024:\n            case 2048:\n            case 4096:\n            case 8192:\n            case 16384:\n            case 32768:\n            case 65536:\n            case 131072:\n            case 262144:\n            case 524288:\n            case 1048576:\n            case 2097152:\n            case 4194304:\n            case 8388608:\n            case 16777216:\n            case 33554432:\n              nextProps = 64;\n              break;\n            case 268435456:\n              nextProps = 134217728;\n              break;\n            default:\n              nextProps = 0;\n          }\n        nextProps =\n          0 !== (nextProps & (JSCompiler_temp.suspendedLanes | renderLanes))\n            ? 0\n            : nextProps;\n        if (0 !== nextProps && nextProps !== JSCompiler_temp$jscomp$0.retryLane)\n          throw (\n            ((JSCompiler_temp$jscomp$0.retryLane = nextProps),\n            enqueueConcurrentRenderForLane(current, nextProps),\n            scheduleUpdateOnFiber(JSCompiler_temp, current, nextProps),\n            SelectiveHydrationException)\n          );\n      }\n      \"$?\" === nextInstance.data || renderDidSuspendDelayIfPossible();\n      workInProgress = retrySuspenseComponentWithoutHydrating(\n        current,\n        workInProgress,\n        renderLanes\n      );\n    } else\n      \"$?\" === nextInstance.data\n        ? ((workInProgress.flags |= 128),\n          (workInProgress.child = current.child),\n          (workInProgress = retryDehydratedSuspenseBoundary.bind(\n            null,\n            current\n          )),\n          (nextInstance._reactRetry = workInProgress),\n          (workInProgress = null))\n        : ((current = JSCompiler_temp$jscomp$0.treeContext),\n          (nextHydratableInstance = getNextHydratable(\n            nextInstance.nextSibling\n          )),\n          (hydrationParentFiber = workInProgress),\n          (isHydrating = !0),\n          (hydrationErrors = null),\n          (rootOrSingletonContext = !1),\n          null !== current &&\n            ((idStack[idStackIndex++] = treeContextId),\n            (idStack[idStackIndex++] = treeContextOverflow),\n            (idStack[idStackIndex++] = treeContextProvider),\n            (treeContextId = current.id),\n            (treeContextOverflow = current.overflow),\n            (treeContextProvider = workInProgress)),\n          (workInProgress = mountSuspensePrimaryChildren(\n            workInProgress,\n            nextProps.children\n          )),\n          (workInProgress.flags |= 4096));\n    return workInProgress;\n  }\n  if (showFallback)\n    return (\n      reuseSuspenseHandlerOnStack(workInProgress),\n      (showFallback = nextProps.fallback),\n      (nextInstance = workInProgress.mode),\n      (JSCompiler_temp$jscomp$0 = current.child),\n      (digest = JSCompiler_temp$jscomp$0.sibling),\n      (nextProps = createWorkInProgress(JSCompiler_temp$jscomp$0, {\n        mode: \"hidden\",\n        children: nextProps.children\n      })),\n      (nextProps.subtreeFlags =\n        JSCompiler_temp$jscomp$0.subtreeFlags & 31457280),\n      null !== digest\n        ? (showFallback = createWorkInProgress(digest, showFallback))\n        : ((showFallback = createFiberFromFragment(\n            showFallback,\n            nextInstance,\n            renderLanes,\n            null\n          )),\n          (showFallback.flags |= 2)),\n      (showFallback.return = workInProgress),\n      (nextProps.return = workInProgress),\n      (nextProps.sibling = showFallback),\n      (workInProgress.child = nextProps),\n      (nextProps = showFallback),\n      (showFallback = workInProgress.child),\n      (nextInstance = current.child.memoizedState),\n      null === nextInstance\n        ? (nextInstance = mountSuspenseOffscreenState(renderLanes))\n        : ((JSCompiler_temp$jscomp$0 = nextInstance.cachePool),\n          null !== JSCompiler_temp$jscomp$0\n            ? ((digest = CacheContext._currentValue),\n              (JSCompiler_temp$jscomp$0 =\n                JSCompiler_temp$jscomp$0.parent !== digest\n                  ? { parent: digest, pool: digest }\n                  : JSCompiler_temp$jscomp$0))\n            : (JSCompiler_temp$jscomp$0 = getSuspendedCache()),\n          (nextInstance = {\n            baseLanes: nextInstance.baseLanes | renderLanes,\n            cachePool: JSCompiler_temp$jscomp$0\n          })),\n      (showFallback.memoizedState = nextInstance),\n      (showFallback.childLanes = getRemainingWorkInPrimaryTree(\n        current,\n        JSCompiler_temp,\n        renderLanes\n      )),\n      (workInProgress.memoizedState = SUSPENDED_MARKER),\n      nextProps\n    );\n  pushPrimaryTreeSuspenseHandler(workInProgress);\n  renderLanes = current.child;\n  current = renderLanes.sibling;\n  renderLanes = createWorkInProgress(renderLanes, {\n    mode: \"visible\",\n    children: nextProps.children\n  });\n  renderLanes.return = workInProgress;\n  renderLanes.sibling = null;\n  null !== current &&\n    ((JSCompiler_temp = workInProgress.deletions),\n    null === JSCompiler_temp\n      ? ((workInProgress.deletions = [current]), (workInProgress.flags |= 16))\n      : JSCompiler_temp.push(current));\n  workInProgress.child = renderLanes;\n  workInProgress.memoizedState = null;\n  return renderLanes;\n}\nfunction mountSuspensePrimaryChildren(workInProgress, primaryChildren) {\n  primaryChildren = mountWorkInProgressOffscreenFiber(\n    { mode: \"visible\", children: primaryChildren },\n    workInProgress.mode\n  );\n  primaryChildren.return = workInProgress;\n  return (workInProgress.child = primaryChildren);\n}\nfunction mountWorkInProgressOffscreenFiber(offscreenProps, mode) {\n  return createFiberFromOffscreen(offscreenProps, mode, 0, null);\n}\nfunction retrySuspenseComponentWithoutHydrating(\n  current,\n  workInProgress,\n  renderLanes\n) {\n  reconcileChildFibers(workInProgress, current.child, null, renderLanes);\n  current = mountSuspensePrimaryChildren(\n    workInProgress,\n    workInProgress.pendingProps.children\n  );\n  current.flags |= 2;\n  workInProgress.memoizedState = null;\n  return current;\n}\nfunction scheduleSuspenseWorkOnFiber(fiber, renderLanes, propagationRoot) {\n  fiber.lanes |= renderLanes;\n  var alternate = fiber.alternate;\n  null !== alternate && (alternate.lanes |= renderLanes);\n  scheduleContextWorkOnParentPath(fiber.return, renderLanes, propagationRoot);\n}\nfunction initSuspenseListRenderState(\n  workInProgress,\n  isBackwards,\n  tail,\n  lastContentRow,\n  tailMode\n) {\n  var renderState = workInProgress.memoizedState;\n  null === renderState\n    ? (workInProgress.memoizedState = {\n        isBackwards: isBackwards,\n        rendering: null,\n        renderingStartTime: 0,\n        last: lastContentRow,\n        tail: tail,\n        tailMode: tailMode\n      })\n    : ((renderState.isBackwards = isBackwards),\n      (renderState.rendering = null),\n      (renderState.renderingStartTime = 0),\n      (renderState.last = lastContentRow),\n      (renderState.tail = tail),\n      (renderState.tailMode = tailMode));\n}\nfunction updateSuspenseListComponent(current, workInProgress, renderLanes) {\n  var nextProps = workInProgress.pendingProps,\n    revealOrder = nextProps.revealOrder,\n    tailMode = nextProps.tail;\n  reconcileChildren(current, workInProgress, nextProps.children, renderLanes);\n  nextProps = suspenseStackCursor.current;\n  if (0 !== (nextProps & 2))\n    (nextProps = (nextProps & 1) | 2), (workInProgress.flags |= 128);\n  else {\n    if (null !== current && 0 !== (current.flags & 128))\n      a: for (current = workInProgress.child; null !== current; ) {\n        if (13 === current.tag)\n          null !== current.memoizedState &&\n            scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n        else if (19 === current.tag)\n          scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n        else if (null !== current.child) {\n          current.child.return = current;\n          current = current.child;\n          continue;\n        }\n        if (current === workInProgress) break a;\n        for (; null === current.sibling; ) {\n          if (null === current.return || current.return === workInProgress)\n            break a;\n          current = current.return;\n        }\n        current.sibling.return = current.return;\n        current = current.sibling;\n      }\n    nextProps &= 1;\n  }\n  push(suspenseStackCursor, nextProps);\n  switch (revealOrder) {\n    case \"forwards\":\n      renderLanes = workInProgress.child;\n      for (revealOrder = null; null !== renderLanes; )\n        (current = renderLanes.alternate),\n          null !== current &&\n            null === findFirstSuspended(current) &&\n            (revealOrder = renderLanes),\n          (renderLanes = renderLanes.sibling);\n      renderLanes = revealOrder;\n      null === renderLanes\n        ? ((revealOrder = workInProgress.child), (workInProgress.child = null))\n        : ((revealOrder = renderLanes.sibling), (renderLanes.sibling = null));\n      initSuspenseListRenderState(\n        workInProgress,\n        !1,\n        revealOrder,\n        renderLanes,\n        tailMode\n      );\n      break;\n    case \"backwards\":\n      renderLanes = null;\n      revealOrder = workInProgress.child;\n      for (workInProgress.child = null; null !== revealOrder; ) {\n        current = revealOrder.alternate;\n        if (null !== current && null === findFirstSuspended(current)) {\n          workInProgress.child = revealOrder;\n          break;\n        }\n        current = revealOrder.sibling;\n        revealOrder.sibling = renderLanes;\n        renderLanes = revealOrder;\n        revealOrder = current;\n      }\n      initSuspenseListRenderState(\n        workInProgress,\n        !0,\n        renderLanes,\n        null,\n        tailMode\n      );\n      break;\n    case \"together\":\n      initSuspenseListRenderState(workInProgress, !1, null, null, void 0);\n      break;\n    default:\n      workInProgress.memoizedState = null;\n  }\n  return workInProgress.child;\n}\nfunction bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes) {\n  null !== current && (workInProgress.dependencies = current.dependencies);\n  workInProgressRootSkippedLanes |= workInProgress.lanes;\n  if (0 === (renderLanes & workInProgress.childLanes))\n    if (null !== current) {\n      if (\n        (propagateParentContextChanges(\n          current,\n          workInProgress,\n          renderLanes,\n          !1\n        ),\n        0 === (renderLanes & workInProgress.childLanes))\n      )\n        return null;\n    } else return null;\n  if (null !== current && workInProgress.child !== current.child)\n    throw Error(formatProdErrorMessage(153));\n  if (null !== workInProgress.child) {\n    current = workInProgress.child;\n    renderLanes = createWorkInProgress(current, current.pendingProps);\n    workInProgress.child = renderLanes;\n    for (renderLanes.return = workInProgress; null !== current.sibling; )\n      (current = current.sibling),\n        (renderLanes = renderLanes.sibling =\n          createWorkInProgress(current, current.pendingProps)),\n        (renderLanes.return = workInProgress);\n    renderLanes.sibling = null;\n  }\n  return workInProgress.child;\n}\nfunction checkScheduledUpdateOrContext(current, renderLanes) {\n  if (0 !== (current.lanes & renderLanes)) return !0;\n  current = current.dependencies;\n  return null !== current && checkIfContextChanged(current) ? !0 : !1;\n}\nfunction attemptEarlyBailoutIfNoScheduledUpdate(\n  current,\n  workInProgress,\n  renderLanes\n) {\n  switch (workInProgress.tag) {\n    case 3:\n      pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n      pushProvider(workInProgress, CacheContext, current.memoizedState.cache);\n      resetHydrationState();\n      break;\n    case 27:\n    case 5:\n      pushHostContext(workInProgress);\n      break;\n    case 4:\n      pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n      break;\n    case 10:\n      pushProvider(\n        workInProgress,\n        workInProgress.type,\n        workInProgress.memoizedProps.value\n      );\n      break;\n    case 13:\n      var state = workInProgress.memoizedState;\n      if (null !== state) {\n        if (null !== state.dehydrated)\n          return (\n            pushPrimaryTreeSuspenseHandler(workInProgress),\n            (workInProgress.flags |= 128),\n            null\n          );\n        if (0 !== (renderLanes & workInProgress.child.childLanes))\n          return updateSuspenseComponent(current, workInProgress, renderLanes);\n        pushPrimaryTreeSuspenseHandler(workInProgress);\n        current = bailoutOnAlreadyFinishedWork(\n          current,\n          workInProgress,\n          renderLanes\n        );\n        return null !== current ? current.sibling : null;\n      }\n      pushPrimaryTreeSuspenseHandler(workInProgress);\n      break;\n    case 19:\n      var didSuspendBefore = 0 !== (current.flags & 128);\n      state = 0 !== (renderLanes & workInProgress.childLanes);\n      state ||\n        (propagateParentContextChanges(\n          current,\n          workInProgress,\n          renderLanes,\n          !1\n        ),\n        (state = 0 !== (renderLanes & workInProgress.childLanes)));\n      if (didSuspendBefore) {\n        if (state)\n          return updateSuspenseListComponent(\n            current,\n            workInProgress,\n            renderLanes\n          );\n        workInProgress.flags |= 128;\n      }\n      didSuspendBefore = workInProgress.memoizedState;\n      null !== didSuspendBefore &&\n        ((didSuspendBefore.rendering = null),\n        (didSuspendBefore.tail = null),\n        (didSuspendBefore.lastEffect = null));\n      push(suspenseStackCursor, suspenseStackCursor.current);\n      if (state) break;\n      else return null;\n    case 22:\n    case 23:\n      return (\n        (workInProgress.lanes = 0),\n        updateOffscreenComponent(current, workInProgress, renderLanes)\n      );\n    case 24:\n      pushProvider(workInProgress, CacheContext, current.memoizedState.cache);\n  }\n  return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n}\nfunction beginWork(current, workInProgress, renderLanes) {\n  if (null !== current)\n    if (current.memoizedProps !== workInProgress.pendingProps)\n      didReceiveUpdate = !0;\n    else {\n      if (\n        !checkScheduledUpdateOrContext(current, renderLanes) &&\n        0 === (workInProgress.flags & 128)\n      )\n        return (\n          (didReceiveUpdate = !1),\n          attemptEarlyBailoutIfNoScheduledUpdate(\n            current,\n            workInProgress,\n            renderLanes\n          )\n        );\n      didReceiveUpdate = 0 !== (current.flags & 131072) ? !0 : !1;\n    }\n  else\n    (didReceiveUpdate = !1),\n      isHydrating &&\n        0 !== (workInProgress.flags & 1048576) &&\n        pushTreeId(workInProgress, treeForkCount, workInProgress.index);\n  workInProgress.lanes = 0;\n  switch (workInProgress.tag) {\n    case 16:\n      a: {\n        current = workInProgress.pendingProps;\n        var lazyComponent = workInProgress.elementType,\n          init = lazyComponent._init;\n        lazyComponent = init(lazyComponent._payload);\n        workInProgress.type = lazyComponent;\n        if (\"function\" === typeof lazyComponent)\n          shouldConstruct(lazyComponent)\n            ? ((current = resolveClassComponentProps(lazyComponent, current)),\n              (workInProgress.tag = 1),\n              (workInProgress = updateClassComponent(\n                null,\n                workInProgress,\n                lazyComponent,\n                current,\n                renderLanes\n              )))\n            : ((workInProgress.tag = 0),\n              (workInProgress = updateFunctionComponent(\n                null,\n                workInProgress,\n                lazyComponent,\n                current,\n                renderLanes\n              )));\n        else {\n          if (void 0 !== lazyComponent && null !== lazyComponent)\n            if (\n              ((init = lazyComponent.$$typeof), init === REACT_FORWARD_REF_TYPE)\n            ) {\n              workInProgress.tag = 11;\n              workInProgress = updateForwardRef(\n                null,\n                workInProgress,\n                lazyComponent,\n                current,\n                renderLanes\n              );\n              break a;\n            } else if (init === REACT_MEMO_TYPE) {\n              workInProgress.tag = 14;\n              workInProgress = updateMemoComponent(\n                null,\n                workInProgress,\n                lazyComponent,\n                current,\n                renderLanes\n              );\n              break a;\n            }\n          workInProgress =\n            getComponentNameFromType(lazyComponent) || lazyComponent;\n          throw Error(formatProdErrorMessage(306, workInProgress, \"\"));\n        }\n      }\n      return workInProgress;\n    case 0:\n      return updateFunctionComponent(\n        current,\n        workInProgress,\n        workInProgress.type,\n        workInProgress.pendingProps,\n        renderLanes\n      );\n    case 1:\n      return (\n        (lazyComponent = workInProgress.type),\n        (init = resolveClassComponentProps(\n          lazyComponent,\n          workInProgress.pendingProps\n        )),\n        updateClassComponent(\n          current,\n          workInProgress,\n          lazyComponent,\n          init,\n          renderLanes\n        )\n      );\n    case 3:\n      a: {\n        pushHostContainer(\n          workInProgress,\n          workInProgress.stateNode.containerInfo\n        );\n        if (null === current) throw Error(formatProdErrorMessage(387));\n        var nextProps = workInProgress.pendingProps;\n        init = workInProgress.memoizedState;\n        lazyComponent = init.element;\n        cloneUpdateQueue(current, workInProgress);\n        processUpdateQueue(workInProgress, nextProps, null, renderLanes);\n        var nextState = workInProgress.memoizedState;\n        nextProps = nextState.cache;\n        pushProvider(workInProgress, CacheContext, nextProps);\n        nextProps !== init.cache &&\n          propagateContextChanges(\n            workInProgress,\n            [CacheContext],\n            renderLanes,\n            !0\n          );\n        suspendIfUpdateReadFromEntangledAsyncAction();\n        nextProps = nextState.element;\n        if (init.isDehydrated)\n          if (\n            ((init = {\n              element: nextProps,\n              isDehydrated: !1,\n              cache: nextState.cache\n            }),\n            (workInProgress.updateQueue.baseState = init),\n            (workInProgress.memoizedState = init),\n            workInProgress.flags & 256)\n          ) {\n            workInProgress = mountHostRootWithoutHydrating(\n              current,\n              workInProgress,\n              nextProps,\n              renderLanes\n            );\n            break a;\n          } else if (nextProps !== lazyComponent) {\n            lazyComponent = createCapturedValueAtFiber(\n              Error(formatProdErrorMessage(424)),\n              workInProgress\n            );\n            queueHydrationError(lazyComponent);\n            workInProgress = mountHostRootWithoutHydrating(\n              current,\n              workInProgress,\n              nextProps,\n              renderLanes\n            );\n            break a;\n          } else\n            for (\n              nextHydratableInstance = getNextHydratable(\n                workInProgress.stateNode.containerInfo.firstChild\n              ),\n                hydrationParentFiber = workInProgress,\n                isHydrating = !0,\n                hydrationErrors = null,\n                rootOrSingletonContext = !0,\n                renderLanes = mountChildFibers(\n                  workInProgress,\n                  null,\n                  nextProps,\n                  renderLanes\n                ),\n                workInProgress.child = renderLanes;\n              renderLanes;\n\n            )\n              (renderLanes.flags = (renderLanes.flags & -3) | 4096),\n                (renderLanes = renderLanes.sibling);\n        else {\n          resetHydrationState();\n          if (nextProps === lazyComponent) {\n            workInProgress = bailoutOnAlreadyFinishedWork(\n              current,\n              workInProgress,\n              renderLanes\n            );\n            break a;\n          }\n          reconcileChildren(current, workInProgress, nextProps, renderLanes);\n        }\n        workInProgress = workInProgress.child;\n      }\n      return workInProgress;\n    case 26:\n      return (\n        markRef(current, workInProgress),\n        null === current\n          ? (renderLanes = getResource(\n              workInProgress.type,\n              null,\n              workInProgress.pendingProps,\n              null\n            ))\n            ? (workInProgress.memoizedState = renderLanes)\n            : isHydrating ||\n              ((renderLanes = workInProgress.type),\n              (current = workInProgress.pendingProps),\n              (lazyComponent = getOwnerDocumentFromRootContainer(\n                rootInstanceStackCursor.current\n              ).createElement(renderLanes)),\n              (lazyComponent[internalInstanceKey] = workInProgress),\n              (lazyComponent[internalPropsKey] = current),\n              setInitialProperties(lazyComponent, renderLanes, current),\n              markNodeAsHoistable(lazyComponent),\n              (workInProgress.stateNode = lazyComponent))\n          : (workInProgress.memoizedState = getResource(\n              workInProgress.type,\n              current.memoizedProps,\n              workInProgress.pendingProps,\n              current.memoizedState\n            )),\n        null\n      );\n    case 27:\n      return (\n        pushHostContext(workInProgress),\n        null === current &&\n          isHydrating &&\n          ((lazyComponent = workInProgress.stateNode =\n            resolveSingletonInstance(\n              workInProgress.type,\n              workInProgress.pendingProps,\n              rootInstanceStackCursor.current\n            )),\n          (hydrationParentFiber = workInProgress),\n          (rootOrSingletonContext = !0),\n          (nextHydratableInstance = getNextHydratable(\n            lazyComponent.firstChild\n          ))),\n        (lazyComponent = workInProgress.pendingProps.children),\n        null !== current || isHydrating\n          ? reconcileChildren(\n              current,\n              workInProgress,\n              lazyComponent,\n              renderLanes\n            )\n          : (workInProgress.child = reconcileChildFibers(\n              workInProgress,\n              null,\n              lazyComponent,\n              renderLanes\n            )),\n        markRef(current, workInProgress),\n        workInProgress.child\n      );\n    case 5:\n      if (null === current && isHydrating) {\n        if ((init = lazyComponent = nextHydratableInstance))\n          (lazyComponent = canHydrateInstance(\n            lazyComponent,\n            workInProgress.type,\n            workInProgress.pendingProps,\n            rootOrSingletonContext\n          )),\n            null !== lazyComponent\n              ? ((workInProgress.stateNode = lazyComponent),\n                (hydrationParentFiber = workInProgress),\n                (nextHydratableInstance = getNextHydratable(\n                  lazyComponent.firstChild\n                )),\n                (rootOrSingletonContext = !1),\n                (init = !0))\n              : (init = !1);\n        init || throwOnHydrationMismatch(workInProgress);\n      }\n      pushHostContext(workInProgress);\n      init = workInProgress.type;\n      nextProps = workInProgress.pendingProps;\n      nextState = null !== current ? current.memoizedProps : null;\n      lazyComponent = nextProps.children;\n      shouldSetTextContent(init, nextProps)\n        ? (lazyComponent = null)\n        : null !== nextState &&\n          shouldSetTextContent(init, nextState) &&\n          (workInProgress.flags |= 32);\n      null !== workInProgress.memoizedState &&\n        ((init = renderWithHooks(\n          current,\n          workInProgress,\n          TransitionAwareHostComponent,\n          null,\n          null,\n          renderLanes\n        )),\n        (HostTransitionContext._currentValue = init));\n      markRef(current, workInProgress);\n      reconcileChildren(current, workInProgress, lazyComponent, renderLanes);\n      return workInProgress.child;\n    case 6:\n      if (null === current && isHydrating) {\n        if ((current = renderLanes = nextHydratableInstance))\n          (renderLanes = canHydrateTextInstance(\n            renderLanes,\n            workInProgress.pendingProps,\n            rootOrSingletonContext\n          )),\n            null !== renderLanes\n              ? ((workInProgress.stateNode = renderLanes),\n                (hydrationParentFiber = workInProgress),\n                (nextHydratableInstance = null),\n                (current = !0))\n              : (current = !1);\n        current || throwOnHydrationMismatch(workInProgress);\n      }\n      return null;\n    case 13:\n      return updateSuspenseComponent(current, workInProgress, renderLanes);\n    case 4:\n      return (\n        pushHostContainer(\n          workInProgress,\n          workInProgress.stateNode.containerInfo\n        ),\n        (lazyComponent = workInProgress.pendingProps),\n        null === current\n          ? (workInProgress.child = reconcileChildFibers(\n              workInProgress,\n              null,\n              lazyComponent,\n              renderLanes\n            ))\n          : reconcileChildren(\n              current,\n              workInProgress,\n              lazyComponent,\n              renderLanes\n            ),\n        workInProgress.child\n      );\n    case 11:\n      return updateForwardRef(\n        current,\n        workInProgress,\n        workInProgress.type,\n        workInProgress.pendingProps,\n        renderLanes\n      );\n    case 7:\n      return (\n        reconcileChildren(\n          current,\n          workInProgress,\n          workInProgress.pendingProps,\n          renderLanes\n        ),\n        workInProgress.child\n      );\n    case 8:\n      return (\n        reconcileChildren(\n          current,\n          workInProgress,\n          workInProgress.pendingProps.children,\n          renderLanes\n        ),\n        workInProgress.child\n      );\n    case 12:\n      return (\n        reconcileChildren(\n          current,\n          workInProgress,\n          workInProgress.pendingProps.children,\n          renderLanes\n        ),\n        workInProgress.child\n      );\n    case 10:\n      return (\n        (lazyComponent = workInProgress.pendingProps),\n        pushProvider(workInProgress, workInProgress.type, lazyComponent.value),\n        reconcileChildren(\n          current,\n          workInProgress,\n          lazyComponent.children,\n          renderLanes\n        ),\n        workInProgress.child\n      );\n    case 9:\n      return (\n        (init = workInProgress.type._context),\n        (lazyComponent = workInProgress.pendingProps.children),\n        prepareToReadContext(workInProgress),\n        (init = readContext(init)),\n        (lazyComponent = lazyComponent(init)),\n        (workInProgress.flags |= 1),\n        reconcileChildren(current, workInProgress, lazyComponent, renderLanes),\n        workInProgress.child\n      );\n    case 14:\n      return updateMemoComponent(\n        current,\n        workInProgress,\n        workInProgress.type,\n        workInProgress.pendingProps,\n        renderLanes\n      );\n    case 15:\n      return updateSimpleMemoComponent(\n        current,\n        workInProgress,\n        workInProgress.type,\n        workInProgress.pendingProps,\n        renderLanes\n      );\n    case 19:\n      return updateSuspenseListComponent(current, workInProgress, renderLanes);\n    case 22:\n      return updateOffscreenComponent(current, workInProgress, renderLanes);\n    case 24:\n      return (\n        prepareToReadContext(workInProgress),\n        (lazyComponent = readContext(CacheContext)),\n        null === current\n          ? ((init = peekCacheFromPool()),\n            null === init &&\n              ((init = workInProgressRoot),\n              (nextProps = createCache()),\n              (init.pooledCache = nextProps),\n              nextProps.refCount++,\n              null !== nextProps && (init.pooledCacheLanes |= renderLanes),\n              (init = nextProps)),\n            (workInProgress.memoizedState = {\n              parent: lazyComponent,\n              cache: init\n            }),\n            initializeUpdateQueue(workInProgress),\n            pushProvider(workInProgress, CacheContext, init))\n          : (0 !== (current.lanes & renderLanes) &&\n              (cloneUpdateQueue(current, workInProgress),\n              processUpdateQueue(workInProgress, null, null, renderLanes),\n              suspendIfUpdateReadFromEntangledAsyncAction()),\n            (init = current.memoizedState),\n            (nextProps = workInProgress.memoizedState),\n            init.parent !== lazyComponent\n              ? ((init = { parent: lazyComponent, cache: lazyComponent }),\n                (workInProgress.memoizedState = init),\n                0 === workInProgress.lanes &&\n                  (workInProgress.memoizedState =\n                    workInProgress.updateQueue.baseState =\n                      init),\n                pushProvider(workInProgress, CacheContext, lazyComponent))\n              : ((lazyComponent = nextProps.cache),\n                pushProvider(workInProgress, CacheContext, lazyComponent),\n                lazyComponent !== init.cache &&\n                  propagateContextChanges(\n                    workInProgress,\n                    [CacheContext],\n                    renderLanes,\n                    !0\n                  ))),\n        reconcileChildren(\n          current,\n          workInProgress,\n          workInProgress.pendingProps.children,\n          renderLanes\n        ),\n        workInProgress.child\n      );\n    case 29:\n      throw workInProgress.pendingProps;\n  }\n  throw Error(formatProdErrorMessage(156, workInProgress.tag));\n}\nvar valueCursor = createCursor(null),\n  currentlyRenderingFiber = null,\n  lastContextDependency = null;\nfunction pushProvider(providerFiber, context, nextValue) {\n  push(valueCursor, context._currentValue);\n  context._currentValue = nextValue;\n}\nfunction popProvider(context) {\n  context._currentValue = valueCursor.current;\n  pop(valueCursor);\n}\nfunction scheduleContextWorkOnParentPath(parent, renderLanes, propagationRoot) {\n  for (; null !== parent; ) {\n    var alternate = parent.alternate;\n    (parent.childLanes & renderLanes) !== renderLanes\n      ? ((parent.childLanes |= renderLanes),\n        null !== alternate && (alternate.childLanes |= renderLanes))\n      : null !== alternate &&\n        (alternate.childLanes & renderLanes) !== renderLanes &&\n        (alternate.childLanes |= renderLanes);\n    if (parent === propagationRoot) break;\n    parent = parent.return;\n  }\n}\nfunction propagateContextChanges(\n  workInProgress,\n  contexts,\n  renderLanes,\n  forcePropagateEntireTree\n) {\n  var fiber = workInProgress.child;\n  null !== fiber && (fiber.return = workInProgress);\n  for (; null !== fiber; ) {\n    var list = fiber.dependencies;\n    if (null !== list) {\n      var nextFiber = fiber.child;\n      list = list.firstContext;\n      a: for (; null !== list; ) {\n        var dependency = list;\n        list = fiber;\n        for (var i = 0; i < contexts.length; i++)\n          if (dependency.context === contexts[i]) {\n            list.lanes |= renderLanes;\n            dependency = list.alternate;\n            null !== dependency && (dependency.lanes |= renderLanes);\n            scheduleContextWorkOnParentPath(\n              list.return,\n              renderLanes,\n              workInProgress\n            );\n            forcePropagateEntireTree || (nextFiber = null);\n            break a;\n          }\n        list = dependency.next;\n      }\n    } else if (18 === fiber.tag) {\n      nextFiber = fiber.return;\n      if (null === nextFiber) throw Error(formatProdErrorMessage(341));\n      nextFiber.lanes |= renderLanes;\n      list = nextFiber.alternate;\n      null !== list && (list.lanes |= renderLanes);\n      scheduleContextWorkOnParentPath(nextFiber, renderLanes, workInProgress);\n      nextFiber = null;\n    } else nextFiber = fiber.child;\n    if (null !== nextFiber) nextFiber.return = fiber;\n    else\n      for (nextFiber = fiber; null !== nextFiber; ) {\n        if (nextFiber === workInProgress) {\n          nextFiber = null;\n          break;\n        }\n        fiber = nextFiber.sibling;\n        if (null !== fiber) {\n          fiber.return = nextFiber.return;\n          nextFiber = fiber;\n          break;\n        }\n        nextFiber = nextFiber.return;\n      }\n    fiber = nextFiber;\n  }\n}\nfunction propagateParentContextChanges(\n  current,\n  workInProgress,\n  renderLanes,\n  forcePropagateEntireTree\n) {\n  current = null;\n  for (\n    var parent = workInProgress, isInsidePropagationBailout = !1;\n    null !== parent;\n\n  ) {\n    if (!isInsidePropagationBailout)\n      if (0 !== (parent.flags & 524288)) isInsidePropagationBailout = !0;\n      else if (0 !== (parent.flags & 262144)) break;\n    if (10 === parent.tag) {\n      var currentParent = parent.alternate;\n      if (null === currentParent) throw Error(formatProdErrorMessage(387));\n      currentParent = currentParent.memoizedProps;\n      if (null !== currentParent) {\n        var context = parent.type;\n        objectIs(parent.pendingProps.value, currentParent.value) ||\n          (null !== current ? current.push(context) : (current = [context]));\n      }\n    } else if (parent === hostTransitionProviderCursor.current) {\n      currentParent = parent.alternate;\n      if (null === currentParent) throw Error(formatProdErrorMessage(387));\n      currentParent.memoizedState.memoizedState !==\n        parent.memoizedState.memoizedState &&\n        (null !== current\n          ? current.push(HostTransitionContext)\n          : (current = [HostTransitionContext]));\n    }\n    parent = parent.return;\n  }\n  null !== current &&\n    propagateContextChanges(\n      workInProgress,\n      current,\n      renderLanes,\n      forcePropagateEntireTree\n    );\n  workInProgress.flags |= 262144;\n}\nfunction checkIfContextChanged(currentDependencies) {\n  for (\n    currentDependencies = currentDependencies.firstContext;\n    null !== currentDependencies;\n\n  ) {\n    if (\n      !objectIs(\n        currentDependencies.context._currentValue,\n        currentDependencies.memoizedValue\n      )\n    )\n      return !0;\n    currentDependencies = currentDependencies.next;\n  }\n  return !1;\n}\nfunction prepareToReadContext(workInProgress) {\n  currentlyRenderingFiber = workInProgress;\n  lastContextDependency = null;\n  workInProgress = workInProgress.dependencies;\n  null !== workInProgress && (workInProgress.firstContext = null);\n}\nfunction readContext(context) {\n  return readContextForConsumer(currentlyRenderingFiber, context);\n}\nfunction readContextDuringReconciliation(consumer, context) {\n  null === currentlyRenderingFiber && prepareToReadContext(consumer);\n  return readContextForConsumer(consumer, context);\n}\nfunction readContextForConsumer(consumer, context) {\n  var value = context._currentValue;\n  context = { context: context, memoizedValue: value, next: null };\n  if (null === lastContextDependency) {\n    if (null === consumer) throw Error(formatProdErrorMessage(308));\n    lastContextDependency = context;\n    consumer.dependencies = { lanes: 0, firstContext: context };\n    consumer.flags |= 524288;\n  } else lastContextDependency = lastContextDependency.next = context;\n  return value;\n}\nvar hasForceUpdate = !1;\nfunction initializeUpdateQueue(fiber) {\n  fiber.updateQueue = {\n    baseState: fiber.memoizedState,\n    firstBaseUpdate: null,\n    lastBaseUpdate: null,\n    shared: { pending: null, lanes: 0, hiddenCallbacks: null },\n    callbacks: null\n  };\n}\nfunction cloneUpdateQueue(current, workInProgress) {\n  current = current.updateQueue;\n  workInProgress.updateQueue === current &&\n    (workInProgress.updateQueue = {\n      baseState: current.baseState,\n      firstBaseUpdate: current.firstBaseUpdate,\n      lastBaseUpdate: current.lastBaseUpdate,\n      shared: current.shared,\n      callbacks: null\n    });\n}\nfunction createUpdate(lane) {\n  return { lane: lane, tag: 0, payload: null, callback: null, next: null };\n}\nfunction enqueueUpdate(fiber, update, lane) {\n  var updateQueue = fiber.updateQueue;\n  if (null === updateQueue) return null;\n  updateQueue = updateQueue.shared;\n  if (0 !== (executionContext & 2)) {\n    var pending = updateQueue.pending;\n    null === pending\n      ? (update.next = update)\n      : ((update.next = pending.next), (pending.next = update));\n    updateQueue.pending = update;\n    update = getRootForUpdatedFiber(fiber);\n    markUpdateLaneFromFiberToRoot(fiber, null, lane);\n    return update;\n  }\n  enqueueUpdate$1(fiber, updateQueue, update, lane);\n  return getRootForUpdatedFiber(fiber);\n}\nfunction entangleTransitions(root, fiber, lane) {\n  fiber = fiber.updateQueue;\n  if (null !== fiber && ((fiber = fiber.shared), 0 !== (lane & 4194176))) {\n    var queueLanes = fiber.lanes;\n    queueLanes &= root.pendingLanes;\n    lane |= queueLanes;\n    fiber.lanes = lane;\n    markRootEntangled(root, lane);\n  }\n}\nfunction enqueueCapturedUpdate(workInProgress, capturedUpdate) {\n  var queue = workInProgress.updateQueue,\n    current = workInProgress.alternate;\n  if (\n    null !== current &&\n    ((current = current.updateQueue), queue === current)\n  ) {\n    var newFirst = null,\n      newLast = null;\n    queue = queue.firstBaseUpdate;\n    if (null !== queue) {\n      do {\n        var clone = {\n          lane: queue.lane,\n          tag: queue.tag,\n          payload: queue.payload,\n          callback: null,\n          next: null\n        };\n        null === newLast\n          ? (newFirst = newLast = clone)\n          : (newLast = newLast.next = clone);\n        queue = queue.next;\n      } while (null !== queue);\n      null === newLast\n        ? (newFirst = newLast = capturedUpdate)\n        : (newLast = newLast.next = capturedUpdate);\n    } else newFirst = newLast = capturedUpdate;\n    queue = {\n      baseState: current.baseState,\n      firstBaseUpdate: newFirst,\n      lastBaseUpdate: newLast,\n      shared: current.shared,\n      callbacks: current.callbacks\n    };\n    workInProgress.updateQueue = queue;\n    return;\n  }\n  workInProgress = queue.lastBaseUpdate;\n  null === workInProgress\n    ? (queue.firstBaseUpdate = capturedUpdate)\n    : (workInProgress.next = capturedUpdate);\n  queue.lastBaseUpdate = capturedUpdate;\n}\nvar didReadFromEntangledAsyncAction = !1;\nfunction suspendIfUpdateReadFromEntangledAsyncAction() {\n  if (didReadFromEntangledAsyncAction) {\n    var entangledActionThenable = currentEntangledActionThenable;\n    if (null !== entangledActionThenable) throw entangledActionThenable;\n  }\n}\nfunction processUpdateQueue(\n  workInProgress$jscomp$0,\n  props,\n  instance$jscomp$0,\n  renderLanes\n) {\n  didReadFromEntangledAsyncAction = !1;\n  var queue = workInProgress$jscomp$0.updateQueue;\n  hasForceUpdate = !1;\n  var firstBaseUpdate = queue.firstBaseUpdate,\n    lastBaseUpdate = queue.lastBaseUpdate,\n    pendingQueue = queue.shared.pending;\n  if (null !== pendingQueue) {\n    queue.shared.pending = null;\n    var lastPendingUpdate = pendingQueue,\n      firstPendingUpdate = lastPendingUpdate.next;\n    lastPendingUpdate.next = null;\n    null === lastBaseUpdate\n      ? (firstBaseUpdate = firstPendingUpdate)\n      : (lastBaseUpdate.next = firstPendingUpdate);\n    lastBaseUpdate = lastPendingUpdate;\n    var current = workInProgress$jscomp$0.alternate;\n    null !== current &&\n      ((current = current.updateQueue),\n      (pendingQueue = current.lastBaseUpdate),\n      pendingQueue !== lastBaseUpdate &&\n        (null === pendingQueue\n          ? (current.firstBaseUpdate = firstPendingUpdate)\n          : (pendingQueue.next = firstPendingUpdate),\n        (current.lastBaseUpdate = lastPendingUpdate)));\n  }\n  if (null !== firstBaseUpdate) {\n    var newState = queue.baseState;\n    lastBaseUpdate = 0;\n    current = firstPendingUpdate = lastPendingUpdate = null;\n    pendingQueue = firstBaseUpdate;\n    do {\n      var updateLane = pendingQueue.lane & -536870913,\n        isHiddenUpdate = updateLane !== pendingQueue.lane;\n      if (\n        isHiddenUpdate\n          ? (workInProgressRootRenderLanes & updateLane) === updateLane\n          : (renderLanes & updateLane) === updateLane\n      ) {\n        0 !== updateLane &&\n          updateLane === currentEntangledLane &&\n          (didReadFromEntangledAsyncAction = !0);\n        null !== current &&\n          (current = current.next =\n            {\n              lane: 0,\n              tag: pendingQueue.tag,\n              payload: pendingQueue.payload,\n              callback: null,\n              next: null\n            });\n        a: {\n          var workInProgress = workInProgress$jscomp$0,\n            update = pendingQueue;\n          updateLane = props;\n          var instance = instance$jscomp$0;\n          switch (update.tag) {\n            case 1:\n              workInProgress = update.payload;\n              if (\"function\" === typeof workInProgress) {\n                newState = workInProgress.call(instance, newState, updateLane);\n                break a;\n              }\n              newState = workInProgress;\n              break a;\n            case 3:\n              workInProgress.flags = (workInProgress.flags & -65537) | 128;\n            case 0:\n              workInProgress = update.payload;\n              updateLane =\n                \"function\" === typeof workInProgress\n                  ? workInProgress.call(instance, newState, updateLane)\n                  : workInProgress;\n              if (null === updateLane || void 0 === updateLane) break a;\n              newState = assign({}, newState, updateLane);\n              break a;\n            case 2:\n              hasForceUpdate = !0;\n          }\n        }\n        updateLane = pendingQueue.callback;\n        null !== updateLane &&\n          ((workInProgress$jscomp$0.flags |= 64),\n          isHiddenUpdate && (workInProgress$jscomp$0.flags |= 8192),\n          (isHiddenUpdate = queue.callbacks),\n          null === isHiddenUpdate\n            ? (queue.callbacks = [updateLane])\n            : isHiddenUpdate.push(updateLane));\n      } else\n        (isHiddenUpdate = {\n          lane: updateLane,\n          tag: pendingQueue.tag,\n          payload: pendingQueue.payload,\n          callback: pendingQueue.callback,\n          next: null\n        }),\n          null === current\n            ? ((firstPendingUpdate = current = isHiddenUpdate),\n              (lastPendingUpdate = newState))\n            : (current = current.next = isHiddenUpdate),\n          (lastBaseUpdate |= updateLane);\n      pendingQueue = pendingQueue.next;\n      if (null === pendingQueue)\n        if (((pendingQueue = queue.shared.pending), null === pendingQueue))\n          break;\n        else\n          (isHiddenUpdate = pendingQueue),\n            (pendingQueue = isHiddenUpdate.next),\n            (isHiddenUpdate.next = null),\n            (queue.lastBaseUpdate = isHiddenUpdate),\n            (queue.shared.pending = null);\n    } while (1);\n    null === current && (lastPendingUpdate = newState);\n    queue.baseState = lastPendingUpdate;\n    queue.firstBaseUpdate = firstPendingUpdate;\n    queue.lastBaseUpdate = current;\n    null === firstBaseUpdate && (queue.shared.lanes = 0);\n    workInProgressRootSkippedLanes |= lastBaseUpdate;\n    workInProgress$jscomp$0.lanes = lastBaseUpdate;\n    workInProgress$jscomp$0.memoizedState = newState;\n  }\n}\nfunction callCallback(callback, context) {\n  if (\"function\" !== typeof callback)\n    throw Error(formatProdErrorMessage(191, callback));\n  callback.call(context);\n}\nfunction commitCallbacks(updateQueue, context) {\n  var callbacks = updateQueue.callbacks;\n  if (null !== callbacks)\n    for (\n      updateQueue.callbacks = null, updateQueue = 0;\n      updateQueue < callbacks.length;\n      updateQueue++\n    )\n      callCallback(callbacks[updateQueue], context);\n}\nfunction commitHookEffectListMount(flags, finishedWork) {\n  try {\n    var updateQueue = finishedWork.updateQueue,\n      lastEffect = null !== updateQueue ? updateQueue.lastEffect : null;\n    if (null !== lastEffect) {\n      var firstEffect = lastEffect.next;\n      updateQueue = firstEffect;\n      do {\n        if ((updateQueue.tag & flags) === flags) {\n          lastEffect = void 0;\n          var create = updateQueue.create,\n            inst = updateQueue.inst;\n          lastEffect = create();\n          inst.destroy = lastEffect;\n        }\n        updateQueue = updateQueue.next;\n      } while (updateQueue !== firstEffect);\n    }\n  } catch (error) {\n    captureCommitPhaseError(finishedWork, finishedWork.return, error);\n  }\n}\nfunction commitHookEffectListUnmount(\n  flags,\n  finishedWork,\n  nearestMountedAncestor$jscomp$0\n) {\n  try {\n    var updateQueue = finishedWork.updateQueue,\n      lastEffect = null !== updateQueue ? updateQueue.lastEffect : null;\n    if (null !== lastEffect) {\n      var firstEffect = lastEffect.next;\n      updateQueue = firstEffect;\n      do {\n        if ((updateQueue.tag & flags) === flags) {\n          var inst = updateQueue.inst,\n            destroy = inst.destroy;\n          if (void 0 !== destroy) {\n            inst.destroy = void 0;\n            lastEffect = finishedWork;\n            var nearestMountedAncestor = nearestMountedAncestor$jscomp$0;\n            try {\n              destroy();\n            } catch (error) {\n              captureCommitPhaseError(\n                lastEffect,\n                nearestMountedAncestor,\n                error\n              );\n            }\n          }\n        }\n        updateQueue = updateQueue.next;\n      } while (updateQueue !== firstEffect);\n    }\n  } catch (error) {\n    captureCommitPhaseError(finishedWork, finishedWork.return, error);\n  }\n}\nfunction commitClassCallbacks(finishedWork) {\n  var updateQueue = finishedWork.updateQueue;\n  if (null !== updateQueue) {\n    var instance = finishedWork.stateNode;\n    try {\n      commitCallbacks(updateQueue, instance);\n    } catch (error) {\n      captureCommitPhaseError(finishedWork, finishedWork.return, error);\n    }\n  }\n}\nfunction safelyCallComponentWillUnmount(\n  current,\n  nearestMountedAncestor,\n  instance\n) {\n  instance.props = resolveClassComponentProps(\n    current.type,\n    current.memoizedProps\n  );\n  instance.state = current.memoizedState;\n  try {\n    instance.componentWillUnmount();\n  } catch (error) {\n    captureCommitPhaseError(current, nearestMountedAncestor, error);\n  }\n}\nfunction safelyAttachRef(current, nearestMountedAncestor) {\n  try {\n    var ref = current.ref;\n    if (null !== ref) {\n      var instance = current.stateNode;\n      switch (current.tag) {\n        case 26:\n        case 27:\n        case 5:\n          var instanceToUse = instance;\n          break;\n        default:\n          instanceToUse = instance;\n      }\n      \"function\" === typeof ref\n        ? (current.refCleanup = ref(instanceToUse))\n        : (ref.current = instanceToUse);\n    }\n  } catch (error) {\n    captureCommitPhaseError(current, nearestMountedAncestor, error);\n  }\n}\nfunction safelyDetachRef(current, nearestMountedAncestor) {\n  var ref = current.ref,\n    refCleanup = current.refCleanup;\n  if (null !== ref)\n    if (\"function\" === typeof refCleanup)\n      try {\n        refCleanup();\n      } catch (error) {\n        captureCommitPhaseError(current, nearestMountedAncestor, error);\n      } finally {\n        (current.refCleanup = null),\n          (current = current.alternate),\n          null != current && (current.refCleanup = null);\n      }\n    else if (\"function\" === typeof ref)\n      try {\n        ref(null);\n      } catch (error$112) {\n        captureCommitPhaseError(current, nearestMountedAncestor, error$112);\n      }\n    else ref.current = null;\n}\nfunction commitHostMount(finishedWork) {\n  var type = finishedWork.type,\n    props = finishedWork.memoizedProps,\n    instance = finishedWork.stateNode;\n  try {\n    a: switch (type) {\n      case \"button\":\n      case \"input\":\n      case \"select\":\n      case \"textarea\":\n        props.autoFocus && instance.focus();\n        break a;\n      case \"img\":\n        props.src\n          ? (instance.src = props.src)\n          : props.srcSet && (instance.srcset = props.srcSet);\n    }\n  } catch (error) {\n    captureCommitPhaseError(finishedWork, finishedWork.return, error);\n  }\n}\nfunction commitHostUpdate(finishedWork, newProps, oldProps) {\n  try {\n    var domElement = finishedWork.stateNode;\n    updateProperties(domElement, finishedWork.type, oldProps, newProps);\n    domElement[internalPropsKey] = newProps;\n  } catch (error) {\n    captureCommitPhaseError(finishedWork, finishedWork.return, error);\n  }\n}\nfunction isHostParent(fiber) {\n  return (\n    5 === fiber.tag ||\n    3 === fiber.tag ||\n    26 === fiber.tag ||\n    27 === fiber.tag ||\n    4 === fiber.tag\n  );\n}\nfunction getHostSibling(fiber) {\n  a: for (;;) {\n    for (; null === fiber.sibling; ) {\n      if (null === fiber.return || isHostParent(fiber.return)) return null;\n      fiber = fiber.return;\n    }\n    fiber.sibling.return = fiber.return;\n    for (\n      fiber = fiber.sibling;\n      5 !== fiber.tag &&\n      6 !== fiber.tag &&\n      27 !== fiber.tag &&\n      18 !== fiber.tag;\n\n    ) {\n      if (fiber.flags & 2) continue a;\n      if (null === fiber.child || 4 === fiber.tag) continue a;\n      else (fiber.child.return = fiber), (fiber = fiber.child);\n    }\n    if (!(fiber.flags & 2)) return fiber.stateNode;\n  }\n}\nfunction insertOrAppendPlacementNodeIntoContainer(node, before, parent) {\n  var tag = node.tag;\n  if (5 === tag || 6 === tag)\n    (node = node.stateNode),\n      before\n        ? 8 === parent.nodeType\n          ? parent.parentNode.insertBefore(node, before)\n          : parent.insertBefore(node, before)\n        : (8 === parent.nodeType\n            ? ((before = parent.parentNode), before.insertBefore(node, parent))\n            : ((before = parent), before.appendChild(node)),\n          (parent = parent._reactRootContainer),\n          (null !== parent && void 0 !== parent) ||\n            null !== before.onclick ||\n            (before.onclick = noop$1));\n  else if (4 !== tag && 27 !== tag && ((node = node.child), null !== node))\n    for (\n      insertOrAppendPlacementNodeIntoContainer(node, before, parent),\n        node = node.sibling;\n      null !== node;\n\n    )\n      insertOrAppendPlacementNodeIntoContainer(node, before, parent),\n        (node = node.sibling);\n}\nfunction insertOrAppendPlacementNode(node, before, parent) {\n  var tag = node.tag;\n  if (5 === tag || 6 === tag)\n    (node = node.stateNode),\n      before ? parent.insertBefore(node, before) : parent.appendChild(node);\n  else if (4 !== tag && 27 !== tag && ((node = node.child), null !== node))\n    for (\n      insertOrAppendPlacementNode(node, before, parent), node = node.sibling;\n      null !== node;\n\n    )\n      insertOrAppendPlacementNode(node, before, parent), (node = node.sibling);\n}\nvar offscreenSubtreeIsHidden = !1,\n  offscreenSubtreeWasHidden = !1,\n  needsFormReset = !1,\n  PossiblyWeakSet = \"function\" === typeof WeakSet ? WeakSet : Set,\n  nextEffect = null,\n  shouldFireAfterActiveInstanceBlur = !1;\nfunction commitBeforeMutationEffects(root, firstChild) {\n  root = root.containerInfo;\n  eventsEnabled = _enabled;\n  root = getActiveElementDeep(root);\n  if (hasSelectionCapabilities(root)) {\n    if (\"selectionStart\" in root)\n      var JSCompiler_temp = {\n        start: root.selectionStart,\n        end: root.selectionEnd\n      };\n    else\n      a: {\n        JSCompiler_temp =\n          ((JSCompiler_temp = root.ownerDocument) &&\n            JSCompiler_temp.defaultView) ||\n          window;\n        var selection =\n          JSCompiler_temp.getSelection && JSCompiler_temp.getSelection();\n        if (selection && 0 !== selection.rangeCount) {\n          JSCompiler_temp = selection.anchorNode;\n          var anchorOffset = selection.anchorOffset,\n            focusNode = selection.focusNode;\n          selection = selection.focusOffset;\n          try {\n            JSCompiler_temp.nodeType, focusNode.nodeType;\n          } catch (e$20) {\n            JSCompiler_temp = null;\n            break a;\n          }\n          var length = 0,\n            start = -1,\n            end = -1,\n            indexWithinAnchor = 0,\n            indexWithinFocus = 0,\n            node = root,\n            parentNode = null;\n          b: for (;;) {\n            for (var next; ; ) {\n              node !== JSCompiler_temp ||\n                (0 !== anchorOffset && 3 !== node.nodeType) ||\n                (start = length + anchorOffset);\n              node !== focusNode ||\n                (0 !== selection && 3 !== node.nodeType) ||\n                (end = length + selection);\n              3 === node.nodeType && (length += node.nodeValue.length);\n              if (null === (next = node.firstChild)) break;\n              parentNode = node;\n              node = next;\n            }\n            for (;;) {\n              if (node === root) break b;\n              parentNode === JSCompiler_temp &&\n                ++indexWithinAnchor === anchorOffset &&\n                (start = length);\n              parentNode === focusNode &&\n                ++indexWithinFocus === selection &&\n                (end = length);\n              if (null !== (next = node.nextSibling)) break;\n              node = parentNode;\n              parentNode = node.parentNode;\n            }\n            node = next;\n          }\n          JSCompiler_temp =\n            -1 === start || -1 === end ? null : { start: start, end: end };\n        } else JSCompiler_temp = null;\n      }\n    JSCompiler_temp = JSCompiler_temp || { start: 0, end: 0 };\n  } else JSCompiler_temp = null;\n  selectionInformation = { focusedElem: root, selectionRange: JSCompiler_temp };\n  _enabled = !1;\n  for (nextEffect = firstChild; null !== nextEffect; )\n    if (\n      ((firstChild = nextEffect),\n      (root = firstChild.child),\n      0 !== (firstChild.subtreeFlags & 1028) && null !== root)\n    )\n      (root.return = firstChild), (nextEffect = root);\n    else\n      for (; null !== nextEffect; ) {\n        firstChild = nextEffect;\n        focusNode = firstChild.alternate;\n        root = firstChild.flags;\n        switch (firstChild.tag) {\n          case 0:\n            break;\n          case 11:\n          case 15:\n            break;\n          case 1:\n            if (0 !== (root & 1024) && null !== focusNode) {\n              root = void 0;\n              JSCompiler_temp = firstChild;\n              anchorOffset = focusNode.memoizedProps;\n              focusNode = focusNode.memoizedState;\n              selection = JSCompiler_temp.stateNode;\n              try {\n                var resolvedPrevProps = resolveClassComponentProps(\n                  JSCompiler_temp.type,\n                  anchorOffset,\n                  JSCompiler_temp.elementType === JSCompiler_temp.type\n                );\n                root = selection.getSnapshotBeforeUpdate(\n                  resolvedPrevProps,\n                  focusNode\n                );\n                selection.__reactInternalSnapshotBeforeUpdate = root;\n              } catch (error) {\n                captureCommitPhaseError(\n                  JSCompiler_temp,\n                  JSCompiler_temp.return,\n                  error\n                );\n              }\n            }\n            break;\n          case 3:\n            if (0 !== (root & 1024))\n              if (\n                ((root = firstChild.stateNode.containerInfo),\n                (JSCompiler_temp = root.nodeType),\n                9 === JSCompiler_temp)\n              )\n                clearContainerSparingly(root);\n              else if (1 === JSCompiler_temp)\n                switch (root.nodeName) {\n                  case \"HEAD\":\n                  case \"HTML\":\n                  case \"BODY\":\n                    clearContainerSparingly(root);\n                    break;\n                  default:\n                    root.textContent = \"\";\n                }\n            break;\n          case 5:\n          case 26:\n          case 27:\n          case 6:\n          case 4:\n          case 17:\n            break;\n          default:\n            if (0 !== (root & 1024)) throw Error(formatProdErrorMessage(163));\n        }\n        root = firstChild.sibling;\n        if (null !== root) {\n          root.return = firstChild.return;\n          nextEffect = root;\n          break;\n        }\n        nextEffect = firstChild.return;\n      }\n  resolvedPrevProps = shouldFireAfterActiveInstanceBlur;\n  shouldFireAfterActiveInstanceBlur = !1;\n  return resolvedPrevProps;\n}\nfunction commitLayoutEffectOnFiber(finishedRoot, current, finishedWork) {\n  var flags = finishedWork.flags;\n  switch (finishedWork.tag) {\n    case 0:\n    case 11:\n    case 15:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      flags & 4 && commitHookEffectListMount(5, finishedWork);\n      break;\n    case 1:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      if (flags & 4)\n        if (((finishedRoot = finishedWork.stateNode), null === current))\n          try {\n            finishedRoot.componentDidMount();\n          } catch (error) {\n            captureCommitPhaseError(finishedWork, finishedWork.return, error);\n          }\n        else {\n          var prevProps = resolveClassComponentProps(\n            finishedWork.type,\n            current.memoizedProps\n          );\n          current = current.memoizedState;\n          try {\n            finishedRoot.componentDidUpdate(\n              prevProps,\n              current,\n              finishedRoot.__reactInternalSnapshotBeforeUpdate\n            );\n          } catch (error$111) {\n            captureCommitPhaseError(\n              finishedWork,\n              finishedWork.return,\n              error$111\n            );\n          }\n        }\n      flags & 64 && commitClassCallbacks(finishedWork);\n      flags & 512 && safelyAttachRef(finishedWork, finishedWork.return);\n      break;\n    case 3:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      if (flags & 64 && ((flags = finishedWork.updateQueue), null !== flags)) {\n        finishedRoot = null;\n        if (null !== finishedWork.child)\n          switch (finishedWork.child.tag) {\n            case 27:\n            case 5:\n              finishedRoot = finishedWork.child.stateNode;\n              break;\n            case 1:\n              finishedRoot = finishedWork.child.stateNode;\n          }\n        try {\n          commitCallbacks(flags, finishedRoot);\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      }\n      break;\n    case 26:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      flags & 512 && safelyAttachRef(finishedWork, finishedWork.return);\n      break;\n    case 27:\n    case 5:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      null === current && flags & 4 && commitHostMount(finishedWork);\n      flags & 512 && safelyAttachRef(finishedWork, finishedWork.return);\n      break;\n    case 12:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      break;\n    case 13:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n      flags & 4 && commitSuspenseHydrationCallbacks(finishedRoot, finishedWork);\n      break;\n    case 22:\n      prevProps =\n        null !== finishedWork.memoizedState || offscreenSubtreeIsHidden;\n      if (!prevProps) {\n        current =\n          (null !== current && null !== current.memoizedState) ||\n          offscreenSubtreeWasHidden;\n        var prevOffscreenSubtreeIsHidden = offscreenSubtreeIsHidden,\n          prevOffscreenSubtreeWasHidden = offscreenSubtreeWasHidden;\n        offscreenSubtreeIsHidden = prevProps;\n        (offscreenSubtreeWasHidden = current) && !prevOffscreenSubtreeWasHidden\n          ? recursivelyTraverseReappearLayoutEffects(\n              finishedRoot,\n              finishedWork,\n              0 !== (finishedWork.subtreeFlags & 8772)\n            )\n          : recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n        offscreenSubtreeIsHidden = prevOffscreenSubtreeIsHidden;\n        offscreenSubtreeWasHidden = prevOffscreenSubtreeWasHidden;\n      }\n      flags & 512 &&\n        (\"manual\" === finishedWork.memoizedProps.mode\n          ? safelyAttachRef(finishedWork, finishedWork.return)\n          : safelyDetachRef(finishedWork, finishedWork.return));\n      break;\n    default:\n      recursivelyTraverseLayoutEffects(finishedRoot, finishedWork);\n  }\n}\nfunction detachFiberAfterEffects(fiber) {\n  var alternate = fiber.alternate;\n  null !== alternate &&\n    ((fiber.alternate = null), detachFiberAfterEffects(alternate));\n  fiber.child = null;\n  fiber.deletions = null;\n  fiber.sibling = null;\n  5 === fiber.tag &&\n    ((alternate = fiber.stateNode),\n    null !== alternate && detachDeletedInstance(alternate));\n  fiber.stateNode = null;\n  fiber.return = null;\n  fiber.dependencies = null;\n  fiber.memoizedProps = null;\n  fiber.memoizedState = null;\n  fiber.pendingProps = null;\n  fiber.stateNode = null;\n  fiber.updateQueue = null;\n}\nvar hostParent = null,\n  hostParentIsContainer = !1;\nfunction recursivelyTraverseDeletionEffects(\n  finishedRoot,\n  nearestMountedAncestor,\n  parent\n) {\n  for (parent = parent.child; null !== parent; )\n    commitDeletionEffectsOnFiber(finishedRoot, nearestMountedAncestor, parent),\n      (parent = parent.sibling);\n}\nfunction commitDeletionEffectsOnFiber(\n  finishedRoot,\n  nearestMountedAncestor,\n  deletedFiber\n) {\n  if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberUnmount)\n    try {\n      injectedHook.onCommitFiberUnmount(rendererID, deletedFiber);\n    } catch (err) {}\n  switch (deletedFiber.tag) {\n    case 26:\n      offscreenSubtreeWasHidden ||\n        safelyDetachRef(deletedFiber, nearestMountedAncestor);\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      deletedFiber.memoizedState\n        ? deletedFiber.memoizedState.count--\n        : deletedFiber.stateNode &&\n          ((deletedFiber = deletedFiber.stateNode),\n          deletedFiber.parentNode.removeChild(deletedFiber));\n      break;\n    case 27:\n      offscreenSubtreeWasHidden ||\n        safelyDetachRef(deletedFiber, nearestMountedAncestor);\n      var prevHostParent = hostParent,\n        prevHostParentIsContainer = hostParentIsContainer;\n      hostParent = deletedFiber.stateNode;\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      deletedFiber = deletedFiber.stateNode;\n      for (\n        nearestMountedAncestor = deletedFiber.attributes;\n        nearestMountedAncestor.length;\n\n      )\n        deletedFiber.removeAttributeNode(nearestMountedAncestor[0]);\n      detachDeletedInstance(deletedFiber);\n      hostParent = prevHostParent;\n      hostParentIsContainer = prevHostParentIsContainer;\n      break;\n    case 5:\n      offscreenSubtreeWasHidden ||\n        safelyDetachRef(deletedFiber, nearestMountedAncestor);\n    case 6:\n      prevHostParentIsContainer = hostParent;\n      var prevHostParentIsContainer$119 = hostParentIsContainer;\n      hostParent = null;\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      hostParent = prevHostParentIsContainer;\n      hostParentIsContainer = prevHostParentIsContainer$119;\n      if (null !== hostParent)\n        if (hostParentIsContainer)\n          try {\n            (finishedRoot = hostParent),\n              (prevHostParent = deletedFiber.stateNode),\n              8 === finishedRoot.nodeType\n                ? finishedRoot.parentNode.removeChild(prevHostParent)\n                : finishedRoot.removeChild(prevHostParent);\n          } catch (error) {\n            captureCommitPhaseError(\n              deletedFiber,\n              nearestMountedAncestor,\n              error\n            );\n          }\n        else\n          try {\n            hostParent.removeChild(deletedFiber.stateNode);\n          } catch (error) {\n            captureCommitPhaseError(\n              deletedFiber,\n              nearestMountedAncestor,\n              error\n            );\n          }\n      break;\n    case 18:\n      null !== hostParent &&\n        (hostParentIsContainer\n          ? ((nearestMountedAncestor = hostParent),\n            (deletedFiber = deletedFiber.stateNode),\n            8 === nearestMountedAncestor.nodeType\n              ? clearSuspenseBoundary(\n                  nearestMountedAncestor.parentNode,\n                  deletedFiber\n                )\n              : 1 === nearestMountedAncestor.nodeType &&\n                clearSuspenseBoundary(nearestMountedAncestor, deletedFiber),\n            retryIfBlockedOn(nearestMountedAncestor))\n          : clearSuspenseBoundary(hostParent, deletedFiber.stateNode));\n      break;\n    case 4:\n      prevHostParent = hostParent;\n      prevHostParentIsContainer = hostParentIsContainer;\n      hostParent = deletedFiber.stateNode.containerInfo;\n      hostParentIsContainer = !0;\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      hostParent = prevHostParent;\n      hostParentIsContainer = prevHostParentIsContainer;\n      break;\n    case 0:\n    case 11:\n    case 14:\n    case 15:\n      offscreenSubtreeWasHidden ||\n        commitHookEffectListUnmount(2, deletedFiber, nearestMountedAncestor);\n      offscreenSubtreeWasHidden ||\n        commitHookEffectListUnmount(4, deletedFiber, nearestMountedAncestor);\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      break;\n    case 1:\n      offscreenSubtreeWasHidden ||\n        (safelyDetachRef(deletedFiber, nearestMountedAncestor),\n        (prevHostParent = deletedFiber.stateNode),\n        \"function\" === typeof prevHostParent.componentWillUnmount &&\n          safelyCallComponentWillUnmount(\n            deletedFiber,\n            nearestMountedAncestor,\n            prevHostParent\n          ));\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      break;\n    case 21:\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      break;\n    case 22:\n      offscreenSubtreeWasHidden ||\n        safelyDetachRef(deletedFiber, nearestMountedAncestor);\n      offscreenSubtreeWasHidden =\n        (prevHostParent = offscreenSubtreeWasHidden) ||\n        null !== deletedFiber.memoizedState;\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n      offscreenSubtreeWasHidden = prevHostParent;\n      break;\n    default:\n      recursivelyTraverseDeletionEffects(\n        finishedRoot,\n        nearestMountedAncestor,\n        deletedFiber\n      );\n  }\n}\nfunction commitSuspenseHydrationCallbacks(finishedRoot, finishedWork) {\n  if (\n    null === finishedWork.memoizedState &&\n    ((finishedRoot = finishedWork.alternate),\n    null !== finishedRoot &&\n      ((finishedRoot = finishedRoot.memoizedState),\n      null !== finishedRoot &&\n        ((finishedRoot = finishedRoot.dehydrated), null !== finishedRoot)))\n  )\n    try {\n      retryIfBlockedOn(finishedRoot);\n    } catch (error) {\n      captureCommitPhaseError(finishedWork, finishedWork.return, error);\n    }\n}\nfunction getRetryCache(finishedWork) {\n  switch (finishedWork.tag) {\n    case 13:\n    case 19:\n      var retryCache = finishedWork.stateNode;\n      null === retryCache &&\n        (retryCache = finishedWork.stateNode = new PossiblyWeakSet());\n      return retryCache;\n    case 22:\n      return (\n        (finishedWork = finishedWork.stateNode),\n        (retryCache = finishedWork._retryCache),\n        null === retryCache &&\n          (retryCache = finishedWork._retryCache = new PossiblyWeakSet()),\n        retryCache\n      );\n    default:\n      throw Error(formatProdErrorMessage(435, finishedWork.tag));\n  }\n}\nfunction attachSuspenseRetryListeners(finishedWork, wakeables) {\n  var retryCache = getRetryCache(finishedWork);\n  wakeables.forEach(function (wakeable) {\n    var retry = resolveRetryWakeable.bind(null, finishedWork, wakeable);\n    retryCache.has(wakeable) ||\n      (retryCache.add(wakeable), wakeable.then(retry, retry));\n  });\n}\nfunction recursivelyTraverseMutationEffects(root$jscomp$0, parentFiber) {\n  var deletions = parentFiber.deletions;\n  if (null !== deletions)\n    for (var i = 0; i < deletions.length; i++) {\n      var childToDelete = deletions[i],\n        root = root$jscomp$0,\n        returnFiber = parentFiber,\n        parent = returnFiber;\n      a: for (; null !== parent; ) {\n        switch (parent.tag) {\n          case 27:\n          case 5:\n            hostParent = parent.stateNode;\n            hostParentIsContainer = !1;\n            break a;\n          case 3:\n            hostParent = parent.stateNode.containerInfo;\n            hostParentIsContainer = !0;\n            break a;\n          case 4:\n            hostParent = parent.stateNode.containerInfo;\n            hostParentIsContainer = !0;\n            break a;\n        }\n        parent = parent.return;\n      }\n      if (null === hostParent) throw Error(formatProdErrorMessage(160));\n      commitDeletionEffectsOnFiber(root, returnFiber, childToDelete);\n      hostParent = null;\n      hostParentIsContainer = !1;\n      root = childToDelete.alternate;\n      null !== root && (root.return = null);\n      childToDelete.return = null;\n    }\n  if (parentFiber.subtreeFlags & 13878)\n    for (parentFiber = parentFiber.child; null !== parentFiber; )\n      commitMutationEffectsOnFiber(parentFiber, root$jscomp$0),\n        (parentFiber = parentFiber.sibling);\n}\nvar currentHoistableRoot = null;\nfunction commitMutationEffectsOnFiber(finishedWork, root) {\n  var current = finishedWork.alternate,\n    flags = finishedWork.flags;\n  switch (finishedWork.tag) {\n    case 0:\n    case 11:\n    case 14:\n    case 15:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      flags & 4 &&\n        (commitHookEffectListUnmount(3, finishedWork, finishedWork.return),\n        commitHookEffectListMount(3, finishedWork),\n        commitHookEffectListUnmount(5, finishedWork, finishedWork.return));\n      break;\n    case 1:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      flags & 512 &&\n        (offscreenSubtreeWasHidden ||\n          null === current ||\n          safelyDetachRef(current, current.return));\n      flags & 64 &&\n        offscreenSubtreeIsHidden &&\n        ((finishedWork = finishedWork.updateQueue),\n        null !== finishedWork &&\n          ((flags = finishedWork.callbacks),\n          null !== flags &&\n            ((current = finishedWork.shared.hiddenCallbacks),\n            (finishedWork.shared.hiddenCallbacks =\n              null === current ? flags : current.concat(flags)))));\n      break;\n    case 26:\n      var hoistableRoot = currentHoistableRoot;\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      flags & 512 &&\n        (offscreenSubtreeWasHidden ||\n          null === current ||\n          safelyDetachRef(current, current.return));\n      if (flags & 4) {\n        var currentResource = null !== current ? current.memoizedState : null;\n        flags = finishedWork.memoizedState;\n        if (null === current)\n          if (null === flags)\n            if (null === finishedWork.stateNode) {\n              a: {\n                flags = finishedWork.type;\n                current = finishedWork.memoizedProps;\n                hoistableRoot = hoistableRoot.ownerDocument || hoistableRoot;\n                b: switch (flags) {\n                  case \"title\":\n                    currentResource =\n                      hoistableRoot.getElementsByTagName(\"title\")[0];\n                    if (\n                      !currentResource ||\n                      currentResource[internalHoistableMarker] ||\n                      currentResource[internalInstanceKey] ||\n                      \"http://www.w3.org/2000/svg\" ===\n                        currentResource.namespaceURI ||\n                      currentResource.hasAttribute(\"itemprop\")\n                    )\n                      (currentResource = hoistableRoot.createElement(flags)),\n                        hoistableRoot.head.insertBefore(\n                          currentResource,\n                          hoistableRoot.querySelector(\"head > title\")\n                        );\n                    setInitialProperties(currentResource, flags, current);\n                    currentResource[internalInstanceKey] = finishedWork;\n                    markNodeAsHoistable(currentResource);\n                    flags = currentResource;\n                    break a;\n                  case \"link\":\n                    var maybeNodes = getHydratableHoistableCache(\n                      \"link\",\n                      \"href\",\n                      hoistableRoot\n                    ).get(flags + (current.href || \"\"));\n                    if (maybeNodes)\n                      for (var i = 0; i < maybeNodes.length; i++)\n                        if (\n                          ((currentResource = maybeNodes[i]),\n                          currentResource.getAttribute(\"href\") ===\n                            (null == current.href ? null : current.href) &&\n                            currentResource.getAttribute(\"rel\") ===\n                              (null == current.rel ? null : current.rel) &&\n                            currentResource.getAttribute(\"title\") ===\n                              (null == current.title ? null : current.title) &&\n                            currentResource.getAttribute(\"crossorigin\") ===\n                              (null == current.crossOrigin\n                                ? null\n                                : current.crossOrigin))\n                        ) {\n                          maybeNodes.splice(i, 1);\n                          break b;\n                        }\n                    currentResource = hoistableRoot.createElement(flags);\n                    setInitialProperties(currentResource, flags, current);\n                    hoistableRoot.head.appendChild(currentResource);\n                    break;\n                  case \"meta\":\n                    if (\n                      (maybeNodes = getHydratableHoistableCache(\n                        \"meta\",\n                        \"content\",\n                        hoistableRoot\n                      ).get(flags + (current.content || \"\")))\n                    )\n                      for (i = 0; i < maybeNodes.length; i++)\n                        if (\n                          ((currentResource = maybeNodes[i]),\n                          currentResource.getAttribute(\"content\") ===\n                            (null == current.content\n                              ? null\n                              : \"\" + current.content) &&\n                            currentResource.getAttribute(\"name\") ===\n                              (null == current.name ? null : current.name) &&\n                            currentResource.getAttribute(\"property\") ===\n                              (null == current.property\n                                ? null\n                                : current.property) &&\n                            currentResource.getAttribute(\"http-equiv\") ===\n                              (null == current.httpEquiv\n                                ? null\n                                : current.httpEquiv) &&\n                            currentResource.getAttribute(\"charset\") ===\n                              (null == current.charSet\n                                ? null\n                                : current.charSet))\n                        ) {\n                          maybeNodes.splice(i, 1);\n                          break b;\n                        }\n                    currentResource = hoistableRoot.createElement(flags);\n                    setInitialProperties(currentResource, flags, current);\n                    hoistableRoot.head.appendChild(currentResource);\n                    break;\n                  default:\n                    throw Error(formatProdErrorMessage(468, flags));\n                }\n                currentResource[internalInstanceKey] = finishedWork;\n                markNodeAsHoistable(currentResource);\n                flags = currentResource;\n              }\n              finishedWork.stateNode = flags;\n            } else\n              mountHoistable(\n                hoistableRoot,\n                finishedWork.type,\n                finishedWork.stateNode\n              );\n          else\n            finishedWork.stateNode = acquireResource(\n              hoistableRoot,\n              flags,\n              finishedWork.memoizedProps\n            );\n        else\n          currentResource !== flags\n            ? (null === currentResource\n                ? null !== current.stateNode &&\n                  ((current = current.stateNode),\n                  current.parentNode.removeChild(current))\n                : currentResource.count--,\n              null === flags\n                ? mountHoistable(\n                    hoistableRoot,\n                    finishedWork.type,\n                    finishedWork.stateNode\n                  )\n                : acquireResource(\n                    hoistableRoot,\n                    flags,\n                    finishedWork.memoizedProps\n                  ))\n            : null === flags &&\n              null !== finishedWork.stateNode &&\n              commitHostUpdate(\n                finishedWork,\n                finishedWork.memoizedProps,\n                current.memoizedProps\n              );\n      }\n      break;\n    case 27:\n      if (flags & 4 && null === finishedWork.alternate) {\n        hoistableRoot = finishedWork.stateNode;\n        currentResource = finishedWork.memoizedProps;\n        try {\n          for (var node = hoistableRoot.firstChild; node; ) {\n            var nextNode = node.nextSibling,\n              nodeName = node.nodeName;\n            node[internalHoistableMarker] ||\n              \"HEAD\" === nodeName ||\n              \"BODY\" === nodeName ||\n              \"SCRIPT\" === nodeName ||\n              \"STYLE\" === nodeName ||\n              (\"LINK\" === nodeName &&\n                \"stylesheet\" === node.rel.toLowerCase()) ||\n              hoistableRoot.removeChild(node);\n            node = nextNode;\n          }\n          for (\n            var type = finishedWork.type, attributes = hoistableRoot.attributes;\n            attributes.length;\n\n          )\n            hoistableRoot.removeAttributeNode(attributes[0]);\n          setInitialProperties(hoistableRoot, type, currentResource);\n          hoistableRoot[internalInstanceKey] = finishedWork;\n          hoistableRoot[internalPropsKey] = currentResource;\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      }\n    case 5:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      flags & 512 &&\n        (offscreenSubtreeWasHidden ||\n          null === current ||\n          safelyDetachRef(current, current.return));\n      if (finishedWork.flags & 32) {\n        hoistableRoot = finishedWork.stateNode;\n        try {\n          setTextContent(hoistableRoot, \"\");\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      }\n      flags & 4 &&\n        null != finishedWork.stateNode &&\n        ((hoistableRoot = finishedWork.memoizedProps),\n        commitHostUpdate(\n          finishedWork,\n          hoistableRoot,\n          null !== current ? current.memoizedProps : hoistableRoot\n        ));\n      flags & 1024 && (needsFormReset = !0);\n      break;\n    case 6:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      if (flags & 4) {\n        if (null === finishedWork.stateNode)\n          throw Error(formatProdErrorMessage(162));\n        flags = finishedWork.memoizedProps;\n        current = finishedWork.stateNode;\n        try {\n          current.nodeValue = flags;\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      }\n      break;\n    case 3:\n      tagCaches = null;\n      hoistableRoot = currentHoistableRoot;\n      currentHoistableRoot = getHoistableRoot(root.containerInfo);\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      currentHoistableRoot = hoistableRoot;\n      commitReconciliationEffects(finishedWork);\n      if (flags & 4 && null !== current && current.memoizedState.isDehydrated)\n        try {\n          retryIfBlockedOn(root.containerInfo);\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      needsFormReset &&\n        ((needsFormReset = !1), recursivelyResetForms(finishedWork));\n      break;\n    case 4:\n      flags = currentHoistableRoot;\n      currentHoistableRoot = getHoistableRoot(\n        finishedWork.stateNode.containerInfo\n      );\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      currentHoistableRoot = flags;\n      break;\n    case 12:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      break;\n    case 13:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      finishedWork.child.flags & 8192 &&\n        (null !== finishedWork.memoizedState) !==\n          (null !== current && null !== current.memoizedState) &&\n        (globalMostRecentFallbackTime = now());\n      flags & 4 &&\n        ((flags = finishedWork.updateQueue),\n        null !== flags &&\n          ((finishedWork.updateQueue = null),\n          attachSuspenseRetryListeners(finishedWork, flags)));\n      break;\n    case 22:\n      flags & 512 &&\n        (offscreenSubtreeWasHidden ||\n          null === current ||\n          safelyDetachRef(current, current.return));\n      node = null !== finishedWork.memoizedState;\n      nextNode = null !== current && null !== current.memoizedState;\n      nodeName = offscreenSubtreeIsHidden;\n      type = offscreenSubtreeWasHidden;\n      offscreenSubtreeIsHidden = nodeName || node;\n      offscreenSubtreeWasHidden = type || nextNode;\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      offscreenSubtreeWasHidden = type;\n      offscreenSubtreeIsHidden = nodeName;\n      commitReconciliationEffects(finishedWork);\n      root = finishedWork.stateNode;\n      root._current = finishedWork;\n      root._visibility &= -3;\n      root._visibility |= root._pendingVisibility & 2;\n      if (\n        flags & 8192 &&\n        ((root._visibility = node\n          ? root._visibility & -2\n          : root._visibility | 1),\n        node &&\n          ((root = offscreenSubtreeIsHidden || offscreenSubtreeWasHidden),\n          null === current ||\n            nextNode ||\n            root ||\n            recursivelyTraverseDisappearLayoutEffects(finishedWork)),\n        null === finishedWork.memoizedProps ||\n          \"manual\" !== finishedWork.memoizedProps.mode)\n      )\n        a: for (current = null, root = finishedWork; ; ) {\n          if (5 === root.tag || 26 === root.tag || 27 === root.tag) {\n            if (null === current) {\n              nextNode = current = root;\n              try {\n                if (((hoistableRoot = nextNode.stateNode), node))\n                  (currentResource = hoistableRoot.style),\n                    \"function\" === typeof currentResource.setProperty\n                      ? currentResource.setProperty(\n                          \"display\",\n                          \"none\",\n                          \"important\"\n                        )\n                      : (currentResource.display = \"none\");\n                else {\n                  maybeNodes = nextNode.stateNode;\n                  i = nextNode.memoizedProps.style;\n                  var display =\n                    void 0 !== i && null !== i && i.hasOwnProperty(\"display\")\n                      ? i.display\n                      : null;\n                  maybeNodes.style.display =\n                    null == display || \"boolean\" === typeof display\n                      ? \"\"\n                      : (\"\" + display).trim();\n                }\n              } catch (error) {\n                captureCommitPhaseError(nextNode, nextNode.return, error);\n              }\n            }\n          } else if (6 === root.tag) {\n            if (null === current) {\n              nextNode = root;\n              try {\n                nextNode.stateNode.nodeValue = node\n                  ? \"\"\n                  : nextNode.memoizedProps;\n              } catch (error) {\n                captureCommitPhaseError(nextNode, nextNode.return, error);\n              }\n            }\n          } else if (\n            ((22 !== root.tag && 23 !== root.tag) ||\n              null === root.memoizedState ||\n              root === finishedWork) &&\n            null !== root.child\n          ) {\n            root.child.return = root;\n            root = root.child;\n            continue;\n          }\n          if (root === finishedWork) break a;\n          for (; null === root.sibling; ) {\n            if (null === root.return || root.return === finishedWork) break a;\n            current === root && (current = null);\n            root = root.return;\n          }\n          current === root && (current = null);\n          root.sibling.return = root.return;\n          root = root.sibling;\n        }\n      flags & 4 &&\n        ((flags = finishedWork.updateQueue),\n        null !== flags &&\n          ((current = flags.retryQueue),\n          null !== current &&\n            ((flags.retryQueue = null),\n            attachSuspenseRetryListeners(finishedWork, current))));\n      break;\n    case 19:\n      recursivelyTraverseMutationEffects(root, finishedWork);\n      commitReconciliationEffects(finishedWork);\n      flags & 4 &&\n        ((flags = finishedWork.updateQueue),\n        null !== flags &&\n          ((finishedWork.updateQueue = null),\n          attachSuspenseRetryListeners(finishedWork, flags)));\n      break;\n    case 21:\n      break;\n    default:\n      recursivelyTraverseMutationEffects(root, finishedWork),\n        commitReconciliationEffects(finishedWork);\n  }\n}\nfunction commitReconciliationEffects(finishedWork) {\n  var flags = finishedWork.flags;\n  if (flags & 2) {\n    try {\n      if (27 !== finishedWork.tag) {\n        a: {\n          for (var parent = finishedWork.return; null !== parent; ) {\n            if (isHostParent(parent)) {\n              var JSCompiler_inline_result = parent;\n              break a;\n            }\n            parent = parent.return;\n          }\n          throw Error(formatProdErrorMessage(160));\n        }\n        switch (JSCompiler_inline_result.tag) {\n          case 27:\n            var parent$jscomp$0 = JSCompiler_inline_result.stateNode,\n              before = getHostSibling(finishedWork);\n            insertOrAppendPlacementNode(finishedWork, before, parent$jscomp$0);\n            break;\n          case 5:\n            var parent$113 = JSCompiler_inline_result.stateNode;\n            JSCompiler_inline_result.flags & 32 &&\n              (setTextContent(parent$113, \"\"),\n              (JSCompiler_inline_result.flags &= -33));\n            var before$114 = getHostSibling(finishedWork);\n            insertOrAppendPlacementNode(finishedWork, before$114, parent$113);\n            break;\n          case 3:\n          case 4:\n            var parent$115 = JSCompiler_inline_result.stateNode.containerInfo,\n              before$116 = getHostSibling(finishedWork);\n            insertOrAppendPlacementNodeIntoContainer(\n              finishedWork,\n              before$116,\n              parent$115\n            );\n            break;\n          default:\n            throw Error(formatProdErrorMessage(161));\n        }\n      }\n    } catch (error) {\n      captureCommitPhaseError(finishedWork, finishedWork.return, error);\n    }\n    finishedWork.flags &= -3;\n  }\n  flags & 4096 && (finishedWork.flags &= -4097);\n}\nfunction recursivelyResetForms(parentFiber) {\n  if (parentFiber.subtreeFlags & 1024)\n    for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n      var fiber = parentFiber;\n      recursivelyResetForms(fiber);\n      5 === fiber.tag && fiber.flags & 1024 && fiber.stateNode.reset();\n      parentFiber = parentFiber.sibling;\n    }\n}\nfunction recursivelyTraverseLayoutEffects(root, parentFiber) {\n  if (parentFiber.subtreeFlags & 8772)\n    for (parentFiber = parentFiber.child; null !== parentFiber; )\n      commitLayoutEffectOnFiber(root, parentFiber.alternate, parentFiber),\n        (parentFiber = parentFiber.sibling);\n}\nfunction recursivelyTraverseDisappearLayoutEffects(parentFiber) {\n  for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n    var finishedWork = parentFiber;\n    switch (finishedWork.tag) {\n      case 0:\n      case 11:\n      case 14:\n      case 15:\n        commitHookEffectListUnmount(4, finishedWork, finishedWork.return);\n        recursivelyTraverseDisappearLayoutEffects(finishedWork);\n        break;\n      case 1:\n        safelyDetachRef(finishedWork, finishedWork.return);\n        var instance = finishedWork.stateNode;\n        \"function\" === typeof instance.componentWillUnmount &&\n          safelyCallComponentWillUnmount(\n            finishedWork,\n            finishedWork.return,\n            instance\n          );\n        recursivelyTraverseDisappearLayoutEffects(finishedWork);\n        break;\n      case 26:\n      case 27:\n      case 5:\n        safelyDetachRef(finishedWork, finishedWork.return);\n        recursivelyTraverseDisappearLayoutEffects(finishedWork);\n        break;\n      case 22:\n        safelyDetachRef(finishedWork, finishedWork.return);\n        null === finishedWork.memoizedState &&\n          recursivelyTraverseDisappearLayoutEffects(finishedWork);\n        break;\n      default:\n        recursivelyTraverseDisappearLayoutEffects(finishedWork);\n    }\n    parentFiber = parentFiber.sibling;\n  }\n}\nfunction recursivelyTraverseReappearLayoutEffects(\n  finishedRoot$jscomp$0,\n  parentFiber,\n  includeWorkInProgressEffects\n) {\n  includeWorkInProgressEffects =\n    includeWorkInProgressEffects && 0 !== (parentFiber.subtreeFlags & 8772);\n  for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n    var current = parentFiber.alternate,\n      finishedRoot = finishedRoot$jscomp$0,\n      finishedWork = parentFiber,\n      flags = finishedWork.flags;\n    switch (finishedWork.tag) {\n      case 0:\n      case 11:\n      case 15:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n        commitHookEffectListMount(4, finishedWork);\n        break;\n      case 1:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n        current = finishedWork;\n        finishedRoot = current.stateNode;\n        if (\"function\" === typeof finishedRoot.componentDidMount)\n          try {\n            finishedRoot.componentDidMount();\n          } catch (error) {\n            captureCommitPhaseError(current, current.return, error);\n          }\n        current = finishedWork;\n        finishedRoot = current.updateQueue;\n        if (null !== finishedRoot) {\n          var instance = current.stateNode;\n          try {\n            var hiddenCallbacks = finishedRoot.shared.hiddenCallbacks;\n            if (null !== hiddenCallbacks)\n              for (\n                finishedRoot.shared.hiddenCallbacks = null, finishedRoot = 0;\n                finishedRoot < hiddenCallbacks.length;\n                finishedRoot++\n              )\n                callCallback(hiddenCallbacks[finishedRoot], instance);\n          } catch (error) {\n            captureCommitPhaseError(current, current.return, error);\n          }\n        }\n        includeWorkInProgressEffects &&\n          flags & 64 &&\n          commitClassCallbacks(finishedWork);\n        safelyAttachRef(finishedWork, finishedWork.return);\n        break;\n      case 26:\n      case 27:\n      case 5:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n        includeWorkInProgressEffects &&\n          null === current &&\n          flags & 4 &&\n          commitHostMount(finishedWork);\n        safelyAttachRef(finishedWork, finishedWork.return);\n        break;\n      case 12:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n        break;\n      case 13:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n        includeWorkInProgressEffects &&\n          flags & 4 &&\n          commitSuspenseHydrationCallbacks(finishedRoot, finishedWork);\n        break;\n      case 22:\n        null === finishedWork.memoizedState &&\n          recursivelyTraverseReappearLayoutEffects(\n            finishedRoot,\n            finishedWork,\n            includeWorkInProgressEffects\n          );\n        safelyAttachRef(finishedWork, finishedWork.return);\n        break;\n      default:\n        recursivelyTraverseReappearLayoutEffects(\n          finishedRoot,\n          finishedWork,\n          includeWorkInProgressEffects\n        );\n    }\n    parentFiber = parentFiber.sibling;\n  }\n}\nfunction commitOffscreenPassiveMountEffects(current, finishedWork) {\n  var previousCache = null;\n  null !== current &&\n    null !== current.memoizedState &&\n    null !== current.memoizedState.cachePool &&\n    (previousCache = current.memoizedState.cachePool.pool);\n  current = null;\n  null !== finishedWork.memoizedState &&\n    null !== finishedWork.memoizedState.cachePool &&\n    (current = finishedWork.memoizedState.cachePool.pool);\n  current !== previousCache &&\n    (null != current && current.refCount++,\n    null != previousCache && releaseCache(previousCache));\n}\nfunction commitCachePassiveMountEffect(current, finishedWork) {\n  current = null;\n  null !== finishedWork.alternate &&\n    (current = finishedWork.alternate.memoizedState.cache);\n  finishedWork = finishedWork.memoizedState.cache;\n  finishedWork !== current &&\n    (finishedWork.refCount++, null != current && releaseCache(current));\n}\nfunction recursivelyTraversePassiveMountEffects(\n  root,\n  parentFiber,\n  committedLanes,\n  committedTransitions\n) {\n  if (parentFiber.subtreeFlags & 10256)\n    for (parentFiber = parentFiber.child; null !== parentFiber; )\n      commitPassiveMountOnFiber(\n        root,\n        parentFiber,\n        committedLanes,\n        committedTransitions\n      ),\n        (parentFiber = parentFiber.sibling);\n}\nfunction commitPassiveMountOnFiber(\n  finishedRoot,\n  finishedWork,\n  committedLanes,\n  committedTransitions\n) {\n  var flags = finishedWork.flags;\n  switch (finishedWork.tag) {\n    case 0:\n    case 11:\n    case 15:\n      recursivelyTraversePassiveMountEffects(\n        finishedRoot,\n        finishedWork,\n        committedLanes,\n        committedTransitions\n      );\n      flags & 2048 && commitHookEffectListMount(9, finishedWork);\n      break;\n    case 3:\n      recursivelyTraversePassiveMountEffects(\n        finishedRoot,\n        finishedWork,\n        committedLanes,\n        committedTransitions\n      );\n      flags & 2048 &&\n        ((finishedRoot = null),\n        null !== finishedWork.alternate &&\n          (finishedRoot = finishedWork.alternate.memoizedState.cache),\n        (finishedWork = finishedWork.memoizedState.cache),\n        finishedWork !== finishedRoot &&\n          (finishedWork.refCount++,\n          null != finishedRoot && releaseCache(finishedRoot)));\n      break;\n    case 12:\n      if (flags & 2048) {\n        recursivelyTraversePassiveMountEffects(\n          finishedRoot,\n          finishedWork,\n          committedLanes,\n          committedTransitions\n        );\n        finishedRoot = finishedWork.stateNode;\n        try {\n          var _finishedWork$memoize2 = finishedWork.memoizedProps,\n            id = _finishedWork$memoize2.id,\n            onPostCommit = _finishedWork$memoize2.onPostCommit;\n          \"function\" === typeof onPostCommit &&\n            onPostCommit(\n              id,\n              null === finishedWork.alternate ? \"mount\" : \"update\",\n              finishedRoot.passiveEffectDuration,\n              -0\n            );\n        } catch (error) {\n          captureCommitPhaseError(finishedWork, finishedWork.return, error);\n        }\n      } else\n        recursivelyTraversePassiveMountEffects(\n          finishedRoot,\n          finishedWork,\n          committedLanes,\n          committedTransitions\n        );\n      break;\n    case 23:\n      break;\n    case 22:\n      _finishedWork$memoize2 = finishedWork.stateNode;\n      null !== finishedWork.memoizedState\n        ? _finishedWork$memoize2._visibility & 4\n          ? recursivelyTraversePassiveMountEffects(\n              finishedRoot,\n              finishedWork,\n              committedLanes,\n              committedTransitions\n            )\n          : recursivelyTraverseAtomicPassiveEffects(finishedRoot, finishedWork)\n        : _finishedWork$memoize2._visibility & 4\n          ? recursivelyTraversePassiveMountEffects(\n              finishedRoot,\n              finishedWork,\n              committedLanes,\n              committedTransitions\n            )\n          : ((_finishedWork$memoize2._visibility |= 4),\n            recursivelyTraverseReconnectPassiveEffects(\n              finishedRoot,\n              finishedWork,\n              committedLanes,\n              committedTransitions,\n              0 !== (finishedWork.subtreeFlags & 10256)\n            ));\n      flags & 2048 &&\n        commitOffscreenPassiveMountEffects(\n          finishedWork.alternate,\n          finishedWork\n        );\n      break;\n    case 24:\n      recursivelyTraversePassiveMountEffects(\n        finishedRoot,\n        finishedWork,\n        committedLanes,\n        committedTransitions\n      );\n      flags & 2048 &&\n        commitCachePassiveMountEffect(finishedWork.alternate, finishedWork);\n      break;\n    default:\n      recursivelyTraversePassiveMountEffects(\n        finishedRoot,\n        finishedWork,\n        committedLanes,\n        committedTransitions\n      );\n  }\n}\nfunction recursivelyTraverseReconnectPassiveEffects(\n  finishedRoot$jscomp$0,\n  parentFiber,\n  committedLanes$jscomp$0,\n  committedTransitions$jscomp$0,\n  includeWorkInProgressEffects\n) {\n  includeWorkInProgressEffects =\n    includeWorkInProgressEffects && 0 !== (parentFiber.subtreeFlags & 10256);\n  for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n    var finishedRoot = finishedRoot$jscomp$0,\n      finishedWork = parentFiber,\n      committedLanes = committedLanes$jscomp$0,\n      committedTransitions = committedTransitions$jscomp$0,\n      flags = finishedWork.flags;\n    switch (finishedWork.tag) {\n      case 0:\n      case 11:\n      case 15:\n        recursivelyTraverseReconnectPassiveEffects(\n          finishedRoot,\n          finishedWork,\n          committedLanes,\n          committedTransitions,\n          includeWorkInProgressEffects\n        );\n        commitHookEffectListMount(8, finishedWork);\n        break;\n      case 23:\n        break;\n      case 22:\n        var instance = finishedWork.stateNode;\n        null !== finishedWork.memoizedState\n          ? instance._visibility & 4\n            ? recursivelyTraverseReconnectPassiveEffects(\n                finishedRoot,\n                finishedWork,\n                committedLanes,\n                committedTransitions,\n                includeWorkInProgressEffects\n              )\n            : recursivelyTraverseAtomicPassiveEffects(\n                finishedRoot,\n                finishedWork\n              )\n          : ((instance._visibility |= 4),\n            recursivelyTraverseReconnectPassiveEffects(\n              finishedRoot,\n              finishedWork,\n              committedLanes,\n              committedTransitions,\n              includeWorkInProgressEffects\n            ));\n        includeWorkInProgressEffects &&\n          flags & 2048 &&\n          commitOffscreenPassiveMountEffects(\n            finishedWork.alternate,\n            finishedWork\n          );\n        break;\n      case 24:\n        recursivelyTraverseReconnectPassiveEffects(\n          finishedRoot,\n          finishedWork,\n          committedLanes,\n          committedTransitions,\n          includeWorkInProgressEffects\n        );\n        includeWorkInProgressEffects &&\n          flags & 2048 &&\n          commitCachePassiveMountEffect(finishedWork.alternate, finishedWork);\n        break;\n      default:\n        recursivelyTraverseReconnectPassiveEffects(\n          finishedRoot,\n          finishedWork,\n          committedLanes,\n          committedTransitions,\n          includeWorkInProgressEffects\n        );\n    }\n    parentFiber = parentFiber.sibling;\n  }\n}\nfunction recursivelyTraverseAtomicPassiveEffects(\n  finishedRoot$jscomp$0,\n  parentFiber\n) {\n  if (parentFiber.subtreeFlags & 10256)\n    for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n      var finishedRoot = finishedRoot$jscomp$0,\n        finishedWork = parentFiber,\n        flags = finishedWork.flags;\n      switch (finishedWork.tag) {\n        case 22:\n          recursivelyTraverseAtomicPassiveEffects(finishedRoot, finishedWork);\n          flags & 2048 &&\n            commitOffscreenPassiveMountEffects(\n              finishedWork.alternate,\n              finishedWork\n            );\n          break;\n        case 24:\n          recursivelyTraverseAtomicPassiveEffects(finishedRoot, finishedWork);\n          flags & 2048 &&\n            commitCachePassiveMountEffect(finishedWork.alternate, finishedWork);\n          break;\n        default:\n          recursivelyTraverseAtomicPassiveEffects(finishedRoot, finishedWork);\n      }\n      parentFiber = parentFiber.sibling;\n    }\n}\nvar suspenseyCommitFlag = 8192;\nfunction recursivelyAccumulateSuspenseyCommit(parentFiber) {\n  if (parentFiber.subtreeFlags & suspenseyCommitFlag)\n    for (parentFiber = parentFiber.child; null !== parentFiber; )\n      accumulateSuspenseyCommitOnFiber(parentFiber),\n        (parentFiber = parentFiber.sibling);\n}\nfunction accumulateSuspenseyCommitOnFiber(fiber) {\n  switch (fiber.tag) {\n    case 26:\n      recursivelyAccumulateSuspenseyCommit(fiber);\n      fiber.flags & suspenseyCommitFlag &&\n        null !== fiber.memoizedState &&\n        suspendResource(\n          currentHoistableRoot,\n          fiber.memoizedState,\n          fiber.memoizedProps\n        );\n      break;\n    case 5:\n      recursivelyAccumulateSuspenseyCommit(fiber);\n      break;\n    case 3:\n    case 4:\n      var previousHoistableRoot = currentHoistableRoot;\n      currentHoistableRoot = getHoistableRoot(fiber.stateNode.containerInfo);\n      recursivelyAccumulateSuspenseyCommit(fiber);\n      currentHoistableRoot = previousHoistableRoot;\n      break;\n    case 22:\n      null === fiber.memoizedState &&\n        ((previousHoistableRoot = fiber.alternate),\n        null !== previousHoistableRoot &&\n        null !== previousHoistableRoot.memoizedState\n          ? ((previousHoistableRoot = suspenseyCommitFlag),\n            (suspenseyCommitFlag = 16777216),\n            recursivelyAccumulateSuspenseyCommit(fiber),\n            (suspenseyCommitFlag = previousHoistableRoot))\n          : recursivelyAccumulateSuspenseyCommit(fiber));\n      break;\n    default:\n      recursivelyAccumulateSuspenseyCommit(fiber);\n  }\n}\nfunction detachAlternateSiblings(parentFiber) {\n  var previousFiber = parentFiber.alternate;\n  if (\n    null !== previousFiber &&\n    ((parentFiber = previousFiber.child), null !== parentFiber)\n  ) {\n    previousFiber.child = null;\n    do\n      (previousFiber = parentFiber.sibling),\n        (parentFiber.sibling = null),\n        (parentFiber = previousFiber);\n    while (null !== parentFiber);\n  }\n}\nfunction recursivelyTraversePassiveUnmountEffects(parentFiber) {\n  var deletions = parentFiber.deletions;\n  if (0 !== (parentFiber.flags & 16)) {\n    if (null !== deletions)\n      for (var i = 0; i < deletions.length; i++) {\n        var childToDelete = deletions[i];\n        nextEffect = childToDelete;\n        commitPassiveUnmountEffectsInsideOfDeletedTree_begin(\n          childToDelete,\n          parentFiber\n        );\n      }\n    detachAlternateSiblings(parentFiber);\n  }\n  if (parentFiber.subtreeFlags & 10256)\n    for (parentFiber = parentFiber.child; null !== parentFiber; )\n      commitPassiveUnmountOnFiber(parentFiber),\n        (parentFiber = parentFiber.sibling);\n}\nfunction commitPassiveUnmountOnFiber(finishedWork) {\n  switch (finishedWork.tag) {\n    case 0:\n    case 11:\n    case 15:\n      recursivelyTraversePassiveUnmountEffects(finishedWork);\n      finishedWork.flags & 2048 &&\n        commitHookEffectListUnmount(9, finishedWork, finishedWork.return);\n      break;\n    case 3:\n      recursivelyTraversePassiveUnmountEffects(finishedWork);\n      break;\n    case 12:\n      recursivelyTraversePassiveUnmountEffects(finishedWork);\n      break;\n    case 22:\n      var instance = finishedWork.stateNode;\n      null !== finishedWork.memoizedState &&\n      instance._visibility & 4 &&\n      (null === finishedWork.return || 13 !== finishedWork.return.tag)\n        ? ((instance._visibility &= -5),\n          recursivelyTraverseDisconnectPassiveEffects(finishedWork))\n        : recursivelyTraversePassiveUnmountEffects(finishedWork);\n      break;\n    default:\n      recursivelyTraversePassiveUnmountEffects(finishedWork);\n  }\n}\nfunction recursivelyTraverseDisconnectPassiveEffects(parentFiber) {\n  var deletions = parentFiber.deletions;\n  if (0 !== (parentFiber.flags & 16)) {\n    if (null !== deletions)\n      for (var i = 0; i < deletions.length; i++) {\n        var childToDelete = deletions[i];\n        nextEffect = childToDelete;\n        commitPassiveUnmountEffectsInsideOfDeletedTree_begin(\n          childToDelete,\n          parentFiber\n        );\n      }\n    detachAlternateSiblings(parentFiber);\n  }\n  for (parentFiber = parentFiber.child; null !== parentFiber; ) {\n    deletions = parentFiber;\n    switch (deletions.tag) {\n      case 0:\n      case 11:\n      case 15:\n        commitHookEffectListUnmount(8, deletions, deletions.return);\n        recursivelyTraverseDisconnectPassiveEffects(deletions);\n        break;\n      case 22:\n        i = deletions.stateNode;\n        i._visibility & 4 &&\n          ((i._visibility &= -5),\n          recursivelyTraverseDisconnectPassiveEffects(deletions));\n        break;\n      default:\n        recursivelyTraverseDisconnectPassiveEffects(deletions);\n    }\n    parentFiber = parentFiber.sibling;\n  }\n}\nfunction commitPassiveUnmountEffectsInsideOfDeletedTree_begin(\n  deletedSubtreeRoot,\n  nearestMountedAncestor\n) {\n  for (; null !== nextEffect; ) {\n    var fiber = nextEffect;\n    switch (fiber.tag) {\n      case 0:\n      case 11:\n      case 15:\n        commitHookEffectListUnmount(8, fiber, nearestMountedAncestor);\n        break;\n      case 23:\n      case 22:\n        if (\n          null !== fiber.memoizedState &&\n          null !== fiber.memoizedState.cachePool\n        ) {\n          var cache = fiber.memoizedState.cachePool.pool;\n          null != cache && cache.refCount++;\n        }\n        break;\n      case 24:\n        releaseCache(fiber.memoizedState.cache);\n    }\n    cache = fiber.child;\n    if (null !== cache) (cache.return = fiber), (nextEffect = cache);\n    else\n      a: for (fiber = deletedSubtreeRoot; null !== nextEffect; ) {\n        cache = nextEffect;\n        var sibling = cache.sibling,\n          returnFiber = cache.return;\n        detachFiberAfterEffects(cache);\n        if (cache === fiber) {\n          nextEffect = null;\n          break a;\n        }\n        if (null !== sibling) {\n          sibling.return = returnFiber;\n          nextEffect = sibling;\n          break a;\n        }\n        nextEffect = returnFiber;\n      }\n  }\n}\nfunction FiberNode(tag, pendingProps, key, mode) {\n  this.tag = tag;\n  this.key = key;\n  this.sibling =\n    this.child =\n    this.return =\n    this.stateNode =\n    this.type =\n    this.elementType =\n      null;\n  this.index = 0;\n  this.refCleanup = this.ref = null;\n  this.pendingProps = pendingProps;\n  this.dependencies =\n    this.memoizedState =\n    this.updateQueue =\n    this.memoizedProps =\n      null;\n  this.mode = mode;\n  this.subtreeFlags = this.flags = 0;\n  this.deletions = null;\n  this.childLanes = this.lanes = 0;\n  this.alternate = null;\n}\nfunction createFiberImplClass(tag, pendingProps, key, mode) {\n  return new FiberNode(tag, pendingProps, key, mode);\n}\nfunction shouldConstruct(Component) {\n  Component = Component.prototype;\n  return !(!Component || !Component.isReactComponent);\n}\nfunction createWorkInProgress(current, pendingProps) {\n  var workInProgress = current.alternate;\n  null === workInProgress\n    ? ((workInProgress = createFiberImplClass(\n        current.tag,\n        pendingProps,\n        current.key,\n        current.mode\n      )),\n      (workInProgress.elementType = current.elementType),\n      (workInProgress.type = current.type),\n      (workInProgress.stateNode = current.stateNode),\n      (workInProgress.alternate = current),\n      (current.alternate = workInProgress))\n    : ((workInProgress.pendingProps = pendingProps),\n      (workInProgress.type = current.type),\n      (workInProgress.flags = 0),\n      (workInProgress.subtreeFlags = 0),\n      (workInProgress.deletions = null));\n  workInProgress.flags = current.flags & 31457280;\n  workInProgress.childLanes = current.childLanes;\n  workInProgress.lanes = current.lanes;\n  workInProgress.child = current.child;\n  workInProgress.memoizedProps = current.memoizedProps;\n  workInProgress.memoizedState = current.memoizedState;\n  workInProgress.updateQueue = current.updateQueue;\n  pendingProps = current.dependencies;\n  workInProgress.dependencies =\n    null === pendingProps\n      ? null\n      : { lanes: pendingProps.lanes, firstContext: pendingProps.firstContext };\n  workInProgress.sibling = current.sibling;\n  workInProgress.index = current.index;\n  workInProgress.ref = current.ref;\n  workInProgress.refCleanup = current.refCleanup;\n  return workInProgress;\n}\nfunction resetWorkInProgress(workInProgress, renderLanes) {\n  workInProgress.flags &= 31457282;\n  var current = workInProgress.alternate;\n  null === current\n    ? ((workInProgress.childLanes = 0),\n      (workInProgress.lanes = renderLanes),\n      (workInProgress.child = null),\n      (workInProgress.subtreeFlags = 0),\n      (workInProgress.memoizedProps = null),\n      (workInProgress.memoizedState = null),\n      (workInProgress.updateQueue = null),\n      (workInProgress.dependencies = null),\n      (workInProgress.stateNode = null))\n    : ((workInProgress.childLanes = current.childLanes),\n      (workInProgress.lanes = current.lanes),\n      (workInProgress.child = current.child),\n      (workInProgress.subtreeFlags = 0),\n      (workInProgress.deletions = null),\n      (workInProgress.memoizedProps = current.memoizedProps),\n      (workInProgress.memoizedState = current.memoizedState),\n      (workInProgress.updateQueue = current.updateQueue),\n      (workInProgress.type = current.type),\n      (renderLanes = current.dependencies),\n      (workInProgress.dependencies =\n        null === renderLanes\n          ? null\n          : {\n              lanes: renderLanes.lanes,\n              firstContext: renderLanes.firstContext\n            }));\n  return workInProgress;\n}\nfunction createFiberFromTypeAndProps(\n  type,\n  key,\n  pendingProps,\n  owner,\n  mode,\n  lanes\n) {\n  var fiberTag = 0;\n  owner = type;\n  if (\"function\" === typeof type) shouldConstruct(type) && (fiberTag = 1);\n  else if (\"string\" === typeof type)\n    fiberTag = isHostHoistableType(\n      type,\n      pendingProps,\n      contextStackCursor.current\n    )\n      ? 26\n      : \"html\" === type || \"head\" === type || \"body\" === type\n        ? 27\n        : 5;\n  else\n    a: switch (type) {\n      case REACT_FRAGMENT_TYPE:\n        return createFiberFromFragment(pendingProps.children, mode, lanes, key);\n      case REACT_STRICT_MODE_TYPE:\n        fiberTag = 8;\n        mode |= 24;\n        break;\n      case REACT_PROFILER_TYPE:\n        return (\n          (type = createFiberImplClass(12, pendingProps, key, mode | 2)),\n          (type.elementType = REACT_PROFILER_TYPE),\n          (type.lanes = lanes),\n          type\n        );\n      case REACT_SUSPENSE_TYPE:\n        return (\n          (type = createFiberImplClass(13, pendingProps, key, mode)),\n          (type.elementType = REACT_SUSPENSE_TYPE),\n          (type.lanes = lanes),\n          type\n        );\n      case REACT_SUSPENSE_LIST_TYPE:\n        return (\n          (type = createFiberImplClass(19, pendingProps, key, mode)),\n          (type.elementType = REACT_SUSPENSE_LIST_TYPE),\n          (type.lanes = lanes),\n          type\n        );\n      case REACT_OFFSCREEN_TYPE:\n        return createFiberFromOffscreen(pendingProps, mode, lanes, key);\n      default:\n        if (\"object\" === typeof type && null !== type)\n          switch (type.$$typeof) {\n            case REACT_PROVIDER_TYPE:\n            case REACT_CONTEXT_TYPE:\n              fiberTag = 10;\n              break a;\n            case REACT_CONSUMER_TYPE:\n              fiberTag = 9;\n              break a;\n            case REACT_FORWARD_REF_TYPE:\n              fiberTag = 11;\n              break a;\n            case REACT_MEMO_TYPE:\n              fiberTag = 14;\n              break a;\n            case REACT_LAZY_TYPE:\n              fiberTag = 16;\n              owner = null;\n              break a;\n          }\n        fiberTag = 29;\n        pendingProps = Error(\n          formatProdErrorMessage(130, null === type ? \"null\" : typeof type, \"\")\n        );\n        owner = null;\n    }\n  key = createFiberImplClass(fiberTag, pendingProps, key, mode);\n  key.elementType = type;\n  key.type = owner;\n  key.lanes = lanes;\n  return key;\n}\nfunction createFiberFromFragment(elements, mode, lanes, key) {\n  elements = createFiberImplClass(7, elements, key, mode);\n  elements.lanes = lanes;\n  return elements;\n}\nfunction createFiberFromOffscreen(pendingProps, mode, lanes, key) {\n  pendingProps = createFiberImplClass(22, pendingProps, key, mode);\n  pendingProps.elementType = REACT_OFFSCREEN_TYPE;\n  pendingProps.lanes = lanes;\n  var primaryChildInstance = {\n    _visibility: 1,\n    _pendingVisibility: 1,\n    _pendingMarkers: null,\n    _retryCache: null,\n    _transitions: null,\n    _current: null,\n    detach: function () {\n      var fiber = primaryChildInstance._current;\n      if (null === fiber) throw Error(formatProdErrorMessage(456));\n      if (0 === (primaryChildInstance._pendingVisibility & 2)) {\n        var root = enqueueConcurrentRenderForLane(fiber, 2);\n        null !== root &&\n          ((primaryChildInstance._pendingVisibility |= 2),\n          scheduleUpdateOnFiber(root, fiber, 2));\n      }\n    },\n    attach: function () {\n      var fiber = primaryChildInstance._current;\n      if (null === fiber) throw Error(formatProdErrorMessage(456));\n      if (0 !== (primaryChildInstance._pendingVisibility & 2)) {\n        var root = enqueueConcurrentRenderForLane(fiber, 2);\n        null !== root &&\n          ((primaryChildInstance._pendingVisibility &= -3),\n          scheduleUpdateOnFiber(root, fiber, 2));\n      }\n    }\n  };\n  pendingProps.stateNode = primaryChildInstance;\n  return pendingProps;\n}\nfunction createFiberFromText(content, mode, lanes) {\n  content = createFiberImplClass(6, content, null, mode);\n  content.lanes = lanes;\n  return content;\n}\nfunction createFiberFromPortal(portal, mode, lanes) {\n  mode = createFiberImplClass(\n    4,\n    null !== portal.children ? portal.children : [],\n    portal.key,\n    mode\n  );\n  mode.lanes = lanes;\n  mode.stateNode = {\n    containerInfo: portal.containerInfo,\n    pendingChildren: null,\n    implementation: portal.implementation\n  };\n  return mode;\n}\nfunction markUpdate(workInProgress) {\n  workInProgress.flags |= 4;\n}\nfunction preloadResourceAndSuspendIfNeeded(workInProgress, resource) {\n  if (\"stylesheet\" !== resource.type || 0 !== (resource.state.loading & 4))\n    workInProgress.flags &= -16777217;\n  else if (((workInProgress.flags |= 16777216), !preloadResource(resource))) {\n    resource = suspenseHandlerStackCursor.current;\n    if (\n      null !== resource &&\n      ((workInProgressRootRenderLanes & 4194176) ===\n      workInProgressRootRenderLanes\n        ? null !== shellBoundary\n        : ((workInProgressRootRenderLanes & 62914560) !==\n            workInProgressRootRenderLanes &&\n            0 === (workInProgressRootRenderLanes & 536870912)) ||\n          resource !== shellBoundary)\n    )\n      throw (\n        ((suspendedThenable = noopSuspenseyCommitThenable),\n        SuspenseyCommitException)\n      );\n    workInProgress.flags |= 8192;\n  }\n}\nfunction scheduleRetryEffect(workInProgress, retryQueue) {\n  null !== retryQueue && (workInProgress.flags |= 4);\n  workInProgress.flags & 16384 &&\n    ((retryQueue =\n      22 !== workInProgress.tag ? claimNextRetryLane() : 536870912),\n    (workInProgress.lanes |= retryQueue),\n    (workInProgressSuspendedRetryLanes |= retryQueue));\n}\nfunction cutOffTailIfNeeded(renderState, hasRenderedATailFallback) {\n  if (!isHydrating)\n    switch (renderState.tailMode) {\n      case \"hidden\":\n        hasRenderedATailFallback = renderState.tail;\n        for (var lastTailNode = null; null !== hasRenderedATailFallback; )\n          null !== hasRenderedATailFallback.alternate &&\n            (lastTailNode = hasRenderedATailFallback),\n            (hasRenderedATailFallback = hasRenderedATailFallback.sibling);\n        null === lastTailNode\n          ? (renderState.tail = null)\n          : (lastTailNode.sibling = null);\n        break;\n      case \"collapsed\":\n        lastTailNode = renderState.tail;\n        for (var lastTailNode$131 = null; null !== lastTailNode; )\n          null !== lastTailNode.alternate && (lastTailNode$131 = lastTailNode),\n            (lastTailNode = lastTailNode.sibling);\n        null === lastTailNode$131\n          ? hasRenderedATailFallback || null === renderState.tail\n            ? (renderState.tail = null)\n            : (renderState.tail.sibling = null)\n          : (lastTailNode$131.sibling = null);\n    }\n}\nfunction bubbleProperties(completedWork) {\n  var didBailout =\n      null !== completedWork.alternate &&\n      completedWork.alternate.child === completedWork.child,\n    newChildLanes = 0,\n    subtreeFlags = 0;\n  if (didBailout)\n    for (var child$132 = completedWork.child; null !== child$132; )\n      (newChildLanes |= child$132.lanes | child$132.childLanes),\n        (subtreeFlags |= child$132.subtreeFlags & 31457280),\n        (subtreeFlags |= child$132.flags & 31457280),\n        (child$132.return = completedWork),\n        (child$132 = child$132.sibling);\n  else\n    for (child$132 = completedWork.child; null !== child$132; )\n      (newChildLanes |= child$132.lanes | child$132.childLanes),\n        (subtreeFlags |= child$132.subtreeFlags),\n        (subtreeFlags |= child$132.flags),\n        (child$132.return = completedWork),\n        (child$132 = child$132.sibling);\n  completedWork.subtreeFlags |= subtreeFlags;\n  completedWork.childLanes = newChildLanes;\n  return didBailout;\n}\nfunction completeWork(current, workInProgress, renderLanes) {\n  var newProps = workInProgress.pendingProps;\n  popTreeContext(workInProgress);\n  switch (workInProgress.tag) {\n    case 16:\n    case 15:\n    case 0:\n    case 11:\n    case 7:\n    case 8:\n    case 12:\n    case 9:\n    case 14:\n      return bubbleProperties(workInProgress), null;\n    case 1:\n      return bubbleProperties(workInProgress), null;\n    case 3:\n      renderLanes = workInProgress.stateNode;\n      newProps = null;\n      null !== current && (newProps = current.memoizedState.cache);\n      workInProgress.memoizedState.cache !== newProps &&\n        (workInProgress.flags |= 2048);\n      popProvider(CacheContext);\n      popHostContainer();\n      renderLanes.pendingContext &&\n        ((renderLanes.context = renderLanes.pendingContext),\n        (renderLanes.pendingContext = null));\n      if (null === current || null === current.child)\n        popHydrationState(workInProgress)\n          ? markUpdate(workInProgress)\n          : null === current ||\n            (current.memoizedState.isDehydrated &&\n              0 === (workInProgress.flags & 256)) ||\n            ((workInProgress.flags |= 1024),\n            null !== hydrationErrors &&\n              (queueRecoverableErrors(hydrationErrors),\n              (hydrationErrors = null)));\n      bubbleProperties(workInProgress);\n      return null;\n    case 26:\n      return (\n        (renderLanes = workInProgress.memoizedState),\n        null === current\n          ? (markUpdate(workInProgress),\n            null !== renderLanes\n              ? (bubbleProperties(workInProgress),\n                preloadResourceAndSuspendIfNeeded(workInProgress, renderLanes))\n              : (bubbleProperties(workInProgress),\n                (workInProgress.flags &= -16777217)))\n          : renderLanes\n            ? renderLanes !== current.memoizedState\n              ? (markUpdate(workInProgress),\n                bubbleProperties(workInProgress),\n                preloadResourceAndSuspendIfNeeded(workInProgress, renderLanes))\n              : (bubbleProperties(workInProgress),\n                (workInProgress.flags &= -16777217))\n            : (current.memoizedProps !== newProps && markUpdate(workInProgress),\n              bubbleProperties(workInProgress),\n              (workInProgress.flags &= -16777217)),\n        null\n      );\n    case 27:\n      popHostContext(workInProgress);\n      renderLanes = rootInstanceStackCursor.current;\n      var type = workInProgress.type;\n      if (null !== current && null != workInProgress.stateNode)\n        current.memoizedProps !== newProps && markUpdate(workInProgress);\n      else {\n        if (!newProps) {\n          if (null === workInProgress.stateNode)\n            throw Error(formatProdErrorMessage(166));\n          bubbleProperties(workInProgress);\n          return null;\n        }\n        current = contextStackCursor.current;\n        popHydrationState(workInProgress)\n          ? prepareToHydrateHostInstance(workInProgress, current)\n          : ((current = resolveSingletonInstance(type, newProps, renderLanes)),\n            (workInProgress.stateNode = current),\n            markUpdate(workInProgress));\n      }\n      bubbleProperties(workInProgress);\n      return null;\n    case 5:\n      popHostContext(workInProgress);\n      renderLanes = workInProgress.type;\n      if (null !== current && null != workInProgress.stateNode)\n        current.memoizedProps !== newProps && markUpdate(workInProgress);\n      else {\n        if (!newProps) {\n          if (null === workInProgress.stateNode)\n            throw Error(formatProdErrorMessage(166));\n          bubbleProperties(workInProgress);\n          return null;\n        }\n        current = contextStackCursor.current;\n        if (popHydrationState(workInProgress))\n          prepareToHydrateHostInstance(workInProgress, current);\n        else {\n          type = getOwnerDocumentFromRootContainer(\n            rootInstanceStackCursor.current\n          );\n          switch (current) {\n            case 1:\n              current = type.createElementNS(\n                \"http://www.w3.org/2000/svg\",\n                renderLanes\n              );\n              break;\n            case 2:\n              current = type.createElementNS(\n                \"http://www.w3.org/1998/Math/MathML\",\n                renderLanes\n              );\n              break;\n            default:\n              switch (renderLanes) {\n                case \"svg\":\n                  current = type.createElementNS(\n                    \"http://www.w3.org/2000/svg\",\n                    renderLanes\n                  );\n                  break;\n                case \"math\":\n                  current = type.createElementNS(\n                    \"http://www.w3.org/1998/Math/MathML\",\n                    renderLanes\n                  );\n                  break;\n                case \"script\":\n                  current = type.createElement(\"div\");\n                  current.innerHTML = \"<script>\\x3c/script>\";\n                  current = current.removeChild(current.firstChild);\n                  break;\n                case \"select\":\n                  current =\n                    \"string\" === typeof newProps.is\n                      ? type.createElement(\"select\", { is: newProps.is })\n                      : type.createElement(\"select\");\n                  newProps.multiple\n                    ? (current.multiple = !0)\n                    : newProps.size && (current.size = newProps.size);\n                  break;\n                default:\n                  current =\n                    \"string\" === typeof newProps.is\n                      ? type.createElement(renderLanes, { is: newProps.is })\n                      : type.createElement(renderLanes);\n              }\n          }\n          current[internalInstanceKey] = workInProgress;\n          current[internalPropsKey] = newProps;\n          a: for (type = workInProgress.child; null !== type; ) {\n            if (5 === type.tag || 6 === type.tag)\n              current.appendChild(type.stateNode);\n            else if (4 !== type.tag && 27 !== type.tag && null !== type.child) {\n              type.child.return = type;\n              type = type.child;\n              continue;\n            }\n            if (type === workInProgress) break a;\n            for (; null === type.sibling; ) {\n              if (null === type.return || type.return === workInProgress)\n                break a;\n              type = type.return;\n            }\n            type.sibling.return = type.return;\n            type = type.sibling;\n          }\n          workInProgress.stateNode = current;\n          a: switch (\n            (setInitialProperties(current, renderLanes, newProps), renderLanes)\n          ) {\n            case \"button\":\n            case \"input\":\n            case \"select\":\n            case \"textarea\":\n              current = !!newProps.autoFocus;\n              break a;\n            case \"img\":\n              current = !0;\n              break a;\n            default:\n              current = !1;\n          }\n          current && markUpdate(workInProgress);\n        }\n      }\n      bubbleProperties(workInProgress);\n      workInProgress.flags &= -16777217;\n      return null;\n    case 6:\n      if (current && null != workInProgress.stateNode)\n        current.memoizedProps !== newProps && markUpdate(workInProgress);\n      else {\n        if (\"string\" !== typeof newProps && null === workInProgress.stateNode)\n          throw Error(formatProdErrorMessage(166));\n        current = rootInstanceStackCursor.current;\n        if (popHydrationState(workInProgress)) {\n          current = workInProgress.stateNode;\n          renderLanes = workInProgress.memoizedProps;\n          newProps = null;\n          type = hydrationParentFiber;\n          if (null !== type)\n            switch (type.tag) {\n              case 27:\n              case 5:\n                newProps = type.memoizedProps;\n            }\n          current[internalInstanceKey] = workInProgress;\n          current =\n            current.nodeValue === renderLanes ||\n            (null !== newProps && !0 === newProps.suppressHydrationWarning) ||\n            checkForUnmatchedText(current.nodeValue, renderLanes)\n              ? !0\n              : !1;\n          current || throwOnHydrationMismatch(workInProgress);\n        } else\n          (current =\n            getOwnerDocumentFromRootContainer(current).createTextNode(\n              newProps\n            )),\n            (current[internalInstanceKey] = workInProgress),\n            (workInProgress.stateNode = current);\n      }\n      bubbleProperties(workInProgress);\n      return null;\n    case 13:\n      newProps = workInProgress.memoizedState;\n      if (\n        null === current ||\n        (null !== current.memoizedState &&\n          null !== current.memoizedState.dehydrated)\n      ) {\n        type = popHydrationState(workInProgress);\n        if (null !== newProps && null !== newProps.dehydrated) {\n          if (null === current) {\n            if (!type) throw Error(formatProdErrorMessage(318));\n            type = workInProgress.memoizedState;\n            type = null !== type ? type.dehydrated : null;\n            if (!type) throw Error(formatProdErrorMessage(317));\n            type[internalInstanceKey] = workInProgress;\n          } else\n            resetHydrationState(),\n              0 === (workInProgress.flags & 128) &&\n                (workInProgress.memoizedState = null),\n              (workInProgress.flags |= 4);\n          bubbleProperties(workInProgress);\n          type = !1;\n        } else\n          null !== hydrationErrors &&\n            (queueRecoverableErrors(hydrationErrors), (hydrationErrors = null)),\n            (type = !0);\n        if (!type) {\n          if (workInProgress.flags & 256)\n            return popSuspenseHandler(workInProgress), workInProgress;\n          popSuspenseHandler(workInProgress);\n          return null;\n        }\n      }\n      popSuspenseHandler(workInProgress);\n      if (0 !== (workInProgress.flags & 128))\n        return (workInProgress.lanes = renderLanes), workInProgress;\n      renderLanes = null !== newProps;\n      current = null !== current && null !== current.memoizedState;\n      if (renderLanes) {\n        newProps = workInProgress.child;\n        type = null;\n        null !== newProps.alternate &&\n          null !== newProps.alternate.memoizedState &&\n          null !== newProps.alternate.memoizedState.cachePool &&\n          (type = newProps.alternate.memoizedState.cachePool.pool);\n        var cache$144 = null;\n        null !== newProps.memoizedState &&\n          null !== newProps.memoizedState.cachePool &&\n          (cache$144 = newProps.memoizedState.cachePool.pool);\n        cache$144 !== type && (newProps.flags |= 2048);\n      }\n      renderLanes !== current &&\n        renderLanes &&\n        (workInProgress.child.flags |= 8192);\n      scheduleRetryEffect(workInProgress, workInProgress.updateQueue);\n      bubbleProperties(workInProgress);\n      return null;\n    case 4:\n      return (\n        popHostContainer(),\n        null === current &&\n          listenToAllSupportedEvents(workInProgress.stateNode.containerInfo),\n        bubbleProperties(workInProgress),\n        null\n      );\n    case 10:\n      return (\n        popProvider(workInProgress.type), bubbleProperties(workInProgress), null\n      );\n    case 19:\n      pop(suspenseStackCursor);\n      type = workInProgress.memoizedState;\n      if (null === type) return bubbleProperties(workInProgress), null;\n      newProps = 0 !== (workInProgress.flags & 128);\n      cache$144 = type.rendering;\n      if (null === cache$144)\n        if (newProps) cutOffTailIfNeeded(type, !1);\n        else {\n          if (\n            0 !== workInProgressRootExitStatus ||\n            (null !== current && 0 !== (current.flags & 128))\n          )\n            for (current = workInProgress.child; null !== current; ) {\n              cache$144 = findFirstSuspended(current);\n              if (null !== cache$144) {\n                workInProgress.flags |= 128;\n                cutOffTailIfNeeded(type, !1);\n                current = cache$144.updateQueue;\n                workInProgress.updateQueue = current;\n                scheduleRetryEffect(workInProgress, current);\n                workInProgress.subtreeFlags = 0;\n                current = renderLanes;\n                for (renderLanes = workInProgress.child; null !== renderLanes; )\n                  resetWorkInProgress(renderLanes, current),\n                    (renderLanes = renderLanes.sibling);\n                push(\n                  suspenseStackCursor,\n                  (suspenseStackCursor.current & 1) | 2\n                );\n                return workInProgress.child;\n              }\n              current = current.sibling;\n            }\n          null !== type.tail &&\n            now() > workInProgressRootRenderTargetTime &&\n            ((workInProgress.flags |= 128),\n            (newProps = !0),\n            cutOffTailIfNeeded(type, !1),\n            (workInProgress.lanes = 4194304));\n        }\n      else {\n        if (!newProps)\n          if (((current = findFirstSuspended(cache$144)), null !== current)) {\n            if (\n              ((workInProgress.flags |= 128),\n              (newProps = !0),\n              (current = current.updateQueue),\n              (workInProgress.updateQueue = current),\n              scheduleRetryEffect(workInProgress, current),\n              cutOffTailIfNeeded(type, !0),\n              null === type.tail &&\n                \"hidden\" === type.tailMode &&\n                !cache$144.alternate &&\n                !isHydrating)\n            )\n              return bubbleProperties(workInProgress), null;\n          } else\n            2 * now() - type.renderingStartTime >\n              workInProgressRootRenderTargetTime &&\n              536870912 !== renderLanes &&\n              ((workInProgress.flags |= 128),\n              (newProps = !0),\n              cutOffTailIfNeeded(type, !1),\n              (workInProgress.lanes = 4194304));\n        type.isBackwards\n          ? ((cache$144.sibling = workInProgress.child),\n            (workInProgress.child = cache$144))\n          : ((current = type.last),\n            null !== current\n              ? (current.sibling = cache$144)\n              : (workInProgress.child = cache$144),\n            (type.last = cache$144));\n      }\n      if (null !== type.tail)\n        return (\n          (workInProgress = type.tail),\n          (type.rendering = workInProgress),\n          (type.tail = workInProgress.sibling),\n          (type.renderingStartTime = now()),\n          (workInProgress.sibling = null),\n          (current = suspenseStackCursor.current),\n          push(suspenseStackCursor, newProps ? (current & 1) | 2 : current & 1),\n          workInProgress\n        );\n      bubbleProperties(workInProgress);\n      return null;\n    case 22:\n    case 23:\n      return (\n        popSuspenseHandler(workInProgress),\n        popHiddenContext(),\n        (newProps = null !== workInProgress.memoizedState),\n        null !== current\n          ? (null !== current.memoizedState) !== newProps &&\n            (workInProgress.flags |= 8192)\n          : newProps && (workInProgress.flags |= 8192),\n        newProps\n          ? 0 !== (renderLanes & 536870912) &&\n            0 === (workInProgress.flags & 128) &&\n            (bubbleProperties(workInProgress),\n            workInProgress.subtreeFlags & 6 && (workInProgress.flags |= 8192))\n          : bubbleProperties(workInProgress),\n        (renderLanes = workInProgress.updateQueue),\n        null !== renderLanes &&\n          scheduleRetryEffect(workInProgress, renderLanes.retryQueue),\n        (renderLanes = null),\n        null !== current &&\n          null !== current.memoizedState &&\n          null !== current.memoizedState.cachePool &&\n          (renderLanes = current.memoizedState.cachePool.pool),\n        (newProps = null),\n        null !== workInProgress.memoizedState &&\n          null !== workInProgress.memoizedState.cachePool &&\n          (newProps = workInProgress.memoizedState.cachePool.pool),\n        newProps !== renderLanes && (workInProgress.flags |= 2048),\n        null !== current && pop(resumedCache),\n        null\n      );\n    case 24:\n      return (\n        (renderLanes = null),\n        null !== current && (renderLanes = current.memoizedState.cache),\n        workInProgress.memoizedState.cache !== renderLanes &&\n          (workInProgress.flags |= 2048),\n        popProvider(CacheContext),\n        bubbleProperties(workInProgress),\n        null\n      );\n    case 25:\n      return null;\n  }\n  throw Error(formatProdErrorMessage(156, workInProgress.tag));\n}\nfunction unwindWork(current, workInProgress) {\n  popTreeContext(workInProgress);\n  switch (workInProgress.tag) {\n    case 1:\n      return (\n        (current = workInProgress.flags),\n        current & 65536\n          ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n          : null\n      );\n    case 3:\n      return (\n        popProvider(CacheContext),\n        popHostContainer(),\n        (current = workInProgress.flags),\n        0 !== (current & 65536) && 0 === (current & 128)\n          ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n          : null\n      );\n    case 26:\n    case 27:\n    case 5:\n      return popHostContext(workInProgress), null;\n    case 13:\n      popSuspenseHandler(workInProgress);\n      current = workInProgress.memoizedState;\n      if (null !== current && null !== current.dehydrated) {\n        if (null === workInProgress.alternate)\n          throw Error(formatProdErrorMessage(340));\n        resetHydrationState();\n      }\n      current = workInProgress.flags;\n      return current & 65536\n        ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n        : null;\n    case 19:\n      return pop(suspenseStackCursor), null;\n    case 4:\n      return popHostContainer(), null;\n    case 10:\n      return popProvider(workInProgress.type), null;\n    case 22:\n    case 23:\n      return (\n        popSuspenseHandler(workInProgress),\n        popHiddenContext(),\n        null !== current && pop(resumedCache),\n        (current = workInProgress.flags),\n        current & 65536\n          ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n          : null\n      );\n    case 24:\n      return popProvider(CacheContext), null;\n    case 25:\n      return null;\n    default:\n      return null;\n  }\n}\nfunction unwindInterruptedWork(current, interruptedWork) {\n  popTreeContext(interruptedWork);\n  switch (interruptedWork.tag) {\n    case 3:\n      popProvider(CacheContext);\n      popHostContainer();\n      break;\n    case 26:\n    case 27:\n    case 5:\n      popHostContext(interruptedWork);\n      break;\n    case 4:\n      popHostContainer();\n      break;\n    case 13:\n      popSuspenseHandler(interruptedWork);\n      break;\n    case 19:\n      pop(suspenseStackCursor);\n      break;\n    case 10:\n      popProvider(interruptedWork.type);\n      break;\n    case 22:\n    case 23:\n      popSuspenseHandler(interruptedWork);\n      popHiddenContext();\n      null !== current && pop(resumedCache);\n      break;\n    case 24:\n      popProvider(CacheContext);\n  }\n}\nvar DefaultAsyncDispatcher = {\n    getCacheForType: function (resourceType) {\n      var cache = readContext(CacheContext),\n        cacheForType = cache.data.get(resourceType);\n      void 0 === cacheForType &&\n        ((cacheForType = resourceType()),\n        cache.data.set(resourceType, cacheForType));\n      return cacheForType;\n    }\n  },\n  PossiblyWeakMap = \"function\" === typeof WeakMap ? WeakMap : Map,\n  executionContext = 0,\n  workInProgressRoot = null,\n  workInProgress = null,\n  workInProgressRootRenderLanes = 0,\n  workInProgressSuspendedReason = 0,\n  workInProgressThrownValue = null,\n  workInProgressRootDidSkipSuspendedSiblings = !1,\n  workInProgressRootIsPrerendering = !1,\n  workInProgressRootDidAttachPingListener = !1,\n  entangledRenderLanes = 0,\n  workInProgressRootExitStatus = 0,\n  workInProgressRootSkippedLanes = 0,\n  workInProgressRootInterleavedUpdatedLanes = 0,\n  workInProgressRootPingedLanes = 0,\n  workInProgressDeferredLane = 0,\n  workInProgressSuspendedRetryLanes = 0,\n  workInProgressRootConcurrentErrors = null,\n  workInProgressRootRecoverableErrors = null,\n  workInProgressRootDidIncludeRecursiveRenderUpdate = !1,\n  globalMostRecentFallbackTime = 0,\n  workInProgressRootRenderTargetTime = Infinity,\n  workInProgressTransitions = null,\n  legacyErrorBoundariesThatAlreadyFailed = null,\n  rootDoesHavePassiveEffects = !1,\n  rootWithPendingPassiveEffects = null,\n  pendingPassiveEffectsLanes = 0,\n  pendingPassiveEffectsRemainingLanes = 0,\n  pendingPassiveTransitions = null,\n  nestedUpdateCount = 0,\n  rootWithNestedUpdates = null;\nfunction requestUpdateLane() {\n  if (0 !== (executionContext & 2) && 0 !== workInProgressRootRenderLanes)\n    return workInProgressRootRenderLanes & -workInProgressRootRenderLanes;\n  if (null !== ReactSharedInternals.T) {\n    var actionScopeLane = currentEntangledLane;\n    return 0 !== actionScopeLane ? actionScopeLane : requestTransitionLane();\n  }\n  return resolveUpdatePriority();\n}\nfunction requestDeferredLane() {\n  0 === workInProgressDeferredLane &&\n    (workInProgressDeferredLane =\n      0 === (workInProgressRootRenderLanes & 536870912) || isHydrating\n        ? claimNextTransitionLane()\n        : 536870912);\n  var suspenseHandler = suspenseHandlerStackCursor.current;\n  null !== suspenseHandler && (suspenseHandler.flags |= 32);\n  return workInProgressDeferredLane;\n}\nfunction scheduleUpdateOnFiber(root, fiber, lane) {\n  if (\n    (root === workInProgressRoot && 2 === workInProgressSuspendedReason) ||\n    null !== root.cancelPendingCommit\n  )\n    prepareFreshStack(root, 0),\n      markRootSuspended(\n        root,\n        workInProgressRootRenderLanes,\n        workInProgressDeferredLane,\n        !1\n      );\n  markRootUpdated$1(root, lane);\n  if (0 === (executionContext & 2) || root !== workInProgressRoot)\n    root === workInProgressRoot &&\n      (0 === (executionContext & 2) &&\n        (workInProgressRootInterleavedUpdatedLanes |= lane),\n      4 === workInProgressRootExitStatus &&\n        markRootSuspended(\n          root,\n          workInProgressRootRenderLanes,\n          workInProgressDeferredLane,\n          !1\n        )),\n      ensureRootIsScheduled(root);\n}\nfunction performWorkOnRoot(root$jscomp$0, lanes, forceSync) {\n  if (0 !== (executionContext & 6)) throw Error(formatProdErrorMessage(327));\n  var shouldTimeSlice =\n      (!forceSync &&\n        0 === (lanes & 60) &&\n        0 === (lanes & root$jscomp$0.expiredLanes)) ||\n      checkIfRootIsPrerendering(root$jscomp$0, lanes),\n    exitStatus = shouldTimeSlice\n      ? renderRootConcurrent(root$jscomp$0, lanes)\n      : renderRootSync(root$jscomp$0, lanes, !0),\n    renderWasConcurrent = shouldTimeSlice;\n  do {\n    if (0 === exitStatus) {\n      workInProgressRootIsPrerendering &&\n        !shouldTimeSlice &&\n        markRootSuspended(root$jscomp$0, lanes, 0, !1);\n      break;\n    } else if (6 === exitStatus)\n      markRootSuspended(\n        root$jscomp$0,\n        lanes,\n        0,\n        !workInProgressRootDidSkipSuspendedSiblings\n      );\n    else {\n      forceSync = root$jscomp$0.current.alternate;\n      if (\n        renderWasConcurrent &&\n        !isRenderConsistentWithExternalStores(forceSync)\n      ) {\n        exitStatus = renderRootSync(root$jscomp$0, lanes, !1);\n        renderWasConcurrent = !1;\n        continue;\n      }\n      if (2 === exitStatus) {\n        renderWasConcurrent = lanes;\n        if (root$jscomp$0.errorRecoveryDisabledLanes & renderWasConcurrent)\n          var JSCompiler_inline_result = 0;\n        else\n          (JSCompiler_inline_result = root$jscomp$0.pendingLanes & -536870913),\n            (JSCompiler_inline_result =\n              0 !== JSCompiler_inline_result\n                ? JSCompiler_inline_result\n                : JSCompiler_inline_result & 536870912\n                  ? 536870912\n                  : 0);\n        if (0 !== JSCompiler_inline_result) {\n          lanes = JSCompiler_inline_result;\n          a: {\n            var root = root$jscomp$0;\n            exitStatus = workInProgressRootConcurrentErrors;\n            var wasRootDehydrated = root.current.memoizedState.isDehydrated;\n            wasRootDehydrated &&\n              (prepareFreshStack(root, JSCompiler_inline_result).flags |= 256);\n            JSCompiler_inline_result = renderRootSync(\n              root,\n              JSCompiler_inline_result,\n              !1\n            );\n            if (2 !== JSCompiler_inline_result) {\n              if (\n                workInProgressRootDidAttachPingListener &&\n                !wasRootDehydrated\n              ) {\n                root.errorRecoveryDisabledLanes |= renderWasConcurrent;\n                workInProgressRootInterleavedUpdatedLanes |=\n                  renderWasConcurrent;\n                exitStatus = 4;\n                break a;\n              }\n              renderWasConcurrent = workInProgressRootRecoverableErrors;\n              workInProgressRootRecoverableErrors = exitStatus;\n              null !== renderWasConcurrent &&\n                queueRecoverableErrors(renderWasConcurrent);\n            }\n            exitStatus = JSCompiler_inline_result;\n          }\n          renderWasConcurrent = !1;\n          if (2 !== exitStatus) continue;\n        }\n      }\n      if (1 === exitStatus) {\n        prepareFreshStack(root$jscomp$0, 0);\n        markRootSuspended(root$jscomp$0, lanes, 0, !0);\n        break;\n      }\n      a: {\n        shouldTimeSlice = root$jscomp$0;\n        switch (exitStatus) {\n          case 0:\n          case 1:\n            throw Error(formatProdErrorMessage(345));\n          case 4:\n            if ((lanes & 4194176) === lanes) {\n              markRootSuspended(\n                shouldTimeSlice,\n                lanes,\n                workInProgressDeferredLane,\n                !workInProgressRootDidSkipSuspendedSiblings\n              );\n              break a;\n            }\n            break;\n          case 2:\n            workInProgressRootRecoverableErrors = null;\n            break;\n          case 3:\n          case 5:\n            break;\n          default:\n            throw Error(formatProdErrorMessage(329));\n        }\n        shouldTimeSlice.finishedWork = forceSync;\n        shouldTimeSlice.finishedLanes = lanes;\n        if (\n          (lanes & 62914560) === lanes &&\n          ((renderWasConcurrent = globalMostRecentFallbackTime + 300 - now()),\n          10 < renderWasConcurrent)\n        ) {\n          markRootSuspended(\n            shouldTimeSlice,\n            lanes,\n            workInProgressDeferredLane,\n            !workInProgressRootDidSkipSuspendedSiblings\n          );\n          if (0 !== getNextLanes(shouldTimeSlice, 0)) break a;\n          shouldTimeSlice.timeoutHandle = scheduleTimeout(\n            commitRootWhenReady.bind(\n              null,\n              shouldTimeSlice,\n              forceSync,\n              workInProgressRootRecoverableErrors,\n              workInProgressTransitions,\n              workInProgressRootDidIncludeRecursiveRenderUpdate,\n              lanes,\n              workInProgressDeferredLane,\n              workInProgressRootInterleavedUpdatedLanes,\n              workInProgressSuspendedRetryLanes,\n              workInProgressRootDidSkipSuspendedSiblings,\n              2,\n              -0,\n              0\n            ),\n            renderWasConcurrent\n          );\n          break a;\n        }\n        commitRootWhenReady(\n          shouldTimeSlice,\n          forceSync,\n          workInProgressRootRecoverableErrors,\n          workInProgressTransitions,\n          workInProgressRootDidIncludeRecursiveRenderUpdate,\n          lanes,\n          workInProgressDeferredLane,\n          workInProgressRootInterleavedUpdatedLanes,\n          workInProgressSuspendedRetryLanes,\n          workInProgressRootDidSkipSuspendedSiblings,\n          0,\n          -0,\n          0\n        );\n      }\n    }\n    break;\n  } while (1);\n  ensureRootIsScheduled(root$jscomp$0);\n}\nfunction queueRecoverableErrors(errors) {\n  null === workInProgressRootRecoverableErrors\n    ? (workInProgressRootRecoverableErrors = errors)\n    : workInProgressRootRecoverableErrors.push.apply(\n        workInProgressRootRecoverableErrors,\n        errors\n      );\n}\nfunction commitRootWhenReady(\n  root,\n  finishedWork,\n  recoverableErrors,\n  transitions,\n  didIncludeRenderPhaseUpdate,\n  lanes,\n  spawnedLane,\n  updatedLanes,\n  suspendedRetryLanes,\n  didSkipSuspendedSiblings,\n  suspendedCommitReason,\n  completedRenderStartTime,\n  completedRenderEndTime\n) {\n  var subtreeFlags = finishedWork.subtreeFlags;\n  if (subtreeFlags & 8192 || 16785408 === (subtreeFlags & 16785408))\n    if (\n      ((suspendedState = { stylesheets: null, count: 0, unsuspend: noop }),\n      accumulateSuspenseyCommitOnFiber(finishedWork),\n      (finishedWork = waitForCommitToBeReady()),\n      null !== finishedWork)\n    ) {\n      root.cancelPendingCommit = finishedWork(\n        commitRoot.bind(\n          null,\n          root,\n          recoverableErrors,\n          transitions,\n          didIncludeRenderPhaseUpdate,\n          spawnedLane,\n          updatedLanes,\n          suspendedRetryLanes,\n          1,\n          completedRenderStartTime,\n          completedRenderEndTime\n        )\n      );\n      markRootSuspended(root, lanes, spawnedLane, !didSkipSuspendedSiblings);\n      return;\n    }\n  commitRoot(\n    root,\n    recoverableErrors,\n    transitions,\n    didIncludeRenderPhaseUpdate,\n    spawnedLane,\n    updatedLanes,\n    suspendedRetryLanes,\n    suspendedCommitReason,\n    completedRenderStartTime,\n    completedRenderEndTime\n  );\n}\nfunction isRenderConsistentWithExternalStores(finishedWork) {\n  for (var node = finishedWork; ; ) {\n    var tag = node.tag;\n    if (\n      (0 === tag || 11 === tag || 15 === tag) &&\n      node.flags & 16384 &&\n      ((tag = node.updateQueue),\n      null !== tag && ((tag = tag.stores), null !== tag))\n    )\n      for (var i = 0; i < tag.length; i++) {\n        var check = tag[i],\n          getSnapshot = check.getSnapshot;\n        check = check.value;\n        try {\n          if (!objectIs(getSnapshot(), check)) return !1;\n        } catch (error) {\n          return !1;\n        }\n      }\n    tag = node.child;\n    if (node.subtreeFlags & 16384 && null !== tag)\n      (tag.return = node), (node = tag);\n    else {\n      if (node === finishedWork) break;\n      for (; null === node.sibling; ) {\n        if (null === node.return || node.return === finishedWork) return !0;\n        node = node.return;\n      }\n      node.sibling.return = node.return;\n      node = node.sibling;\n    }\n  }\n  return !0;\n}\nfunction markRootSuspended(\n  root,\n  suspendedLanes,\n  spawnedLane,\n  didAttemptEntireTree\n) {\n  suspendedLanes &= ~workInProgressRootPingedLanes;\n  suspendedLanes &= ~workInProgressRootInterleavedUpdatedLanes;\n  root.suspendedLanes |= suspendedLanes;\n  root.pingedLanes &= ~suspendedLanes;\n  didAttemptEntireTree && (root.warmLanes |= suspendedLanes);\n  didAttemptEntireTree = root.expirationTimes;\n  for (var lanes = suspendedLanes; 0 < lanes; ) {\n    var index$6 = 31 - clz32(lanes),\n      lane = 1 << index$6;\n    didAttemptEntireTree[index$6] = -1;\n    lanes &= ~lane;\n  }\n  0 !== spawnedLane &&\n    markSpawnedDeferredLane(root, spawnedLane, suspendedLanes);\n}\nfunction flushSyncWork$1() {\n  return 0 === (executionContext & 6)\n    ? (flushSyncWorkAcrossRoots_impl(0, !1), !1)\n    : !0;\n}\nfunction resetWorkInProgressStack() {\n  if (null !== workInProgress) {\n    if (0 === workInProgressSuspendedReason)\n      var interruptedWork = workInProgress.return;\n    else\n      (interruptedWork = workInProgress),\n        (lastContextDependency = currentlyRenderingFiber = null),\n        resetHooksOnUnwind(interruptedWork),\n        (thenableState$1 = null),\n        (thenableIndexCounter$1 = 0),\n        (interruptedWork = workInProgress);\n    for (; null !== interruptedWork; )\n      unwindInterruptedWork(interruptedWork.alternate, interruptedWork),\n        (interruptedWork = interruptedWork.return);\n    workInProgress = null;\n  }\n}\nfunction prepareFreshStack(root, lanes) {\n  root.finishedWork = null;\n  root.finishedLanes = 0;\n  var timeoutHandle = root.timeoutHandle;\n  -1 !== timeoutHandle &&\n    ((root.timeoutHandle = -1), cancelTimeout(timeoutHandle));\n  timeoutHandle = root.cancelPendingCommit;\n  null !== timeoutHandle &&\n    ((root.cancelPendingCommit = null), timeoutHandle());\n  resetWorkInProgressStack();\n  workInProgressRoot = root;\n  workInProgress = timeoutHandle = createWorkInProgress(root.current, null);\n  workInProgressRootRenderLanes = lanes;\n  workInProgressSuspendedReason = 0;\n  workInProgressThrownValue = null;\n  workInProgressRootDidSkipSuspendedSiblings = !1;\n  workInProgressRootIsPrerendering = checkIfRootIsPrerendering(root, lanes);\n  workInProgressRootDidAttachPingListener = !1;\n  workInProgressSuspendedRetryLanes =\n    workInProgressDeferredLane =\n    workInProgressRootPingedLanes =\n    workInProgressRootInterleavedUpdatedLanes =\n    workInProgressRootSkippedLanes =\n    workInProgressRootExitStatus =\n      0;\n  workInProgressRootRecoverableErrors = workInProgressRootConcurrentErrors =\n    null;\n  workInProgressRootDidIncludeRecursiveRenderUpdate = !1;\n  0 !== (lanes & 8) && (lanes |= lanes & 32);\n  var allEntangledLanes = root.entangledLanes;\n  if (0 !== allEntangledLanes)\n    for (\n      root = root.entanglements, allEntangledLanes &= lanes;\n      0 < allEntangledLanes;\n\n    ) {\n      var index$4 = 31 - clz32(allEntangledLanes),\n        lane = 1 << index$4;\n      lanes |= root[index$4];\n      allEntangledLanes &= ~lane;\n    }\n  entangledRenderLanes = lanes;\n  finishQueueingConcurrentUpdates();\n  return timeoutHandle;\n}\nfunction handleThrow(root, thrownValue) {\n  currentlyRenderingFiber$1 = null;\n  ReactSharedInternals.H = ContextOnlyDispatcher;\n  thrownValue === SuspenseException\n    ? ((thrownValue = getSuspendedThenable()),\n      (workInProgressSuspendedReason = 3))\n    : thrownValue === SuspenseyCommitException\n      ? ((thrownValue = getSuspendedThenable()),\n        (workInProgressSuspendedReason = 4))\n      : (workInProgressSuspendedReason =\n          thrownValue === SelectiveHydrationException\n            ? 8\n            : null !== thrownValue &&\n                \"object\" === typeof thrownValue &&\n                \"function\" === typeof thrownValue.then\n              ? 6\n              : 1);\n  workInProgressThrownValue = thrownValue;\n  null === workInProgress &&\n    ((workInProgressRootExitStatus = 1),\n    logUncaughtError(\n      root,\n      createCapturedValueAtFiber(thrownValue, root.current)\n    ));\n}\nfunction pushDispatcher() {\n  var prevDispatcher = ReactSharedInternals.H;\n  ReactSharedInternals.H = ContextOnlyDispatcher;\n  return null === prevDispatcher ? ContextOnlyDispatcher : prevDispatcher;\n}\nfunction pushAsyncDispatcher() {\n  var prevAsyncDispatcher = ReactSharedInternals.A;\n  ReactSharedInternals.A = DefaultAsyncDispatcher;\n  return prevAsyncDispatcher;\n}\nfunction renderDidSuspendDelayIfPossible() {\n  workInProgressRootExitStatus = 4;\n  workInProgressRootDidSkipSuspendedSiblings ||\n    ((workInProgressRootRenderLanes & 4194176) !==\n      workInProgressRootRenderLanes &&\n      null !== suspenseHandlerStackCursor.current) ||\n    (workInProgressRootIsPrerendering = !0);\n  (0 === (workInProgressRootSkippedLanes & 134217727) &&\n    0 === (workInProgressRootInterleavedUpdatedLanes & 134217727)) ||\n    null === workInProgressRoot ||\n    markRootSuspended(\n      workInProgressRoot,\n      workInProgressRootRenderLanes,\n      workInProgressDeferredLane,\n      !1\n    );\n}\nfunction renderRootSync(root, lanes, shouldYieldForPrerendering) {\n  var prevExecutionContext = executionContext;\n  executionContext |= 2;\n  var prevDispatcher = pushDispatcher(),\n    prevAsyncDispatcher = pushAsyncDispatcher();\n  if (workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes)\n    (workInProgressTransitions = null), prepareFreshStack(root, lanes);\n  lanes = !1;\n  var exitStatus = workInProgressRootExitStatus;\n  a: do\n    try {\n      if (0 !== workInProgressSuspendedReason && null !== workInProgress) {\n        var unitOfWork = workInProgress,\n          thrownValue = workInProgressThrownValue;\n        switch (workInProgressSuspendedReason) {\n          case 8:\n            resetWorkInProgressStack();\n            exitStatus = 6;\n            break a;\n          case 3:\n          case 2:\n          case 6:\n            null === suspenseHandlerStackCursor.current && (lanes = !0);\n            var reason = workInProgressSuspendedReason;\n            workInProgressSuspendedReason = 0;\n            workInProgressThrownValue = null;\n            throwAndUnwindWorkLoop(root, unitOfWork, thrownValue, reason);\n            if (\n              shouldYieldForPrerendering &&\n              workInProgressRootIsPrerendering\n            ) {\n              exitStatus = 0;\n              break a;\n            }\n            break;\n          default:\n            (reason = workInProgressSuspendedReason),\n              (workInProgressSuspendedReason = 0),\n              (workInProgressThrownValue = null),\n              throwAndUnwindWorkLoop(root, unitOfWork, thrownValue, reason);\n        }\n      }\n      workLoopSync();\n      exitStatus = workInProgressRootExitStatus;\n      break;\n    } catch (thrownValue$164) {\n      handleThrow(root, thrownValue$164);\n    }\n  while (1);\n  lanes && root.shellSuspendCounter++;\n  lastContextDependency = currentlyRenderingFiber = null;\n  executionContext = prevExecutionContext;\n  ReactSharedInternals.H = prevDispatcher;\n  ReactSharedInternals.A = prevAsyncDispatcher;\n  null === workInProgress &&\n    ((workInProgressRoot = null),\n    (workInProgressRootRenderLanes = 0),\n    finishQueueingConcurrentUpdates());\n  return exitStatus;\n}\nfunction workLoopSync() {\n  for (; null !== workInProgress; ) performUnitOfWork(workInProgress);\n}\nfunction renderRootConcurrent(root, lanes) {\n  var prevExecutionContext = executionContext;\n  executionContext |= 2;\n  var prevDispatcher = pushDispatcher(),\n    prevAsyncDispatcher = pushAsyncDispatcher();\n  workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes\n    ? ((workInProgressTransitions = null),\n      (workInProgressRootRenderTargetTime = now() + 500),\n      prepareFreshStack(root, lanes))\n    : (workInProgressRootIsPrerendering = checkIfRootIsPrerendering(\n        root,\n        lanes\n      ));\n  a: do\n    try {\n      if (0 !== workInProgressSuspendedReason && null !== workInProgress) {\n        lanes = workInProgress;\n        var thrownValue = workInProgressThrownValue;\n        b: switch (workInProgressSuspendedReason) {\n          case 1:\n            workInProgressSuspendedReason = 0;\n            workInProgressThrownValue = null;\n            throwAndUnwindWorkLoop(root, lanes, thrownValue, 1);\n            break;\n          case 2:\n            if (isThenableResolved(thrownValue)) {\n              workInProgressSuspendedReason = 0;\n              workInProgressThrownValue = null;\n              replaySuspendedUnitOfWork(lanes);\n              break;\n            }\n            lanes = function () {\n              2 === workInProgressSuspendedReason &&\n                workInProgressRoot === root &&\n                (workInProgressSuspendedReason = 7);\n              ensureRootIsScheduled(root);\n            };\n            thrownValue.then(lanes, lanes);\n            break a;\n          case 3:\n            workInProgressSuspendedReason = 7;\n            break a;\n          case 4:\n            workInProgressSuspendedReason = 5;\n            break a;\n          case 7:\n            isThenableResolved(thrownValue)\n              ? ((workInProgressSuspendedReason = 0),\n                (workInProgressThrownValue = null),\n                replaySuspendedUnitOfWork(lanes))\n              : ((workInProgressSuspendedReason = 0),\n                (workInProgressThrownValue = null),\n                throwAndUnwindWorkLoop(root, lanes, thrownValue, 7));\n            break;\n          case 5:\n            var resource = null;\n            switch (workInProgress.tag) {\n              case 26:\n                resource = workInProgress.memoizedState;\n              case 5:\n              case 27:\n                var hostFiber = workInProgress;\n                if (resource ? preloadResource(resource) : 1) {\n                  workInProgressSuspendedReason = 0;\n                  workInProgressThrownValue = null;\n                  var sibling = hostFiber.sibling;\n                  if (null !== sibling) workInProgress = sibling;\n                  else {\n                    var returnFiber = hostFiber.return;\n                    null !== returnFiber\n                      ? ((workInProgress = returnFiber),\n                        completeUnitOfWork(returnFiber))\n                      : (workInProgress = null);\n                  }\n                  break b;\n                }\n            }\n            workInProgressSuspendedReason = 0;\n            workInProgressThrownValue = null;\n            throwAndUnwindWorkLoop(root, lanes, thrownValue, 5);\n            break;\n          case 6:\n            workInProgressSuspendedReason = 0;\n            workInProgressThrownValue = null;\n            throwAndUnwindWorkLoop(root, lanes, thrownValue, 6);\n            break;\n          case 8:\n            resetWorkInProgressStack();\n            workInProgressRootExitStatus = 6;\n            break a;\n          default:\n            throw Error(formatProdErrorMessage(462));\n        }\n      }\n      workLoopConcurrent();\n      break;\n    } catch (thrownValue$166) {\n      handleThrow(root, thrownValue$166);\n    }\n  while (1);\n  lastContextDependency = currentlyRenderingFiber = null;\n  ReactSharedInternals.H = prevDispatcher;\n  ReactSharedInternals.A = prevAsyncDispatcher;\n  executionContext = prevExecutionContext;\n  if (null !== workInProgress) return 0;\n  workInProgressRoot = null;\n  workInProgressRootRenderLanes = 0;\n  finishQueueingConcurrentUpdates();\n  return workInProgressRootExitStatus;\n}\nfunction workLoopConcurrent() {\n  for (; null !== workInProgress && !shouldYield(); )\n    performUnitOfWork(workInProgress);\n}\nfunction performUnitOfWork(unitOfWork) {\n  var next = beginWork(unitOfWork.alternate, unitOfWork, entangledRenderLanes);\n  unitOfWork.memoizedProps = unitOfWork.pendingProps;\n  null === next ? completeUnitOfWork(unitOfWork) : (workInProgress = next);\n}\nfunction replaySuspendedUnitOfWork(unitOfWork) {\n  var next = unitOfWork;\n  var current = next.alternate;\n  switch (next.tag) {\n    case 15:\n    case 0:\n      next = replayFunctionComponent(\n        current,\n        next,\n        next.pendingProps,\n        next.type,\n        void 0,\n        workInProgressRootRenderLanes\n      );\n      break;\n    case 11:\n      next = replayFunctionComponent(\n        current,\n        next,\n        next.pendingProps,\n        next.type.render,\n        next.ref,\n        workInProgressRootRenderLanes\n      );\n      break;\n    case 5:\n      resetHooksOnUnwind(next);\n    default:\n      unwindInterruptedWork(current, next),\n        (next = workInProgress =\n          resetWorkInProgress(next, entangledRenderLanes)),\n        (next = beginWork(current, next, entangledRenderLanes));\n  }\n  unitOfWork.memoizedProps = unitOfWork.pendingProps;\n  null === next ? completeUnitOfWork(unitOfWork) : (workInProgress = next);\n}\nfunction throwAndUnwindWorkLoop(\n  root,\n  unitOfWork,\n  thrownValue,\n  suspendedReason\n) {\n  lastContextDependency = currentlyRenderingFiber = null;\n  resetHooksOnUnwind(unitOfWork);\n  thenableState$1 = null;\n  thenableIndexCounter$1 = 0;\n  var returnFiber = unitOfWork.return;\n  try {\n    if (\n      throwException(\n        root,\n        returnFiber,\n        unitOfWork,\n        thrownValue,\n        workInProgressRootRenderLanes\n      )\n    ) {\n      workInProgressRootExitStatus = 1;\n      logUncaughtError(\n        root,\n        createCapturedValueAtFiber(thrownValue, root.current)\n      );\n      workInProgress = null;\n      return;\n    }\n  } catch (error) {\n    if (null !== returnFiber) throw ((workInProgress = returnFiber), error);\n    workInProgressRootExitStatus = 1;\n    logUncaughtError(\n      root,\n      createCapturedValueAtFiber(thrownValue, root.current)\n    );\n    workInProgress = null;\n    return;\n  }\n  if (unitOfWork.flags & 32768) {\n    if (isHydrating || 1 === suspendedReason) root = !0;\n    else if (\n      workInProgressRootIsPrerendering ||\n      0 !== (workInProgressRootRenderLanes & 536870912)\n    )\n      root = !1;\n    else if (\n      ((workInProgressRootDidSkipSuspendedSiblings = root = !0),\n      2 === suspendedReason || 3 === suspendedReason || 6 === suspendedReason)\n    )\n      (suspendedReason = suspenseHandlerStackCursor.current),\n        null !== suspendedReason &&\n          13 === suspendedReason.tag &&\n          (suspendedReason.flags |= 16384);\n    unwindUnitOfWork(unitOfWork, root);\n  } else completeUnitOfWork(unitOfWork);\n}\nfunction completeUnitOfWork(unitOfWork) {\n  var completedWork = unitOfWork;\n  do {\n    if (0 !== (completedWork.flags & 32768)) {\n      unwindUnitOfWork(\n        completedWork,\n        workInProgressRootDidSkipSuspendedSiblings\n      );\n      return;\n    }\n    unitOfWork = completedWork.return;\n    var next = completeWork(\n      completedWork.alternate,\n      completedWork,\n      entangledRenderLanes\n    );\n    if (null !== next) {\n      workInProgress = next;\n      return;\n    }\n    completedWork = completedWork.sibling;\n    if (null !== completedWork) {\n      workInProgress = completedWork;\n      return;\n    }\n    workInProgress = completedWork = unitOfWork;\n  } while (null !== completedWork);\n  0 === workInProgressRootExitStatus && (workInProgressRootExitStatus = 5);\n}\nfunction unwindUnitOfWork(unitOfWork, skipSiblings) {\n  do {\n    var next = unwindWork(unitOfWork.alternate, unitOfWork);\n    if (null !== next) {\n      next.flags &= 32767;\n      workInProgress = next;\n      return;\n    }\n    next = unitOfWork.return;\n    null !== next &&\n      ((next.flags |= 32768), (next.subtreeFlags = 0), (next.deletions = null));\n    if (\n      !skipSiblings &&\n      ((unitOfWork = unitOfWork.sibling), null !== unitOfWork)\n    ) {\n      workInProgress = unitOfWork;\n      return;\n    }\n    workInProgress = unitOfWork = next;\n  } while (null !== unitOfWork);\n  workInProgressRootExitStatus = 6;\n  workInProgress = null;\n}\nfunction commitRoot(\n  root,\n  recoverableErrors,\n  transitions,\n  didIncludeRenderPhaseUpdate,\n  spawnedLane,\n  updatedLanes,\n  suspendedRetryLanes,\n  suspendedCommitReason,\n  completedRenderStartTime,\n  completedRenderEndTime\n) {\n  var prevTransition = ReactSharedInternals.T,\n    previousUpdateLanePriority = ReactDOMSharedInternals.p;\n  try {\n    (ReactDOMSharedInternals.p = 2),\n      (ReactSharedInternals.T = null),\n      commitRootImpl(\n        root,\n        recoverableErrors,\n        transitions,\n        didIncludeRenderPhaseUpdate,\n        previousUpdateLanePriority,\n        spawnedLane,\n        updatedLanes,\n        suspendedRetryLanes,\n        suspendedCommitReason,\n        completedRenderStartTime,\n        completedRenderEndTime\n      );\n  } finally {\n    (ReactSharedInternals.T = prevTransition),\n      (ReactDOMSharedInternals.p = previousUpdateLanePriority);\n  }\n}\nfunction commitRootImpl(\n  root,\n  recoverableErrors,\n  transitions,\n  didIncludeRenderPhaseUpdate,\n  renderPriorityLevel,\n  spawnedLane,\n  updatedLanes,\n  suspendedRetryLanes\n) {\n  do flushPassiveEffects();\n  while (null !== rootWithPendingPassiveEffects);\n  if (0 !== (executionContext & 6)) throw Error(formatProdErrorMessage(327));\n  var finishedWork = root.finishedWork;\n  didIncludeRenderPhaseUpdate = root.finishedLanes;\n  if (null === finishedWork) return null;\n  root.finishedWork = null;\n  root.finishedLanes = 0;\n  if (finishedWork === root.current) throw Error(formatProdErrorMessage(177));\n  root.callbackNode = null;\n  root.callbackPriority = 0;\n  root.cancelPendingCommit = null;\n  var remainingLanes = finishedWork.lanes | finishedWork.childLanes;\n  remainingLanes |= concurrentlyUpdatedLanes;\n  markRootFinished(\n    root,\n    didIncludeRenderPhaseUpdate,\n    remainingLanes,\n    spawnedLane,\n    updatedLanes,\n    suspendedRetryLanes\n  );\n  root === workInProgressRoot &&\n    ((workInProgress = workInProgressRoot = null),\n    (workInProgressRootRenderLanes = 0));\n  (0 === (finishedWork.subtreeFlags & 10256) &&\n    0 === (finishedWork.flags & 10256)) ||\n    rootDoesHavePassiveEffects ||\n    ((rootDoesHavePassiveEffects = !0),\n    (pendingPassiveEffectsRemainingLanes = remainingLanes),\n    (pendingPassiveTransitions = transitions),\n    scheduleCallback$1(NormalPriority$1, function () {\n      flushPassiveEffects(!0);\n      return null;\n    }));\n  transitions = 0 !== (finishedWork.flags & 15990);\n  0 !== (finishedWork.subtreeFlags & 15990) || transitions\n    ? ((transitions = ReactSharedInternals.T),\n      (ReactSharedInternals.T = null),\n      (spawnedLane = ReactDOMSharedInternals.p),\n      (ReactDOMSharedInternals.p = 2),\n      (updatedLanes = executionContext),\n      (executionContext |= 4),\n      commitBeforeMutationEffects(root, finishedWork),\n      commitMutationEffectsOnFiber(finishedWork, root),\n      restoreSelection(selectionInformation, root.containerInfo),\n      (_enabled = !!eventsEnabled),\n      (selectionInformation = eventsEnabled = null),\n      (root.current = finishedWork),\n      commitLayoutEffectOnFiber(root, finishedWork.alternate, finishedWork),\n      requestPaint(),\n      (executionContext = updatedLanes),\n      (ReactDOMSharedInternals.p = spawnedLane),\n      (ReactSharedInternals.T = transitions))\n    : (root.current = finishedWork);\n  rootDoesHavePassiveEffects\n    ? ((rootDoesHavePassiveEffects = !1),\n      (rootWithPendingPassiveEffects = root),\n      (pendingPassiveEffectsLanes = didIncludeRenderPhaseUpdate))\n    : releaseRootPooledCache(root, remainingLanes);\n  remainingLanes = root.pendingLanes;\n  0 === remainingLanes && (legacyErrorBoundariesThatAlreadyFailed = null);\n  onCommitRoot(finishedWork.stateNode, renderPriorityLevel);\n  ensureRootIsScheduled(root);\n  if (null !== recoverableErrors)\n    for (\n      renderPriorityLevel = root.onRecoverableError, finishedWork = 0;\n      finishedWork < recoverableErrors.length;\n      finishedWork++\n    )\n      (remainingLanes = recoverableErrors[finishedWork]),\n        renderPriorityLevel(remainingLanes.value, {\n          componentStack: remainingLanes.stack\n        });\n  0 !== (pendingPassiveEffectsLanes & 3) && flushPassiveEffects();\n  remainingLanes = root.pendingLanes;\n  0 !== (didIncludeRenderPhaseUpdate & 4194218) && 0 !== (remainingLanes & 42)\n    ? root === rootWithNestedUpdates\n      ? nestedUpdateCount++\n      : ((nestedUpdateCount = 0), (rootWithNestedUpdates = root))\n    : (nestedUpdateCount = 0);\n  flushSyncWorkAcrossRoots_impl(0, !1);\n  return null;\n}\nfunction releaseRootPooledCache(root, remainingLanes) {\n  0 === (root.pooledCacheLanes &= remainingLanes) &&\n    ((remainingLanes = root.pooledCache),\n    null != remainingLanes &&\n      ((root.pooledCache = null), releaseCache(remainingLanes)));\n}\nfunction flushPassiveEffects() {\n  if (null !== rootWithPendingPassiveEffects) {\n    var root$170 = rootWithPendingPassiveEffects,\n      remainingLanes = pendingPassiveEffectsRemainingLanes;\n    pendingPassiveEffectsRemainingLanes = 0;\n    var renderPriority = lanesToEventPriority(pendingPassiveEffectsLanes),\n      prevTransition = ReactSharedInternals.T,\n      previousPriority = ReactDOMSharedInternals.p;\n    try {\n      ReactDOMSharedInternals.p = 32 > renderPriority ? 32 : renderPriority;\n      ReactSharedInternals.T = null;\n      if (null === rootWithPendingPassiveEffects)\n        var JSCompiler_inline_result = !1;\n      else {\n        renderPriority = pendingPassiveTransitions;\n        pendingPassiveTransitions = null;\n        var root = rootWithPendingPassiveEffects,\n          lanes = pendingPassiveEffectsLanes;\n        rootWithPendingPassiveEffects = null;\n        pendingPassiveEffectsLanes = 0;\n        if (0 !== (executionContext & 6))\n          throw Error(formatProdErrorMessage(331));\n        var prevExecutionContext = executionContext;\n        executionContext |= 4;\n        commitPassiveUnmountOnFiber(root.current);\n        commitPassiveMountOnFiber(root, root.current, lanes, renderPriority);\n        executionContext = prevExecutionContext;\n        flushSyncWorkAcrossRoots_impl(0, !1);\n        if (\n          injectedHook &&\n          \"function\" === typeof injectedHook.onPostCommitFiberRoot\n        )\n          try {\n            injectedHook.onPostCommitFiberRoot(rendererID, root);\n          } catch (err) {}\n        JSCompiler_inline_result = !0;\n      }\n      return JSCompiler_inline_result;\n    } finally {\n      (ReactDOMSharedInternals.p = previousPriority),\n        (ReactSharedInternals.T = prevTransition),\n        releaseRootPooledCache(root$170, remainingLanes);\n    }\n  }\n  return !1;\n}\nfunction captureCommitPhaseErrorOnRoot(rootFiber, sourceFiber, error) {\n  sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n  sourceFiber = createRootErrorUpdate(rootFiber.stateNode, sourceFiber, 2);\n  rootFiber = enqueueUpdate(rootFiber, sourceFiber, 2);\n  null !== rootFiber &&\n    (markRootUpdated$1(rootFiber, 2), ensureRootIsScheduled(rootFiber));\n}\nfunction captureCommitPhaseError(sourceFiber, nearestMountedAncestor, error) {\n  if (3 === sourceFiber.tag)\n    captureCommitPhaseErrorOnRoot(sourceFiber, sourceFiber, error);\n  else\n    for (; null !== nearestMountedAncestor; ) {\n      if (3 === nearestMountedAncestor.tag) {\n        captureCommitPhaseErrorOnRoot(\n          nearestMountedAncestor,\n          sourceFiber,\n          error\n        );\n        break;\n      } else if (1 === nearestMountedAncestor.tag) {\n        var instance = nearestMountedAncestor.stateNode;\n        if (\n          \"function\" ===\n            typeof nearestMountedAncestor.type.getDerivedStateFromError ||\n          (\"function\" === typeof instance.componentDidCatch &&\n            (null === legacyErrorBoundariesThatAlreadyFailed ||\n              !legacyErrorBoundariesThatAlreadyFailed.has(instance)))\n        ) {\n          sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n          error = createClassErrorUpdate(2);\n          instance = enqueueUpdate(nearestMountedAncestor, error, 2);\n          null !== instance &&\n            (initializeClassErrorUpdate(\n              error,\n              instance,\n              nearestMountedAncestor,\n              sourceFiber\n            ),\n            markRootUpdated$1(instance, 2),\n            ensureRootIsScheduled(instance));\n          break;\n        }\n      }\n      nearestMountedAncestor = nearestMountedAncestor.return;\n    }\n}\nfunction attachPingListener(root, wakeable, lanes) {\n  var pingCache = root.pingCache;\n  if (null === pingCache) {\n    pingCache = root.pingCache = new PossiblyWeakMap();\n    var threadIDs = new Set();\n    pingCache.set(wakeable, threadIDs);\n  } else\n    (threadIDs = pingCache.get(wakeable)),\n      void 0 === threadIDs &&\n        ((threadIDs = new Set()), pingCache.set(wakeable, threadIDs));\n  threadIDs.has(lanes) ||\n    ((workInProgressRootDidAttachPingListener = !0),\n    threadIDs.add(lanes),\n    (root = pingSuspendedRoot.bind(null, root, wakeable, lanes)),\n    wakeable.then(root, root));\n}\nfunction pingSuspendedRoot(root, wakeable, pingedLanes) {\n  var pingCache = root.pingCache;\n  null !== pingCache && pingCache.delete(wakeable);\n  root.pingedLanes |= root.suspendedLanes & pingedLanes;\n  root.warmLanes &= ~pingedLanes;\n  workInProgressRoot === root &&\n    (workInProgressRootRenderLanes & pingedLanes) === pingedLanes &&\n    (4 === workInProgressRootExitStatus ||\n    (3 === workInProgressRootExitStatus &&\n      (workInProgressRootRenderLanes & 62914560) ===\n        workInProgressRootRenderLanes &&\n      300 > now() - globalMostRecentFallbackTime)\n      ? 0 === (executionContext & 2) && prepareFreshStack(root, 0)\n      : (workInProgressRootPingedLanes |= pingedLanes),\n    workInProgressSuspendedRetryLanes === workInProgressRootRenderLanes &&\n      (workInProgressSuspendedRetryLanes = 0));\n  ensureRootIsScheduled(root);\n}\nfunction retryTimedOutBoundary(boundaryFiber, retryLane) {\n  0 === retryLane && (retryLane = claimNextRetryLane());\n  boundaryFiber = enqueueConcurrentRenderForLane(boundaryFiber, retryLane);\n  null !== boundaryFiber &&\n    (markRootUpdated$1(boundaryFiber, retryLane),\n    ensureRootIsScheduled(boundaryFiber));\n}\nfunction retryDehydratedSuspenseBoundary(boundaryFiber) {\n  var suspenseState = boundaryFiber.memoizedState,\n    retryLane = 0;\n  null !== suspenseState && (retryLane = suspenseState.retryLane);\n  retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nfunction resolveRetryWakeable(boundaryFiber, wakeable) {\n  var retryLane = 0;\n  switch (boundaryFiber.tag) {\n    case 13:\n      var retryCache = boundaryFiber.stateNode;\n      var suspenseState = boundaryFiber.memoizedState;\n      null !== suspenseState && (retryLane = suspenseState.retryLane);\n      break;\n    case 19:\n      retryCache = boundaryFiber.stateNode;\n      break;\n    case 22:\n      retryCache = boundaryFiber.stateNode._retryCache;\n      break;\n    default:\n      throw Error(formatProdErrorMessage(314));\n  }\n  null !== retryCache && retryCache.delete(wakeable);\n  retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nfunction scheduleCallback$1(priorityLevel, callback) {\n  return scheduleCallback$3(priorityLevel, callback);\n}\nvar firstScheduledRoot = null,\n  lastScheduledRoot = null,\n  didScheduleMicrotask = !1,\n  mightHavePendingSyncWork = !1,\n  isFlushingWork = !1,\n  currentEventTransitionLane = 0;\nfunction ensureRootIsScheduled(root) {\n  root !== lastScheduledRoot &&\n    null === root.next &&\n    (null === lastScheduledRoot\n      ? (firstScheduledRoot = lastScheduledRoot = root)\n      : (lastScheduledRoot = lastScheduledRoot.next = root));\n  mightHavePendingSyncWork = !0;\n  didScheduleMicrotask ||\n    ((didScheduleMicrotask = !0),\n    scheduleImmediateTask(processRootScheduleInMicrotask));\n}\nfunction flushSyncWorkAcrossRoots_impl(syncTransitionLanes, onlyLegacy) {\n  if (!isFlushingWork && mightHavePendingSyncWork) {\n    isFlushingWork = !0;\n    do {\n      var didPerformSomeWork = !1;\n      for (var root$172 = firstScheduledRoot; null !== root$172; ) {\n        if (!onlyLegacy)\n          if (0 !== syncTransitionLanes) {\n            var pendingLanes = root$172.pendingLanes;\n            if (0 === pendingLanes) var JSCompiler_inline_result = 0;\n            else {\n              var suspendedLanes = root$172.suspendedLanes,\n                pingedLanes = root$172.pingedLanes;\n              JSCompiler_inline_result =\n                (1 << (31 - clz32(42 | syncTransitionLanes) + 1)) - 1;\n              JSCompiler_inline_result &=\n                pendingLanes & ~(suspendedLanes & ~pingedLanes);\n              JSCompiler_inline_result =\n                JSCompiler_inline_result & 201326677\n                  ? (JSCompiler_inline_result & 201326677) | 1\n                  : JSCompiler_inline_result\n                    ? JSCompiler_inline_result | 2\n                    : 0;\n            }\n            0 !== JSCompiler_inline_result &&\n              ((didPerformSomeWork = !0),\n              performSyncWorkOnRoot(root$172, JSCompiler_inline_result));\n          } else\n            (JSCompiler_inline_result = workInProgressRootRenderLanes),\n              (JSCompiler_inline_result = getNextLanes(\n                root$172,\n                root$172 === workInProgressRoot ? JSCompiler_inline_result : 0\n              )),\n              0 === (JSCompiler_inline_result & 3) ||\n                checkIfRootIsPrerendering(root$172, JSCompiler_inline_result) ||\n                ((didPerformSomeWork = !0),\n                performSyncWorkOnRoot(root$172, JSCompiler_inline_result));\n        root$172 = root$172.next;\n      }\n    } while (didPerformSomeWork);\n    isFlushingWork = !1;\n  }\n}\nfunction processRootScheduleInMicrotask() {\n  mightHavePendingSyncWork = didScheduleMicrotask = !1;\n  var syncTransitionLanes = 0;\n  0 !== currentEventTransitionLane &&\n    (shouldAttemptEagerTransition() &&\n      (syncTransitionLanes = currentEventTransitionLane),\n    (currentEventTransitionLane = 0));\n  for (\n    var currentTime = now(), prev = null, root = firstScheduledRoot;\n    null !== root;\n\n  ) {\n    var next = root.next,\n      nextLanes = scheduleTaskForRootDuringMicrotask(root, currentTime);\n    if (0 === nextLanes)\n      (root.next = null),\n        null === prev ? (firstScheduledRoot = next) : (prev.next = next),\n        null === next && (lastScheduledRoot = prev);\n    else if (\n      ((prev = root), 0 !== syncTransitionLanes || 0 !== (nextLanes & 3))\n    )\n      mightHavePendingSyncWork = !0;\n    root = next;\n  }\n  flushSyncWorkAcrossRoots_impl(syncTransitionLanes, !1);\n}\nfunction scheduleTaskForRootDuringMicrotask(root, currentTime) {\n  for (\n    var suspendedLanes = root.suspendedLanes,\n      pingedLanes = root.pingedLanes,\n      expirationTimes = root.expirationTimes,\n      lanes = root.pendingLanes & -62914561;\n    0 < lanes;\n\n  ) {\n    var index$5 = 31 - clz32(lanes),\n      lane = 1 << index$5,\n      expirationTime = expirationTimes[index$5];\n    if (-1 === expirationTime) {\n      if (0 === (lane & suspendedLanes) || 0 !== (lane & pingedLanes))\n        expirationTimes[index$5] = computeExpirationTime(lane, currentTime);\n    } else expirationTime <= currentTime && (root.expiredLanes |= lane);\n    lanes &= ~lane;\n  }\n  currentTime = workInProgressRoot;\n  suspendedLanes = workInProgressRootRenderLanes;\n  suspendedLanes = getNextLanes(\n    root,\n    root === currentTime ? suspendedLanes : 0\n  );\n  pingedLanes = root.callbackNode;\n  if (\n    0 === suspendedLanes ||\n    (root === currentTime && 2 === workInProgressSuspendedReason) ||\n    null !== root.cancelPendingCommit\n  )\n    return (\n      null !== pingedLanes &&\n        null !== pingedLanes &&\n        cancelCallback$1(pingedLanes),\n      (root.callbackNode = null),\n      (root.callbackPriority = 0)\n    );\n  if (\n    0 === (suspendedLanes & 3) ||\n    checkIfRootIsPrerendering(root, suspendedLanes)\n  ) {\n    currentTime = suspendedLanes & -suspendedLanes;\n    if (currentTime === root.callbackPriority) return currentTime;\n    null !== pingedLanes && cancelCallback$1(pingedLanes);\n    switch (lanesToEventPriority(suspendedLanes)) {\n      case 2:\n      case 8:\n        suspendedLanes = UserBlockingPriority;\n        break;\n      case 32:\n        suspendedLanes = NormalPriority$1;\n        break;\n      case 268435456:\n        suspendedLanes = IdlePriority;\n        break;\n      default:\n        suspendedLanes = NormalPriority$1;\n    }\n    pingedLanes = performWorkOnRootViaSchedulerTask.bind(null, root);\n    suspendedLanes = scheduleCallback$3(suspendedLanes, pingedLanes);\n    root.callbackPriority = currentTime;\n    root.callbackNode = suspendedLanes;\n    return currentTime;\n  }\n  null !== pingedLanes && null !== pingedLanes && cancelCallback$1(pingedLanes);\n  root.callbackPriority = 2;\n  root.callbackNode = null;\n  return 2;\n}\nfunction performWorkOnRootViaSchedulerTask(root, didTimeout) {\n  var originalCallbackNode = root.callbackNode;\n  if (flushPassiveEffects() && root.callbackNode !== originalCallbackNode)\n    return null;\n  var workInProgressRootRenderLanes$jscomp$0 = workInProgressRootRenderLanes;\n  workInProgressRootRenderLanes$jscomp$0 = getNextLanes(\n    root,\n    root === workInProgressRoot ? workInProgressRootRenderLanes$jscomp$0 : 0\n  );\n  if (0 === workInProgressRootRenderLanes$jscomp$0) return null;\n  performWorkOnRoot(root, workInProgressRootRenderLanes$jscomp$0, didTimeout);\n  scheduleTaskForRootDuringMicrotask(root, now());\n  return null != root.callbackNode && root.callbackNode === originalCallbackNode\n    ? performWorkOnRootViaSchedulerTask.bind(null, root)\n    : null;\n}\nfunction performSyncWorkOnRoot(root, lanes) {\n  if (flushPassiveEffects()) return null;\n  performWorkOnRoot(root, lanes, !0);\n}\nfunction scheduleImmediateTask(cb) {\n  scheduleMicrotask(function () {\n    0 !== (executionContext & 6)\n      ? scheduleCallback$3(ImmediatePriority, cb)\n      : cb();\n  });\n}\nfunction requestTransitionLane() {\n  0 === currentEventTransitionLane &&\n    (currentEventTransitionLane = claimNextTransitionLane());\n  return currentEventTransitionLane;\n}\nfunction coerceFormActionProp(actionProp) {\n  return null == actionProp ||\n    \"symbol\" === typeof actionProp ||\n    \"boolean\" === typeof actionProp\n    ? null\n    : \"function\" === typeof actionProp\n      ? actionProp\n      : sanitizeURL(\"\" + actionProp);\n}\nfunction createFormDataWithSubmitter(form, submitter) {\n  var temp = submitter.ownerDocument.createElement(\"input\");\n  temp.name = submitter.name;\n  temp.value = submitter.value;\n  form.id && temp.setAttribute(\"form\", form.id);\n  submitter.parentNode.insertBefore(temp, submitter);\n  form = new FormData(form);\n  temp.parentNode.removeChild(temp);\n  return form;\n}\nfunction extractEvents$1(\n  dispatchQueue,\n  domEventName,\n  maybeTargetInst,\n  nativeEvent,\n  nativeEventTarget\n) {\n  if (\n    \"submit\" === domEventName &&\n    maybeTargetInst &&\n    maybeTargetInst.stateNode === nativeEventTarget\n  ) {\n    var action = coerceFormActionProp(\n        (nativeEventTarget[internalPropsKey] || null).action\n      ),\n      submitter = nativeEvent.submitter;\n    submitter &&\n      ((domEventName = (domEventName = submitter[internalPropsKey] || null)\n        ? coerceFormActionProp(domEventName.formAction)\n        : submitter.getAttribute(\"formAction\")),\n      null !== domEventName && ((action = domEventName), (submitter = null)));\n    var event = new SyntheticEvent(\n      \"action\",\n      \"action\",\n      null,\n      nativeEvent,\n      nativeEventTarget\n    );\n    dispatchQueue.push({\n      event: event,\n      listeners: [\n        {\n          instance: null,\n          listener: function () {\n            if (nativeEvent.defaultPrevented) {\n              if (0 !== currentEventTransitionLane) {\n                var formData = submitter\n                  ? createFormDataWithSubmitter(nativeEventTarget, submitter)\n                  : new FormData(nativeEventTarget);\n                startHostTransition(\n                  maybeTargetInst,\n                  {\n                    pending: !0,\n                    data: formData,\n                    method: nativeEventTarget.method,\n                    action: action\n                  },\n                  null,\n                  formData\n                );\n              }\n            } else\n              \"function\" === typeof action &&\n                (event.preventDefault(),\n                (formData = submitter\n                  ? createFormDataWithSubmitter(nativeEventTarget, submitter)\n                  : new FormData(nativeEventTarget)),\n                startHostTransition(\n                  maybeTargetInst,\n                  {\n                    pending: !0,\n                    data: formData,\n                    method: nativeEventTarget.method,\n                    action: action\n                  },\n                  action,\n                  formData\n                ));\n          },\n          currentTarget: nativeEventTarget\n        }\n      ]\n    });\n  }\n}\nfor (\n  var i$jscomp$inline_1439 = 0;\n  i$jscomp$inline_1439 < simpleEventPluginEvents.length;\n  i$jscomp$inline_1439++\n) {\n  var eventName$jscomp$inline_1440 =\n      simpleEventPluginEvents[i$jscomp$inline_1439],\n    domEventName$jscomp$inline_1441 =\n      eventName$jscomp$inline_1440.toLowerCase(),\n    capitalizedEvent$jscomp$inline_1442 =\n      eventName$jscomp$inline_1440[0].toUpperCase() +\n      eventName$jscomp$inline_1440.slice(1);\n  registerSimpleEvent(\n    domEventName$jscomp$inline_1441,\n    \"on\" + capitalizedEvent$jscomp$inline_1442\n  );\n}\nregisterSimpleEvent(ANIMATION_END, \"onAnimationEnd\");\nregisterSimpleEvent(ANIMATION_ITERATION, \"onAnimationIteration\");\nregisterSimpleEvent(ANIMATION_START, \"onAnimationStart\");\nregisterSimpleEvent(\"dblclick\", \"onDoubleClick\");\nregisterSimpleEvent(\"focusin\", \"onFocus\");\nregisterSimpleEvent(\"focusout\", \"onBlur\");\nregisterSimpleEvent(TRANSITION_RUN, \"onTransitionRun\");\nregisterSimpleEvent(TRANSITION_START, \"onTransitionStart\");\nregisterSimpleEvent(TRANSITION_CANCEL, \"onTransitionCancel\");\nregisterSimpleEvent(TRANSITION_END, \"onTransitionEnd\");\nregisterDirectEvent(\"onMouseEnter\", [\"mouseout\", \"mouseover\"]);\nregisterDirectEvent(\"onMouseLeave\", [\"mouseout\", \"mouseover\"]);\nregisterDirectEvent(\"onPointerEnter\", [\"pointerout\", \"pointerover\"]);\nregisterDirectEvent(\"onPointerLeave\", [\"pointerout\", \"pointerover\"]);\nregisterTwoPhaseEvent(\n  \"onChange\",\n  \"change click focusin focusout input keydown keyup selectionchange\".split(\" \")\n);\nregisterTwoPhaseEvent(\n  \"onSelect\",\n  \"focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange\".split(\n    \" \"\n  )\n);\nregisterTwoPhaseEvent(\"onBeforeInput\", [\n  \"compositionend\",\n  \"keypress\",\n  \"textInput\",\n  \"paste\"\n]);\nregisterTwoPhaseEvent(\n  \"onCompositionEnd\",\n  \"compositionend focusout keydown keypress keyup mousedown\".split(\" \")\n);\nregisterTwoPhaseEvent(\n  \"onCompositionStart\",\n  \"compositionstart focusout keydown keypress keyup mousedown\".split(\" \")\n);\nregisterTwoPhaseEvent(\n  \"onCompositionUpdate\",\n  \"compositionupdate focusout keydown keypress keyup mousedown\".split(\" \")\n);\nvar mediaEventTypes =\n    \"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting\".split(\n      \" \"\n    ),\n  nonDelegatedEvents = new Set(\n    \"beforetoggle cancel close invalid load scroll scrollend toggle\"\n      .split(\" \")\n      .concat(mediaEventTypes)\n  );\nfunction processDispatchQueue(dispatchQueue, eventSystemFlags) {\n  eventSystemFlags = 0 !== (eventSystemFlags & 4);\n  for (var i = 0; i < dispatchQueue.length; i++) {\n    var _dispatchQueue$i = dispatchQueue[i],\n      event = _dispatchQueue$i.event;\n    _dispatchQueue$i = _dispatchQueue$i.listeners;\n    a: {\n      var previousInstance = void 0;\n      if (eventSystemFlags)\n        for (\n          var i$jscomp$0 = _dispatchQueue$i.length - 1;\n          0 <= i$jscomp$0;\n          i$jscomp$0--\n        ) {\n          var _dispatchListeners$i = _dispatchQueue$i[i$jscomp$0],\n            instance = _dispatchListeners$i.instance,\n            currentTarget = _dispatchListeners$i.currentTarget;\n          _dispatchListeners$i = _dispatchListeners$i.listener;\n          if (instance !== previousInstance && event.isPropagationStopped())\n            break a;\n          previousInstance = _dispatchListeners$i;\n          event.currentTarget = currentTarget;\n          try {\n            previousInstance(event);\n          } catch (error) {\n            reportGlobalError(error);\n          }\n          event.currentTarget = null;\n          previousInstance = instance;\n        }\n      else\n        for (\n          i$jscomp$0 = 0;\n          i$jscomp$0 < _dispatchQueue$i.length;\n          i$jscomp$0++\n        ) {\n          _dispatchListeners$i = _dispatchQueue$i[i$jscomp$0];\n          instance = _dispatchListeners$i.instance;\n          currentTarget = _dispatchListeners$i.currentTarget;\n          _dispatchListeners$i = _dispatchListeners$i.listener;\n          if (instance !== previousInstance && event.isPropagationStopped())\n            break a;\n          previousInstance = _dispatchListeners$i;\n          event.currentTarget = currentTarget;\n          try {\n            previousInstance(event);\n          } catch (error) {\n            reportGlobalError(error);\n          }\n          event.currentTarget = null;\n          previousInstance = instance;\n        }\n    }\n  }\n}\nfunction listenToNonDelegatedEvent(domEventName, targetElement) {\n  var JSCompiler_inline_result = targetElement[internalEventHandlersKey];\n  void 0 === JSCompiler_inline_result &&\n    (JSCompiler_inline_result = targetElement[internalEventHandlersKey] =\n      new Set());\n  var listenerSetKey = domEventName + \"__bubble\";\n  JSCompiler_inline_result.has(listenerSetKey) ||\n    (addTrappedEventListener(targetElement, domEventName, 2, !1),\n    JSCompiler_inline_result.add(listenerSetKey));\n}\nfunction listenToNativeEvent(domEventName, isCapturePhaseListener, target) {\n  var eventSystemFlags = 0;\n  isCapturePhaseListener && (eventSystemFlags |= 4);\n  addTrappedEventListener(\n    target,\n    domEventName,\n    eventSystemFlags,\n    isCapturePhaseListener\n  );\n}\nvar listeningMarker = \"_reactListening\" + Math.random().toString(36).slice(2);\nfunction listenToAllSupportedEvents(rootContainerElement) {\n  if (!rootContainerElement[listeningMarker]) {\n    rootContainerElement[listeningMarker] = !0;\n    allNativeEvents.forEach(function (domEventName) {\n      \"selectionchange\" !== domEventName &&\n        (nonDelegatedEvents.has(domEventName) ||\n          listenToNativeEvent(domEventName, !1, rootContainerElement),\n        listenToNativeEvent(domEventName, !0, rootContainerElement));\n    });\n    var ownerDocument =\n      9 === rootContainerElement.nodeType\n        ? rootContainerElement\n        : rootContainerElement.ownerDocument;\n    null === ownerDocument ||\n      ownerDocument[listeningMarker] ||\n      ((ownerDocument[listeningMarker] = !0),\n      listenToNativeEvent(\"selectionchange\", !1, ownerDocument));\n  }\n}\nfunction addTrappedEventListener(\n  targetContainer,\n  domEventName,\n  eventSystemFlags,\n  isCapturePhaseListener\n) {\n  switch (getEventPriority(domEventName)) {\n    case 2:\n      var listenerWrapper = dispatchDiscreteEvent;\n      break;\n    case 8:\n      listenerWrapper = dispatchContinuousEvent;\n      break;\n    default:\n      listenerWrapper = dispatchEvent;\n  }\n  eventSystemFlags = listenerWrapper.bind(\n    null,\n    domEventName,\n    eventSystemFlags,\n    targetContainer\n  );\n  listenerWrapper = void 0;\n  !passiveBrowserEventsSupported ||\n    (\"touchstart\" !== domEventName &&\n      \"touchmove\" !== domEventName &&\n      \"wheel\" !== domEventName) ||\n    (listenerWrapper = !0);\n  isCapturePhaseListener\n    ? void 0 !== listenerWrapper\n      ? targetContainer.addEventListener(domEventName, eventSystemFlags, {\n          capture: !0,\n          passive: listenerWrapper\n        })\n      : targetContainer.addEventListener(domEventName, eventSystemFlags, !0)\n    : void 0 !== listenerWrapper\n      ? targetContainer.addEventListener(domEventName, eventSystemFlags, {\n          passive: listenerWrapper\n        })\n      : targetContainer.addEventListener(domEventName, eventSystemFlags, !1);\n}\nfunction dispatchEventForPluginEventSystem(\n  domEventName,\n  eventSystemFlags,\n  nativeEvent,\n  targetInst$jscomp$0,\n  targetContainer\n) {\n  var ancestorInst = targetInst$jscomp$0;\n  if (\n    0 === (eventSystemFlags & 1) &&\n    0 === (eventSystemFlags & 2) &&\n    null !== targetInst$jscomp$0\n  )\n    a: for (;;) {\n      if (null === targetInst$jscomp$0) return;\n      var nodeTag = targetInst$jscomp$0.tag;\n      if (3 === nodeTag || 4 === nodeTag) {\n        var container = targetInst$jscomp$0.stateNode.containerInfo;\n        if (\n          container === targetContainer ||\n          (8 === container.nodeType && container.parentNode === targetContainer)\n        )\n          break;\n        if (4 === nodeTag)\n          for (nodeTag = targetInst$jscomp$0.return; null !== nodeTag; ) {\n            var grandTag = nodeTag.tag;\n            if (3 === grandTag || 4 === grandTag)\n              if (\n                ((grandTag = nodeTag.stateNode.containerInfo),\n                grandTag === targetContainer ||\n                  (8 === grandTag.nodeType &&\n                    grandTag.parentNode === targetContainer))\n              )\n                return;\n            nodeTag = nodeTag.return;\n          }\n        for (; null !== container; ) {\n          nodeTag = getClosestInstanceFromNode(container);\n          if (null === nodeTag) return;\n          grandTag = nodeTag.tag;\n          if (\n            5 === grandTag ||\n            6 === grandTag ||\n            26 === grandTag ||\n            27 === grandTag\n          ) {\n            targetInst$jscomp$0 = ancestorInst = nodeTag;\n            continue a;\n          }\n          container = container.parentNode;\n        }\n      }\n      targetInst$jscomp$0 = targetInst$jscomp$0.return;\n    }\n  batchedUpdates$1(function () {\n    var targetInst = ancestorInst,\n      nativeEventTarget = getEventTarget(nativeEvent),\n      dispatchQueue = [];\n    a: {\n      var reactName = topLevelEventsToReactNames.get(domEventName);\n      if (void 0 !== reactName) {\n        var SyntheticEventCtor = SyntheticEvent,\n          reactEventType = domEventName;\n        switch (domEventName) {\n          case \"keypress\":\n            if (0 === getEventCharCode(nativeEvent)) break a;\n          case \"keydown\":\n          case \"keyup\":\n            SyntheticEventCtor = SyntheticKeyboardEvent;\n            break;\n          case \"focusin\":\n            reactEventType = \"focus\";\n            SyntheticEventCtor = SyntheticFocusEvent;\n            break;\n          case \"focusout\":\n            reactEventType = \"blur\";\n            SyntheticEventCtor = SyntheticFocusEvent;\n            break;\n          case \"beforeblur\":\n          case \"afterblur\":\n            SyntheticEventCtor = SyntheticFocusEvent;\n            break;\n          case \"click\":\n            if (2 === nativeEvent.button) break a;\n          case \"auxclick\":\n          case \"dblclick\":\n          case \"mousedown\":\n          case \"mousemove\":\n          case \"mouseup\":\n          case \"mouseout\":\n          case \"mouseover\":\n          case \"contextmenu\":\n            SyntheticEventCtor = SyntheticMouseEvent;\n            break;\n          case \"drag\":\n          case \"dragend\":\n          case \"dragenter\":\n          case \"dragexit\":\n          case \"dragleave\":\n          case \"dragover\":\n          case \"dragstart\":\n          case \"drop\":\n            SyntheticEventCtor = SyntheticDragEvent;\n            break;\n          case \"touchcancel\":\n          case \"touchend\":\n          case \"touchmove\":\n          case \"touchstart\":\n            SyntheticEventCtor = SyntheticTouchEvent;\n            break;\n          case ANIMATION_END:\n          case ANIMATION_ITERATION:\n          case ANIMATION_START:\n            SyntheticEventCtor = SyntheticAnimationEvent;\n            break;\n          case TRANSITION_END:\n            SyntheticEventCtor = SyntheticTransitionEvent;\n            break;\n          case \"scroll\":\n          case \"scrollend\":\n            SyntheticEventCtor = SyntheticUIEvent;\n            break;\n          case \"wheel\":\n            SyntheticEventCtor = SyntheticWheelEvent;\n            break;\n          case \"copy\":\n          case \"cut\":\n          case \"paste\":\n            SyntheticEventCtor = SyntheticClipboardEvent;\n            break;\n          case \"gotpointercapture\":\n          case \"lostpointercapture\":\n          case \"pointercancel\":\n          case \"pointerdown\":\n          case \"pointermove\":\n          case \"pointerout\":\n          case \"pointerover\":\n          case \"pointerup\":\n            SyntheticEventCtor = SyntheticPointerEvent;\n            break;\n          case \"toggle\":\n          case \"beforetoggle\":\n            SyntheticEventCtor = SyntheticToggleEvent;\n        }\n        var inCapturePhase = 0 !== (eventSystemFlags & 4),\n          accumulateTargetOnly =\n            !inCapturePhase &&\n            (\"scroll\" === domEventName || \"scrollend\" === domEventName),\n          reactEventName = inCapturePhase\n            ? null !== reactName\n              ? reactName + \"Capture\"\n              : null\n            : reactName;\n        inCapturePhase = [];\n        for (\n          var instance = targetInst, lastHostComponent;\n          null !== instance;\n\n        ) {\n          var _instance = instance;\n          lastHostComponent = _instance.stateNode;\n          _instance = _instance.tag;\n          (5 !== _instance && 26 !== _instance && 27 !== _instance) ||\n            null === lastHostComponent ||\n            null === reactEventName ||\n            ((_instance = getListener(instance, reactEventName)),\n            null != _instance &&\n              inCapturePhase.push(\n                createDispatchListener(instance, _instance, lastHostComponent)\n              ));\n          if (accumulateTargetOnly) break;\n          instance = instance.return;\n        }\n        0 < inCapturePhase.length &&\n          ((reactName = new SyntheticEventCtor(\n            reactName,\n            reactEventType,\n            null,\n            nativeEvent,\n            nativeEventTarget\n          )),\n          dispatchQueue.push({ event: reactName, listeners: inCapturePhase }));\n      }\n    }\n    if (0 === (eventSystemFlags & 7)) {\n      a: {\n        reactName =\n          \"mouseover\" === domEventName || \"pointerover\" === domEventName;\n        SyntheticEventCtor =\n          \"mouseout\" === domEventName || \"pointerout\" === domEventName;\n        if (\n          reactName &&\n          nativeEvent !== currentReplayingEvent &&\n          (reactEventType =\n            nativeEvent.relatedTarget || nativeEvent.fromElement) &&\n          (getClosestInstanceFromNode(reactEventType) ||\n            reactEventType[internalContainerInstanceKey])\n        )\n          break a;\n        if (SyntheticEventCtor || reactName) {\n          reactName =\n            nativeEventTarget.window === nativeEventTarget\n              ? nativeEventTarget\n              : (reactName = nativeEventTarget.ownerDocument)\n                ? reactName.defaultView || reactName.parentWindow\n                : window;\n          if (SyntheticEventCtor) {\n            if (\n              ((reactEventType =\n                nativeEvent.relatedTarget || nativeEvent.toElement),\n              (SyntheticEventCtor = targetInst),\n              (reactEventType = reactEventType\n                ? getClosestInstanceFromNode(reactEventType)\n                : null),\n              null !== reactEventType &&\n                ((accumulateTargetOnly =\n                  getNearestMountedFiber(reactEventType)),\n                (inCapturePhase = reactEventType.tag),\n                reactEventType !== accumulateTargetOnly ||\n                  (5 !== inCapturePhase &&\n                    27 !== inCapturePhase &&\n                    6 !== inCapturePhase)))\n            )\n              reactEventType = null;\n          } else (SyntheticEventCtor = null), (reactEventType = targetInst);\n          if (SyntheticEventCtor !== reactEventType) {\n            inCapturePhase = SyntheticMouseEvent;\n            _instance = \"onMouseLeave\";\n            reactEventName = \"onMouseEnter\";\n            instance = \"mouse\";\n            if (\"pointerout\" === domEventName || \"pointerover\" === domEventName)\n              (inCapturePhase = SyntheticPointerEvent),\n                (_instance = \"onPointerLeave\"),\n                (reactEventName = \"onPointerEnter\"),\n                (instance = \"pointer\");\n            accumulateTargetOnly =\n              null == SyntheticEventCtor\n                ? reactName\n                : getNodeFromInstance(SyntheticEventCtor);\n            lastHostComponent =\n              null == reactEventType\n                ? reactName\n                : getNodeFromInstance(reactEventType);\n            reactName = new inCapturePhase(\n              _instance,\n              instance + \"leave\",\n              SyntheticEventCtor,\n              nativeEvent,\n              nativeEventTarget\n            );\n            reactName.target = accumulateTargetOnly;\n            reactName.relatedTarget = lastHostComponent;\n            _instance = null;\n            getClosestInstanceFromNode(nativeEventTarget) === targetInst &&\n              ((inCapturePhase = new inCapturePhase(\n                reactEventName,\n                instance + \"enter\",\n                reactEventType,\n                nativeEvent,\n                nativeEventTarget\n              )),\n              (inCapturePhase.target = lastHostComponent),\n              (inCapturePhase.relatedTarget = accumulateTargetOnly),\n              (_instance = inCapturePhase));\n            accumulateTargetOnly = _instance;\n            if (SyntheticEventCtor && reactEventType)\n              b: {\n                inCapturePhase = SyntheticEventCtor;\n                reactEventName = reactEventType;\n                instance = 0;\n                for (\n                  lastHostComponent = inCapturePhase;\n                  lastHostComponent;\n                  lastHostComponent = getParent(lastHostComponent)\n                )\n                  instance++;\n                lastHostComponent = 0;\n                for (\n                  _instance = reactEventName;\n                  _instance;\n                  _instance = getParent(_instance)\n                )\n                  lastHostComponent++;\n                for (; 0 < instance - lastHostComponent; )\n                  (inCapturePhase = getParent(inCapturePhase)), instance--;\n                for (; 0 < lastHostComponent - instance; )\n                  (reactEventName = getParent(reactEventName)),\n                    lastHostComponent--;\n                for (; instance--; ) {\n                  if (\n                    inCapturePhase === reactEventName ||\n                    (null !== reactEventName &&\n                      inCapturePhase === reactEventName.alternate)\n                  )\n                    break b;\n                  inCapturePhase = getParent(inCapturePhase);\n                  reactEventName = getParent(reactEventName);\n                }\n                inCapturePhase = null;\n              }\n            else inCapturePhase = null;\n            null !== SyntheticEventCtor &&\n              accumulateEnterLeaveListenersForEvent(\n                dispatchQueue,\n                reactName,\n                SyntheticEventCtor,\n                inCapturePhase,\n                !1\n              );\n            null !== reactEventType &&\n              null !== accumulateTargetOnly &&\n              accumulateEnterLeaveListenersForEvent(\n                dispatchQueue,\n                accumulateTargetOnly,\n                reactEventType,\n                inCapturePhase,\n                !0\n              );\n          }\n        }\n      }\n      a: {\n        reactName = targetInst ? getNodeFromInstance(targetInst) : window;\n        SyntheticEventCtor =\n          reactName.nodeName && reactName.nodeName.toLowerCase();\n        if (\n          \"select\" === SyntheticEventCtor ||\n          (\"input\" === SyntheticEventCtor && \"file\" === reactName.type)\n        )\n          var getTargetInstFunc = getTargetInstForChangeEvent;\n        else if (isTextInputElement(reactName))\n          if (isInputEventSupported)\n            getTargetInstFunc = getTargetInstForInputOrChangeEvent;\n          else {\n            getTargetInstFunc = getTargetInstForInputEventPolyfill;\n            var handleEventFunc = handleEventsForInputEventPolyfill;\n          }\n        else\n          (SyntheticEventCtor = reactName.nodeName),\n            !SyntheticEventCtor ||\n            \"input\" !== SyntheticEventCtor.toLowerCase() ||\n            (\"checkbox\" !== reactName.type && \"radio\" !== reactName.type)\n              ? targetInst &&\n                isCustomElement(targetInst.elementType) &&\n                (getTargetInstFunc = getTargetInstForChangeEvent)\n              : (getTargetInstFunc = getTargetInstForClickEvent);\n        if (\n          getTargetInstFunc &&\n          (getTargetInstFunc = getTargetInstFunc(domEventName, targetInst))\n        ) {\n          createAndAccumulateChangeEvent(\n            dispatchQueue,\n            getTargetInstFunc,\n            nativeEvent,\n            nativeEventTarget\n          );\n          break a;\n        }\n        handleEventFunc && handleEventFunc(domEventName, reactName, targetInst);\n        \"focusout\" === domEventName &&\n          targetInst &&\n          \"number\" === reactName.type &&\n          null != targetInst.memoizedProps.value &&\n          setDefaultValue(reactName, \"number\", reactName.value);\n      }\n      handleEventFunc = targetInst ? getNodeFromInstance(targetInst) : window;\n      switch (domEventName) {\n        case \"focusin\":\n          if (\n            isTextInputElement(handleEventFunc) ||\n            \"true\" === handleEventFunc.contentEditable\n          )\n            (activeElement = handleEventFunc),\n              (activeElementInst = targetInst),\n              (lastSelection = null);\n          break;\n        case \"focusout\":\n          lastSelection = activeElementInst = activeElement = null;\n          break;\n        case \"mousedown\":\n          mouseDown = !0;\n          break;\n        case \"contextmenu\":\n        case \"mouseup\":\n        case \"dragend\":\n          mouseDown = !1;\n          constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget);\n          break;\n        case \"selectionchange\":\n          if (skipSelectionChangeEvent) break;\n        case \"keydown\":\n        case \"keyup\":\n          constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget);\n      }\n      var fallbackData;\n      if (canUseCompositionEvent)\n        b: {\n          switch (domEventName) {\n            case \"compositionstart\":\n              var eventType = \"onCompositionStart\";\n              break b;\n            case \"compositionend\":\n              eventType = \"onCompositionEnd\";\n              break b;\n            case \"compositionupdate\":\n              eventType = \"onCompositionUpdate\";\n              break b;\n          }\n          eventType = void 0;\n        }\n      else\n        isComposing\n          ? isFallbackCompositionEnd(domEventName, nativeEvent) &&\n            (eventType = \"onCompositionEnd\")\n          : \"keydown\" === domEventName &&\n            229 === nativeEvent.keyCode &&\n            (eventType = \"onCompositionStart\");\n      eventType &&\n        (useFallbackCompositionData &&\n          \"ko\" !== nativeEvent.locale &&\n          (isComposing || \"onCompositionStart\" !== eventType\n            ? \"onCompositionEnd\" === eventType &&\n              isComposing &&\n              (fallbackData = getData())\n            : ((root = nativeEventTarget),\n              (startText = \"value\" in root ? root.value : root.textContent),\n              (isComposing = !0))),\n        (handleEventFunc = accumulateTwoPhaseListeners(targetInst, eventType)),\n        0 < handleEventFunc.length &&\n          ((eventType = new SyntheticCompositionEvent(\n            eventType,\n            domEventName,\n            null,\n            nativeEvent,\n            nativeEventTarget\n          )),\n          dispatchQueue.push({ event: eventType, listeners: handleEventFunc }),\n          fallbackData\n            ? (eventType.data = fallbackData)\n            : ((fallbackData = getDataFromCustomEvent(nativeEvent)),\n              null !== fallbackData && (eventType.data = fallbackData))));\n      if (\n        (fallbackData = canUseTextInputEvent\n          ? getNativeBeforeInputChars(domEventName, nativeEvent)\n          : getFallbackBeforeInputChars(domEventName, nativeEvent))\n      )\n        (eventType = accumulateTwoPhaseListeners(targetInst, \"onBeforeInput\")),\n          0 < eventType.length &&\n            ((handleEventFunc = new SyntheticCompositionEvent(\n              \"onBeforeInput\",\n              \"beforeinput\",\n              null,\n              nativeEvent,\n              nativeEventTarget\n            )),\n            dispatchQueue.push({\n              event: handleEventFunc,\n              listeners: eventType\n            }),\n            (handleEventFunc.data = fallbackData));\n      extractEvents$1(\n        dispatchQueue,\n        domEventName,\n        targetInst,\n        nativeEvent,\n        nativeEventTarget\n      );\n    }\n    processDispatchQueue(dispatchQueue, eventSystemFlags);\n  });\n}\nfunction createDispatchListener(instance, listener, currentTarget) {\n  return {\n    instance: instance,\n    listener: listener,\n    currentTarget: currentTarget\n  };\n}\nfunction accumulateTwoPhaseListeners(targetFiber, reactName) {\n  for (\n    var captureName = reactName + \"Capture\", listeners = [];\n    null !== targetFiber;\n\n  ) {\n    var _instance2 = targetFiber,\n      stateNode = _instance2.stateNode;\n    _instance2 = _instance2.tag;\n    (5 !== _instance2 && 26 !== _instance2 && 27 !== _instance2) ||\n      null === stateNode ||\n      ((_instance2 = getListener(targetFiber, captureName)),\n      null != _instance2 &&\n        listeners.unshift(\n          createDispatchListener(targetFiber, _instance2, stateNode)\n        ),\n      (_instance2 = getListener(targetFiber, reactName)),\n      null != _instance2 &&\n        listeners.push(\n          createDispatchListener(targetFiber, _instance2, stateNode)\n        ));\n    targetFiber = targetFiber.return;\n  }\n  return listeners;\n}\nfunction getParent(inst) {\n  if (null === inst) return null;\n  do inst = inst.return;\n  while (inst && 5 !== inst.tag && 27 !== inst.tag);\n  return inst ? inst : null;\n}\nfunction accumulateEnterLeaveListenersForEvent(\n  dispatchQueue,\n  event,\n  target,\n  common,\n  inCapturePhase\n) {\n  for (\n    var registrationName = event._reactName, listeners = [];\n    null !== target && target !== common;\n\n  ) {\n    var _instance3 = target,\n      alternate = _instance3.alternate,\n      stateNode = _instance3.stateNode;\n    _instance3 = _instance3.tag;\n    if (null !== alternate && alternate === common) break;\n    (5 !== _instance3 && 26 !== _instance3 && 27 !== _instance3) ||\n      null === stateNode ||\n      ((alternate = stateNode),\n      inCapturePhase\n        ? ((stateNode = getListener(target, registrationName)),\n          null != stateNode &&\n            listeners.unshift(\n              createDispatchListener(target, stateNode, alternate)\n            ))\n        : inCapturePhase ||\n          ((stateNode = getListener(target, registrationName)),\n          null != stateNode &&\n            listeners.push(\n              createDispatchListener(target, stateNode, alternate)\n            )));\n    target = target.return;\n  }\n  0 !== listeners.length &&\n    dispatchQueue.push({ event: event, listeners: listeners });\n}\nvar NORMALIZE_NEWLINES_REGEX = /\\r\\n?/g,\n  NORMALIZE_NULL_AND_REPLACEMENT_REGEX = /\\u0000|\\uFFFD/g;\nfunction normalizeMarkupForTextOrAttribute(markup) {\n  return (\"string\" === typeof markup ? markup : \"\" + markup)\n    .replace(NORMALIZE_NEWLINES_REGEX, \"\\n\")\n    .replace(NORMALIZE_NULL_AND_REPLACEMENT_REGEX, \"\");\n}\nfunction checkForUnmatchedText(serverText, clientText) {\n  clientText = normalizeMarkupForTextOrAttribute(clientText);\n  return normalizeMarkupForTextOrAttribute(serverText) === clientText ? !0 : !1;\n}\nfunction noop$1() {}\nfunction setProp(domElement, tag, key, value, props, prevValue) {\n  switch (key) {\n    case \"children\":\n      \"string\" === typeof value\n        ? \"body\" === tag ||\n          (\"textarea\" === tag && \"\" === value) ||\n          setTextContent(domElement, value)\n        : (\"number\" === typeof value || \"bigint\" === typeof value) &&\n          \"body\" !== tag &&\n          setTextContent(domElement, \"\" + value);\n      break;\n    case \"className\":\n      setValueForKnownAttribute(domElement, \"class\", value);\n      break;\n    case \"tabIndex\":\n      setValueForKnownAttribute(domElement, \"tabindex\", value);\n      break;\n    case \"dir\":\n    case \"role\":\n    case \"viewBox\":\n    case \"width\":\n    case \"height\":\n      setValueForKnownAttribute(domElement, key, value);\n      break;\n    case \"style\":\n      setValueForStyles(domElement, value, prevValue);\n      break;\n    case \"data\":\n      if (\"object\" !== tag) {\n        setValueForKnownAttribute(domElement, \"data\", value);\n        break;\n      }\n    case \"src\":\n    case \"href\":\n      if (\"\" === value && (\"a\" !== tag || \"href\" !== key)) {\n        domElement.removeAttribute(key);\n        break;\n      }\n      if (\n        null == value ||\n        \"function\" === typeof value ||\n        \"symbol\" === typeof value ||\n        \"boolean\" === typeof value\n      ) {\n        domElement.removeAttribute(key);\n        break;\n      }\n      value = sanitizeURL(\"\" + value);\n      domElement.setAttribute(key, value);\n      break;\n    case \"action\":\n    case \"formAction\":\n      if (\"function\" === typeof value) {\n        domElement.setAttribute(\n          key,\n          \"javascript:throw new Error('A React form was unexpectedly submitted. If you called form.submit() manually, consider using form.requestSubmit() instead. If you\\\\'re trying to use event.stopPropagation() in a submit event handler, consider also calling event.preventDefault().')\"\n        );\n        break;\n      } else\n        \"function\" === typeof prevValue &&\n          (\"formAction\" === key\n            ? (\"input\" !== tag &&\n                setProp(domElement, tag, \"name\", props.name, props, null),\n              setProp(\n                domElement,\n                tag,\n                \"formEncType\",\n                props.formEncType,\n                props,\n                null\n              ),\n              setProp(\n                domElement,\n                tag,\n                \"formMethod\",\n                props.formMethod,\n                props,\n                null\n              ),\n              setProp(\n                domElement,\n                tag,\n                \"formTarget\",\n                props.formTarget,\n                props,\n                null\n              ))\n            : (setProp(domElement, tag, \"encType\", props.encType, props, null),\n              setProp(domElement, tag, \"method\", props.method, props, null),\n              setProp(domElement, tag, \"target\", props.target, props, null)));\n      if (\n        null == value ||\n        \"symbol\" === typeof value ||\n        \"boolean\" === typeof value\n      ) {\n        domElement.removeAttribute(key);\n        break;\n      }\n      value = sanitizeURL(\"\" + value);\n      domElement.setAttribute(key, value);\n      break;\n    case \"onClick\":\n      null != value && (domElement.onclick = noop$1);\n      break;\n    case \"onScroll\":\n      null != value && listenToNonDelegatedEvent(\"scroll\", domElement);\n      break;\n    case \"onScrollEnd\":\n      null != value && listenToNonDelegatedEvent(\"scrollend\", domElement);\n      break;\n    case \"dangerouslySetInnerHTML\":\n      if (null != value) {\n        if (\"object\" !== typeof value || !(\"__html\" in value))\n          throw Error(formatProdErrorMessage(61));\n        key = value.__html;\n        if (null != key) {\n          if (null != props.children) throw Error(formatProdErrorMessage(60));\n          domElement.innerHTML = key;\n        }\n      }\n      break;\n    case \"multiple\":\n      domElement.multiple =\n        value && \"function\" !== typeof value && \"symbol\" !== typeof value;\n      break;\n    case \"muted\":\n      domElement.muted =\n        value && \"function\" !== typeof value && \"symbol\" !== typeof value;\n      break;\n    case \"suppressContentEditableWarning\":\n    case \"suppressHydrationWarning\":\n    case \"defaultValue\":\n    case \"defaultChecked\":\n    case \"innerHTML\":\n    case \"ref\":\n      break;\n    case \"autoFocus\":\n      break;\n    case \"xlinkHref\":\n      if (\n        null == value ||\n        \"function\" === typeof value ||\n        \"boolean\" === typeof value ||\n        \"symbol\" === typeof value\n      ) {\n        domElement.removeAttribute(\"xlink:href\");\n        break;\n      }\n      key = sanitizeURL(\"\" + value);\n      domElement.setAttributeNS(\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:href\",\n        key\n      );\n      break;\n    case \"contentEditable\":\n    case \"spellCheck\":\n    case \"draggable\":\n    case \"value\":\n    case \"autoReverse\":\n    case \"externalResourcesRequired\":\n    case \"focusable\":\n    case \"preserveAlpha\":\n      null != value && \"function\" !== typeof value && \"symbol\" !== typeof value\n        ? domElement.setAttribute(key, \"\" + value)\n        : domElement.removeAttribute(key);\n      break;\n    case \"inert\":\n    case \"allowFullScreen\":\n    case \"async\":\n    case \"autoPlay\":\n    case \"controls\":\n    case \"default\":\n    case \"defer\":\n    case \"disabled\":\n    case \"disablePictureInPicture\":\n    case \"disableRemotePlayback\":\n    case \"formNoValidate\":\n    case \"hidden\":\n    case \"loop\":\n    case \"noModule\":\n    case \"noValidate\":\n    case \"open\":\n    case \"playsInline\":\n    case \"readOnly\":\n    case \"required\":\n    case \"reversed\":\n    case \"scoped\":\n    case \"seamless\":\n    case \"itemScope\":\n      value && \"function\" !== typeof value && \"symbol\" !== typeof value\n        ? domElement.setAttribute(key, \"\")\n        : domElement.removeAttribute(key);\n      break;\n    case \"capture\":\n    case \"download\":\n      !0 === value\n        ? domElement.setAttribute(key, \"\")\n        : !1 !== value &&\n            null != value &&\n            \"function\" !== typeof value &&\n            \"symbol\" !== typeof value\n          ? domElement.setAttribute(key, value)\n          : domElement.removeAttribute(key);\n      break;\n    case \"cols\":\n    case \"rows\":\n    case \"size\":\n    case \"span\":\n      null != value &&\n      \"function\" !== typeof value &&\n      \"symbol\" !== typeof value &&\n      !isNaN(value) &&\n      1 <= value\n        ? domElement.setAttribute(key, value)\n        : domElement.removeAttribute(key);\n      break;\n    case \"rowSpan\":\n    case \"start\":\n      null == value ||\n      \"function\" === typeof value ||\n      \"symbol\" === typeof value ||\n      isNaN(value)\n        ? domElement.removeAttribute(key)\n        : domElement.setAttribute(key, value);\n      break;\n    case \"popover\":\n      listenToNonDelegatedEvent(\"beforetoggle\", domElement);\n      listenToNonDelegatedEvent(\"toggle\", domElement);\n      setValueForAttribute(domElement, \"popover\", value);\n      break;\n    case \"xlinkActuate\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:actuate\",\n        value\n      );\n      break;\n    case \"xlinkArcrole\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:arcrole\",\n        value\n      );\n      break;\n    case \"xlinkRole\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:role\",\n        value\n      );\n      break;\n    case \"xlinkShow\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:show\",\n        value\n      );\n      break;\n    case \"xlinkTitle\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:title\",\n        value\n      );\n      break;\n    case \"xlinkType\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/1999/xlink\",\n        \"xlink:type\",\n        value\n      );\n      break;\n    case \"xmlBase\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/XML/1998/namespace\",\n        \"xml:base\",\n        value\n      );\n      break;\n    case \"xmlLang\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/XML/1998/namespace\",\n        \"xml:lang\",\n        value\n      );\n      break;\n    case \"xmlSpace\":\n      setValueForNamespacedAttribute(\n        domElement,\n        \"http://www.w3.org/XML/1998/namespace\",\n        \"xml:space\",\n        value\n      );\n      break;\n    case \"is\":\n      setValueForAttribute(domElement, \"is\", value);\n      break;\n    case \"innerText\":\n    case \"textContent\":\n      break;\n    default:\n      if (\n        !(2 < key.length) ||\n        (\"o\" !== key[0] && \"O\" !== key[0]) ||\n        (\"n\" !== key[1] && \"N\" !== key[1])\n      )\n        (key = aliases.get(key) || key),\n          setValueForAttribute(domElement, key, value);\n  }\n}\nfunction setPropOnCustomElement(domElement, tag, key, value, props, prevValue) {\n  switch (key) {\n    case \"style\":\n      setValueForStyles(domElement, value, prevValue);\n      break;\n    case \"dangerouslySetInnerHTML\":\n      if (null != value) {\n        if (\"object\" !== typeof value || !(\"__html\" in value))\n          throw Error(formatProdErrorMessage(61));\n        key = value.__html;\n        if (null != key) {\n          if (null != props.children) throw Error(formatProdErrorMessage(60));\n          domElement.innerHTML = key;\n        }\n      }\n      break;\n    case \"children\":\n      \"string\" === typeof value\n        ? setTextContent(domElement, value)\n        : (\"number\" === typeof value || \"bigint\" === typeof value) &&\n          setTextContent(domElement, \"\" + value);\n      break;\n    case \"onScroll\":\n      null != value && listenToNonDelegatedEvent(\"scroll\", domElement);\n      break;\n    case \"onScrollEnd\":\n      null != value && listenToNonDelegatedEvent(\"scrollend\", domElement);\n      break;\n    case \"onClick\":\n      null != value && (domElement.onclick = noop$1);\n      break;\n    case \"suppressContentEditableWarning\":\n    case \"suppressHydrationWarning\":\n    case \"innerHTML\":\n    case \"ref\":\n      break;\n    case \"innerText\":\n    case \"textContent\":\n      break;\n    default:\n      if (!registrationNameDependencies.hasOwnProperty(key))\n        a: {\n          if (\n            \"o\" === key[0] &&\n            \"n\" === key[1] &&\n            ((props = key.endsWith(\"Capture\")),\n            (tag = key.slice(2, props ? key.length - 7 : void 0)),\n            (prevValue = domElement[internalPropsKey] || null),\n            (prevValue = null != prevValue ? prevValue[key] : null),\n            \"function\" === typeof prevValue &&\n              domElement.removeEventListener(tag, prevValue, props),\n            \"function\" === typeof value)\n          ) {\n            \"function\" !== typeof prevValue &&\n              null !== prevValue &&\n              (key in domElement\n                ? (domElement[key] = null)\n                : domElement.hasAttribute(key) &&\n                  domElement.removeAttribute(key));\n            domElement.addEventListener(tag, value, props);\n            break a;\n          }\n          key in domElement\n            ? (domElement[key] = value)\n            : !0 === value\n              ? domElement.setAttribute(key, \"\")\n              : setValueForAttribute(domElement, key, value);\n        }\n  }\n}\nfunction setInitialProperties(domElement, tag, props) {\n  switch (tag) {\n    case \"div\":\n    case \"span\":\n    case \"svg\":\n    case \"path\":\n    case \"a\":\n    case \"g\":\n    case \"p\":\n    case \"li\":\n      break;\n    case \"img\":\n      listenToNonDelegatedEvent(\"error\", domElement);\n      listenToNonDelegatedEvent(\"load\", domElement);\n      var hasSrc = !1,\n        hasSrcSet = !1,\n        propKey;\n      for (propKey in props)\n        if (props.hasOwnProperty(propKey)) {\n          var propValue = props[propKey];\n          if (null != propValue)\n            switch (propKey) {\n              case \"src\":\n                hasSrc = !0;\n                break;\n              case \"srcSet\":\n                hasSrcSet = !0;\n                break;\n              case \"children\":\n              case \"dangerouslySetInnerHTML\":\n                throw Error(formatProdErrorMessage(137, tag));\n              default:\n                setProp(domElement, tag, propKey, propValue, props, null);\n            }\n        }\n      hasSrcSet &&\n        setProp(domElement, tag, \"srcSet\", props.srcSet, props, null);\n      hasSrc && setProp(domElement, tag, \"src\", props.src, props, null);\n      return;\n    case \"input\":\n      listenToNonDelegatedEvent(\"invalid\", domElement);\n      var defaultValue = (propKey = propValue = hasSrcSet = null),\n        checked = null,\n        defaultChecked = null;\n      for (hasSrc in props)\n        if (props.hasOwnProperty(hasSrc)) {\n          var propValue$186 = props[hasSrc];\n          if (null != propValue$186)\n            switch (hasSrc) {\n              case \"name\":\n                hasSrcSet = propValue$186;\n                break;\n              case \"type\":\n                propValue = propValue$186;\n                break;\n              case \"checked\":\n                checked = propValue$186;\n                break;\n              case \"defaultChecked\":\n                defaultChecked = propValue$186;\n                break;\n              case \"value\":\n                propKey = propValue$186;\n                break;\n              case \"defaultValue\":\n                defaultValue = propValue$186;\n                break;\n              case \"children\":\n              case \"dangerouslySetInnerHTML\":\n                if (null != propValue$186)\n                  throw Error(formatProdErrorMessage(137, tag));\n                break;\n              default:\n                setProp(domElement, tag, hasSrc, propValue$186, props, null);\n            }\n        }\n      initInput(\n        domElement,\n        propKey,\n        defaultValue,\n        checked,\n        defaultChecked,\n        propValue,\n        hasSrcSet,\n        !1\n      );\n      track(domElement);\n      return;\n    case \"select\":\n      listenToNonDelegatedEvent(\"invalid\", domElement);\n      hasSrc = propValue = propKey = null;\n      for (hasSrcSet in props)\n        if (\n          props.hasOwnProperty(hasSrcSet) &&\n          ((defaultValue = props[hasSrcSet]), null != defaultValue)\n        )\n          switch (hasSrcSet) {\n            case \"value\":\n              propKey = defaultValue;\n              break;\n            case \"defaultValue\":\n              propValue = defaultValue;\n              break;\n            case \"multiple\":\n              hasSrc = defaultValue;\n            default:\n              setProp(domElement, tag, hasSrcSet, defaultValue, props, null);\n          }\n      tag = propKey;\n      props = propValue;\n      domElement.multiple = !!hasSrc;\n      null != tag\n        ? updateOptions(domElement, !!hasSrc, tag, !1)\n        : null != props && updateOptions(domElement, !!hasSrc, props, !0);\n      return;\n    case \"textarea\":\n      listenToNonDelegatedEvent(\"invalid\", domElement);\n      propKey = hasSrcSet = hasSrc = null;\n      for (propValue in props)\n        if (\n          props.hasOwnProperty(propValue) &&\n          ((defaultValue = props[propValue]), null != defaultValue)\n        )\n          switch (propValue) {\n            case \"value\":\n              hasSrc = defaultValue;\n              break;\n            case \"defaultValue\":\n              hasSrcSet = defaultValue;\n              break;\n            case \"children\":\n              propKey = defaultValue;\n              break;\n            case \"dangerouslySetInnerHTML\":\n              if (null != defaultValue) throw Error(formatProdErrorMessage(91));\n              break;\n            default:\n              setProp(domElement, tag, propValue, defaultValue, props, null);\n          }\n      initTextarea(domElement, hasSrc, hasSrcSet, propKey);\n      track(domElement);\n      return;\n    case \"option\":\n      for (checked in props)\n        if (\n          props.hasOwnProperty(checked) &&\n          ((hasSrc = props[checked]), null != hasSrc)\n        )\n          switch (checked) {\n            case \"selected\":\n              domElement.selected =\n                hasSrc &&\n                \"function\" !== typeof hasSrc &&\n                \"symbol\" !== typeof hasSrc;\n              break;\n            default:\n              setProp(domElement, tag, checked, hasSrc, props, null);\n          }\n      return;\n    case \"dialog\":\n      listenToNonDelegatedEvent(\"cancel\", domElement);\n      listenToNonDelegatedEvent(\"close\", domElement);\n      break;\n    case \"iframe\":\n    case \"object\":\n      listenToNonDelegatedEvent(\"load\", domElement);\n      break;\n    case \"video\":\n    case \"audio\":\n      for (hasSrc = 0; hasSrc < mediaEventTypes.length; hasSrc++)\n        listenToNonDelegatedEvent(mediaEventTypes[hasSrc], domElement);\n      break;\n    case \"image\":\n      listenToNonDelegatedEvent(\"error\", domElement);\n      listenToNonDelegatedEvent(\"load\", domElement);\n      break;\n    case \"details\":\n      listenToNonDelegatedEvent(\"toggle\", domElement);\n      break;\n    case \"embed\":\n    case \"source\":\n    case \"link\":\n      listenToNonDelegatedEvent(\"error\", domElement),\n        listenToNonDelegatedEvent(\"load\", domElement);\n    case \"area\":\n    case \"base\":\n    case \"br\":\n    case \"col\":\n    case \"hr\":\n    case \"keygen\":\n    case \"meta\":\n    case \"param\":\n    case \"track\":\n    case \"wbr\":\n    case \"menuitem\":\n      for (defaultChecked in props)\n        if (\n          props.hasOwnProperty(defaultChecked) &&\n          ((hasSrc = props[defaultChecked]), null != hasSrc)\n        )\n          switch (defaultChecked) {\n            case \"children\":\n            case \"dangerouslySetInnerHTML\":\n              throw Error(formatProdErrorMessage(137, tag));\n            default:\n              setProp(domElement, tag, defaultChecked, hasSrc, props, null);\n          }\n      return;\n    default:\n      if (isCustomElement(tag)) {\n        for (propValue$186 in props)\n          props.hasOwnProperty(propValue$186) &&\n            ((hasSrc = props[propValue$186]),\n            void 0 !== hasSrc &&\n              setPropOnCustomElement(\n                domElement,\n                tag,\n                propValue$186,\n                hasSrc,\n                props,\n                void 0\n              ));\n        return;\n      }\n  }\n  for (defaultValue in props)\n    props.hasOwnProperty(defaultValue) &&\n      ((hasSrc = props[defaultValue]),\n      null != hasSrc &&\n        setProp(domElement, tag, defaultValue, hasSrc, props, null));\n}\nfunction updateProperties(domElement, tag, lastProps, nextProps) {\n  switch (tag) {\n    case \"div\":\n    case \"span\":\n    case \"svg\":\n    case \"path\":\n    case \"a\":\n    case \"g\":\n    case \"p\":\n    case \"li\":\n      break;\n    case \"input\":\n      var name = null,\n        type = null,\n        value = null,\n        defaultValue = null,\n        lastDefaultValue = null,\n        checked = null,\n        defaultChecked = null;\n      for (propKey in lastProps) {\n        var lastProp = lastProps[propKey];\n        if (lastProps.hasOwnProperty(propKey) && null != lastProp)\n          switch (propKey) {\n            case \"checked\":\n              break;\n            case \"value\":\n              break;\n            case \"defaultValue\":\n              lastDefaultValue = lastProp;\n            default:\n              nextProps.hasOwnProperty(propKey) ||\n                setProp(domElement, tag, propKey, null, nextProps, lastProp);\n          }\n      }\n      for (var propKey$203 in nextProps) {\n        var propKey = nextProps[propKey$203];\n        lastProp = lastProps[propKey$203];\n        if (\n          nextProps.hasOwnProperty(propKey$203) &&\n          (null != propKey || null != lastProp)\n        )\n          switch (propKey$203) {\n            case \"type\":\n              type = propKey;\n              break;\n            case \"name\":\n              name = propKey;\n              break;\n            case \"checked\":\n              checked = propKey;\n              break;\n            case \"defaultChecked\":\n              defaultChecked = propKey;\n              break;\n            case \"value\":\n              value = propKey;\n              break;\n            case \"defaultValue\":\n              defaultValue = propKey;\n              break;\n            case \"children\":\n            case \"dangerouslySetInnerHTML\":\n              if (null != propKey)\n                throw Error(formatProdErrorMessage(137, tag));\n              break;\n            default:\n              propKey !== lastProp &&\n                setProp(\n                  domElement,\n                  tag,\n                  propKey$203,\n                  propKey,\n                  nextProps,\n                  lastProp\n                );\n          }\n      }\n      updateInput(\n        domElement,\n        value,\n        defaultValue,\n        lastDefaultValue,\n        checked,\n        defaultChecked,\n        type,\n        name\n      );\n      return;\n    case \"select\":\n      propKey = value = defaultValue = propKey$203 = null;\n      for (type in lastProps)\n        if (\n          ((lastDefaultValue = lastProps[type]),\n          lastProps.hasOwnProperty(type) && null != lastDefaultValue)\n        )\n          switch (type) {\n            case \"value\":\n              break;\n            case \"multiple\":\n              propKey = lastDefaultValue;\n            default:\n              nextProps.hasOwnProperty(type) ||\n                setProp(\n                  domElement,\n                  tag,\n                  type,\n                  null,\n                  nextProps,\n                  lastDefaultValue\n                );\n          }\n      for (name in nextProps)\n        if (\n          ((type = nextProps[name]),\n          (lastDefaultValue = lastProps[name]),\n          nextProps.hasOwnProperty(name) &&\n            (null != type || null != lastDefaultValue))\n        )\n          switch (name) {\n            case \"value\":\n              propKey$203 = type;\n              break;\n            case \"defaultValue\":\n              defaultValue = type;\n              break;\n            case \"multiple\":\n              value = type;\n            default:\n              type !== lastDefaultValue &&\n                setProp(\n                  domElement,\n                  tag,\n                  name,\n                  type,\n                  nextProps,\n                  lastDefaultValue\n                );\n          }\n      tag = defaultValue;\n      lastProps = value;\n      nextProps = propKey;\n      null != propKey$203\n        ? updateOptions(domElement, !!lastProps, propKey$203, !1)\n        : !!nextProps !== !!lastProps &&\n          (null != tag\n            ? updateOptions(domElement, !!lastProps, tag, !0)\n            : updateOptions(domElement, !!lastProps, lastProps ? [] : \"\", !1));\n      return;\n    case \"textarea\":\n      propKey = propKey$203 = null;\n      for (defaultValue in lastProps)\n        if (\n          ((name = lastProps[defaultValue]),\n          lastProps.hasOwnProperty(defaultValue) &&\n            null != name &&\n            !nextProps.hasOwnProperty(defaultValue))\n        )\n          switch (defaultValue) {\n            case \"value\":\n              break;\n            case \"children\":\n              break;\n            default:\n              setProp(domElement, tag, defaultValue, null, nextProps, name);\n          }\n      for (value in nextProps)\n        if (\n          ((name = nextProps[value]),\n          (type = lastProps[value]),\n          nextProps.hasOwnProperty(value) && (null != name || null != type))\n        )\n          switch (value) {\n            case \"value\":\n              propKey$203 = name;\n              break;\n            case \"defaultValue\":\n              propKey = name;\n              break;\n            case \"children\":\n              break;\n            case \"dangerouslySetInnerHTML\":\n              if (null != name) throw Error(formatProdErrorMessage(91));\n              break;\n            default:\n              name !== type &&\n                setProp(domElement, tag, value, name, nextProps, type);\n          }\n      updateTextarea(domElement, propKey$203, propKey);\n      return;\n    case \"option\":\n      for (var propKey$219 in lastProps)\n        if (\n          ((propKey$203 = lastProps[propKey$219]),\n          lastProps.hasOwnProperty(propKey$219) &&\n            null != propKey$203 &&\n            !nextProps.hasOwnProperty(propKey$219))\n        )\n          switch (propKey$219) {\n            case \"selected\":\n              domElement.selected = !1;\n              break;\n            default:\n              setProp(\n                domElement,\n                tag,\n                propKey$219,\n                null,\n                nextProps,\n                propKey$203\n              );\n          }\n      for (lastDefaultValue in nextProps)\n        if (\n          ((propKey$203 = nextProps[lastDefaultValue]),\n          (propKey = lastProps[lastDefaultValue]),\n          nextProps.hasOwnProperty(lastDefaultValue) &&\n            propKey$203 !== propKey &&\n            (null != propKey$203 || null != propKey))\n        )\n          switch (lastDefaultValue) {\n            case \"selected\":\n              domElement.selected =\n                propKey$203 &&\n                \"function\" !== typeof propKey$203 &&\n                \"symbol\" !== typeof propKey$203;\n              break;\n            default:\n              setProp(\n                domElement,\n                tag,\n                lastDefaultValue,\n                propKey$203,\n                nextProps,\n                propKey\n              );\n          }\n      return;\n    case \"img\":\n    case \"link\":\n    case \"area\":\n    case \"base\":\n    case \"br\":\n    case \"col\":\n    case \"embed\":\n    case \"hr\":\n    case \"keygen\":\n    case \"meta\":\n    case \"param\":\n    case \"source\":\n    case \"track\":\n    case \"wbr\":\n    case \"menuitem\":\n      for (var propKey$224 in lastProps)\n        (propKey$203 = lastProps[propKey$224]),\n          lastProps.hasOwnProperty(propKey$224) &&\n            null != propKey$203 &&\n            !nextProps.hasOwnProperty(propKey$224) &&\n            setProp(domElement, tag, propKey$224, null, nextProps, propKey$203);\n      for (checked in nextProps)\n        if (\n          ((propKey$203 = nextProps[checked]),\n          (propKey = lastProps[checked]),\n          nextProps.hasOwnProperty(checked) &&\n            propKey$203 !== propKey &&\n            (null != propKey$203 || null != propKey))\n        )\n          switch (checked) {\n            case \"children\":\n            case \"dangerouslySetInnerHTML\":\n              if (null != propKey$203)\n                throw Error(formatProdErrorMessage(137, tag));\n              break;\n            default:\n              setProp(\n                domElement,\n                tag,\n                checked,\n                propKey$203,\n                nextProps,\n                propKey\n              );\n          }\n      return;\n    default:\n      if (isCustomElement(tag)) {\n        for (var propKey$229 in lastProps)\n          (propKey$203 = lastProps[propKey$229]),\n            lastProps.hasOwnProperty(propKey$229) &&\n              void 0 !== propKey$203 &&\n              !nextProps.hasOwnProperty(propKey$229) &&\n              setPropOnCustomElement(\n                domElement,\n                tag,\n                propKey$229,\n                void 0,\n                nextProps,\n                propKey$203\n              );\n        for (defaultChecked in nextProps)\n          (propKey$203 = nextProps[defaultChecked]),\n            (propKey = lastProps[defaultChecked]),\n            !nextProps.hasOwnProperty(defaultChecked) ||\n              propKey$203 === propKey ||\n              (void 0 === propKey$203 && void 0 === propKey) ||\n              setPropOnCustomElement(\n                domElement,\n                tag,\n                defaultChecked,\n                propKey$203,\n                nextProps,\n                propKey\n              );\n        return;\n      }\n  }\n  for (var propKey$234 in lastProps)\n    (propKey$203 = lastProps[propKey$234]),\n      lastProps.hasOwnProperty(propKey$234) &&\n        null != propKey$203 &&\n        !nextProps.hasOwnProperty(propKey$234) &&\n        setProp(domElement, tag, propKey$234, null, nextProps, propKey$203);\n  for (lastProp in nextProps)\n    (propKey$203 = nextProps[lastProp]),\n      (propKey = lastProps[lastProp]),\n      !nextProps.hasOwnProperty(lastProp) ||\n        propKey$203 === propKey ||\n        (null == propKey$203 && null == propKey) ||\n        setProp(domElement, tag, lastProp, propKey$203, nextProps, propKey);\n}\nvar eventsEnabled = null,\n  selectionInformation = null;\nfunction getOwnerDocumentFromRootContainer(rootContainerElement) {\n  return 9 === rootContainerElement.nodeType\n    ? rootContainerElement\n    : rootContainerElement.ownerDocument;\n}\nfunction getOwnHostContext(namespaceURI) {\n  switch (namespaceURI) {\n    case \"http://www.w3.org/2000/svg\":\n      return 1;\n    case \"http://www.w3.org/1998/Math/MathML\":\n      return 2;\n    default:\n      return 0;\n  }\n}\nfunction getChildHostContextProd(parentNamespace, type) {\n  if (0 === parentNamespace)\n    switch (type) {\n      case \"svg\":\n        return 1;\n      case \"math\":\n        return 2;\n      default:\n        return 0;\n    }\n  return 1 === parentNamespace && \"foreignObject\" === type\n    ? 0\n    : parentNamespace;\n}\nfunction shouldSetTextContent(type, props) {\n  return (\n    \"textarea\" === type ||\n    \"noscript\" === type ||\n    \"string\" === typeof props.children ||\n    \"number\" === typeof props.children ||\n    \"bigint\" === typeof props.children ||\n    (\"object\" === typeof props.dangerouslySetInnerHTML &&\n      null !== props.dangerouslySetInnerHTML &&\n      null != props.dangerouslySetInnerHTML.__html)\n  );\n}\nvar currentPopstateTransitionEvent = null;\nfunction shouldAttemptEagerTransition() {\n  var event = window.event;\n  if (event && \"popstate\" === event.type) {\n    if (event === currentPopstateTransitionEvent) return !1;\n    currentPopstateTransitionEvent = event;\n    return !0;\n  }\n  currentPopstateTransitionEvent = null;\n  return !1;\n}\nvar scheduleTimeout = \"function\" === typeof setTimeout ? setTimeout : void 0,\n  cancelTimeout = \"function\" === typeof clearTimeout ? clearTimeout : void 0,\n  localPromise = \"function\" === typeof Promise ? Promise : void 0,\n  scheduleMicrotask =\n    \"function\" === typeof queueMicrotask\n      ? queueMicrotask\n      : \"undefined\" !== typeof localPromise\n        ? function (callback) {\n            return localPromise\n              .resolve(null)\n              .then(callback)\n              .catch(handleErrorInNextTick);\n          }\n        : scheduleTimeout;\nfunction handleErrorInNextTick(error) {\n  setTimeout(function () {\n    throw error;\n  });\n}\nfunction clearSuspenseBoundary(parentInstance, suspenseInstance) {\n  var node = suspenseInstance,\n    depth = 0;\n  do {\n    var nextNode = node.nextSibling;\n    parentInstance.removeChild(node);\n    if (nextNode && 8 === nextNode.nodeType)\n      if (((node = nextNode.data), \"/$\" === node)) {\n        if (0 === depth) {\n          parentInstance.removeChild(nextNode);\n          retryIfBlockedOn(suspenseInstance);\n          return;\n        }\n        depth--;\n      } else (\"$\" !== node && \"$?\" !== node && \"$!\" !== node) || depth++;\n    node = nextNode;\n  } while (node);\n  retryIfBlockedOn(suspenseInstance);\n}\nfunction clearContainerSparingly(container) {\n  var nextNode = container.firstChild;\n  nextNode && 10 === nextNode.nodeType && (nextNode = nextNode.nextSibling);\n  for (; nextNode; ) {\n    var node = nextNode;\n    nextNode = nextNode.nextSibling;\n    switch (node.nodeName) {\n      case \"HTML\":\n      case \"HEAD\":\n      case \"BODY\":\n        clearContainerSparingly(node);\n        detachDeletedInstance(node);\n        continue;\n      case \"SCRIPT\":\n      case \"STYLE\":\n        continue;\n      case \"LINK\":\n        if (\"stylesheet\" === node.rel.toLowerCase()) continue;\n    }\n    container.removeChild(node);\n  }\n}\nfunction canHydrateInstance(instance, type, props, inRootOrSingleton) {\n  for (; 1 === instance.nodeType; ) {\n    var anyProps = props;\n    if (instance.nodeName.toLowerCase() !== type.toLowerCase()) {\n      if (\n        !inRootOrSingleton &&\n        (\"INPUT\" !== instance.nodeName || \"hidden\" !== instance.type)\n      )\n        break;\n    } else if (!inRootOrSingleton)\n      if (\"input\" === type && \"hidden\" === instance.type) {\n        var name = null == anyProps.name ? null : \"\" + anyProps.name;\n        if (\n          \"hidden\" === anyProps.type &&\n          instance.getAttribute(\"name\") === name\n        )\n          return instance;\n      } else return instance;\n    else if (!instance[internalHoistableMarker])\n      switch (type) {\n        case \"meta\":\n          if (!instance.hasAttribute(\"itemprop\")) break;\n          return instance;\n        case \"link\":\n          name = instance.getAttribute(\"rel\");\n          if (\"stylesheet\" === name && instance.hasAttribute(\"data-precedence\"))\n            break;\n          else if (\n            name !== anyProps.rel ||\n            instance.getAttribute(\"href\") !==\n              (null == anyProps.href ? null : anyProps.href) ||\n            instance.getAttribute(\"crossorigin\") !==\n              (null == anyProps.crossOrigin ? null : anyProps.crossOrigin) ||\n            instance.getAttribute(\"title\") !==\n              (null == anyProps.title ? null : anyProps.title)\n          )\n            break;\n          return instance;\n        case \"style\":\n          if (instance.hasAttribute(\"data-precedence\")) break;\n          return instance;\n        case \"script\":\n          name = instance.getAttribute(\"src\");\n          if (\n            (name !== (null == anyProps.src ? null : anyProps.src) ||\n              instance.getAttribute(\"type\") !==\n                (null == anyProps.type ? null : anyProps.type) ||\n              instance.getAttribute(\"crossorigin\") !==\n                (null == anyProps.crossOrigin ? null : anyProps.crossOrigin)) &&\n            name &&\n            instance.hasAttribute(\"async\") &&\n            !instance.hasAttribute(\"itemprop\")\n          )\n            break;\n          return instance;\n        default:\n          return instance;\n      }\n    instance = getNextHydratable(instance.nextSibling);\n    if (null === instance) break;\n  }\n  return null;\n}\nfunction canHydrateTextInstance(instance, text, inRootOrSingleton) {\n  if (\"\" === text) return null;\n  for (; 3 !== instance.nodeType; ) {\n    if (\n      (1 !== instance.nodeType ||\n        \"INPUT\" !== instance.nodeName ||\n        \"hidden\" !== instance.type) &&\n      !inRootOrSingleton\n    )\n      return null;\n    instance = getNextHydratable(instance.nextSibling);\n    if (null === instance) return null;\n  }\n  return instance;\n}\nfunction getNextHydratable(node) {\n  for (; null != node; node = node.nextSibling) {\n    var nodeType = node.nodeType;\n    if (1 === nodeType || 3 === nodeType) break;\n    if (8 === nodeType) {\n      nodeType = node.data;\n      if (\n        \"$\" === nodeType ||\n        \"$!\" === nodeType ||\n        \"$?\" === nodeType ||\n        \"F!\" === nodeType ||\n        \"F\" === nodeType\n      )\n        break;\n      if (\"/$\" === nodeType) return null;\n    }\n  }\n  return node;\n}\nfunction getParentSuspenseInstance(targetInstance) {\n  targetInstance = targetInstance.previousSibling;\n  for (var depth = 0; targetInstance; ) {\n    if (8 === targetInstance.nodeType) {\n      var data = targetInstance.data;\n      if (\"$\" === data || \"$!\" === data || \"$?\" === data) {\n        if (0 === depth) return targetInstance;\n        depth--;\n      } else \"/$\" === data && depth++;\n    }\n    targetInstance = targetInstance.previousSibling;\n  }\n  return null;\n}\nfunction resolveSingletonInstance(type, props, rootContainerInstance) {\n  props = getOwnerDocumentFromRootContainer(rootContainerInstance);\n  switch (type) {\n    case \"html\":\n      type = props.documentElement;\n      if (!type) throw Error(formatProdErrorMessage(452));\n      return type;\n    case \"head\":\n      type = props.head;\n      if (!type) throw Error(formatProdErrorMessage(453));\n      return type;\n    case \"body\":\n      type = props.body;\n      if (!type) throw Error(formatProdErrorMessage(454));\n      return type;\n    default:\n      throw Error(formatProdErrorMessage(451));\n  }\n}\nvar preloadPropsMap = new Map(),\n  preconnectsSet = new Set();\nfunction getHoistableRoot(container) {\n  return \"function\" === typeof container.getRootNode\n    ? container.getRootNode()\n    : container.ownerDocument;\n}\nvar previousDispatcher = ReactDOMSharedInternals.d;\nReactDOMSharedInternals.d = {\n  f: flushSyncWork,\n  r: requestFormReset,\n  D: prefetchDNS,\n  C: preconnect,\n  L: preload,\n  m: preloadModule,\n  X: preinitScript,\n  S: preinitStyle,\n  M: preinitModuleScript\n};\nfunction flushSyncWork() {\n  var previousWasRendering = previousDispatcher.f(),\n    wasRendering = flushSyncWork$1();\n  return previousWasRendering || wasRendering;\n}\nfunction requestFormReset(form) {\n  var formInst = getInstanceFromNode(form);\n  null !== formInst && 5 === formInst.tag && \"form\" === formInst.type\n    ? requestFormReset$1(formInst)\n    : previousDispatcher.r(form);\n}\nvar globalDocument = \"undefined\" === typeof document ? null : document;\nfunction preconnectAs(rel, href, crossOrigin) {\n  var ownerDocument = globalDocument;\n  if (ownerDocument && \"string\" === typeof href && href) {\n    var limitedEscapedHref =\n      escapeSelectorAttributeValueInsideDoubleQuotes(href);\n    limitedEscapedHref =\n      'link[rel=\"' + rel + '\"][href=\"' + limitedEscapedHref + '\"]';\n    \"string\" === typeof crossOrigin &&\n      (limitedEscapedHref += '[crossorigin=\"' + crossOrigin + '\"]');\n    preconnectsSet.has(limitedEscapedHref) ||\n      (preconnectsSet.add(limitedEscapedHref),\n      (rel = { rel: rel, crossOrigin: crossOrigin, href: href }),\n      null === ownerDocument.querySelector(limitedEscapedHref) &&\n        ((href = ownerDocument.createElement(\"link\")),\n        setInitialProperties(href, \"link\", rel),\n        markNodeAsHoistable(href),\n        ownerDocument.head.appendChild(href)));\n  }\n}\nfunction prefetchDNS(href) {\n  previousDispatcher.D(href);\n  preconnectAs(\"dns-prefetch\", href, null);\n}\nfunction preconnect(href, crossOrigin) {\n  previousDispatcher.C(href, crossOrigin);\n  preconnectAs(\"preconnect\", href, crossOrigin);\n}\nfunction preload(href, as, options) {\n  previousDispatcher.L(href, as, options);\n  var ownerDocument = globalDocument;\n  if (ownerDocument && href && as) {\n    var preloadSelector =\n      'link[rel=\"preload\"][as=\"' +\n      escapeSelectorAttributeValueInsideDoubleQuotes(as) +\n      '\"]';\n    \"image\" === as\n      ? options && options.imageSrcSet\n        ? ((preloadSelector +=\n            '[imagesrcset=\"' +\n            escapeSelectorAttributeValueInsideDoubleQuotes(\n              options.imageSrcSet\n            ) +\n            '\"]'),\n          \"string\" === typeof options.imageSizes &&\n            (preloadSelector +=\n              '[imagesizes=\"' +\n              escapeSelectorAttributeValueInsideDoubleQuotes(\n                options.imageSizes\n              ) +\n              '\"]'))\n        : (preloadSelector +=\n            '[href=\"' +\n            escapeSelectorAttributeValueInsideDoubleQuotes(href) +\n            '\"]')\n      : (preloadSelector +=\n          '[href=\"' +\n          escapeSelectorAttributeValueInsideDoubleQuotes(href) +\n          '\"]');\n    var key = preloadSelector;\n    switch (as) {\n      case \"style\":\n        key = getStyleKey(href);\n        break;\n      case \"script\":\n        key = getScriptKey(href);\n    }\n    preloadPropsMap.has(key) ||\n      ((href = assign(\n        {\n          rel: \"preload\",\n          href:\n            \"image\" === as && options && options.imageSrcSet ? void 0 : href,\n          as: as\n        },\n        options\n      )),\n      preloadPropsMap.set(key, href),\n      null !== ownerDocument.querySelector(preloadSelector) ||\n        (\"style\" === as &&\n          ownerDocument.querySelector(getStylesheetSelectorFromKey(key))) ||\n        (\"script\" === as &&\n          ownerDocument.querySelector(getScriptSelectorFromKey(key))) ||\n        ((as = ownerDocument.createElement(\"link\")),\n        setInitialProperties(as, \"link\", href),\n        markNodeAsHoistable(as),\n        ownerDocument.head.appendChild(as)));\n  }\n}\nfunction preloadModule(href, options) {\n  previousDispatcher.m(href, options);\n  var ownerDocument = globalDocument;\n  if (ownerDocument && href) {\n    var as = options && \"string\" === typeof options.as ? options.as : \"script\",\n      preloadSelector =\n        'link[rel=\"modulepreload\"][as=\"' +\n        escapeSelectorAttributeValueInsideDoubleQuotes(as) +\n        '\"][href=\"' +\n        escapeSelectorAttributeValueInsideDoubleQuotes(href) +\n        '\"]',\n      key = preloadSelector;\n    switch (as) {\n      case \"audioworklet\":\n      case \"paintworklet\":\n      case \"serviceworker\":\n      case \"sharedworker\":\n      case \"worker\":\n      case \"script\":\n        key = getScriptKey(href);\n    }\n    if (\n      !preloadPropsMap.has(key) &&\n      ((href = assign({ rel: \"modulepreload\", href: href }, options)),\n      preloadPropsMap.set(key, href),\n      null === ownerDocument.querySelector(preloadSelector))\n    ) {\n      switch (as) {\n        case \"audioworklet\":\n        case \"paintworklet\":\n        case \"serviceworker\":\n        case \"sharedworker\":\n        case \"worker\":\n        case \"script\":\n          if (ownerDocument.querySelector(getScriptSelectorFromKey(key)))\n            return;\n      }\n      as = ownerDocument.createElement(\"link\");\n      setInitialProperties(as, \"link\", href);\n      markNodeAsHoistable(as);\n      ownerDocument.head.appendChild(as);\n    }\n  }\n}\nfunction preinitStyle(href, precedence, options) {\n  previousDispatcher.S(href, precedence, options);\n  var ownerDocument = globalDocument;\n  if (ownerDocument && href) {\n    var styles = getResourcesFromRoot(ownerDocument).hoistableStyles,\n      key = getStyleKey(href);\n    precedence = precedence || \"default\";\n    var resource = styles.get(key);\n    if (!resource) {\n      var state = { loading: 0, preload: null };\n      if (\n        (resource = ownerDocument.querySelector(\n          getStylesheetSelectorFromKey(key)\n        ))\n      )\n        state.loading = 5;\n      else {\n        href = assign(\n          { rel: \"stylesheet\", href: href, \"data-precedence\": precedence },\n          options\n        );\n        (options = preloadPropsMap.get(key)) &&\n          adoptPreloadPropsForStylesheet(href, options);\n        var link = (resource = ownerDocument.createElement(\"link\"));\n        markNodeAsHoistable(link);\n        setInitialProperties(link, \"link\", href);\n        link._p = new Promise(function (resolve, reject) {\n          link.onload = resolve;\n          link.onerror = reject;\n        });\n        link.addEventListener(\"load\", function () {\n          state.loading |= 1;\n        });\n        link.addEventListener(\"error\", function () {\n          state.loading |= 2;\n        });\n        state.loading |= 4;\n        insertStylesheet(resource, precedence, ownerDocument);\n      }\n      resource = {\n        type: \"stylesheet\",\n        instance: resource,\n        count: 1,\n        state: state\n      };\n      styles.set(key, resource);\n    }\n  }\n}\nfunction preinitScript(src, options) {\n  previousDispatcher.X(src, options);\n  var ownerDocument = globalDocument;\n  if (ownerDocument && src) {\n    var scripts = getResourcesFromRoot(ownerDocument).hoistableScripts,\n      key = getScriptKey(src),\n      resource = scripts.get(key);\n    resource ||\n      ((resource = ownerDocument.querySelector(getScriptSelectorFromKey(key))),\n      resource ||\n        ((src = assign({ src: src, async: !0 }, options)),\n        (options = preloadPropsMap.get(key)) &&\n          adoptPreloadPropsForScript(src, options),\n        (resource = ownerDocument.createElement(\"script\")),\n        markNodeAsHoistable(resource),\n        setInitialProperties(resource, \"link\", src),\n        ownerDocument.head.appendChild(resource)),\n      (resource = {\n        type: \"script\",\n        instance: resource,\n        count: 1,\n        state: null\n      }),\n      scripts.set(key, resource));\n  }\n}\nfunction preinitModuleScript(src, options) {\n  previousDispatcher.M(src, options);\n  var ownerDocument = globalDocument;\n  if (ownerDocument && src) {\n    var scripts = getResourcesFromRoot(ownerDocument).hoistableScripts,\n      key = getScriptKey(src),\n      resource = scripts.get(key);\n    resource ||\n      ((resource = ownerDocument.querySelector(getScriptSelectorFromKey(key))),\n      resource ||\n        ((src = assign({ src: src, async: !0, type: \"module\" }, options)),\n        (options = preloadPropsMap.get(key)) &&\n          adoptPreloadPropsForScript(src, options),\n        (resource = ownerDocument.createElement(\"script\")),\n        markNodeAsHoistable(resource),\n        setInitialProperties(resource, \"link\", src),\n        ownerDocument.head.appendChild(resource)),\n      (resource = {\n        type: \"script\",\n        instance: resource,\n        count: 1,\n        state: null\n      }),\n      scripts.set(key, resource));\n  }\n}\nfunction getResource(type, currentProps, pendingProps, currentResource) {\n  var JSCompiler_inline_result = (JSCompiler_inline_result =\n    rootInstanceStackCursor.current)\n    ? getHoistableRoot(JSCompiler_inline_result)\n    : null;\n  if (!JSCompiler_inline_result) throw Error(formatProdErrorMessage(446));\n  switch (type) {\n    case \"meta\":\n    case \"title\":\n      return null;\n    case \"style\":\n      return \"string\" === typeof pendingProps.precedence &&\n        \"string\" === typeof pendingProps.href\n        ? ((currentProps = getStyleKey(pendingProps.href)),\n          (pendingProps = getResourcesFromRoot(\n            JSCompiler_inline_result\n          ).hoistableStyles),\n          (currentResource = pendingProps.get(currentProps)),\n          currentResource ||\n            ((currentResource = {\n              type: \"style\",\n              instance: null,\n              count: 0,\n              state: null\n            }),\n            pendingProps.set(currentProps, currentResource)),\n          currentResource)\n        : { type: \"void\", instance: null, count: 0, state: null };\n    case \"link\":\n      if (\n        \"stylesheet\" === pendingProps.rel &&\n        \"string\" === typeof pendingProps.href &&\n        \"string\" === typeof pendingProps.precedence\n      ) {\n        type = getStyleKey(pendingProps.href);\n        var styles$242 = getResourcesFromRoot(\n            JSCompiler_inline_result\n          ).hoistableStyles,\n          resource$243 = styles$242.get(type);\n        resource$243 ||\n          ((JSCompiler_inline_result =\n            JSCompiler_inline_result.ownerDocument || JSCompiler_inline_result),\n          (resource$243 = {\n            type: \"stylesheet\",\n            instance: null,\n            count: 0,\n            state: { loading: 0, preload: null }\n          }),\n          styles$242.set(type, resource$243),\n          (styles$242 = JSCompiler_inline_result.querySelector(\n            getStylesheetSelectorFromKey(type)\n          )) &&\n            !styles$242._p &&\n            ((resource$243.instance = styles$242),\n            (resource$243.state.loading = 5)),\n          preloadPropsMap.has(type) ||\n            ((pendingProps = {\n              rel: \"preload\",\n              as: \"style\",\n              href: pendingProps.href,\n              crossOrigin: pendingProps.crossOrigin,\n              integrity: pendingProps.integrity,\n              media: pendingProps.media,\n              hrefLang: pendingProps.hrefLang,\n              referrerPolicy: pendingProps.referrerPolicy\n            }),\n            preloadPropsMap.set(type, pendingProps),\n            styles$242 ||\n              preloadStylesheet(\n                JSCompiler_inline_result,\n                type,\n                pendingProps,\n                resource$243.state\n              )));\n        if (currentProps && null === currentResource)\n          throw Error(formatProdErrorMessage(528, \"\"));\n        return resource$243;\n      }\n      if (currentProps && null !== currentResource)\n        throw Error(formatProdErrorMessage(529, \"\"));\n      return null;\n    case \"script\":\n      return (\n        (currentProps = pendingProps.async),\n        (pendingProps = pendingProps.src),\n        \"string\" === typeof pendingProps &&\n        currentProps &&\n        \"function\" !== typeof currentProps &&\n        \"symbol\" !== typeof currentProps\n          ? ((currentProps = getScriptKey(pendingProps)),\n            (pendingProps = getResourcesFromRoot(\n              JSCompiler_inline_result\n            ).hoistableScripts),\n            (currentResource = pendingProps.get(currentProps)),\n            currentResource ||\n              ((currentResource = {\n                type: \"script\",\n                instance: null,\n                count: 0,\n                state: null\n              }),\n              pendingProps.set(currentProps, currentResource)),\n            currentResource)\n          : { type: \"void\", instance: null, count: 0, state: null }\n      );\n    default:\n      throw Error(formatProdErrorMessage(444, type));\n  }\n}\nfunction getStyleKey(href) {\n  return 'href=\"' + escapeSelectorAttributeValueInsideDoubleQuotes(href) + '\"';\n}\nfunction getStylesheetSelectorFromKey(key) {\n  return 'link[rel=\"stylesheet\"][' + key + \"]\";\n}\nfunction stylesheetPropsFromRawProps(rawProps) {\n  return assign({}, rawProps, {\n    \"data-precedence\": rawProps.precedence,\n    precedence: null\n  });\n}\nfunction preloadStylesheet(ownerDocument, key, preloadProps, state) {\n  ownerDocument.querySelector('link[rel=\"preload\"][as=\"style\"][' + key + \"]\")\n    ? (state.loading = 1)\n    : ((key = ownerDocument.createElement(\"link\")),\n      (state.preload = key),\n      key.addEventListener(\"load\", function () {\n        return (state.loading |= 1);\n      }),\n      key.addEventListener(\"error\", function () {\n        return (state.loading |= 2);\n      }),\n      setInitialProperties(key, \"link\", preloadProps),\n      markNodeAsHoistable(key),\n      ownerDocument.head.appendChild(key));\n}\nfunction getScriptKey(src) {\n  return '[src=\"' + escapeSelectorAttributeValueInsideDoubleQuotes(src) + '\"]';\n}\nfunction getScriptSelectorFromKey(key) {\n  return \"script[async]\" + key;\n}\nfunction acquireResource(hoistableRoot, resource, props) {\n  resource.count++;\n  if (null === resource.instance)\n    switch (resource.type) {\n      case \"style\":\n        var instance = hoistableRoot.querySelector(\n          'style[data-href~=\"' +\n            escapeSelectorAttributeValueInsideDoubleQuotes(props.href) +\n            '\"]'\n        );\n        if (instance)\n          return (\n            (resource.instance = instance),\n            markNodeAsHoistable(instance),\n            instance\n          );\n        var styleProps = assign({}, props, {\n          \"data-href\": props.href,\n          \"data-precedence\": props.precedence,\n          href: null,\n          precedence: null\n        });\n        instance = (hoistableRoot.ownerDocument || hoistableRoot).createElement(\n          \"style\"\n        );\n        markNodeAsHoistable(instance);\n        setInitialProperties(instance, \"style\", styleProps);\n        insertStylesheet(instance, props.precedence, hoistableRoot);\n        return (resource.instance = instance);\n      case \"stylesheet\":\n        styleProps = getStyleKey(props.href);\n        var instance$248 = hoistableRoot.querySelector(\n          getStylesheetSelectorFromKey(styleProps)\n        );\n        if (instance$248)\n          return (\n            (resource.state.loading |= 4),\n            (resource.instance = instance$248),\n            markNodeAsHoistable(instance$248),\n            instance$248\n          );\n        instance = stylesheetPropsFromRawProps(props);\n        (styleProps = preloadPropsMap.get(styleProps)) &&\n          adoptPreloadPropsForStylesheet(instance, styleProps);\n        instance$248 = (\n          hoistableRoot.ownerDocument || hoistableRoot\n        ).createElement(\"link\");\n        markNodeAsHoistable(instance$248);\n        var linkInstance = instance$248;\n        linkInstance._p = new Promise(function (resolve, reject) {\n          linkInstance.onload = resolve;\n          linkInstance.onerror = reject;\n        });\n        setInitialProperties(instance$248, \"link\", instance);\n        resource.state.loading |= 4;\n        insertStylesheet(instance$248, props.precedence, hoistableRoot);\n        return (resource.instance = instance$248);\n      case \"script\":\n        instance$248 = getScriptKey(props.src);\n        if (\n          (styleProps = hoistableRoot.querySelector(\n            getScriptSelectorFromKey(instance$248)\n          ))\n        )\n          return (\n            (resource.instance = styleProps),\n            markNodeAsHoistable(styleProps),\n            styleProps\n          );\n        instance = props;\n        if ((styleProps = preloadPropsMap.get(instance$248)))\n          (instance = assign({}, props)),\n            adoptPreloadPropsForScript(instance, styleProps);\n        hoistableRoot = hoistableRoot.ownerDocument || hoistableRoot;\n        styleProps = hoistableRoot.createElement(\"script\");\n        markNodeAsHoistable(styleProps);\n        setInitialProperties(styleProps, \"link\", instance);\n        hoistableRoot.head.appendChild(styleProps);\n        return (resource.instance = styleProps);\n      case \"void\":\n        return null;\n      default:\n        throw Error(formatProdErrorMessage(443, resource.type));\n    }\n  else\n    \"stylesheet\" === resource.type &&\n      0 === (resource.state.loading & 4) &&\n      ((instance = resource.instance),\n      (resource.state.loading |= 4),\n      insertStylesheet(instance, props.precedence, hoistableRoot));\n  return resource.instance;\n}\nfunction insertStylesheet(instance, precedence, root) {\n  for (\n    var nodes = root.querySelectorAll(\n        'link[rel=\"stylesheet\"][data-precedence],style[data-precedence]'\n      ),\n      last = nodes.length ? nodes[nodes.length - 1] : null,\n      prior = last,\n      i = 0;\n    i < nodes.length;\n    i++\n  ) {\n    var node = nodes[i];\n    if (node.dataset.precedence === precedence) prior = node;\n    else if (prior !== last) break;\n  }\n  prior\n    ? prior.parentNode.insertBefore(instance, prior.nextSibling)\n    : ((precedence = 9 === root.nodeType ? root.head : root),\n      precedence.insertBefore(instance, precedence.firstChild));\n}\nfunction adoptPreloadPropsForStylesheet(stylesheetProps, preloadProps) {\n  null == stylesheetProps.crossOrigin &&\n    (stylesheetProps.crossOrigin = preloadProps.crossOrigin);\n  null == stylesheetProps.referrerPolicy &&\n    (stylesheetProps.referrerPolicy = preloadProps.referrerPolicy);\n  null == stylesheetProps.title && (stylesheetProps.title = preloadProps.title);\n}\nfunction adoptPreloadPropsForScript(scriptProps, preloadProps) {\n  null == scriptProps.crossOrigin &&\n    (scriptProps.crossOrigin = preloadProps.crossOrigin);\n  null == scriptProps.referrerPolicy &&\n    (scriptProps.referrerPolicy = preloadProps.referrerPolicy);\n  null == scriptProps.integrity &&\n    (scriptProps.integrity = preloadProps.integrity);\n}\nvar tagCaches = null;\nfunction getHydratableHoistableCache(type, keyAttribute, ownerDocument) {\n  if (null === tagCaches) {\n    var cache = new Map();\n    var caches = (tagCaches = new Map());\n    caches.set(ownerDocument, cache);\n  } else\n    (caches = tagCaches),\n      (cache = caches.get(ownerDocument)),\n      cache || ((cache = new Map()), caches.set(ownerDocument, cache));\n  if (cache.has(type)) return cache;\n  cache.set(type, null);\n  ownerDocument = ownerDocument.getElementsByTagName(type);\n  for (caches = 0; caches < ownerDocument.length; caches++) {\n    var node = ownerDocument[caches];\n    if (\n      !(\n        node[internalHoistableMarker] ||\n        node[internalInstanceKey] ||\n        (\"link\" === type && \"stylesheet\" === node.getAttribute(\"rel\"))\n      ) &&\n      \"http://www.w3.org/2000/svg\" !== node.namespaceURI\n    ) {\n      var nodeKey = node.getAttribute(keyAttribute) || \"\";\n      nodeKey = type + nodeKey;\n      var existing = cache.get(nodeKey);\n      existing ? existing.push(node) : cache.set(nodeKey, [node]);\n    }\n  }\n  return cache;\n}\nfunction mountHoistable(hoistableRoot, type, instance) {\n  hoistableRoot = hoistableRoot.ownerDocument || hoistableRoot;\n  hoistableRoot.head.insertBefore(\n    instance,\n    \"title\" === type ? hoistableRoot.querySelector(\"head > title\") : null\n  );\n}\nfunction isHostHoistableType(type, props, hostContext) {\n  if (1 === hostContext || null != props.itemProp) return !1;\n  switch (type) {\n    case \"meta\":\n    case \"title\":\n      return !0;\n    case \"style\":\n      if (\n        \"string\" !== typeof props.precedence ||\n        \"string\" !== typeof props.href ||\n        \"\" === props.href\n      )\n        break;\n      return !0;\n    case \"link\":\n      if (\n        \"string\" !== typeof props.rel ||\n        \"string\" !== typeof props.href ||\n        \"\" === props.href ||\n        props.onLoad ||\n        props.onError\n      )\n        break;\n      switch (props.rel) {\n        case \"stylesheet\":\n          return (\n            (type = props.disabled),\n            \"string\" === typeof props.precedence && null == type\n          );\n        default:\n          return !0;\n      }\n    case \"script\":\n      if (\n        props.async &&\n        \"function\" !== typeof props.async &&\n        \"symbol\" !== typeof props.async &&\n        !props.onLoad &&\n        !props.onError &&\n        props.src &&\n        \"string\" === typeof props.src\n      )\n        return !0;\n  }\n  return !1;\n}\nfunction preloadResource(resource) {\n  return \"stylesheet\" === resource.type && 0 === (resource.state.loading & 3)\n    ? !1\n    : !0;\n}\nvar suspendedState = null;\nfunction noop() {}\nfunction suspendResource(hoistableRoot, resource, props) {\n  if (null === suspendedState) throw Error(formatProdErrorMessage(475));\n  var state = suspendedState;\n  if (\n    \"stylesheet\" === resource.type &&\n    (\"string\" !== typeof props.media ||\n      !1 !== matchMedia(props.media).matches) &&\n    0 === (resource.state.loading & 4)\n  ) {\n    if (null === resource.instance) {\n      var key = getStyleKey(props.href),\n        instance = hoistableRoot.querySelector(\n          getStylesheetSelectorFromKey(key)\n        );\n      if (instance) {\n        hoistableRoot = instance._p;\n        null !== hoistableRoot &&\n          \"object\" === typeof hoistableRoot &&\n          \"function\" === typeof hoistableRoot.then &&\n          (state.count++,\n          (state = onUnsuspend.bind(state)),\n          hoistableRoot.then(state, state));\n        resource.state.loading |= 4;\n        resource.instance = instance;\n        markNodeAsHoistable(instance);\n        return;\n      }\n      instance = hoistableRoot.ownerDocument || hoistableRoot;\n      props = stylesheetPropsFromRawProps(props);\n      (key = preloadPropsMap.get(key)) &&\n        adoptPreloadPropsForStylesheet(props, key);\n      instance = instance.createElement(\"link\");\n      markNodeAsHoistable(instance);\n      var linkInstance = instance;\n      linkInstance._p = new Promise(function (resolve, reject) {\n        linkInstance.onload = resolve;\n        linkInstance.onerror = reject;\n      });\n      setInitialProperties(instance, \"link\", props);\n      resource.instance = instance;\n    }\n    null === state.stylesheets && (state.stylesheets = new Map());\n    state.stylesheets.set(resource, hoistableRoot);\n    (hoistableRoot = resource.state.preload) &&\n      0 === (resource.state.loading & 3) &&\n      (state.count++,\n      (resource = onUnsuspend.bind(state)),\n      hoistableRoot.addEventListener(\"load\", resource),\n      hoistableRoot.addEventListener(\"error\", resource));\n  }\n}\nfunction waitForCommitToBeReady() {\n  if (null === suspendedState) throw Error(formatProdErrorMessage(475));\n  var state = suspendedState;\n  state.stylesheets &&\n    0 === state.count &&\n    insertSuspendedStylesheets(state, state.stylesheets);\n  return 0 < state.count\n    ? function (commit) {\n        var stylesheetTimer = setTimeout(function () {\n          state.stylesheets &&\n            insertSuspendedStylesheets(state, state.stylesheets);\n          if (state.unsuspend) {\n            var unsuspend = state.unsuspend;\n            state.unsuspend = null;\n            unsuspend();\n          }\n        }, 6e4);\n        state.unsuspend = commit;\n        return function () {\n          state.unsuspend = null;\n          clearTimeout(stylesheetTimer);\n        };\n      }\n    : null;\n}\nfunction onUnsuspend() {\n  this.count--;\n  if (0 === this.count)\n    if (this.stylesheets) insertSuspendedStylesheets(this, this.stylesheets);\n    else if (this.unsuspend) {\n      var unsuspend = this.unsuspend;\n      this.unsuspend = null;\n      unsuspend();\n    }\n}\nvar precedencesByRoot = null;\nfunction insertSuspendedStylesheets(state, resources) {\n  state.stylesheets = null;\n  null !== state.unsuspend &&\n    (state.count++,\n    (precedencesByRoot = new Map()),\n    resources.forEach(insertStylesheetIntoRoot, state),\n    (precedencesByRoot = null),\n    onUnsuspend.call(state));\n}\nfunction insertStylesheetIntoRoot(root, resource) {\n  if (!(resource.state.loading & 4)) {\n    var precedences = precedencesByRoot.get(root);\n    if (precedences) var last = precedences.get(null);\n    else {\n      precedences = new Map();\n      precedencesByRoot.set(root, precedences);\n      for (\n        var nodes = root.querySelectorAll(\n            \"link[data-precedence],style[data-precedence]\"\n          ),\n          i = 0;\n        i < nodes.length;\n        i++\n      ) {\n        var node = nodes[i];\n        if (\n          \"LINK\" === node.nodeName ||\n          \"not all\" !== node.getAttribute(\"media\")\n        )\n          precedences.set(node.dataset.precedence, node), (last = node);\n      }\n      last && precedences.set(null, last);\n    }\n    nodes = resource.instance;\n    node = nodes.getAttribute(\"data-precedence\");\n    i = precedences.get(node) || last;\n    i === last && precedences.set(null, nodes);\n    precedences.set(node, nodes);\n    this.count++;\n    last = onUnsuspend.bind(this);\n    nodes.addEventListener(\"load\", last);\n    nodes.addEventListener(\"error\", last);\n    i\n      ? i.parentNode.insertBefore(nodes, i.nextSibling)\n      : ((root = 9 === root.nodeType ? root.head : root),\n        root.insertBefore(nodes, root.firstChild));\n    resource.state.loading |= 4;\n  }\n}\nvar HostTransitionContext = {\n  $$typeof: REACT_CONTEXT_TYPE,\n  Provider: null,\n  Consumer: null,\n  _currentValue: sharedNotPendingObject,\n  _currentValue2: sharedNotPendingObject,\n  _threadCount: 0\n};\nfunction FiberRootNode(\n  containerInfo,\n  tag,\n  hydrate,\n  identifierPrefix,\n  onUncaughtError,\n  onCaughtError,\n  onRecoverableError,\n  formState\n) {\n  this.tag = 1;\n  this.containerInfo = containerInfo;\n  this.finishedWork =\n    this.pingCache =\n    this.current =\n    this.pendingChildren =\n      null;\n  this.timeoutHandle = -1;\n  this.callbackNode =\n    this.next =\n    this.pendingContext =\n    this.context =\n    this.cancelPendingCommit =\n      null;\n  this.callbackPriority = 0;\n  this.expirationTimes = createLaneMap(-1);\n  this.entangledLanes =\n    this.shellSuspendCounter =\n    this.errorRecoveryDisabledLanes =\n    this.finishedLanes =\n    this.expiredLanes =\n    this.warmLanes =\n    this.pingedLanes =\n    this.suspendedLanes =\n    this.pendingLanes =\n      0;\n  this.entanglements = createLaneMap(0);\n  this.hiddenUpdates = createLaneMap(null);\n  this.identifierPrefix = identifierPrefix;\n  this.onUncaughtError = onUncaughtError;\n  this.onCaughtError = onCaughtError;\n  this.onRecoverableError = onRecoverableError;\n  this.pooledCache = null;\n  this.pooledCacheLanes = 0;\n  this.formState = formState;\n  this.incompleteTransitions = new Map();\n}\nfunction createFiberRoot(\n  containerInfo,\n  tag,\n  hydrate,\n  initialChildren,\n  hydrationCallbacks,\n  isStrictMode,\n  identifierPrefix,\n  onUncaughtError,\n  onCaughtError,\n  onRecoverableError,\n  transitionCallbacks,\n  formState\n) {\n  containerInfo = new FiberRootNode(\n    containerInfo,\n    tag,\n    hydrate,\n    identifierPrefix,\n    onUncaughtError,\n    onCaughtError,\n    onRecoverableError,\n    formState\n  );\n  tag = 1;\n  !0 === isStrictMode && (tag |= 24);\n  isStrictMode = createFiberImplClass(3, null, null, tag);\n  containerInfo.current = isStrictMode;\n  isStrictMode.stateNode = containerInfo;\n  tag = createCache();\n  tag.refCount++;\n  containerInfo.pooledCache = tag;\n  tag.refCount++;\n  isStrictMode.memoizedState = {\n    element: initialChildren,\n    isDehydrated: hydrate,\n    cache: tag\n  };\n  initializeUpdateQueue(isStrictMode);\n  return containerInfo;\n}\nfunction getContextForSubtree(parentComponent) {\n  if (!parentComponent) return emptyContextObject;\n  parentComponent = emptyContextObject;\n  return parentComponent;\n}\nfunction updateContainerImpl(\n  rootFiber,\n  lane,\n  element,\n  container,\n  parentComponent,\n  callback\n) {\n  parentComponent = getContextForSubtree(parentComponent);\n  null === container.context\n    ? (container.context = parentComponent)\n    : (container.pendingContext = parentComponent);\n  container = createUpdate(lane);\n  container.payload = { element: element };\n  callback = void 0 === callback ? null : callback;\n  null !== callback && (container.callback = callback);\n  element = enqueueUpdate(rootFiber, container, lane);\n  null !== element &&\n    (scheduleUpdateOnFiber(element, rootFiber, lane),\n    entangleTransitions(element, rootFiber, lane));\n}\nfunction markRetryLaneImpl(fiber, retryLane) {\n  fiber = fiber.memoizedState;\n  if (null !== fiber && null !== fiber.dehydrated) {\n    var a = fiber.retryLane;\n    fiber.retryLane = 0 !== a && a < retryLane ? a : retryLane;\n  }\n}\nfunction markRetryLaneIfNotHydrated(fiber, retryLane) {\n  markRetryLaneImpl(fiber, retryLane);\n  (fiber = fiber.alternate) && markRetryLaneImpl(fiber, retryLane);\n}\nfunction attemptContinuousHydration(fiber) {\n  if (13 === fiber.tag) {\n    var root = enqueueConcurrentRenderForLane(fiber, 67108864);\n    null !== root && scheduleUpdateOnFiber(root, fiber, 67108864);\n    markRetryLaneIfNotHydrated(fiber, 67108864);\n  }\n}\nvar _enabled = !0;\nfunction dispatchDiscreteEvent(\n  domEventName,\n  eventSystemFlags,\n  container,\n  nativeEvent\n) {\n  var prevTransition = ReactSharedInternals.T;\n  ReactSharedInternals.T = null;\n  var previousPriority = ReactDOMSharedInternals.p;\n  try {\n    (ReactDOMSharedInternals.p = 2),\n      dispatchEvent(domEventName, eventSystemFlags, container, nativeEvent);\n  } finally {\n    (ReactDOMSharedInternals.p = previousPriority),\n      (ReactSharedInternals.T = prevTransition);\n  }\n}\nfunction dispatchContinuousEvent(\n  domEventName,\n  eventSystemFlags,\n  container,\n  nativeEvent\n) {\n  var prevTransition = ReactSharedInternals.T;\n  ReactSharedInternals.T = null;\n  var previousPriority = ReactDOMSharedInternals.p;\n  try {\n    (ReactDOMSharedInternals.p = 8),\n      dispatchEvent(domEventName, eventSystemFlags, container, nativeEvent);\n  } finally {\n    (ReactDOMSharedInternals.p = previousPriority),\n      (ReactSharedInternals.T = prevTransition);\n  }\n}\nfunction dispatchEvent(\n  domEventName,\n  eventSystemFlags,\n  targetContainer,\n  nativeEvent\n) {\n  if (_enabled) {\n    var blockedOn = findInstanceBlockingEvent(nativeEvent);\n    if (null === blockedOn)\n      dispatchEventForPluginEventSystem(\n        domEventName,\n        eventSystemFlags,\n        nativeEvent,\n        return_targetInst,\n        targetContainer\n      ),\n        clearIfContinuousEvent(domEventName, nativeEvent);\n    else if (\n      queueIfContinuousEvent(\n        blockedOn,\n        domEventName,\n        eventSystemFlags,\n        targetContainer,\n        nativeEvent\n      )\n    )\n      nativeEvent.stopPropagation();\n    else if (\n      (clearIfContinuousEvent(domEventName, nativeEvent),\n      eventSystemFlags & 4 &&\n        -1 < discreteReplayableEvents.indexOf(domEventName))\n    ) {\n      for (; null !== blockedOn; ) {\n        var fiber = getInstanceFromNode(blockedOn);\n        if (null !== fiber)\n          switch (fiber.tag) {\n            case 3:\n              fiber = fiber.stateNode;\n              if (fiber.current.memoizedState.isDehydrated) {\n                var lanes = getHighestPriorityLanes(fiber.pendingLanes);\n                if (0 !== lanes) {\n                  var root = fiber;\n                  root.pendingLanes |= 2;\n                  for (root.entangledLanes |= 2; lanes; ) {\n                    var lane = 1 << (31 - clz32(lanes));\n                    root.entanglements[1] |= lane;\n                    lanes &= ~lane;\n                  }\n                  ensureRootIsScheduled(fiber);\n                  0 === (executionContext & 6) &&\n                    ((workInProgressRootRenderTargetTime = now() + 500),\n                    flushSyncWorkAcrossRoots_impl(0, !1));\n                }\n              }\n              break;\n            case 13:\n              (root = enqueueConcurrentRenderForLane(fiber, 2)),\n                null !== root && scheduleUpdateOnFiber(root, fiber, 2),\n                flushSyncWork$1(),\n                markRetryLaneIfNotHydrated(fiber, 2);\n          }\n        fiber = findInstanceBlockingEvent(nativeEvent);\n        null === fiber &&\n          dispatchEventForPluginEventSystem(\n            domEventName,\n            eventSystemFlags,\n            nativeEvent,\n            return_targetInst,\n            targetContainer\n          );\n        if (fiber === blockedOn) break;\n        blockedOn = fiber;\n      }\n      null !== blockedOn && nativeEvent.stopPropagation();\n    } else\n      dispatchEventForPluginEventSystem(\n        domEventName,\n        eventSystemFlags,\n        nativeEvent,\n        null,\n        targetContainer\n      );\n  }\n}\nfunction findInstanceBlockingEvent(nativeEvent) {\n  nativeEvent = getEventTarget(nativeEvent);\n  return findInstanceBlockingTarget(nativeEvent);\n}\nvar return_targetInst = null;\nfunction findInstanceBlockingTarget(targetNode) {\n  return_targetInst = null;\n  targetNode = getClosestInstanceFromNode(targetNode);\n  if (null !== targetNode) {\n    var nearestMounted = getNearestMountedFiber(targetNode);\n    if (null === nearestMounted) targetNode = null;\n    else {\n      var tag = nearestMounted.tag;\n      if (13 === tag) {\n        targetNode = getSuspenseInstanceFromFiber(nearestMounted);\n        if (null !== targetNode) return targetNode;\n        targetNode = null;\n      } else if (3 === tag) {\n        if (nearestMounted.stateNode.current.memoizedState.isDehydrated)\n          return 3 === nearestMounted.tag\n            ? nearestMounted.stateNode.containerInfo\n            : null;\n        targetNode = null;\n      } else nearestMounted !== targetNode && (targetNode = null);\n    }\n  }\n  return_targetInst = targetNode;\n  return null;\n}\nfunction getEventPriority(domEventName) {\n  switch (domEventName) {\n    case \"beforetoggle\":\n    case \"cancel\":\n    case \"click\":\n    case \"close\":\n    case \"contextmenu\":\n    case \"copy\":\n    case \"cut\":\n    case \"auxclick\":\n    case \"dblclick\":\n    case \"dragend\":\n    case \"dragstart\":\n    case \"drop\":\n    case \"focusin\":\n    case \"focusout\":\n    case \"input\":\n    case \"invalid\":\n    case \"keydown\":\n    case \"keypress\":\n    case \"keyup\":\n    case \"mousedown\":\n    case \"mouseup\":\n    case \"paste\":\n    case \"pause\":\n    case \"play\":\n    case \"pointercancel\":\n    case \"pointerdown\":\n    case \"pointerup\":\n    case \"ratechange\":\n    case \"reset\":\n    case \"resize\":\n    case \"seeked\":\n    case \"submit\":\n    case \"toggle\":\n    case \"touchcancel\":\n    case \"touchend\":\n    case \"touchstart\":\n    case \"volumechange\":\n    case \"change\":\n    case \"selectionchange\":\n    case \"textInput\":\n    case \"compositionstart\":\n    case \"compositionend\":\n    case \"compositionupdate\":\n    case \"beforeblur\":\n    case \"afterblur\":\n    case \"beforeinput\":\n    case \"blur\":\n    case \"fullscreenchange\":\n    case \"focus\":\n    case \"hashchange\":\n    case \"popstate\":\n    case \"select\":\n    case \"selectstart\":\n      return 2;\n    case \"drag\":\n    case \"dragenter\":\n    case \"dragexit\":\n    case \"dragleave\":\n    case \"dragover\":\n    case \"mousemove\":\n    case \"mouseout\":\n    case \"mouseover\":\n    case \"pointermove\":\n    case \"pointerout\":\n    case \"pointerover\":\n    case \"scroll\":\n    case \"touchmove\":\n    case \"wheel\":\n    case \"mouseenter\":\n    case \"mouseleave\":\n    case \"pointerenter\":\n    case \"pointerleave\":\n      return 8;\n    case \"message\":\n      switch (getCurrentPriorityLevel()) {\n        case ImmediatePriority:\n          return 2;\n        case UserBlockingPriority:\n          return 8;\n        case NormalPriority$1:\n        case LowPriority:\n          return 32;\n        case IdlePriority:\n          return 268435456;\n        default:\n          return 32;\n      }\n    default:\n      return 32;\n  }\n}\nvar hasScheduledReplayAttempt = !1,\n  queuedFocus = null,\n  queuedDrag = null,\n  queuedMouse = null,\n  queuedPointers = new Map(),\n  queuedPointerCaptures = new Map(),\n  queuedExplicitHydrationTargets = [],\n  discreteReplayableEvents =\n    \"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\".split(\n      \" \"\n    );\nfunction clearIfContinuousEvent(domEventName, nativeEvent) {\n  switch (domEventName) {\n    case \"focusin\":\n    case \"focusout\":\n      queuedFocus = null;\n      break;\n    case \"dragenter\":\n    case \"dragleave\":\n      queuedDrag = null;\n      break;\n    case \"mouseover\":\n    case \"mouseout\":\n      queuedMouse = null;\n      break;\n    case \"pointerover\":\n    case \"pointerout\":\n      queuedPointers.delete(nativeEvent.pointerId);\n      break;\n    case \"gotpointercapture\":\n    case \"lostpointercapture\":\n      queuedPointerCaptures.delete(nativeEvent.pointerId);\n  }\n}\nfunction accumulateOrCreateContinuousQueuedReplayableEvent(\n  existingQueuedEvent,\n  blockedOn,\n  domEventName,\n  eventSystemFlags,\n  targetContainer,\n  nativeEvent\n) {\n  if (\n    null === existingQueuedEvent ||\n    existingQueuedEvent.nativeEvent !== nativeEvent\n  )\n    return (\n      (existingQueuedEvent = {\n        blockedOn: blockedOn,\n        domEventName: domEventName,\n        eventSystemFlags: eventSystemFlags,\n        nativeEvent: nativeEvent,\n        targetContainers: [targetContainer]\n      }),\n      null !== blockedOn &&\n        ((blockedOn = getInstanceFromNode(blockedOn)),\n        null !== blockedOn && attemptContinuousHydration(blockedOn)),\n      existingQueuedEvent\n    );\n  existingQueuedEvent.eventSystemFlags |= eventSystemFlags;\n  blockedOn = existingQueuedEvent.targetContainers;\n  null !== targetContainer &&\n    -1 === blockedOn.indexOf(targetContainer) &&\n    blockedOn.push(targetContainer);\n  return existingQueuedEvent;\n}\nfunction queueIfContinuousEvent(\n  blockedOn,\n  domEventName,\n  eventSystemFlags,\n  targetContainer,\n  nativeEvent\n) {\n  switch (domEventName) {\n    case \"focusin\":\n      return (\n        (queuedFocus = accumulateOrCreateContinuousQueuedReplayableEvent(\n          queuedFocus,\n          blockedOn,\n          domEventName,\n          eventSystemFlags,\n          targetContainer,\n          nativeEvent\n        )),\n        !0\n      );\n    case \"dragenter\":\n      return (\n        (queuedDrag = accumulateOrCreateContinuousQueuedReplayableEvent(\n          queuedDrag,\n          blockedOn,\n          domEventName,\n          eventSystemFlags,\n          targetContainer,\n          nativeEvent\n        )),\n        !0\n      );\n    case \"mouseover\":\n      return (\n        (queuedMouse = accumulateOrCreateContinuousQueuedReplayableEvent(\n          queuedMouse,\n          blockedOn,\n          domEventName,\n          eventSystemFlags,\n          targetContainer,\n          nativeEvent\n        )),\n        !0\n      );\n    case \"pointerover\":\n      var pointerId = nativeEvent.pointerId;\n      queuedPointers.set(\n        pointerId,\n        accumulateOrCreateContinuousQueuedReplayableEvent(\n          queuedPointers.get(pointerId) || null,\n          blockedOn,\n          domEventName,\n          eventSystemFlags,\n          targetContainer,\n          nativeEvent\n        )\n      );\n      return !0;\n    case \"gotpointercapture\":\n      return (\n        (pointerId = nativeEvent.pointerId),\n        queuedPointerCaptures.set(\n          pointerId,\n          accumulateOrCreateContinuousQueuedReplayableEvent(\n            queuedPointerCaptures.get(pointerId) || null,\n            blockedOn,\n            domEventName,\n            eventSystemFlags,\n            targetContainer,\n            nativeEvent\n          )\n        ),\n        !0\n      );\n  }\n  return !1;\n}\nfunction attemptExplicitHydrationTarget(queuedTarget) {\n  var targetInst = getClosestInstanceFromNode(queuedTarget.target);\n  if (null !== targetInst) {\n    var nearestMounted = getNearestMountedFiber(targetInst);\n    if (null !== nearestMounted)\n      if (((targetInst = nearestMounted.tag), 13 === targetInst)) {\n        if (\n          ((targetInst = getSuspenseInstanceFromFiber(nearestMounted)),\n          null !== targetInst)\n        ) {\n          queuedTarget.blockedOn = targetInst;\n          runWithPriority(queuedTarget.priority, function () {\n            if (13 === nearestMounted.tag) {\n              var lane = requestUpdateLane(),\n                root = enqueueConcurrentRenderForLane(nearestMounted, lane);\n              null !== root &&\n                scheduleUpdateOnFiber(root, nearestMounted, lane);\n              markRetryLaneIfNotHydrated(nearestMounted, lane);\n            }\n          });\n          return;\n        }\n      } else if (\n        3 === targetInst &&\n        nearestMounted.stateNode.current.memoizedState.isDehydrated\n      ) {\n        queuedTarget.blockedOn =\n          3 === nearestMounted.tag\n            ? nearestMounted.stateNode.containerInfo\n            : null;\n        return;\n      }\n  }\n  queuedTarget.blockedOn = null;\n}\nfunction attemptReplayContinuousQueuedEvent(queuedEvent) {\n  if (null !== queuedEvent.blockedOn) return !1;\n  for (\n    var targetContainers = queuedEvent.targetContainers;\n    0 < targetContainers.length;\n\n  ) {\n    var nextBlockedOn = findInstanceBlockingEvent(queuedEvent.nativeEvent);\n    if (null === nextBlockedOn) {\n      nextBlockedOn = queuedEvent.nativeEvent;\n      var nativeEventClone = new nextBlockedOn.constructor(\n        nextBlockedOn.type,\n        nextBlockedOn\n      );\n      currentReplayingEvent = nativeEventClone;\n      nextBlockedOn.target.dispatchEvent(nativeEventClone);\n      currentReplayingEvent = null;\n    } else\n      return (\n        (targetContainers = getInstanceFromNode(nextBlockedOn)),\n        null !== targetContainers &&\n          attemptContinuousHydration(targetContainers),\n        (queuedEvent.blockedOn = nextBlockedOn),\n        !1\n      );\n    targetContainers.shift();\n  }\n  return !0;\n}\nfunction attemptReplayContinuousQueuedEventInMap(queuedEvent, key, map) {\n  attemptReplayContinuousQueuedEvent(queuedEvent) && map.delete(key);\n}\nfunction replayUnblockedEvents() {\n  hasScheduledReplayAttempt = !1;\n  null !== queuedFocus &&\n    attemptReplayContinuousQueuedEvent(queuedFocus) &&\n    (queuedFocus = null);\n  null !== queuedDrag &&\n    attemptReplayContinuousQueuedEvent(queuedDrag) &&\n    (queuedDrag = null);\n  null !== queuedMouse &&\n    attemptReplayContinuousQueuedEvent(queuedMouse) &&\n    (queuedMouse = null);\n  queuedPointers.forEach(attemptReplayContinuousQueuedEventInMap);\n  queuedPointerCaptures.forEach(attemptReplayContinuousQueuedEventInMap);\n}\nfunction scheduleCallbackIfUnblocked(queuedEvent, unblocked) {\n  queuedEvent.blockedOn === unblocked &&\n    ((queuedEvent.blockedOn = null),\n    hasScheduledReplayAttempt ||\n      ((hasScheduledReplayAttempt = !0),\n      Scheduler.unstable_scheduleCallback(\n        Scheduler.unstable_NormalPriority,\n        replayUnblockedEvents\n      )));\n}\nvar lastScheduledReplayQueue = null;\nfunction scheduleReplayQueueIfNeeded(formReplayingQueue) {\n  lastScheduledReplayQueue !== formReplayingQueue &&\n    ((lastScheduledReplayQueue = formReplayingQueue),\n    Scheduler.unstable_scheduleCallback(\n      Scheduler.unstable_NormalPriority,\n      function () {\n        lastScheduledReplayQueue === formReplayingQueue &&\n          (lastScheduledReplayQueue = null);\n        for (var i = 0; i < formReplayingQueue.length; i += 3) {\n          var form = formReplayingQueue[i],\n            submitterOrAction = formReplayingQueue[i + 1],\n            formData = formReplayingQueue[i + 2];\n          if (\"function\" !== typeof submitterOrAction)\n            if (null === findInstanceBlockingTarget(submitterOrAction || form))\n              continue;\n            else break;\n          var formInst = getInstanceFromNode(form);\n          null !== formInst &&\n            (formReplayingQueue.splice(i, 3),\n            (i -= 3),\n            startHostTransition(\n              formInst,\n              {\n                pending: !0,\n                data: formData,\n                method: form.method,\n                action: submitterOrAction\n              },\n              submitterOrAction,\n              formData\n            ));\n        }\n      }\n    ));\n}\nfunction retryIfBlockedOn(unblocked) {\n  function unblock(queuedEvent) {\n    return scheduleCallbackIfUnblocked(queuedEvent, unblocked);\n  }\n  null !== queuedFocus && scheduleCallbackIfUnblocked(queuedFocus, unblocked);\n  null !== queuedDrag && scheduleCallbackIfUnblocked(queuedDrag, unblocked);\n  null !== queuedMouse && scheduleCallbackIfUnblocked(queuedMouse, unblocked);\n  queuedPointers.forEach(unblock);\n  queuedPointerCaptures.forEach(unblock);\n  for (var i = 0; i < queuedExplicitHydrationTargets.length; i++) {\n    var queuedTarget = queuedExplicitHydrationTargets[i];\n    queuedTarget.blockedOn === unblocked && (queuedTarget.blockedOn = null);\n  }\n  for (\n    ;\n    0 < queuedExplicitHydrationTargets.length &&\n    ((i = queuedExplicitHydrationTargets[0]), null === i.blockedOn);\n\n  )\n    attemptExplicitHydrationTarget(i),\n      null === i.blockedOn && queuedExplicitHydrationTargets.shift();\n  i = (unblocked.ownerDocument || unblocked).$$reactFormReplay;\n  if (null != i)\n    for (queuedTarget = 0; queuedTarget < i.length; queuedTarget += 3) {\n      var form = i[queuedTarget],\n        submitterOrAction = i[queuedTarget + 1],\n        formProps = form[internalPropsKey] || null;\n      if (\"function\" === typeof submitterOrAction)\n        formProps || scheduleReplayQueueIfNeeded(i);\n      else if (formProps) {\n        var action = null;\n        if (submitterOrAction && submitterOrAction.hasAttribute(\"formAction\"))\n          if (\n            ((form = submitterOrAction),\n            (formProps = submitterOrAction[internalPropsKey] || null))\n          )\n            action = formProps.formAction;\n          else {\n            if (null !== findInstanceBlockingTarget(form)) continue;\n          }\n        else action = formProps.action;\n        \"function\" === typeof action\n          ? (i[queuedTarget + 1] = action)\n          : (i.splice(queuedTarget, 3), (queuedTarget -= 3));\n        scheduleReplayQueueIfNeeded(i);\n      }\n    }\n}\nfunction ReactDOMRoot(internalRoot) {\n  this._internalRoot = internalRoot;\n}\nReactDOMHydrationRoot.prototype.render = ReactDOMRoot.prototype.render =\n  function (children) {\n    var root = this._internalRoot;\n    if (null === root) throw Error(formatProdErrorMessage(409));\n    var current = root.current,\n      lane = requestUpdateLane();\n    updateContainerImpl(current, lane, children, root, null, null);\n  };\nReactDOMHydrationRoot.prototype.unmount = ReactDOMRoot.prototype.unmount =\n  function () {\n    var root = this._internalRoot;\n    if (null !== root) {\n      this._internalRoot = null;\n      var container = root.containerInfo;\n      0 === root.tag && flushPassiveEffects();\n      updateContainerImpl(root.current, 2, null, root, null, null);\n      flushSyncWork$1();\n      container[internalContainerInstanceKey] = null;\n    }\n  };\nfunction ReactDOMHydrationRoot(internalRoot) {\n  this._internalRoot = internalRoot;\n}\nReactDOMHydrationRoot.prototype.unstable_scheduleHydration = function (target) {\n  if (target) {\n    var updatePriority = resolveUpdatePriority();\n    target = { blockedOn: null, target: target, priority: updatePriority };\n    for (\n      var i = 0;\n      i < queuedExplicitHydrationTargets.length &&\n      0 !== updatePriority &&\n      updatePriority < queuedExplicitHydrationTargets[i].priority;\n      i++\n    );\n    queuedExplicitHydrationTargets.splice(i, 0, target);\n    0 === i && attemptExplicitHydrationTarget(target);\n  }\n};\nvar isomorphicReactPackageVersion$jscomp$inline_1686 = React.version;\nif (\n  \"19.0.0\" !==\n  isomorphicReactPackageVersion$jscomp$inline_1686\n)\n  throw Error(\n    formatProdErrorMessage(\n      527,\n      isomorphicReactPackageVersion$jscomp$inline_1686,\n      \"19.0.0\"\n    )\n  );\nReactDOMSharedInternals.findDOMNode = function (componentOrElement) {\n  var fiber = componentOrElement._reactInternals;\n  if (void 0 === fiber) {\n    if (\"function\" === typeof componentOrElement.render)\n      throw Error(formatProdErrorMessage(188));\n    componentOrElement = Object.keys(componentOrElement).join(\",\");\n    throw Error(formatProdErrorMessage(268, componentOrElement));\n  }\n  componentOrElement = findCurrentFiberUsingSlowPath(fiber);\n  componentOrElement =\n    null !== componentOrElement\n      ? findCurrentHostFiberImpl(componentOrElement)\n      : null;\n  componentOrElement =\n    null === componentOrElement ? null : componentOrElement.stateNode;\n  return componentOrElement;\n};\nvar internals$jscomp$inline_2165 = {\n  bundleType: 0,\n  version: \"19.0.0\",\n  rendererPackageName: \"react-dom\",\n  currentDispatcherRef: ReactSharedInternals,\n  findFiberByHostInstance: getClosestInstanceFromNode,\n  reconcilerVersion: \"19.0.0\"\n};\nif (\"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__) {\n  var hook$jscomp$inline_2166 = __REACT_DEVTOOLS_GLOBAL_HOOK__;\n  if (\n    !hook$jscomp$inline_2166.isDisabled &&\n    hook$jscomp$inline_2166.supportsFiber\n  )\n    try {\n      (rendererID = hook$jscomp$inline_2166.inject(\n        internals$jscomp$inline_2165\n      )),\n        (injectedHook = hook$jscomp$inline_2166);\n    } catch (err) {}\n}\nexports.createRoot = function (container, options) {\n  if (!isValidContainer(container)) throw Error(formatProdErrorMessage(299));\n  var isStrictMode = !1,\n    identifierPrefix = \"\",\n    onUncaughtError = defaultOnUncaughtError,\n    onCaughtError = defaultOnCaughtError,\n    onRecoverableError = defaultOnRecoverableError,\n    transitionCallbacks = null;\n  null !== options &&\n    void 0 !== options &&\n    (!0 === options.unstable_strictMode && (isStrictMode = !0),\n    void 0 !== options.identifierPrefix &&\n      (identifierPrefix = options.identifierPrefix),\n    void 0 !== options.onUncaughtError &&\n      (onUncaughtError = options.onUncaughtError),\n    void 0 !== options.onCaughtError && (onCaughtError = options.onCaughtError),\n    void 0 !== options.onRecoverableError &&\n      (onRecoverableError = options.onRecoverableError),\n    void 0 !== options.unstable_transitionCallbacks &&\n      (transitionCallbacks = options.unstable_transitionCallbacks));\n  options = createFiberRoot(\n    container,\n    1,\n    !1,\n    null,\n    null,\n    isStrictMode,\n    identifierPrefix,\n    onUncaughtError,\n    onCaughtError,\n    onRecoverableError,\n    transitionCallbacks,\n    null\n  );\n  container[internalContainerInstanceKey] = options.current;\n  listenToAllSupportedEvents(\n    8 === container.nodeType ? container.parentNode : container\n  );\n  return new ReactDOMRoot(options);\n};\nexports.hydrateRoot = function (container, initialChildren, options) {\n  if (!isValidContainer(container)) throw Error(formatProdErrorMessage(299));\n  var isStrictMode = !1,\n    identifierPrefix = \"\",\n    onUncaughtError = defaultOnUncaughtError,\n    onCaughtError = defaultOnCaughtError,\n    onRecoverableError = defaultOnRecoverableError,\n    transitionCallbacks = null,\n    formState = null;\n  null !== options &&\n    void 0 !== options &&\n    (!0 === options.unstable_strictMode && (isStrictMode = !0),\n    void 0 !== options.identifierPrefix &&\n      (identifierPrefix = options.identifierPrefix),\n    void 0 !== options.onUncaughtError &&\n      (onUncaughtError = options.onUncaughtError),\n    void 0 !== options.onCaughtError && (onCaughtError = options.onCaughtError),\n    void 0 !== options.onRecoverableError &&\n      (onRecoverableError = options.onRecoverableError),\n    void 0 !== options.unstable_transitionCallbacks &&\n      (transitionCallbacks = options.unstable_transitionCallbacks),\n    void 0 !== options.formState && (formState = options.formState));\n  initialChildren = createFiberRoot(\n    container,\n    1,\n    !0,\n    initialChildren,\n    null != options ? options : null,\n    isStrictMode,\n    identifierPrefix,\n    onUncaughtError,\n    onCaughtError,\n    onRecoverableError,\n    transitionCallbacks,\n    formState\n  );\n  initialChildren.context = getContextForSubtree(null);\n  options = initialChildren.current;\n  isStrictMode = requestUpdateLane();\n  identifierPrefix = createUpdate(isStrictMode);\n  identifierPrefix.callback = null;\n  enqueueUpdate(options, identifierPrefix, isStrictMode);\n  initialChildren.current.lanes = isStrictMode;\n  markRootUpdated$1(initialChildren, isStrictMode);\n  ensureRootIsScheduled(initialChildren);\n  container[internalContainerInstanceKey] = initialChildren.current;\n  listenToAllSupportedEvents(container);\n  return new ReactDOMHydrationRoot(initialChildren);\n};\nexports.version = \"19.0.0\";\n","/**\n * @license React\n * react-dom.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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\";\nvar React = require(\"react\");\nfunction formatProdErrorMessage(code) {\n  var url = \"https://react.dev/errors/\" + code;\n  if (1 < arguments.length) {\n    url += \"?args[]=\" + encodeURIComponent(arguments[1]);\n    for (var i = 2; i < arguments.length; i++)\n      url += \"&args[]=\" + encodeURIComponent(arguments[i]);\n  }\n  return (\n    \"Minified React error #\" +\n    code +\n    \"; visit \" +\n    url +\n    \" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"\n  );\n}\nfunction noop() {}\nvar Internals = {\n    d: {\n      f: noop,\n      r: function () {\n        throw Error(formatProdErrorMessage(522));\n      },\n      D: noop,\n      C: noop,\n      L: noop,\n      m: noop,\n      X: noop,\n      S: noop,\n      M: noop\n    },\n    p: 0,\n    findDOMNode: null\n  },\n  REACT_PORTAL_TYPE = Symbol.for(\"react.portal\");\nfunction createPortal$1(children, containerInfo, implementation) {\n  var key =\n    3 < arguments.length && void 0 !== arguments[3] ? arguments[3] : null;\n  return {\n    $$typeof: REACT_PORTAL_TYPE,\n    key: null == key ? null : \"\" + key,\n    children: children,\n    containerInfo: containerInfo,\n    implementation: implementation\n  };\n}\nvar ReactSharedInternals =\n  React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;\nfunction getCrossOriginStringAs(as, input) {\n  if (\"font\" === as) return \"\";\n  if (\"string\" === typeof input)\n    return \"use-credentials\" === input ? input : \"\";\n}\nexports.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE =\n  Internals;\nexports.createPortal = function (children, container) {\n  var key =\n    2 < arguments.length && void 0 !== arguments[2] ? arguments[2] : null;\n  if (\n    !container ||\n    (1 !== container.nodeType &&\n      9 !== container.nodeType &&\n      11 !== container.nodeType)\n  )\n    throw Error(formatProdErrorMessage(299));\n  return createPortal$1(children, container, null, key);\n};\nexports.flushSync = function (fn) {\n  var previousTransition = ReactSharedInternals.T,\n    previousUpdatePriority = Internals.p;\n  try {\n    if (((ReactSharedInternals.T = null), (Internals.p = 2), fn)) return fn();\n  } finally {\n    (ReactSharedInternals.T = previousTransition),\n      (Internals.p = previousUpdatePriority),\n      Internals.d.f();\n  }\n};\nexports.preconnect = function (href, options) {\n  \"string\" === typeof href &&\n    (options\n      ? ((options = options.crossOrigin),\n        (options =\n          \"string\" === typeof options\n            ? \"use-credentials\" === options\n              ? options\n              : \"\"\n            : void 0))\n      : (options = null),\n    Internals.d.C(href, options));\n};\nexports.prefetchDNS = function (href) {\n  \"string\" === typeof href && Internals.d.D(href);\n};\nexports.preinit = function (href, options) {\n  if (\"string\" === typeof href && options && \"string\" === typeof options.as) {\n    var as = options.as,\n      crossOrigin = getCrossOriginStringAs(as, options.crossOrigin),\n      integrity =\n        \"string\" === typeof options.integrity ? options.integrity : void 0,\n      fetchPriority =\n        \"string\" === typeof options.fetchPriority\n          ? options.fetchPriority\n          : void 0;\n    \"style\" === as\n      ? Internals.d.S(\n          href,\n          \"string\" === typeof options.precedence ? options.precedence : void 0,\n          {\n            crossOrigin: crossOrigin,\n            integrity: integrity,\n            fetchPriority: fetchPriority\n          }\n        )\n      : \"script\" === as &&\n        Internals.d.X(href, {\n          crossOrigin: crossOrigin,\n          integrity: integrity,\n          fetchPriority: fetchPriority,\n          nonce: \"string\" === typeof options.nonce ? options.nonce : void 0\n        });\n  }\n};\nexports.preinitModule = function (href, options) {\n  if (\"string\" === typeof href)\n    if (\"object\" === typeof options && null !== options) {\n      if (null == options.as || \"script\" === options.as) {\n        var crossOrigin = getCrossOriginStringAs(\n          options.as,\n          options.crossOrigin\n        );\n        Internals.d.M(href, {\n          crossOrigin: crossOrigin,\n          integrity:\n            \"string\" === typeof options.integrity ? options.integrity : void 0,\n          nonce: \"string\" === typeof options.nonce ? options.nonce : void 0\n        });\n      }\n    } else null == options && Internals.d.M(href);\n};\nexports.preload = function (href, options) {\n  if (\n    \"string\" === typeof href &&\n    \"object\" === typeof options &&\n    null !== options &&\n    \"string\" === typeof options.as\n  ) {\n    var as = options.as,\n      crossOrigin = getCrossOriginStringAs(as, options.crossOrigin);\n    Internals.d.L(href, as, {\n      crossOrigin: crossOrigin,\n      integrity:\n        \"string\" === typeof options.integrity ? options.integrity : void 0,\n      nonce: \"string\" === typeof options.nonce ? options.nonce : void 0,\n      type: \"string\" === typeof options.type ? options.type : void 0,\n      fetchPriority:\n        \"string\" === typeof options.fetchPriority\n          ? options.fetchPriority\n          : void 0,\n      referrerPolicy:\n        \"string\" === typeof options.referrerPolicy\n          ? options.referrerPolicy\n          : void 0,\n      imageSrcSet:\n        \"string\" === typeof options.imageSrcSet ? options.imageSrcSet : void 0,\n      imageSizes:\n        \"string\" === typeof options.imageSizes ? options.imageSizes : void 0,\n      media: \"string\" === typeof options.media ? options.media : void 0\n    });\n  }\n};\nexports.preloadModule = function (href, options) {\n  if (\"string\" === typeof href)\n    if (options) {\n      var crossOrigin = getCrossOriginStringAs(options.as, options.crossOrigin);\n      Internals.d.m(href, {\n        as:\n          \"string\" === typeof options.as && \"script\" !== options.as\n            ? options.as\n            : void 0,\n        crossOrigin: crossOrigin,\n        integrity:\n          \"string\" === typeof options.integrity ? options.integrity : void 0\n      });\n    } else Internals.d.m(href);\n};\nexports.requestFormReset = function (form) {\n  Internals.d.r(form);\n};\nexports.unstable_batchedUpdates = function (fn, a) {\n  return fn(a);\n};\nexports.useFormState = function (action, initialState, permalink) {\n  return ReactSharedInternals.H.useFormState(action, initialState, permalink);\n};\nexports.useFormStatus = function () {\n  return ReactSharedInternals.H.useHostTransitionStatus();\n};\nexports.version = \"19.0.0\";\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-client.production.js');\n} else {\n  module.exports = require('./cjs/react-dom-client.development.js');\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.js');\n} else {\n  module.exports = require('./cjs/react-dom.development.js');\n}\n","/** @license React v17.0.2\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'use strict';var b=60103,c=60106,d=60107,e=60108,f=60114,g=60109,h=60110,k=60112,l=60113,m=60120,n=60115,p=60116,q=60121,r=60122,u=60117,v=60129,w=60131;\nif(\"function\"===typeof Symbol&&Symbol.for){var x=Symbol.for;b=x(\"react.element\");c=x(\"react.portal\");d=x(\"react.fragment\");e=x(\"react.strict_mode\");f=x(\"react.profiler\");g=x(\"react.provider\");h=x(\"react.context\");k=x(\"react.forward_ref\");l=x(\"react.suspense\");m=x(\"react.suspense_list\");n=x(\"react.memo\");p=x(\"react.lazy\");q=x(\"react.block\");r=x(\"react.server.block\");u=x(\"react.fundamental\");v=x(\"react.debug_trace_mode\");w=x(\"react.legacy_hidden\")}\nfunction y(a){if(\"object\"===typeof a&&null!==a){var t=a.$$typeof;switch(t){case b:switch(a=a.type,a){case d:case f:case e:case l:case m:return a;default:switch(a=a&&a.$$typeof,a){case h:case k:case p:case n:case g:return a;default:return t}}case c:return t}}}var z=g,A=b,B=k,C=d,D=p,E=n,F=c,G=f,H=e,I=l;exports.ContextConsumer=h;exports.ContextProvider=z;exports.Element=A;exports.ForwardRef=B;exports.Fragment=C;exports.Lazy=D;exports.Memo=E;exports.Portal=F;exports.Profiler=G;exports.StrictMode=H;\nexports.Suspense=I;exports.isAsyncMode=function(){return!1};exports.isConcurrentMode=function(){return!1};exports.isContextConsumer=function(a){return y(a)===h};exports.isContextProvider=function(a){return y(a)===g};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===b};exports.isForwardRef=function(a){return y(a)===k};exports.isFragment=function(a){return y(a)===d};exports.isLazy=function(a){return y(a)===p};exports.isMemo=function(a){return y(a)===n};\nexports.isPortal=function(a){return y(a)===c};exports.isProfiler=function(a){return y(a)===f};exports.isStrictMode=function(a){return y(a)===e};exports.isSuspense=function(a){return y(a)===l};exports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===d||a===f||a===v||a===e||a===l||a===m||a===w||\"object\"===typeof a&&null!==a&&(a.$$typeof===p||a.$$typeof===n||a.$$typeof===g||a.$$typeof===h||a.$$typeof===k||a.$$typeof===u||a.$$typeof===q||a[0]===r)?!0:!1};\nexports.typeOf=y;\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","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n  , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n  Events.prototype = Object.create(null);\n\n  //\n  // This hack is needed because the `__proto__` property is still inherited in\n  // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n  //\n  if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n  this.fn = fn;\n  this.context = context;\n  this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n  if (typeof fn !== 'function') {\n    throw new TypeError('The listener must be a function');\n  }\n\n  var listener = new EE(fn, context || emitter, once)\n    , evt = prefix ? prefix + event : event;\n\n  if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n  else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n  else emitter._events[evt] = [emitter._events[evt], listener];\n\n  return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n  if (--emitter._eventsCount === 0) emitter._events = new Events();\n  else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n  this._events = new Events();\n  this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n  var names = []\n    , events\n    , name;\n\n  if (this._eventsCount === 0) return names;\n\n  for (name in (events = this._events)) {\n    if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n  }\n\n  if (Object.getOwnPropertySymbols) {\n    return names.concat(Object.getOwnPropertySymbols(events));\n  }\n\n  return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n  var evt = prefix ? prefix + event : event\n    , handlers = this._events[evt];\n\n  if (!handlers) return [];\n  if (handlers.fn) return [handlers.fn];\n\n  for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n    ee[i] = handlers[i].fn;\n  }\n\n  return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n  var evt = prefix ? prefix + event : event\n    , listeners = this._events[evt];\n\n  if (!listeners) return 0;\n  if (listeners.fn) return 1;\n  return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n  var evt = prefix ? prefix + event : event;\n\n  if (!this._events[evt]) return false;\n\n  var listeners = this._events[evt]\n    , len = arguments.length\n    , args\n    , i;\n\n  if (listeners.fn) {\n    if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n    switch (len) {\n      case 1: return listeners.fn.call(listeners.context), true;\n      case 2: return listeners.fn.call(listeners.context, a1), true;\n      case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n      case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n      case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n      case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n    }\n\n    for (i = 1, args = new Array(len -1); i < len; i++) {\n      args[i - 1] = arguments[i];\n    }\n\n    listeners.fn.apply(listeners.context, args);\n  } else {\n    var length = listeners.length\n      , j;\n\n    for (i = 0; i < length; i++) {\n      if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n      switch (len) {\n        case 1: listeners[i].fn.call(listeners[i].context); break;\n        case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n        case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n        case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n        default:\n          if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n            args[j - 1] = arguments[j];\n          }\n\n          listeners[i].fn.apply(listeners[i].context, args);\n      }\n    }\n  }\n\n  return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n  return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n  return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n  var evt = prefix ? prefix + event : event;\n\n  if (!this._events[evt]) return this;\n  if (!fn) {\n    clearEvent(this, evt);\n    return this;\n  }\n\n  var listeners = this._events[evt];\n\n  if (listeners.fn) {\n    if (\n      listeners.fn === fn &&\n      (!once || listeners.once) &&\n      (!context || listeners.context === context)\n    ) {\n      clearEvent(this, evt);\n    }\n  } else {\n    for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n      if (\n        listeners[i].fn !== fn ||\n        (once && !listeners[i].once) ||\n        (context && listeners[i].context !== context)\n      ) {\n        events.push(listeners[i]);\n      }\n    }\n\n    //\n    // Reset the array, or remove it completely if we have no more listeners.\n    //\n    if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n    else clearEvent(this, evt);\n  }\n\n  return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n  var evt;\n\n  if (event) {\n    evt = prefix ? prefix + event : event;\n    if (this._events[evt]) clearEvent(this, evt);\n  } else {\n    this._events = new Events();\n    this._eventsCount = 0;\n  }\n\n  return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n  module.exports = EventEmitter;\n}\n","/**\n * RegExp to match cookie-name in RFC 6265 sec 4.1.1\n * This refers out to the obsoleted definition of token in RFC 2616 sec 2.2\n * which has been replaced by the token definition in RFC 7230 appendix B.\n *\n * cookie-name       = token\n * token             = 1*tchar\n * tchar             = \"!\" / \"#\" / \"$\" / \"%\" / \"&\" / \"'\" /\n *                     \"*\" / \"+\" / \"-\" / \".\" / \"^\" / \"_\" /\n *                     \"`\" / \"|\" / \"~\" / DIGIT / ALPHA\n *\n * Note: Allowing more characters - https://github.com/jshttp/cookie/issues/191\n * Allow same range as cookie value, except `=`, which delimits end of name.\n */\nconst cookieNameRegExp = /^[\\u0021-\\u003A\\u003C\\u003E-\\u007E]+$/;\n\n/**\n * RegExp to match cookie-value in RFC 6265 sec 4.1.1\n *\n * cookie-value      = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE )\n * cookie-octet      = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E\n *                     ; US-ASCII characters excluding CTLs,\n *                     ; whitespace DQUOTE, comma, semicolon,\n *                     ; and backslash\n *\n * Allowing more characters: https://github.com/jshttp/cookie/issues/191\n * Comma, backslash, and DQUOTE are not part of the parsing algorithm.\n */\nconst cookieValueRegExp = /^[\\u0021-\\u003A\\u003C-\\u007E]*$/;\n\n/**\n * RegExp to match domain-value in RFC 6265 sec 4.1.1\n *\n * domain-value      = <subdomain>\n *                     ; defined in [RFC1034], Section 3.5, as\n *                     ; enhanced by [RFC1123], Section 2.1\n * <subdomain>       = <label> | <subdomain> \".\" <label>\n * <label>           = <let-dig> [ [ <ldh-str> ] <let-dig> ]\n *                     Labels must be 63 characters or less.\n *                     'let-dig' not 'letter' in the first char, per RFC1123\n * <ldh-str>         = <let-dig-hyp> | <let-dig-hyp> <ldh-str>\n * <let-dig-hyp>     = <let-dig> | \"-\"\n * <let-dig>         = <letter> | <digit>\n * <letter>          = any one of the 52 alphabetic characters A through Z in\n *                     upper case and a through z in lower case\n * <digit>           = any one of the ten digits 0 through 9\n *\n * Keep support for leading dot: https://github.com/jshttp/cookie/issues/173\n *\n * > (Note that a leading %x2E (\".\"), if present, is ignored even though that\n * character is not permitted, but a trailing %x2E (\".\"), if present, will\n * cause the user agent to ignore the attribute.)\n */\nconst domainValueRegExp =\n  /^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i;\n\n/**\n * RegExp to match path-value in RFC 6265 sec 4.1.1\n *\n * path-value        = <any CHAR except CTLs or \";\">\n * CHAR              = %x01-7F\n *                     ; defined in RFC 5234 appendix B.1\n */\nconst pathValueRegExp = /^[\\u0020-\\u003A\\u003D-\\u007E]*$/;\n\nconst __toString = Object.prototype.toString;\n\nconst NullObject = /* @__PURE__ */ (() => {\n  const C = function () {};\n  C.prototype = Object.create(null);\n  return C;\n})() as unknown as { new (): any };\n\n/**\n * Parse options.\n */\nexport interface ParseOptions {\n  /**\n   * Specifies a function that will be used to decode a [cookie-value](https://datatracker.ietf.org/doc/html/rfc6265#section-4.1.1).\n   * Since the value of a cookie has a limited character set (and must be a simple string), this function can be used to decode\n   * a previously-encoded cookie value into a JavaScript string.\n   *\n   * The default function is the global `decodeURIComponent`, wrapped in a `try..catch`. If an error\n   * is thrown it will return the cookie's original value. If you provide your own encode/decode\n   * scheme you must ensure errors are appropriately handled.\n   *\n   * @default decode\n   */\n  decode?: (str: string) => string | undefined;\n}\n\n/**\n * Parse a cookie header.\n *\n * Parse the given cookie header string into an object\n * The object has the various cookies as keys(names) => values\n */\nexport function parse(\n  str: string,\n  options?: ParseOptions,\n): Record<string, string | undefined> {\n  const obj: Record<string, string | undefined> = new NullObject();\n  const len = str.length;\n  // RFC 6265 sec 4.1.1, RFC 2616 2.2 defines a cookie name consists of one char minimum, plus '='.\n  if (len < 2) return obj;\n\n  const dec = options?.decode || decode;\n  let index = 0;\n\n  do {\n    const eqIdx = str.indexOf(\"=\", index);\n    if (eqIdx === -1) break; // No more cookie pairs.\n\n    const colonIdx = str.indexOf(\";\", index);\n    const endIdx = colonIdx === -1 ? len : colonIdx;\n\n    if (eqIdx > endIdx) {\n      // backtrack on prior semicolon\n      index = str.lastIndexOf(\";\", eqIdx - 1) + 1;\n      continue;\n    }\n\n    const keyStartIdx = startIndex(str, index, eqIdx);\n    const keyEndIdx = endIndex(str, eqIdx, keyStartIdx);\n    const key = str.slice(keyStartIdx, keyEndIdx);\n\n    // only assign once\n    if (obj[key] === undefined) {\n      let valStartIdx = startIndex(str, eqIdx + 1, endIdx);\n      let valEndIdx = endIndex(str, endIdx, valStartIdx);\n\n      const value = dec(str.slice(valStartIdx, valEndIdx));\n      obj[key] = value;\n    }\n\n    index = endIdx + 1;\n  } while (index < len);\n\n  return obj;\n}\n\nfunction startIndex(str: string, index: number, max: number) {\n  do {\n    const code = str.charCodeAt(index);\n    if (code !== 0x20 /*   */ && code !== 0x09 /* \\t */) return index;\n  } while (++index < max);\n  return max;\n}\n\nfunction endIndex(str: string, index: number, min: number) {\n  while (index > min) {\n    const code = str.charCodeAt(--index);\n    if (code !== 0x20 /*   */ && code !== 0x09 /* \\t */) return index + 1;\n  }\n  return min;\n}\n\n/**\n * Serialize options.\n */\nexport interface SerializeOptions {\n  /**\n   * Specifies a function that will be used to encode a [cookie-value](https://datatracker.ietf.org/doc/html/rfc6265#section-4.1.1).\n   * Since value of a cookie has a limited character set (and must be a simple string), this function can be used to encode\n   * a value into a string suited for a cookie's value, and should mirror `decode` when parsing.\n   *\n   * @default encodeURIComponent\n   */\n  encode?: (str: string) => string;\n  /**\n   * Specifies the `number` (in seconds) to be the value for the [`Max-Age` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.2).\n   *\n   * The [cookie storage model specification](https://tools.ietf.org/html/rfc6265#section-5.3) states that if both `expires` and\n   * `maxAge` are set, then `maxAge` takes precedence, but it is possible not all clients by obey this,\n   * so if both are set, they should point to the same date and time.\n   */\n  maxAge?: number;\n  /**\n   * Specifies the `Date` object to be the value for the [`Expires` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.1).\n   * When no expiration is set clients consider this a \"non-persistent cookie\" and delete it the current session is over.\n   *\n   * The [cookie storage model specification](https://tools.ietf.org/html/rfc6265#section-5.3) states that if both `expires` and\n   * `maxAge` are set, then `maxAge` takes precedence, but it is possible not all clients by obey this,\n   * so if both are set, they should point to the same date and time.\n   */\n  expires?: Date;\n  /**\n   * Specifies the value for the [`Domain` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.3).\n   * When no domain is set clients consider the cookie to apply to the current domain only.\n   */\n  domain?: string;\n  /**\n   * Specifies the value for the [`Path` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.4).\n   * When no path is set, the path is considered the [\"default path\"](https://tools.ietf.org/html/rfc6265#section-5.1.4).\n   */\n  path?: string;\n  /**\n   * Enables the [`HttpOnly` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.6).\n   * When enabled, clients will not allow client-side JavaScript to see the cookie in `document.cookie`.\n   */\n  httpOnly?: boolean;\n  /**\n   * Enables the [`Secure` `Set-Cookie` attribute](https://tools.ietf.org/html/rfc6265#section-5.2.5).\n   * When enabled, clients will only send the cookie back if the browser has a HTTPS connection.\n   */\n  secure?: boolean;\n  /**\n   * Enables the [`Partitioned` `Set-Cookie` attribute](https://tools.ietf.org/html/draft-cutler-httpbis-partitioned-cookies/).\n   * When enabled, clients will only send the cookie back when the current domain _and_ top-level domain matches.\n   *\n   * This is an attribute that has not yet been fully standardized, and may change in the future.\n   * This also means clients may ignore this attribute until they understand it. More information\n   * about can be found in [the proposal](https://github.com/privacycg/CHIPS).\n   */\n  partitioned?: boolean;\n  /**\n   * Specifies the value for the [`Priority` `Set-Cookie` attribute](https://tools.ietf.org/html/draft-west-cookie-priority-00#section-4.1).\n   *\n   * - `'low'` will set the `Priority` attribute to `Low`.\n   * - `'medium'` will set the `Priority` attribute to `Medium`, the default priority when not set.\n   * - `'high'` will set the `Priority` attribute to `High`.\n   *\n   * More information about priority levels can be found in [the specification](https://tools.ietf.org/html/draft-west-cookie-priority-00#section-4.1).\n   */\n  priority?: \"low\" | \"medium\" | \"high\";\n  /**\n   * Specifies the value for the [`SameSite` `Set-Cookie` attribute](https://tools.ietf.org/html/draft-ietf-httpbis-rfc6265bis-09#section-5.4.7).\n   *\n   * - `true` will set the `SameSite` attribute to `Strict` for strict same site enforcement.\n   * - `'lax'` will set the `SameSite` attribute to `Lax` for lax same site enforcement.\n   * - `'none'` will set the `SameSite` attribute to `None` for an explicit cross-site cookie.\n   * - `'strict'` will set the `SameSite` attribute to `Strict` for strict same site enforcement.\n   *\n   * More information about enforcement levels can be found in [the specification](https://tools.ietf.org/html/draft-ietf-httpbis-rfc6265bis-09#section-5.4.7).\n   */\n  sameSite?: boolean | \"lax\" | \"strict\" | \"none\";\n}\n\n/**\n * Serialize data into a cookie header.\n *\n * Serialize a name value pair into a cookie string suitable for\n * http headers. An optional options object specifies cookie parameters.\n *\n * serialize('foo', 'bar', { httpOnly: true })\n *   => \"foo=bar; httpOnly\"\n */\nexport function serialize(\n  name: string,\n  val: string,\n  options?: SerializeOptions,\n): string {\n  const enc = options?.encode || encodeURIComponent;\n\n  if (!cookieNameRegExp.test(name)) {\n    throw new TypeError(`argument name is invalid: ${name}`);\n  }\n\n  const value = enc(val);\n\n  if (!cookieValueRegExp.test(value)) {\n    throw new TypeError(`argument val is invalid: ${val}`);\n  }\n\n  let str = name + \"=\" + value;\n  if (!options) return str;\n\n  if (options.maxAge !== undefined) {\n    if (!Number.isInteger(options.maxAge)) {\n      throw new TypeError(`option maxAge is invalid: ${options.maxAge}`);\n    }\n\n    str += \"; Max-Age=\" + options.maxAge;\n  }\n\n  if (options.domain) {\n    if (!domainValueRegExp.test(options.domain)) {\n      throw new TypeError(`option domain is invalid: ${options.domain}`);\n    }\n\n    str += \"; Domain=\" + options.domain;\n  }\n\n  if (options.path) {\n    if (!pathValueRegExp.test(options.path)) {\n      throw new TypeError(`option path is invalid: ${options.path}`);\n    }\n\n    str += \"; Path=\" + options.path;\n  }\n\n  if (options.expires) {\n    if (\n      !isDate(options.expires) ||\n      !Number.isFinite(options.expires.valueOf())\n    ) {\n      throw new TypeError(`option expires is invalid: ${options.expires}`);\n    }\n\n    str += \"; Expires=\" + options.expires.toUTCString();\n  }\n\n  if (options.httpOnly) {\n    str += \"; HttpOnly\";\n  }\n\n  if (options.secure) {\n    str += \"; Secure\";\n  }\n\n  if (options.partitioned) {\n    str += \"; Partitioned\";\n  }\n\n  if (options.priority) {\n    const priority =\n      typeof options.priority === \"string\"\n        ? options.priority.toLowerCase()\n        : undefined;\n    switch (priority) {\n      case \"low\":\n        str += \"; Priority=Low\";\n        break;\n      case \"medium\":\n        str += \"; Priority=Medium\";\n        break;\n      case \"high\":\n        str += \"; Priority=High\";\n        break;\n      default:\n        throw new TypeError(`option priority is invalid: ${options.priority}`);\n    }\n  }\n\n  if (options.sameSite) {\n    const sameSite =\n      typeof options.sameSite === \"string\"\n        ? options.sameSite.toLowerCase()\n        : options.sameSite;\n    switch (sameSite) {\n      case true:\n      case \"strict\":\n        str += \"; SameSite=Strict\";\n        break;\n      case \"lax\":\n        str += \"; SameSite=Lax\";\n        break;\n      case \"none\":\n        str += \"; SameSite=None\";\n        break;\n      default:\n        throw new TypeError(`option sameSite is invalid: ${options.sameSite}`);\n    }\n  }\n\n  return str;\n}\n\n/**\n * URL-decode string value. Optimized to skip native call when no %.\n */\nfunction decode(str: string): string {\n  if (str.indexOf(\"%\") === -1) return str;\n\n  try {\n    return decodeURIComponent(str);\n  } catch (e) {\n    return str;\n  }\n}\n\n/**\n * Determine if value is a Date.\n */\nfunction isDate(val: any): val is Date {\n  return __toString.call(val) === \"[object Date]\";\n}\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _warning = _interopRequireDefault(require(\"warning\"));\n\nvar checkIndexBounds = function checkIndexBounds(props) {\n  var index = props.index,\n      children = props.children;\n\n  var childrenCount = _react.default.Children.count(children);\n\n  process.env.NODE_ENV !== \"production\" ? (0, _warning.default)(index >= 0 && index <= childrenCount, \"react-swipeable-view: the new index: \".concat(index, \" is out of bounds: [0-\").concat(childrenCount, \"].\")) : void 0;\n};\n\nvar _default = checkIndexBounds;\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = computeIndex;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _constant = _interopRequireDefault(require(\"./constant\"));\n\nfunction computeIndex(params) {\n  var children = params.children,\n      startIndex = params.startIndex,\n      startX = params.startX,\n      pageX = params.pageX,\n      viewLength = params.viewLength,\n      resistance = params.resistance;\n  var indexMax = _react.default.Children.count(children) - 1;\n  var index = startIndex + (startX - pageX) / viewLength;\n  var newStartX;\n\n  if (!resistance) {\n    // Reset the starting point\n    if (index < 0) {\n      index = 0;\n      newStartX = (index - startIndex) * viewLength + pageX;\n    } else if (index > indexMax) {\n      index = indexMax;\n      newStartX = (index - startIndex) * viewLength + pageX;\n    }\n  } else if (index < 0) {\n    index = Math.exp(index * _constant.default.RESISTANCE_COEF) - 1;\n  } else if (index > indexMax) {\n    index = indexMax + 1 - Math.exp((indexMax - index) * _constant.default.RESISTANCE_COEF);\n  }\n\n  return {\n    index: index,\n    startX: newStartX\n  };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\nvar _default = {\n  RESISTANCE_COEF: 0.6,\n  // This value is closed to what browsers are using internally to\n  // trigger a native scroll.\n  UNCERTAINTY_THRESHOLD: 3 // px\n\n};\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar getDisplaySameSlide = function getDisplaySameSlide(props, nextProps) {\n  var displaySameSlide = false;\n\n  var getChildrenKey = function getChildrenKey(child) {\n    return child ? child.key : 'empty';\n  };\n\n  if (props.children.length && nextProps.children.length) {\n    var oldKeys = _react.default.Children.map(props.children, getChildrenKey);\n\n    var oldKey = oldKeys[props.index];\n\n    if (oldKey !== null && oldKey !== undefined) {\n      var newKeys = _react.default.Children.map(nextProps.children, getChildrenKey);\n\n      var newKey = newKeys[nextProps.index];\n\n      if (oldKey === newKey) {\n        displaySameSlide = true;\n      }\n    }\n  }\n\n  return displaySameSlide;\n};\n\nvar _default = getDisplaySameSlide;\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nObject.defineProperty(exports, \"checkIndexBounds\", {\n  enumerable: true,\n  get: function get() {\n    return _checkIndexBounds.default;\n  }\n});\nObject.defineProperty(exports, \"computeIndex\", {\n  enumerable: true,\n  get: function get() {\n    return _computeIndex.default;\n  }\n});\nObject.defineProperty(exports, \"constant\", {\n  enumerable: true,\n  get: function get() {\n    return _constant.default;\n  }\n});\nObject.defineProperty(exports, \"getDisplaySameSlide\", {\n  enumerable: true,\n  get: function get() {\n    return _getDisplaySameSlide.default;\n  }\n});\nObject.defineProperty(exports, \"mod\", {\n  enumerable: true,\n  get: function get() {\n    return _mod.default;\n  }\n});\n\nvar _checkIndexBounds = _interopRequireDefault(require(\"./checkIndexBounds\"));\n\nvar _computeIndex = _interopRequireDefault(require(\"./computeIndex\"));\n\nvar _constant = _interopRequireDefault(require(\"./constant\"));\n\nvar _getDisplaySameSlide = _interopRequireDefault(require(\"./getDisplaySameSlide\"));\n\nvar _mod = _interopRequireDefault(require(\"./mod\"));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\n// Extended version of % with negative integer support.\nfunction mod(n, m) {\n  var q = n % m;\n  return q < 0 ? q + m : q;\n}\n\nvar _default = mod;\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.getDomTreeShapes = getDomTreeShapes;\nexports.findNativeHandler = findNativeHandler;\nexports.default = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _createClass2 = _interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));\n\nvar _possibleConstructorReturn2 = _interopRequireDefault(require(\"@babel/runtime/helpers/possibleConstructorReturn\"));\n\nvar _getPrototypeOf2 = _interopRequireDefault(require(\"@babel/runtime/helpers/getPrototypeOf\"));\n\nvar _inherits2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inherits\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _warning = _interopRequireDefault(require(\"warning\"));\n\nvar _reactSwipeableViewsCore = require(\"react-swipeable-views-core\");\n\nfunction addEventListener(node, event, handler, options) {\n  node.addEventListener(event, handler, options);\n  return {\n    remove: function remove() {\n      node.removeEventListener(event, handler, options);\n    }\n  };\n}\n\nvar styles = {\n  container: {\n    direction: 'ltr',\n    display: 'flex',\n    willChange: 'transform'\n  },\n  slide: {\n    width: '100%',\n    WebkitFlexShrink: 0,\n    flexShrink: 0,\n    overflow: 'auto'\n  }\n};\nvar axisProperties = {\n  root: {\n    x: {\n      overflowX: 'hidden'\n    },\n    'x-reverse': {\n      overflowX: 'hidden'\n    },\n    y: {\n      overflowY: 'hidden'\n    },\n    'y-reverse': {\n      overflowY: 'hidden'\n    }\n  },\n  flexDirection: {\n    x: 'row',\n    'x-reverse': 'row-reverse',\n    y: 'column',\n    'y-reverse': 'column-reverse'\n  },\n  transform: {\n    x: function x(translate) {\n      return \"translate(\".concat(-translate, \"%, 0)\");\n    },\n    'x-reverse': function xReverse(translate) {\n      return \"translate(\".concat(translate, \"%, 0)\");\n    },\n    y: function y(translate) {\n      return \"translate(0, \".concat(-translate, \"%)\");\n    },\n    'y-reverse': function yReverse(translate) {\n      return \"translate(0, \".concat(translate, \"%)\");\n    }\n  },\n  length: {\n    x: 'width',\n    'x-reverse': 'width',\n    y: 'height',\n    'y-reverse': 'height'\n  },\n  rotationMatrix: {\n    x: {\n      x: [1, 0],\n      y: [0, 1]\n    },\n    'x-reverse': {\n      x: [-1, 0],\n      y: [0, 1]\n    },\n    y: {\n      x: [0, 1],\n      y: [1, 0]\n    },\n    'y-reverse': {\n      x: [0, -1],\n      y: [1, 0]\n    }\n  },\n  scrollPosition: {\n    x: 'scrollLeft',\n    'x-reverse': 'scrollLeft',\n    y: 'scrollTop',\n    'y-reverse': 'scrollTop'\n  },\n  scrollLength: {\n    x: 'scrollWidth',\n    'x-reverse': 'scrollWidth',\n    y: 'scrollHeight',\n    'y-reverse': 'scrollHeight'\n  },\n  clientLength: {\n    x: 'clientWidth',\n    'x-reverse': 'clientWidth',\n    y: 'clientHeight',\n    'y-reverse': 'clientHeight'\n  }\n};\n\nfunction createTransition(property, options) {\n  var duration = options.duration,\n      easeFunction = options.easeFunction,\n      delay = options.delay;\n  return \"\".concat(property, \" \").concat(duration, \" \").concat(easeFunction, \" \").concat(delay);\n} // We are using a 2x2 rotation matrix.\n\n\nfunction applyRotationMatrix(touch, axis) {\n  var rotationMatrix = axisProperties.rotationMatrix[axis];\n  return {\n    pageX: rotationMatrix.x[0] * touch.pageX + rotationMatrix.x[1] * touch.pageY,\n    pageY: rotationMatrix.y[0] * touch.pageX + rotationMatrix.y[1] * touch.pageY\n  };\n}\n\nfunction adaptMouse(event) {\n  event.touches = [{\n    pageX: event.pageX,\n    pageY: event.pageY\n  }];\n  return event;\n}\n\nfunction getDomTreeShapes(element, rootNode) {\n  var domTreeShapes = [];\n\n  while (element && element !== rootNode) {\n    // We reach a Swipeable View, no need to look higher in the dom tree.\n    if (element.hasAttribute('data-swipeable')) {\n      break;\n    }\n\n    var style = window.getComputedStyle(element);\n\n    if ( // Ignore the scroll children if the element is absolute positioned.\n    style.getPropertyValue('position') === 'absolute' || // Ignore the scroll children if the element has an overflowX hidden\n    style.getPropertyValue('overflow-x') === 'hidden') {\n      domTreeShapes = [];\n    } else if (element.clientWidth > 0 && element.scrollWidth > element.clientWidth || element.clientHeight > 0 && element.scrollHeight > element.clientHeight) {\n      // Ignore the nodes that have no width.\n      // Keep elements with a scroll\n      domTreeShapes.push({\n        element: element,\n        scrollWidth: element.scrollWidth,\n        scrollHeight: element.scrollHeight,\n        clientWidth: element.clientWidth,\n        clientHeight: element.clientHeight,\n        scrollLeft: element.scrollLeft,\n        scrollTop: element.scrollTop\n      });\n    }\n\n    element = element.parentNode;\n  }\n\n  return domTreeShapes;\n} // We can only have one node at the time claiming ownership for handling the swipe.\n// Otherwise, the UX would be confusing.\n// That's why we use a singleton here.\n\n\nvar nodeWhoClaimedTheScroll = null;\n\nfunction findNativeHandler(params) {\n  var domTreeShapes = params.domTreeShapes,\n      pageX = params.pageX,\n      startX = params.startX,\n      axis = params.axis;\n  return domTreeShapes.some(function (shape) {\n    // Determine if we are going backward or forward.\n    var goingForward = pageX >= startX;\n\n    if (axis === 'x' || axis === 'y') {\n      goingForward = !goingForward;\n    }\n\n    var scrollPosition = shape[axisProperties.scrollPosition[axis]];\n    var areNotAtStart = scrollPosition > 0;\n    var areNotAtEnd = scrollPosition + shape[axisProperties.clientLength[axis]] < shape[axisProperties.scrollLength[axis]];\n\n    if (goingForward && areNotAtEnd || !goingForward && areNotAtStart) {\n      nodeWhoClaimedTheScroll = shape.element;\n      return true;\n    }\n\n    return false;\n  });\n}\n\nvar SwipeableViews =\n/*#__PURE__*/\nfunction (_React$Component) {\n  (0, _inherits2.default)(SwipeableViews, _React$Component);\n\n  function SwipeableViews(props) {\n    var _this;\n\n    (0, _classCallCheck2.default)(this, SwipeableViews);\n    _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(SwipeableViews).call(this, props));\n    _this.rootNode = null;\n    _this.containerNode = null;\n    _this.ignoreNextScrollEvents = false;\n    _this.viewLength = 0;\n    _this.startX = 0;\n    _this.lastX = 0;\n    _this.vx = 0;\n    _this.startY = 0;\n    _this.isSwiping = undefined;\n    _this.started = false;\n    _this.startIndex = 0;\n    _this.transitionListener = null;\n    _this.touchMoveListener = null;\n    _this.activeSlide = null;\n    _this.indexCurrent = null;\n    _this.firstRenderTimeout = null;\n\n    _this.setRootNode = function (node) {\n      _this.rootNode = node;\n    };\n\n    _this.setContainerNode = function (node) {\n      _this.containerNode = node;\n    };\n\n    _this.setActiveSlide = function (node) {\n      _this.activeSlide = node;\n\n      _this.updateHeight();\n    };\n\n    _this.handleSwipeStart = function (event) {\n      var axis = _this.props.axis;\n      var touch = applyRotationMatrix(event.touches[0], axis);\n      _this.viewLength = _this.rootNode.getBoundingClientRect()[axisProperties.length[axis]];\n      _this.startX = touch.pageX;\n      _this.lastX = touch.pageX;\n      _this.vx = 0;\n      _this.startY = touch.pageY;\n      _this.isSwiping = undefined;\n      _this.started = true;\n      var computedStyle = window.getComputedStyle(_this.containerNode);\n      var transform = computedStyle.getPropertyValue('-webkit-transform') || computedStyle.getPropertyValue('transform');\n\n      if (transform && transform !== 'none') {\n        var transformValues = transform.split('(')[1].split(')')[0].split(',');\n        var rootStyle = window.getComputedStyle(_this.rootNode);\n        var tranformNormalized = applyRotationMatrix({\n          pageX: parseInt(transformValues[4], 10),\n          pageY: parseInt(transformValues[5], 10)\n        }, axis);\n        _this.startIndex = -tranformNormalized.pageX / (_this.viewLength - parseInt(rootStyle.paddingLeft, 10) - parseInt(rootStyle.paddingRight, 10)) || 0;\n      }\n    };\n\n    _this.handleSwipeMove = function (event) {\n      // The touch start event can be cancel.\n      // Makes sure we set a starting point.\n      if (!_this.started) {\n        _this.handleTouchStart(event);\n\n        return;\n      } // We are not supposed to hanlde this touch move.\n\n\n      if (nodeWhoClaimedTheScroll !== null && nodeWhoClaimedTheScroll !== _this.rootNode) {\n        return;\n      }\n\n      var _this$props = _this.props,\n          axis = _this$props.axis,\n          children = _this$props.children,\n          ignoreNativeScroll = _this$props.ignoreNativeScroll,\n          onSwitching = _this$props.onSwitching,\n          resistance = _this$props.resistance;\n      var touch = applyRotationMatrix(event.touches[0], axis); // We don't know yet.\n\n      if (_this.isSwiping === undefined) {\n        var dx = Math.abs(touch.pageX - _this.startX);\n        var dy = Math.abs(touch.pageY - _this.startY);\n        var isSwiping = dx > dy && dx > _reactSwipeableViewsCore.constant.UNCERTAINTY_THRESHOLD; // We let the parent handle the scroll.\n\n        if (!resistance && (axis === 'y' || axis === 'y-reverse') && (_this.indexCurrent === 0 && _this.startX < touch.pageX || _this.indexCurrent === _react.default.Children.count(_this.props.children) - 1 && _this.startX > touch.pageX)) {\n          _this.isSwiping = false;\n          return;\n        } // We are likely to be swiping, let's prevent the scroll event.\n\n\n        if (dx > dy) {\n          event.preventDefault();\n        }\n\n        if (isSwiping === true || dy > _reactSwipeableViewsCore.constant.UNCERTAINTY_THRESHOLD) {\n          _this.isSwiping = isSwiping;\n          _this.startX = touch.pageX; // Shift the starting point.\n\n          return; // Let's wait the next touch event to move something.\n        }\n      }\n\n      if (_this.isSwiping !== true) {\n        return;\n      } // We are swiping, let's prevent the scroll event.\n\n\n      event.preventDefault(); // Low Pass filter.\n\n      _this.vx = _this.vx * 0.5 + (touch.pageX - _this.lastX) * 0.5;\n      _this.lastX = touch.pageX;\n\n      var _computeIndex = (0, _reactSwipeableViewsCore.computeIndex)({\n        children: children,\n        resistance: resistance,\n        pageX: touch.pageX,\n        startIndex: _this.startIndex,\n        startX: _this.startX,\n        viewLength: _this.viewLength\n      }),\n          index = _computeIndex.index,\n          startX = _computeIndex.startX; // Add support for native scroll elements.\n\n\n      if (nodeWhoClaimedTheScroll === null && !ignoreNativeScroll) {\n        var domTreeShapes = getDomTreeShapes(event.target, _this.rootNode);\n        var hasFoundNativeHandler = findNativeHandler({\n          domTreeShapes: domTreeShapes,\n          startX: _this.startX,\n          pageX: touch.pageX,\n          axis: axis\n        }); // We abort the touch move handler.\n\n        if (hasFoundNativeHandler) {\n          return;\n        }\n      } // We are moving toward the edges.\n\n\n      if (startX) {\n        _this.startX = startX;\n      } else if (nodeWhoClaimedTheScroll === null) {\n        nodeWhoClaimedTheScroll = _this.rootNode;\n      }\n\n      _this.setIndexCurrent(index);\n\n      var callback = function callback() {\n        if (onSwitching) {\n          onSwitching(index, 'move');\n        }\n      };\n\n      if (_this.state.displaySameSlide || !_this.state.isDragging) {\n        _this.setState({\n          displaySameSlide: false,\n          isDragging: true\n        }, callback);\n      }\n\n      callback();\n    };\n\n    _this.handleSwipeEnd = function () {\n      nodeWhoClaimedTheScroll = null; // The touch start event can be cancel.\n      // Makes sure that a starting point is set.\n\n      if (!_this.started) {\n        return;\n      }\n\n      _this.started = false;\n\n      if (_this.isSwiping !== true) {\n        return;\n      }\n\n      var indexLatest = _this.state.indexLatest;\n      var indexCurrent = _this.indexCurrent;\n      var delta = indexLatest - indexCurrent;\n      var indexNew; // Quick movement\n\n      if (Math.abs(_this.vx) > _this.props.threshold) {\n        if (_this.vx > 0) {\n          indexNew = Math.floor(indexCurrent);\n        } else {\n          indexNew = Math.ceil(indexCurrent);\n        }\n      } else if (Math.abs(delta) > _this.props.hysteresis) {\n        // Some hysteresis with indexLatest.\n        indexNew = delta > 0 ? Math.floor(indexCurrent) : Math.ceil(indexCurrent);\n      } else {\n        indexNew = indexLatest;\n      }\n\n      var indexMax = _react.default.Children.count(_this.props.children) - 1;\n\n      if (indexNew < 0) {\n        indexNew = 0;\n      } else if (indexNew > indexMax) {\n        indexNew = indexMax;\n      }\n\n      _this.setIndexCurrent(indexNew);\n\n      _this.setState({\n        indexLatest: indexNew,\n        isDragging: false\n      }, function () {\n        if (_this.props.onSwitching) {\n          _this.props.onSwitching(indexNew, 'end');\n        }\n\n        if (_this.props.onChangeIndex && indexNew !== indexLatest) {\n          _this.props.onChangeIndex(indexNew, indexLatest, {\n            reason: 'swipe'\n          });\n        } // Manually calling handleTransitionEnd in that case as isn't otherwise.\n\n\n        if (indexCurrent === indexLatest) {\n          _this.handleTransitionEnd();\n        }\n      });\n    };\n\n    _this.handleTouchStart = function (event) {\n      if (_this.props.onTouchStart) {\n        _this.props.onTouchStart(event);\n      }\n\n      _this.handleSwipeStart(event);\n    };\n\n    _this.handleTouchEnd = function (event) {\n      if (_this.props.onTouchEnd) {\n        _this.props.onTouchEnd(event);\n      }\n\n      _this.handleSwipeEnd(event);\n    };\n\n    _this.handleMouseDown = function (event) {\n      if (_this.props.onMouseDown) {\n        _this.props.onMouseDown(event);\n      }\n\n      event.persist();\n\n      _this.handleSwipeStart(adaptMouse(event));\n    };\n\n    _this.handleMouseUp = function (event) {\n      if (_this.props.onMouseUp) {\n        _this.props.onMouseUp(event);\n      }\n\n      _this.handleSwipeEnd(adaptMouse(event));\n    };\n\n    _this.handleMouseLeave = function (event) {\n      if (_this.props.onMouseLeave) {\n        _this.props.onMouseLeave(event);\n      } // Filter out events\n\n\n      if (_this.started) {\n        _this.handleSwipeEnd(adaptMouse(event));\n      }\n    };\n\n    _this.handleMouseMove = function (event) {\n      if (_this.props.onMouseMove) {\n        _this.props.onMouseMove(event);\n      } // Filter out events\n\n\n      if (_this.started) {\n        _this.handleSwipeMove(adaptMouse(event));\n      }\n    };\n\n    _this.handleScroll = function (event) {\n      if (_this.props.onScroll) {\n        _this.props.onScroll(event);\n      } // Ignore events bubbling up.\n\n\n      if (event.target !== _this.rootNode) {\n        return;\n      }\n\n      if (_this.ignoreNextScrollEvents) {\n        _this.ignoreNextScrollEvents = false;\n        return;\n      }\n\n      var indexLatest = _this.state.indexLatest;\n      var indexNew = Math.ceil(event.target.scrollLeft / event.target.clientWidth) + indexLatest;\n      _this.ignoreNextScrollEvents = true; // Reset the scroll position.\n\n      event.target.scrollLeft = 0;\n\n      if (_this.props.onChangeIndex && indexNew !== indexLatest) {\n        _this.props.onChangeIndex(indexNew, indexLatest, {\n          reason: 'focus'\n        });\n      }\n    };\n\n    _this.updateHeight = function () {\n      if (_this.activeSlide !== null) {\n        var child = _this.activeSlide.children[0];\n\n        if (child !== undefined && child.offsetHeight !== undefined && _this.state.heightLatest !== child.offsetHeight) {\n          _this.setState({\n            heightLatest: child.offsetHeight\n          });\n        }\n      }\n    };\n\n    if (process.env.NODE_ENV !== 'production') {\n      (0, _reactSwipeableViewsCore.checkIndexBounds)(props);\n    }\n\n    _this.state = {\n      indexLatest: props.index,\n      // Set to true as soon as the component is swiping.\n      // It's the state counter part of this.isSwiping.\n      isDragging: false,\n      // Help with SSR logic and lazy loading logic.\n      renderOnlyActive: !props.disableLazyLoading,\n      heightLatest: 0,\n      // Let the render method that we are going to display the same slide than previously.\n      displaySameSlide: true\n    };\n\n    _this.setIndexCurrent(props.index);\n\n    return _this;\n  }\n\n  (0, _createClass2.default)(SwipeableViews, [{\n    key: \"getChildContext\",\n    value: function getChildContext() {\n      var _this2 = this;\n\n      return {\n        swipeableViews: {\n          slideUpdateHeight: function slideUpdateHeight() {\n            _this2.updateHeight();\n          }\n        }\n      };\n    }\n  }, {\n    key: \"componentDidMount\",\n    value: function componentDidMount() {\n      var _this3 = this;\n\n      // Subscribe to transition end events.\n      this.transitionListener = addEventListener(this.containerNode, 'transitionend', function (event) {\n        if (event.target !== _this3.containerNode) {\n          return;\n        }\n\n        _this3.handleTransitionEnd();\n      }); // Block the thread to handle that event.\n\n      this.touchMoveListener = addEventListener(this.rootNode, 'touchmove', function (event) {\n        // Handling touch events is disabled.\n        if (_this3.props.disabled) {\n          return;\n        }\n\n        _this3.handleSwipeMove(event);\n      }, {\n        passive: false\n      });\n\n      if (!this.props.disableLazyLoading) {\n        this.firstRenderTimeout = setTimeout(function () {\n          _this3.setState({\n            renderOnlyActive: false\n          });\n        }, 0);\n      } // Send all functions in an object if action param is set.\n\n\n      if (this.props.action) {\n        this.props.action({\n          updateHeight: this.updateHeight\n        });\n      }\n    }\n  }, {\n    key: \"componentWillReceiveProps\",\n    value: function componentWillReceiveProps(nextProps) {\n      var index = nextProps.index;\n\n      if (typeof index === 'number' && index !== this.props.index) {\n        if (process.env.NODE_ENV !== 'production') {\n          (0, _reactSwipeableViewsCore.checkIndexBounds)(nextProps);\n        }\n\n        this.setIndexCurrent(index);\n        this.setState({\n          // If true, we are going to change the children. We shoudn't animate it.\n          displaySameSlide: (0, _reactSwipeableViewsCore.getDisplaySameSlide)(this.props, nextProps),\n          indexLatest: index\n        });\n      }\n    }\n  }, {\n    key: \"componentWillUnmount\",\n    value: function componentWillUnmount() {\n      this.transitionListener.remove();\n      this.touchMoveListener.remove();\n      clearTimeout(this.firstRenderTimeout);\n    }\n  }, {\n    key: \"setIndexCurrent\",\n    value: function setIndexCurrent(indexCurrent) {\n      if (!this.props.animateTransitions && this.indexCurrent !== indexCurrent) {\n        this.handleTransitionEnd();\n      }\n\n      this.indexCurrent = indexCurrent;\n\n      if (this.containerNode) {\n        var axis = this.props.axis;\n        var transform = axisProperties.transform[axis](indexCurrent * 100);\n        this.containerNode.style.WebkitTransform = transform;\n        this.containerNode.style.transform = transform;\n      }\n    }\n  }, {\n    key: \"handleTransitionEnd\",\n    value: function handleTransitionEnd() {\n      if (!this.props.onTransitionEnd) {\n        return;\n      } // Filters out when changing the children\n\n\n      if (this.state.displaySameSlide) {\n        return;\n      } // The rest callback is triggered when swiping. It's just noise.\n      // We filter it out.\n\n\n      if (!this.state.isDragging) {\n        this.props.onTransitionEnd();\n      }\n    }\n  }, {\n    key: \"render\",\n    value: function render() {\n      var _this4 = this;\n\n      var _this$props2 = this.props,\n          action = _this$props2.action,\n          animateHeight = _this$props2.animateHeight,\n          animateTransitions = _this$props2.animateTransitions,\n          axis = _this$props2.axis,\n          children = _this$props2.children,\n          containerStyleProp = _this$props2.containerStyle,\n          disabled = _this$props2.disabled,\n          disableLazyLoading = _this$props2.disableLazyLoading,\n          enableMouseEvents = _this$props2.enableMouseEvents,\n          hysteresis = _this$props2.hysteresis,\n          ignoreNativeScroll = _this$props2.ignoreNativeScroll,\n          index = _this$props2.index,\n          onChangeIndex = _this$props2.onChangeIndex,\n          onSwitching = _this$props2.onSwitching,\n          onTransitionEnd = _this$props2.onTransitionEnd,\n          resistance = _this$props2.resistance,\n          slideStyleProp = _this$props2.slideStyle,\n          slideClassName = _this$props2.slideClassName,\n          springConfig = _this$props2.springConfig,\n          style = _this$props2.style,\n          threshold = _this$props2.threshold,\n          other = (0, _objectWithoutProperties2.default)(_this$props2, [\"action\", \"animateHeight\", \"animateTransitions\", \"axis\", \"children\", \"containerStyle\", \"disabled\", \"disableLazyLoading\", \"enableMouseEvents\", \"hysteresis\", \"ignoreNativeScroll\", \"index\", \"onChangeIndex\", \"onSwitching\", \"onTransitionEnd\", \"resistance\", \"slideStyle\", \"slideClassName\", \"springConfig\", \"style\", \"threshold\"]);\n      var _this$state = this.state,\n          displaySameSlide = _this$state.displaySameSlide,\n          heightLatest = _this$state.heightLatest,\n          indexLatest = _this$state.indexLatest,\n          isDragging = _this$state.isDragging,\n          renderOnlyActive = _this$state.renderOnlyActive;\n      var touchEvents = !disabled ? {\n        onTouchStart: this.handleTouchStart,\n        onTouchEnd: this.handleTouchEnd\n      } : {};\n      var mouseEvents = !disabled && enableMouseEvents ? {\n        onMouseDown: this.handleMouseDown,\n        onMouseUp: this.handleMouseUp,\n        onMouseLeave: this.handleMouseLeave,\n        onMouseMove: this.handleMouseMove\n      } : {}; // There is no point to animate if we are already providing a height.\n\n      process.env.NODE_ENV !== \"production\" ? (0, _warning.default)(!animateHeight || !containerStyleProp || !containerStyleProp.height, \"react-swipeable-view: You are setting animateHeight to true but you are\\nalso providing a custom height.\\nThe custom height has a higher priority than the animateHeight property.\\nSo animateHeight is most likely having no effect at all.\") : void 0;\n      var slideStyle = (0, _extends2.default)({}, styles.slide, slideStyleProp);\n      var transition;\n      var WebkitTransition;\n\n      if (isDragging || !animateTransitions || displaySameSlide) {\n        transition = 'all 0s ease 0s';\n        WebkitTransition = 'all 0s ease 0s';\n      } else {\n        transition = createTransition('transform', springConfig);\n        WebkitTransition = createTransition('-webkit-transform', springConfig);\n\n        if (heightLatest !== 0) {\n          var additionalTranstion = \", \".concat(createTransition('height', springConfig));\n          transition += additionalTranstion;\n          WebkitTransition += additionalTranstion;\n        }\n      }\n\n      var containerStyle = {\n        height: null,\n        WebkitFlexDirection: axisProperties.flexDirection[axis],\n        flexDirection: axisProperties.flexDirection[axis],\n        WebkitTransition: WebkitTransition,\n        transition: transition\n      }; // Apply the styles for SSR considerations\n\n      if (!renderOnlyActive) {\n        var transform = axisProperties.transform[axis](this.indexCurrent * 100);\n        containerStyle.WebkitTransform = transform;\n        containerStyle.transform = transform;\n      }\n\n      if (animateHeight) {\n        containerStyle.height = heightLatest;\n      }\n\n      return _react.default.createElement(\"div\", (0, _extends2.default)({\n        ref: this.setRootNode,\n        style: (0, _extends2.default)({}, axisProperties.root[axis], style)\n      }, other, touchEvents, mouseEvents, {\n        onScroll: this.handleScroll\n      }), _react.default.createElement(\"div\", {\n        ref: this.setContainerNode,\n        style: (0, _extends2.default)({}, containerStyle, styles.container, containerStyleProp),\n        className: \"react-swipeable-view-container\"\n      }, _react.default.Children.map(children, function (child, indexChild) {\n        if (renderOnlyActive && indexChild !== indexLatest) {\n          return null;\n        }\n\n        process.env.NODE_ENV !== \"production\" ? (0, _warning.default)(_react.default.isValidElement(child), \"react-swipeable-view: one of the children provided is invalid: \".concat(child, \".\\nWe are expecting a valid React Element\")) : void 0;\n        var ref;\n        var hidden = true;\n\n        if (indexChild === indexLatest) {\n          hidden = false;\n\n          if (animateHeight) {\n            ref = _this4.setActiveSlide;\n            slideStyle.overflowY = 'hidden';\n          }\n        }\n\n        return _react.default.createElement(\"div\", {\n          ref: ref,\n          style: slideStyle,\n          className: slideClassName,\n          \"aria-hidden\": hidden,\n          \"data-swipeable\": \"true\"\n        }, child);\n      })));\n    }\n  }]);\n  return SwipeableViews;\n}(_react.default.Component); // Added as an ads for people using the React dev tools in production.\n// So they know, the tool used to build the awesome UI they\n// are looking at/retro engineering.\n\n\nSwipeableViews.displayName = 'ReactSwipableView';\nSwipeableViews.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * This is callback property. It's called by the component on mount.\n   * This is useful when you want to trigger an action programmatically.\n   * It currently only supports updateHeight() action.\n   *\n   * @param {object} actions This object contains all posible actions\n   * that can be triggered programmatically.\n   */\n  action: _propTypes.default.func,\n\n  /**\n   * If `true`, the height of the container will be animated to match the current slide height.\n   * Animating another style property has a negative impact regarding performance.\n   */\n  animateHeight: _propTypes.default.bool,\n\n  /**\n   * If `false`, changes to the index prop will not cause an animated transition.\n   */\n  animateTransitions: _propTypes.default.bool,\n\n  /**\n   * The axis on which the slides will slide.\n   */\n  axis: _propTypes.default.oneOf(['x', 'x-reverse', 'y', 'y-reverse']),\n\n  /**\n   * Use this property to provide your slides.\n   */\n  children: _propTypes.default.node.isRequired,\n\n  /**\n   * This is the inlined style that will be applied\n   * to each slide container.\n   */\n  containerStyle: _propTypes.default.object,\n\n  /**\n   * If `true`, it will disable touch events.\n   * This is useful when you want to prohibit the user from changing slides.\n   */\n  disabled: _propTypes.default.bool,\n\n  /**\n   * This is the config used to disable lazyloding,\n   * if `true` will render all the views in first rendering.\n   */\n  disableLazyLoading: _propTypes.default.bool,\n\n  /**\n   * If `true`, it will enable mouse events.\n   * This will allow the user to perform the relevant swipe actions with a mouse.\n   */\n  enableMouseEvents: _propTypes.default.bool,\n\n  /**\n   * Configure hysteresis between slides. This value determines how far\n   * should user swipe to switch slide.\n   */\n  hysteresis: _propTypes.default.number,\n\n  /**\n   * If `true`, it will ignore native scroll container.\n   * It can be used to filter out false positive that blocks the swipe.\n   */\n  ignoreNativeScroll: _propTypes.default.bool,\n\n  /**\n   * This is the index of the slide to show.\n   * This is useful when you want to change the default slide shown.\n   * Or when you have tabs linked to each slide.\n   */\n  index: _propTypes.default.number,\n\n  /**\n   * This is callback prop. It's call by the\n   * component when the shown slide change after a swipe made by the user.\n   * This is useful when you have tabs linked to each slide.\n   *\n   * @param {integer} index This is the current index of the slide.\n   * @param {integer} indexLatest This is the oldest index of the slide.\n   * @param {object} meta Meta data containing more information about the event.\n   */\n  onChangeIndex: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onMouseDown: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onMouseLeave: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onMouseMove: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onMouseUp: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onScroll: _propTypes.default.func,\n\n  /**\n   * This is callback prop. It's called by the\n   * component when the slide switching.\n   * This is useful when you want to implement something corresponding\n   * to the current slide position.\n   *\n   * @param {integer} index This is the current index of the slide.\n   * @param {string} type Can be either `move` or `end`.\n   */\n  onSwitching: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onTouchEnd: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onTouchMove: _propTypes.default.func,\n\n  /**\n   * @ignore\n   */\n  onTouchStart: _propTypes.default.func,\n\n  /**\n   * The callback that fires when the animation comes to a rest.\n   * This is useful to defer CPU intensive task.\n   */\n  onTransitionEnd: _propTypes.default.func,\n\n  /**\n   * If `true`, it will add bounds effect on the edges.\n   */\n  resistance: _propTypes.default.bool,\n\n  /**\n   * This is the className that will be applied\n   * on the slide component.\n   */\n  slideClassName: _propTypes.default.string,\n\n  /**\n   * This is the inlined style that will be applied\n   * on the slide component.\n   */\n  slideStyle: _propTypes.default.object,\n\n  /**\n   * This is the config used to create CSS transitions.\n   * This is useful to change the dynamic of the transition.\n   */\n  springConfig: _propTypes.default.shape({\n    delay: _propTypes.default.string,\n    duration: _propTypes.default.string,\n    easeFunction: _propTypes.default.string\n  }),\n\n  /**\n   * This is the inlined style that will be applied\n   * on the root component.\n   */\n  style: _propTypes.default.object,\n\n  /**\n   * This is the threshold used for detecting a quick swipe.\n   * If the computed speed is above this value, the index change.\n   */\n  threshold: _propTypes.default.number\n} : {};\nSwipeableViews.defaultProps = {\n  animateHeight: false,\n  animateTransitions: true,\n  axis: 'x',\n  disabled: false,\n  disableLazyLoading: false,\n  enableMouseEvents: false,\n  hysteresis: 0.6,\n  ignoreNativeScroll: false,\n  index: 0,\n  threshold: 5,\n  springConfig: {\n    duration: '0.35s',\n    easeFunction: 'cubic-bezier(0.15, 0.3, 0.25, 1)',\n    delay: '0s'\n  },\n  resistance: false\n};\nSwipeableViews.childContextTypes = {\n  swipeableViews: _propTypes.default.shape({\n    slideUpdateHeight: _propTypes.default.func\n  })\n};\nvar _default = SwipeableViews;\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _SwipeableViews = _interopRequireDefault(require(\"./SwipeableViews\"));\n\nvar _default = _SwipeableViews.default;\nexports.default = _default;","/**\n * @license React\n * react-jsx-runtime.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n  REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\");\nfunction jsxProd(type, config, maybeKey) {\n  var key = null;\n  void 0 !== maybeKey && (key = \"\" + maybeKey);\n  void 0 !== config.key && (key = \"\" + config.key);\n  if (\"key\" in config) {\n    maybeKey = {};\n    for (var propName in config)\n      \"key\" !== propName && (maybeKey[propName] = config[propName]);\n  } else maybeKey = config;\n  config = maybeKey.ref;\n  return {\n    $$typeof: REACT_ELEMENT_TYPE,\n    type: type,\n    key: key,\n    ref: void 0 !== config ? config : null,\n    props: maybeKey\n  };\n}\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.jsx = jsxProd;\nexports.jsxs = jsxProd;\n","/**\n * @license React\n * react.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n  REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n  REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n  REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n  REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n  REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n  REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n  REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n  REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n  REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n  REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n  MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nfunction getIteratorFn(maybeIterable) {\n  if (null === maybeIterable || \"object\" !== typeof maybeIterable) return null;\n  maybeIterable =\n    (MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||\n    maybeIterable[\"@@iterator\"];\n  return \"function\" === typeof maybeIterable ? maybeIterable : null;\n}\nvar ReactNoopUpdateQueue = {\n    isMounted: function () {\n      return !1;\n    },\n    enqueueForceUpdate: function () {},\n    enqueueReplaceState: function () {},\n    enqueueSetState: function () {}\n  },\n  assign = Object.assign,\n  emptyObject = {};\nfunction Component(props, context, updater) {\n  this.props = props;\n  this.context = context;\n  this.refs = emptyObject;\n  this.updater = updater || ReactNoopUpdateQueue;\n}\nComponent.prototype.isReactComponent = {};\nComponent.prototype.setState = function (partialState, callback) {\n  if (\n    \"object\" !== typeof partialState &&\n    \"function\" !== typeof partialState &&\n    null != partialState\n  )\n    throw Error(\n      \"takes an object of state variables to update or a function which returns an object of state variables.\"\n    );\n  this.updater.enqueueSetState(this, partialState, callback, \"setState\");\n};\nComponent.prototype.forceUpdate = function (callback) {\n  this.updater.enqueueForceUpdate(this, callback, \"forceUpdate\");\n};\nfunction ComponentDummy() {}\nComponentDummy.prototype = Component.prototype;\nfunction PureComponent(props, context, updater) {\n  this.props = props;\n  this.context = context;\n  this.refs = emptyObject;\n  this.updater = updater || ReactNoopUpdateQueue;\n}\nvar pureComponentPrototype = (PureComponent.prototype = new ComponentDummy());\npureComponentPrototype.constructor = PureComponent;\nassign(pureComponentPrototype, Component.prototype);\npureComponentPrototype.isPureReactComponent = !0;\nvar isArrayImpl = Array.isArray,\n  ReactSharedInternals = { H: null, A: null, T: null, S: null },\n  hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction ReactElement(type, key, self, source, owner, props) {\n  self = props.ref;\n  return {\n    $$typeof: REACT_ELEMENT_TYPE,\n    type: type,\n    key: key,\n    ref: void 0 !== self ? self : null,\n    props: props\n  };\n}\nfunction cloneAndReplaceKey(oldElement, newKey) {\n  return ReactElement(\n    oldElement.type,\n    newKey,\n    void 0,\n    void 0,\n    void 0,\n    oldElement.props\n  );\n}\nfunction isValidElement(object) {\n  return (\n    \"object\" === typeof object &&\n    null !== object &&\n    object.$$typeof === REACT_ELEMENT_TYPE\n  );\n}\nfunction escape(key) {\n  var escaperLookup = { \"=\": \"=0\", \":\": \"=2\" };\n  return (\n    \"$\" +\n    key.replace(/[=:]/g, function (match) {\n      return escaperLookup[match];\n    })\n  );\n}\nvar userProvidedKeyEscapeRegex = /\\/+/g;\nfunction getElementKey(element, index) {\n  return \"object\" === typeof element && null !== element && null != element.key\n    ? escape(\"\" + element.key)\n    : index.toString(36);\n}\nfunction noop$1() {}\nfunction resolveThenable(thenable) {\n  switch (thenable.status) {\n    case \"fulfilled\":\n      return thenable.value;\n    case \"rejected\":\n      throw thenable.reason;\n    default:\n      switch (\n        (\"string\" === typeof thenable.status\n          ? thenable.then(noop$1, noop$1)\n          : ((thenable.status = \"pending\"),\n            thenable.then(\n              function (fulfilledValue) {\n                \"pending\" === thenable.status &&\n                  ((thenable.status = \"fulfilled\"),\n                  (thenable.value = fulfilledValue));\n              },\n              function (error) {\n                \"pending\" === thenable.status &&\n                  ((thenable.status = \"rejected\"), (thenable.reason = error));\n              }\n            )),\n        thenable.status)\n      ) {\n        case \"fulfilled\":\n          return thenable.value;\n        case \"rejected\":\n          throw thenable.reason;\n      }\n  }\n  throw thenable;\n}\nfunction mapIntoArray(children, array, escapedPrefix, nameSoFar, callback) {\n  var type = typeof children;\n  if (\"undefined\" === type || \"boolean\" === type) children = null;\n  var invokeCallback = !1;\n  if (null === children) invokeCallback = !0;\n  else\n    switch (type) {\n      case \"bigint\":\n      case \"string\":\n      case \"number\":\n        invokeCallback = !0;\n        break;\n      case \"object\":\n        switch (children.$$typeof) {\n          case REACT_ELEMENT_TYPE:\n          case REACT_PORTAL_TYPE:\n            invokeCallback = !0;\n            break;\n          case REACT_LAZY_TYPE:\n            return (\n              (invokeCallback = children._init),\n              mapIntoArray(\n                invokeCallback(children._payload),\n                array,\n                escapedPrefix,\n                nameSoFar,\n                callback\n              )\n            );\n        }\n    }\n  if (invokeCallback)\n    return (\n      (callback = callback(children)),\n      (invokeCallback =\n        \"\" === nameSoFar ? \".\" + getElementKey(children, 0) : nameSoFar),\n      isArrayImpl(callback)\n        ? ((escapedPrefix = \"\"),\n          null != invokeCallback &&\n            (escapedPrefix =\n              invokeCallback.replace(userProvidedKeyEscapeRegex, \"$&/\") + \"/\"),\n          mapIntoArray(callback, array, escapedPrefix, \"\", function (c) {\n            return c;\n          }))\n        : null != callback &&\n          (isValidElement(callback) &&\n            (callback = cloneAndReplaceKey(\n              callback,\n              escapedPrefix +\n                (null == callback.key ||\n                (children && children.key === callback.key)\n                  ? \"\"\n                  : (\"\" + callback.key).replace(\n                      userProvidedKeyEscapeRegex,\n                      \"$&/\"\n                    ) + \"/\") +\n                invokeCallback\n            )),\n          array.push(callback)),\n      1\n    );\n  invokeCallback = 0;\n  var nextNamePrefix = \"\" === nameSoFar ? \".\" : nameSoFar + \":\";\n  if (isArrayImpl(children))\n    for (var i = 0; i < children.length; i++)\n      (nameSoFar = children[i]),\n        (type = nextNamePrefix + getElementKey(nameSoFar, i)),\n        (invokeCallback += mapIntoArray(\n          nameSoFar,\n          array,\n          escapedPrefix,\n          type,\n          callback\n        ));\n  else if (((i = getIteratorFn(children)), \"function\" === typeof i))\n    for (\n      children = i.call(children), i = 0;\n      !(nameSoFar = children.next()).done;\n\n    )\n      (nameSoFar = nameSoFar.value),\n        (type = nextNamePrefix + getElementKey(nameSoFar, i++)),\n        (invokeCallback += mapIntoArray(\n          nameSoFar,\n          array,\n          escapedPrefix,\n          type,\n          callback\n        ));\n  else if (\"object\" === type) {\n    if (\"function\" === typeof children.then)\n      return mapIntoArray(\n        resolveThenable(children),\n        array,\n        escapedPrefix,\n        nameSoFar,\n        callback\n      );\n    array = String(children);\n    throw Error(\n      \"Objects are not valid as a React child (found: \" +\n        (\"[object Object]\" === array\n          ? \"object with keys {\" + Object.keys(children).join(\", \") + \"}\"\n          : array) +\n        \"). If you meant to render a collection of children, use an array instead.\"\n    );\n  }\n  return invokeCallback;\n}\nfunction mapChildren(children, func, context) {\n  if (null == children) return children;\n  var result = [],\n    count = 0;\n  mapIntoArray(children, result, \"\", \"\", function (child) {\n    return func.call(context, child, count++);\n  });\n  return result;\n}\nfunction lazyInitializer(payload) {\n  if (-1 === payload._status) {\n    var ctor = payload._result;\n    ctor = ctor();\n    ctor.then(\n      function (moduleObject) {\n        if (0 === payload._status || -1 === payload._status)\n          (payload._status = 1), (payload._result = moduleObject);\n      },\n      function (error) {\n        if (0 === payload._status || -1 === payload._status)\n          (payload._status = 2), (payload._result = error);\n      }\n    );\n    -1 === payload._status && ((payload._status = 0), (payload._result = ctor));\n  }\n  if (1 === payload._status) return payload._result.default;\n  throw payload._result;\n}\nvar reportGlobalError =\n  \"function\" === typeof reportError\n    ? reportError\n    : function (error) {\n        if (\n          \"object\" === typeof window &&\n          \"function\" === typeof window.ErrorEvent\n        ) {\n          var event = new window.ErrorEvent(\"error\", {\n            bubbles: !0,\n            cancelable: !0,\n            message:\n              \"object\" === typeof error &&\n              null !== error &&\n              \"string\" === typeof error.message\n                ? String(error.message)\n                : String(error),\n            error: error\n          });\n          if (!window.dispatchEvent(event)) return;\n        } else if (\n          \"object\" === typeof process &&\n          \"function\" === typeof process.emit\n        ) {\n          process.emit(\"uncaughtException\", error);\n          return;\n        }\n        console.error(error);\n      };\nfunction noop() {}\nexports.Children = {\n  map: mapChildren,\n  forEach: function (children, forEachFunc, forEachContext) {\n    mapChildren(\n      children,\n      function () {\n        forEachFunc.apply(this, arguments);\n      },\n      forEachContext\n    );\n  },\n  count: function (children) {\n    var n = 0;\n    mapChildren(children, function () {\n      n++;\n    });\n    return n;\n  },\n  toArray: function (children) {\n    return (\n      mapChildren(children, function (child) {\n        return child;\n      }) || []\n    );\n  },\n  only: function (children) {\n    if (!isValidElement(children))\n      throw Error(\n        \"React.Children.only expected to receive a single React element child.\"\n      );\n    return children;\n  }\n};\nexports.Component = Component;\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.Profiler = REACT_PROFILER_TYPE;\nexports.PureComponent = PureComponent;\nexports.StrictMode = REACT_STRICT_MODE_TYPE;\nexports.Suspense = REACT_SUSPENSE_TYPE;\nexports.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE =\n  ReactSharedInternals;\nexports.act = function () {\n  throw Error(\"act(...) is not supported in production builds of React.\");\n};\nexports.cache = function (fn) {\n  return function () {\n    return fn.apply(null, arguments);\n  };\n};\nexports.cloneElement = function (element, config, children) {\n  if (null === element || void 0 === element)\n    throw Error(\n      \"The argument must be a React element, but you passed \" + element + \".\"\n    );\n  var props = assign({}, element.props),\n    key = element.key,\n    owner = void 0;\n  if (null != config)\n    for (propName in (void 0 !== config.ref && (owner = void 0),\n    void 0 !== config.key && (key = \"\" + config.key),\n    config))\n      !hasOwnProperty.call(config, propName) ||\n        \"key\" === propName ||\n        \"__self\" === propName ||\n        \"__source\" === propName ||\n        (\"ref\" === propName && void 0 === config.ref) ||\n        (props[propName] = config[propName]);\n  var propName = arguments.length - 2;\n  if (1 === propName) props.children = children;\n  else if (1 < propName) {\n    for (var childArray = Array(propName), i = 0; i < propName; i++)\n      childArray[i] = arguments[i + 2];\n    props.children = childArray;\n  }\n  return ReactElement(element.type, key, void 0, void 0, owner, props);\n};\nexports.createContext = function (defaultValue) {\n  defaultValue = {\n    $$typeof: REACT_CONTEXT_TYPE,\n    _currentValue: defaultValue,\n    _currentValue2: defaultValue,\n    _threadCount: 0,\n    Provider: null,\n    Consumer: null\n  };\n  defaultValue.Provider = defaultValue;\n  defaultValue.Consumer = {\n    $$typeof: REACT_CONSUMER_TYPE,\n    _context: defaultValue\n  };\n  return defaultValue;\n};\nexports.createElement = function (type, config, children) {\n  var propName,\n    props = {},\n    key = null;\n  if (null != config)\n    for (propName in (void 0 !== config.key && (key = \"\" + config.key), config))\n      hasOwnProperty.call(config, propName) &&\n        \"key\" !== propName &&\n        \"__self\" !== propName &&\n        \"__source\" !== propName &&\n        (props[propName] = config[propName]);\n  var childrenLength = arguments.length - 2;\n  if (1 === childrenLength) props.children = children;\n  else if (1 < childrenLength) {\n    for (var childArray = Array(childrenLength), i = 0; i < childrenLength; i++)\n      childArray[i] = arguments[i + 2];\n    props.children = childArray;\n  }\n  if (type && type.defaultProps)\n    for (propName in ((childrenLength = type.defaultProps), childrenLength))\n      void 0 === props[propName] &&\n        (props[propName] = childrenLength[propName]);\n  return ReactElement(type, key, void 0, void 0, null, props);\n};\nexports.createRef = function () {\n  return { current: null };\n};\nexports.forwardRef = function (render) {\n  return { $$typeof: REACT_FORWARD_REF_TYPE, render: render };\n};\nexports.isValidElement = isValidElement;\nexports.lazy = function (ctor) {\n  return {\n    $$typeof: REACT_LAZY_TYPE,\n    _payload: { _status: -1, _result: ctor },\n    _init: lazyInitializer\n  };\n};\nexports.memo = function (type, compare) {\n  return {\n    $$typeof: REACT_MEMO_TYPE,\n    type: type,\n    compare: void 0 === compare ? null : compare\n  };\n};\nexports.startTransition = function (scope) {\n  var prevTransition = ReactSharedInternals.T,\n    currentTransition = {};\n  ReactSharedInternals.T = currentTransition;\n  try {\n    var returnValue = scope(),\n      onStartTransitionFinish = ReactSharedInternals.S;\n    null !== onStartTransitionFinish &&\n      onStartTransitionFinish(currentTransition, returnValue);\n    \"object\" === typeof returnValue &&\n      null !== returnValue &&\n      \"function\" === typeof returnValue.then &&\n      returnValue.then(noop, reportGlobalError);\n  } catch (error) {\n    reportGlobalError(error);\n  } finally {\n    ReactSharedInternals.T = prevTransition;\n  }\n};\nexports.unstable_useCacheRefresh = function () {\n  return ReactSharedInternals.H.useCacheRefresh();\n};\nexports.use = function (usable) {\n  return ReactSharedInternals.H.use(usable);\n};\nexports.useActionState = function (action, initialState, permalink) {\n  return ReactSharedInternals.H.useActionState(action, initialState, permalink);\n};\nexports.useCallback = function (callback, deps) {\n  return ReactSharedInternals.H.useCallback(callback, deps);\n};\nexports.useContext = function (Context) {\n  return ReactSharedInternals.H.useContext(Context);\n};\nexports.useDebugValue = function () {};\nexports.useDeferredValue = function (value, initialValue) {\n  return ReactSharedInternals.H.useDeferredValue(value, initialValue);\n};\nexports.useEffect = function (create, deps) {\n  return ReactSharedInternals.H.useEffect(create, deps);\n};\nexports.useId = function () {\n  return ReactSharedInternals.H.useId();\n};\nexports.useImperativeHandle = function (ref, create, deps) {\n  return ReactSharedInternals.H.useImperativeHandle(ref, create, deps);\n};\nexports.useInsertionEffect = function (create, deps) {\n  return ReactSharedInternals.H.useInsertionEffect(create, deps);\n};\nexports.useLayoutEffect = function (create, deps) {\n  return ReactSharedInternals.H.useLayoutEffect(create, deps);\n};\nexports.useMemo = function (create, deps) {\n  return ReactSharedInternals.H.useMemo(create, deps);\n};\nexports.useOptimistic = function (passthrough, reducer) {\n  return ReactSharedInternals.H.useOptimistic(passthrough, reducer);\n};\nexports.useReducer = function (reducer, initialArg, init) {\n  return ReactSharedInternals.H.useReducer(reducer, initialArg, init);\n};\nexports.useRef = function (initialValue) {\n  return ReactSharedInternals.H.useRef(initialValue);\n};\nexports.useState = function (initialState) {\n  return ReactSharedInternals.H.useState(initialState);\n};\nexports.useSyncExternalStore = function (\n  subscribe,\n  getSnapshot,\n  getServerSnapshot\n) {\n  return ReactSharedInternals.H.useSyncExternalStore(\n    subscribe,\n    getSnapshot,\n    getServerSnapshot\n  );\n};\nexports.useTransition = function () {\n  return ReactSharedInternals.H.useTransition();\n};\nexports.version = \"19.0.0\";\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./cjs/react.production.js');\n} else {\n  module.exports = require('./cjs/react.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./cjs/react-jsx-runtime.production.js');\n} else {\n  module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","/**\n * @license React\n * scheduler.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and 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\";\nfunction push(heap, node) {\n  var index = heap.length;\n  heap.push(node);\n  a: for (; 0 < index; ) {\n    var parentIndex = (index - 1) >>> 1,\n      parent = heap[parentIndex];\n    if (0 < compare(parent, node))\n      (heap[parentIndex] = node), (heap[index] = parent), (index = parentIndex);\n    else break a;\n  }\n}\nfunction peek(heap) {\n  return 0 === heap.length ? null : heap[0];\n}\nfunction pop(heap) {\n  if (0 === heap.length) return null;\n  var first = heap[0],\n    last = heap.pop();\n  if (last !== first) {\n    heap[0] = last;\n    a: for (\n      var index = 0, length = heap.length, halfLength = length >>> 1;\n      index < halfLength;\n\n    ) {\n      var leftIndex = 2 * (index + 1) - 1,\n        left = heap[leftIndex],\n        rightIndex = leftIndex + 1,\n        right = heap[rightIndex];\n      if (0 > compare(left, last))\n        rightIndex < length && 0 > compare(right, left)\n          ? ((heap[index] = right),\n            (heap[rightIndex] = last),\n            (index = rightIndex))\n          : ((heap[index] = left),\n            (heap[leftIndex] = last),\n            (index = leftIndex));\n      else if (rightIndex < length && 0 > compare(right, last))\n        (heap[index] = right), (heap[rightIndex] = last), (index = rightIndex);\n      else break a;\n    }\n  }\n  return first;\n}\nfunction compare(a, b) {\n  var diff = a.sortIndex - b.sortIndex;\n  return 0 !== diff ? diff : a.id - b.id;\n}\nexports.unstable_now = void 0;\nif (\"object\" === typeof performance && \"function\" === typeof performance.now) {\n  var localPerformance = performance;\n  exports.unstable_now = function () {\n    return localPerformance.now();\n  };\n} else {\n  var localDate = Date,\n    initialTime = localDate.now();\n  exports.unstable_now = function () {\n    return localDate.now() - initialTime;\n  };\n}\nvar taskQueue = [],\n  timerQueue = [],\n  taskIdCounter = 1,\n  currentTask = null,\n  currentPriorityLevel = 3,\n  isPerformingWork = !1,\n  isHostCallbackScheduled = !1,\n  isHostTimeoutScheduled = !1,\n  localSetTimeout = \"function\" === typeof setTimeout ? setTimeout : null,\n  localClearTimeout = \"function\" === typeof clearTimeout ? clearTimeout : null,\n  localSetImmediate = \"undefined\" !== typeof setImmediate ? setImmediate : null;\nfunction advanceTimers(currentTime) {\n  for (var timer = peek(timerQueue); null !== timer; ) {\n    if (null === timer.callback) pop(timerQueue);\n    else if (timer.startTime <= currentTime)\n      pop(timerQueue),\n        (timer.sortIndex = timer.expirationTime),\n        push(taskQueue, timer);\n    else break;\n    timer = peek(timerQueue);\n  }\n}\nfunction handleTimeout(currentTime) {\n  isHostTimeoutScheduled = !1;\n  advanceTimers(currentTime);\n  if (!isHostCallbackScheduled)\n    if (null !== peek(taskQueue))\n      (isHostCallbackScheduled = !0), requestHostCallback();\n    else {\n      var firstTimer = peek(timerQueue);\n      null !== firstTimer &&\n        requestHostTimeout(handleTimeout, firstTimer.startTime - currentTime);\n    }\n}\nvar isMessageLoopRunning = !1,\n  taskTimeoutID = -1,\n  frameInterval = 5,\n  startTime = -1;\nfunction shouldYieldToHost() {\n  return exports.unstable_now() - startTime < frameInterval ? !1 : !0;\n}\nfunction performWorkUntilDeadline() {\n  if (isMessageLoopRunning) {\n    var currentTime = exports.unstable_now();\n    startTime = currentTime;\n    var hasMoreWork = !0;\n    try {\n      a: {\n        isHostCallbackScheduled = !1;\n        isHostTimeoutScheduled &&\n          ((isHostTimeoutScheduled = !1),\n          localClearTimeout(taskTimeoutID),\n          (taskTimeoutID = -1));\n        isPerformingWork = !0;\n        var previousPriorityLevel = currentPriorityLevel;\n        try {\n          b: {\n            advanceTimers(currentTime);\n            for (\n              currentTask = peek(taskQueue);\n              null !== currentTask &&\n              !(\n                currentTask.expirationTime > currentTime && shouldYieldToHost()\n              );\n\n            ) {\n              var callback = currentTask.callback;\n              if (\"function\" === typeof callback) {\n                currentTask.callback = null;\n                currentPriorityLevel = currentTask.priorityLevel;\n                var continuationCallback = callback(\n                  currentTask.expirationTime <= currentTime\n                );\n                currentTime = exports.unstable_now();\n                if (\"function\" === typeof continuationCallback) {\n                  currentTask.callback = continuationCallback;\n                  advanceTimers(currentTime);\n                  hasMoreWork = !0;\n                  break b;\n                }\n                currentTask === peek(taskQueue) && pop(taskQueue);\n                advanceTimers(currentTime);\n              } else pop(taskQueue);\n              currentTask = peek(taskQueue);\n            }\n            if (null !== currentTask) hasMoreWork = !0;\n            else {\n              var firstTimer = peek(timerQueue);\n              null !== firstTimer &&\n                requestHostTimeout(\n                  handleTimeout,\n                  firstTimer.startTime - currentTime\n                );\n              hasMoreWork = !1;\n            }\n          }\n          break a;\n        } finally {\n          (currentTask = null),\n            (currentPriorityLevel = previousPriorityLevel),\n            (isPerformingWork = !1);\n        }\n        hasMoreWork = void 0;\n      }\n    } finally {\n      hasMoreWork\n        ? schedulePerformWorkUntilDeadline()\n        : (isMessageLoopRunning = !1);\n    }\n  }\n}\nvar schedulePerformWorkUntilDeadline;\nif (\"function\" === typeof localSetImmediate)\n  schedulePerformWorkUntilDeadline = function () {\n    localSetImmediate(performWorkUntilDeadline);\n  };\nelse if (\"undefined\" !== typeof MessageChannel) {\n  var channel = new MessageChannel(),\n    port = channel.port2;\n  channel.port1.onmessage = performWorkUntilDeadline;\n  schedulePerformWorkUntilDeadline = function () {\n    port.postMessage(null);\n  };\n} else\n  schedulePerformWorkUntilDeadline = function () {\n    localSetTimeout(performWorkUntilDeadline, 0);\n  };\nfunction requestHostCallback() {\n  isMessageLoopRunning ||\n    ((isMessageLoopRunning = !0), schedulePerformWorkUntilDeadline());\n}\nfunction requestHostTimeout(callback, ms) {\n  taskTimeoutID = localSetTimeout(function () {\n    callback(exports.unstable_now());\n  }, ms);\n}\nexports.unstable_IdlePriority = 5;\nexports.unstable_ImmediatePriority = 1;\nexports.unstable_LowPriority = 4;\nexports.unstable_NormalPriority = 3;\nexports.unstable_Profiling = null;\nexports.unstable_UserBlockingPriority = 2;\nexports.unstable_cancelCallback = function (task) {\n  task.callback = null;\n};\nexports.unstable_continueExecution = function () {\n  isHostCallbackScheduled ||\n    isPerformingWork ||\n    ((isHostCallbackScheduled = !0), requestHostCallback());\n};\nexports.unstable_forceFrameRate = function (fps) {\n  0 > fps || 125 < fps\n    ? console.error(\n        \"forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported\"\n      )\n    : (frameInterval = 0 < fps ? Math.floor(1e3 / fps) : 5);\n};\nexports.unstable_getCurrentPriorityLevel = function () {\n  return currentPriorityLevel;\n};\nexports.unstable_getFirstCallbackNode = function () {\n  return peek(taskQueue);\n};\nexports.unstable_next = function (eventHandler) {\n  switch (currentPriorityLevel) {\n    case 1:\n    case 2:\n    case 3:\n      var priorityLevel = 3;\n      break;\n    default:\n      priorityLevel = currentPriorityLevel;\n  }\n  var previousPriorityLevel = currentPriorityLevel;\n  currentPriorityLevel = priorityLevel;\n  try {\n    return eventHandler();\n  } finally {\n    currentPriorityLevel = previousPriorityLevel;\n  }\n};\nexports.unstable_pauseExecution = function () {};\nexports.unstable_requestPaint = function () {};\nexports.unstable_runWithPriority = function (priorityLevel, eventHandler) {\n  switch (priorityLevel) {\n    case 1:\n    case 2:\n    case 3:\n    case 4:\n    case 5:\n      break;\n    default:\n      priorityLevel = 3;\n  }\n  var previousPriorityLevel = currentPriorityLevel;\n  currentPriorityLevel = priorityLevel;\n  try {\n    return eventHandler();\n  } finally {\n    currentPriorityLevel = previousPriorityLevel;\n  }\n};\nexports.unstable_scheduleCallback = function (\n  priorityLevel,\n  callback,\n  options\n) {\n  var currentTime = exports.unstable_now();\n  \"object\" === typeof options && null !== options\n    ? ((options = options.delay),\n      (options =\n        \"number\" === typeof options && 0 < options\n          ? currentTime + options\n          : currentTime))\n    : (options = currentTime);\n  switch (priorityLevel) {\n    case 1:\n      var timeout = -1;\n      break;\n    case 2:\n      timeout = 250;\n      break;\n    case 5:\n      timeout = 1073741823;\n      break;\n    case 4:\n      timeout = 1e4;\n      break;\n    default:\n      timeout = 5e3;\n  }\n  timeout = options + timeout;\n  priorityLevel = {\n    id: taskIdCounter++,\n    callback: callback,\n    priorityLevel: priorityLevel,\n    startTime: options,\n    expirationTime: timeout,\n    sortIndex: -1\n  };\n  options > currentTime\n    ? ((priorityLevel.sortIndex = options),\n      push(timerQueue, priorityLevel),\n      null === peek(taskQueue) &&\n        priorityLevel === peek(timerQueue) &&\n        (isHostTimeoutScheduled\n          ? (localClearTimeout(taskTimeoutID), (taskTimeoutID = -1))\n          : (isHostTimeoutScheduled = !0),\n        requestHostTimeout(handleTimeout, options - currentTime)))\n    : ((priorityLevel.sortIndex = timeout),\n      push(taskQueue, priorityLevel),\n      isHostCallbackScheduled ||\n        isPerformingWork ||\n        ((isHostCallbackScheduled = !0), requestHostCallback()));\n  return priorityLevel;\n};\nexports.unstable_shouldYield = shouldYieldToHost;\nexports.unstable_wrapCallback = function (callback) {\n  var parentPriorityLevel = currentPriorityLevel;\n  return function () {\n    var previousPriorityLevel = currentPriorityLevel;\n    currentPriorityLevel = parentPriorityLevel;\n    try {\n      return callback.apply(this, arguments);\n    } finally {\n      currentPriorityLevel = previousPriorityLevel;\n    }\n  };\n};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./cjs/scheduler.production.js');\n} else {\n  module.exports = require('./cjs/scheduler.development.js');\n}\n","//\n\nmodule.exports = function shallowEqual(objA, objB, compare, compareContext) {\n  var ret = compare ? compare.call(compareContext, objA, objB) : void 0;\n\n  if (ret !== void 0) {\n    return !!ret;\n  }\n\n  if (objA === objB) {\n    return true;\n  }\n\n  if (typeof objA !== \"object\" || !objA || typeof objB !== \"object\" || !objB) {\n    return false;\n  }\n\n  var keysA = Object.keys(objA);\n  var keysB = Object.keys(objB);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(objB);\n\n  // Test for A's keys different from B.\n  for (var idx = 0; idx < keysA.length; idx++) {\n    var key = keysA[idx];\n\n    if (!bHasOwnProperty(key)) {\n      return false;\n    }\n\n    var valueA = objA[key];\n    var valueB = objB[key];\n\n    ret = compare ? compare.call(compareContext, valueA, valueB, key) : void 0;\n\n    if (ret === false || (ret === void 0 && valueA !== valueB)) {\n      return false;\n    }\n  }\n\n  return true;\n};\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\n'use strict';\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar __DEV__ = process.env.NODE_ENV !== 'production';\n\nvar warning = function() {};\n\nif (__DEV__) {\n  var printWarning = function printWarning(format, args) {\n    var len = arguments.length;\n    args = new Array(len > 1 ? len - 1 : 0);\n    for (var key = 1; key < len; key++) {\n      args[key - 1] = arguments[key];\n    }\n    var argIndex = 0;\n    var message = 'Warning: ' +\n      format.replace(/%s/g, function() {\n        return args[argIndex++];\n      });\n    if (typeof console !== 'undefined') {\n      console.error(message);\n    }\n    try {\n      // --- Welcome to debugging React ---\n      // This error was thrown as a convenience so that you can use this stack\n      // to find the callsite that caused this warning to fire.\n      throw new Error(message);\n    } catch (x) {}\n  }\n\n  warning = function(condition, format, args) {\n    var len = arguments.length;\n    args = new Array(len > 2 ? len - 2 : 0);\n    for (var key = 2; key < len; key++) {\n      args[key - 2] = arguments[key];\n    }\n    if (format === undefined) {\n      throw new Error(\n          '`warning(condition, format, ...args)` requires a warning ' +\n          'message argument'\n      );\n    }\n    if (!condition) {\n      printWarning.apply(null, [format].concat(args));\n    }\n  };\n}\n\nmodule.exports = warning;\n","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    default: obj\n  };\n}\n\nmodule.exports = _interopRequireDefault;","function _assertThisInitialized(self) {\n  if (self === void 0) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return self;\n}\n\nmodule.exports = _assertThisInitialized;","function _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n    Object.defineProperty(target, descriptor.key, descriptor);\n  }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  return Constructor;\n}\n\nmodule.exports = _createClass;","function _extends() {\n  module.exports = _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}\n\nmodule.exports = _extends;","function _getPrototypeOf(o) {\n  module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n    return o.__proto__ || Object.getPrototypeOf(o);\n  };\n  return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;","var setPrototypeOf = require(\"./setPrototypeOf\");\n\nfunction _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function\");\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits;","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    default: obj\n  };\n}\n\nmodule.exports = _interopRequireDefault;","var objectWithoutPropertiesLoose = require(\"./objectWithoutPropertiesLoose\");\n\nfunction _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}\n\nmodule.exports = _objectWithoutProperties;","function _objectWithoutPropertiesLoose(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose;","var _typeof = require(\"../helpers/typeof\");\n\nvar assertThisInitialized = require(\"./assertThisInitialized\");\n\nfunction _possibleConstructorReturn(self, call) {\n  if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n    return call;\n  }\n\n  return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn;","function _setPrototypeOf(o, p) {\n  module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n    o.__proto__ = p;\n    return o;\n  };\n\n  return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nfunction _typeof(obj) {\n  if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n    module.exports = _typeof = function _typeof(obj) {\n      return _typeof2(obj);\n    };\n  } else {\n    module.exports = _typeof = function _typeof(obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n    };\n  }\n\n  return _typeof(obj);\n}\n\nmodule.exports = _typeof;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"2681e3dd\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var inProgress = {};\nvar dataWebpackPrefix = \"villanos-esports:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t792: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkvillanos_esports\"] = self[\"webpackChunkvillanos_esports\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","__webpack_require__.nc = undefined;","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nfunction _objectWithoutProperties(e, t) {\n  if (null == e) return {};\n  var o,\n    r,\n    i = objectWithoutPropertiesLoose(e, t);\n  if (Object.getOwnPropertySymbols) {\n    var s = Object.getOwnPropertySymbols(e);\n    for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]);\n  }\n  return i;\n}\nexport { _objectWithoutProperties as default };","function _objectWithoutPropertiesLoose(r, e) {\n  if (null == r) return {};\n  var t = {};\n  for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n    if (e.includes(n)) continue;\n    t[n] = r[n];\n  }\n  return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","function _typeof(o) {\n  \"@babel/helpers - typeof\";\n\n  return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n    return typeof o;\n  } : function (o) {\n    return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n  }, _typeof(o);\n}\nexport { _typeof as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n  var i = toPrimitive(t, \"string\");\n  return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n  if (\"object\" != _typeof(t) || !t) return t;\n  var e = t[Symbol.toPrimitive];\n  if (void 0 !== e) {\n    var i = e.call(t, r || \"default\");\n    if (\"object\" != _typeof(i)) return i;\n    throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n  }\n  return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n  return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n    value: t,\n    enumerable: !0,\n    configurable: !0,\n    writable: !0\n  }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import defineProperty from \"./defineProperty.js\";\nfunction ownKeys(e, r) {\n  var t = Object.keys(e);\n  if (Object.getOwnPropertySymbols) {\n    var o = Object.getOwnPropertySymbols(e);\n    r && (o = o.filter(function (r) {\n      return Object.getOwnPropertyDescriptor(e, r).enumerable;\n    })), t.push.apply(t, o);\n  }\n  return t;\n}\nfunction _objectSpread2(e) {\n  for (var r = 1; r < arguments.length; r++) {\n    var t = null != arguments[r] ? arguments[r] : {};\n    r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n      defineProperty(e, r, t[r]);\n    }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n      Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n    });\n  }\n  return e;\n}\nexport { _objectSpread2 as default };","/**\n * react-router v7.1.1\n *\n * Copyright (c) Remix Software Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.md file in the root directory of this source tree.\n *\n * @license MIT\n */\n\n// lib/router/history.ts\nvar Action = /* @__PURE__ */ ((Action2) => {\n  Action2[\"Pop\"] = \"POP\";\n  Action2[\"Push\"] = \"PUSH\";\n  Action2[\"Replace\"] = \"REPLACE\";\n  return Action2;\n})(Action || {});\nvar PopStateEventType = \"popstate\";\nfunction createMemoryHistory(options = {}) {\n  let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n  let entries;\n  entries = initialEntries.map(\n    (entry, index2) => createMemoryLocation(\n      entry,\n      typeof entry === \"string\" ? null : entry.state,\n      index2 === 0 ? \"default\" : void 0\n    )\n  );\n  let index = clampIndex(\n    initialIndex == null ? entries.length - 1 : initialIndex\n  );\n  let action = \"POP\" /* Pop */;\n  let listener = null;\n  function clampIndex(n) {\n    return Math.min(Math.max(n, 0), entries.length - 1);\n  }\n  function getCurrentLocation() {\n    return entries[index];\n  }\n  function createMemoryLocation(to, state = null, key) {\n    let location = createLocation(\n      entries ? getCurrentLocation().pathname : \"/\",\n      to,\n      state,\n      key\n    );\n    warning(\n      location.pathname.charAt(0) === \"/\",\n      `relative pathnames are not supported in memory history: ${JSON.stringify(\n        to\n      )}`\n    );\n    return location;\n  }\n  function createHref2(to) {\n    return typeof to === \"string\" ? to : createPath(to);\n  }\n  let history = {\n    get index() {\n      return index;\n    },\n    get action() {\n      return action;\n    },\n    get location() {\n      return getCurrentLocation();\n    },\n    createHref: createHref2,\n    createURL(to) {\n      return new URL(createHref2(to), \"http://localhost\");\n    },\n    encodeLocation(to) {\n      let path = typeof to === \"string\" ? parsePath(to) : to;\n      return {\n        pathname: path.pathname || \"\",\n        search: path.search || \"\",\n        hash: path.hash || \"\"\n      };\n    },\n    push(to, state) {\n      action = \"PUSH\" /* Push */;\n      let nextLocation = createMemoryLocation(to, state);\n      index += 1;\n      entries.splice(index, entries.length, nextLocation);\n      if (v5Compat && listener) {\n        listener({ action, location: nextLocation, delta: 1 });\n      }\n    },\n    replace(to, state) {\n      action = \"REPLACE\" /* Replace */;\n      let nextLocation = createMemoryLocation(to, state);\n      entries[index] = nextLocation;\n      if (v5Compat && listener) {\n        listener({ action, location: nextLocation, delta: 0 });\n      }\n    },\n    go(delta) {\n      action = \"POP\" /* Pop */;\n      let nextIndex = clampIndex(index + delta);\n      let nextLocation = entries[nextIndex];\n      index = nextIndex;\n      if (listener) {\n        listener({ action, location: nextLocation, delta });\n      }\n    },\n    listen(fn) {\n      listener = fn;\n      return () => {\n        listener = null;\n      };\n    }\n  };\n  return history;\n}\nfunction createBrowserHistory(options = {}) {\n  function createBrowserLocation(window2, globalHistory) {\n    let { pathname, search, hash } = window2.location;\n    return createLocation(\n      \"\",\n      { pathname, search, hash },\n      // state defaults to `null` because `window.history.state` does\n      globalHistory.state && globalHistory.state.usr || null,\n      globalHistory.state && globalHistory.state.key || \"default\"\n    );\n  }\n  function createBrowserHref(window2, to) {\n    return typeof to === \"string\" ? to : createPath(to);\n  }\n  return getUrlBasedHistory(\n    createBrowserLocation,\n    createBrowserHref,\n    null,\n    options\n  );\n}\nfunction createHashHistory(options = {}) {\n  function createHashLocation(window2, globalHistory) {\n    let {\n      pathname = \"/\",\n      search = \"\",\n      hash = \"\"\n    } = parsePath(window2.location.hash.substring(1));\n    if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n      pathname = \"/\" + pathname;\n    }\n    return createLocation(\n      \"\",\n      { pathname, search, hash },\n      // state defaults to `null` because `window.history.state` does\n      globalHistory.state && globalHistory.state.usr || null,\n      globalHistory.state && globalHistory.state.key || \"default\"\n    );\n  }\n  function createHashHref(window2, to) {\n    let base = window2.document.querySelector(\"base\");\n    let href = \"\";\n    if (base && base.getAttribute(\"href\")) {\n      let url = window2.location.href;\n      let hashIndex = url.indexOf(\"#\");\n      href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n    }\n    return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n  }\n  function validateHashLocation(location, to) {\n    warning(\n      location.pathname.charAt(0) === \"/\",\n      `relative pathnames are not supported in hash history.push(${JSON.stringify(\n        to\n      )})`\n    );\n  }\n  return getUrlBasedHistory(\n    createHashLocation,\n    createHashHref,\n    validateHashLocation,\n    options\n  );\n}\nfunction invariant(value, message) {\n  if (value === false || value === null || typeof value === \"undefined\") {\n    throw new Error(message);\n  }\n}\nfunction warning(cond, message) {\n  if (!cond) {\n    if (typeof console !== \"undefined\") console.warn(message);\n    try {\n      throw new Error(message);\n    } catch (e) {\n    }\n  }\n}\nfunction createKey() {\n  return Math.random().toString(36).substring(2, 10);\n}\nfunction getHistoryState(location, index) {\n  return {\n    usr: location.state,\n    key: location.key,\n    idx: index\n  };\n}\nfunction createLocation(current, to, state = null, key) {\n  let location = {\n    pathname: typeof current === \"string\" ? current : current.pathname,\n    search: \"\",\n    hash: \"\",\n    ...typeof to === \"string\" ? parsePath(to) : to,\n    state,\n    // TODO: This could be cleaned up.  push/replace should probably just take\n    // full Locations now and avoid the need to run through this flow at all\n    // But that's a pretty big refactor to the current test suite so going to\n    // keep as is for the time being and just let any incoming keys take precedence\n    key: to && to.key || key || createKey()\n  };\n  return location;\n}\nfunction createPath({\n  pathname = \"/\",\n  search = \"\",\n  hash = \"\"\n}) {\n  if (search && search !== \"?\")\n    pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n  if (hash && hash !== \"#\")\n    pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n  return pathname;\n}\nfunction parsePath(path) {\n  let parsedPath = {};\n  if (path) {\n    let hashIndex = path.indexOf(\"#\");\n    if (hashIndex >= 0) {\n      parsedPath.hash = path.substring(hashIndex);\n      path = path.substring(0, hashIndex);\n    }\n    let searchIndex = path.indexOf(\"?\");\n    if (searchIndex >= 0) {\n      parsedPath.search = path.substring(searchIndex);\n      path = path.substring(0, searchIndex);\n    }\n    if (path) {\n      parsedPath.pathname = path;\n    }\n  }\n  return parsedPath;\n}\nfunction getUrlBasedHistory(getLocation, createHref2, validateLocation, options = {}) {\n  let { window: window2 = document.defaultView, v5Compat = false } = options;\n  let globalHistory = window2.history;\n  let action = \"POP\" /* Pop */;\n  let listener = null;\n  let index = getIndex();\n  if (index == null) {\n    index = 0;\n    globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n  }\n  function getIndex() {\n    let state = globalHistory.state || { idx: null };\n    return state.idx;\n  }\n  function handlePop() {\n    action = \"POP\" /* Pop */;\n    let nextIndex = getIndex();\n    let delta = nextIndex == null ? null : nextIndex - index;\n    index = nextIndex;\n    if (listener) {\n      listener({ action, location: history.location, delta });\n    }\n  }\n  function push(to, state) {\n    action = \"PUSH\" /* Push */;\n    let location = createLocation(history.location, to, state);\n    if (validateLocation) validateLocation(location, to);\n    index = getIndex() + 1;\n    let historyState = getHistoryState(location, index);\n    let url = history.createHref(location);\n    try {\n      globalHistory.pushState(historyState, \"\", url);\n    } catch (error) {\n      if (error instanceof DOMException && error.name === \"DataCloneError\") {\n        throw error;\n      }\n      window2.location.assign(url);\n    }\n    if (v5Compat && listener) {\n      listener({ action, location: history.location, delta: 1 });\n    }\n  }\n  function replace2(to, state) {\n    action = \"REPLACE\" /* Replace */;\n    let location = createLocation(history.location, to, state);\n    if (validateLocation) validateLocation(location, to);\n    index = getIndex();\n    let historyState = getHistoryState(location, index);\n    let url = history.createHref(location);\n    globalHistory.replaceState(historyState, \"\", url);\n    if (v5Compat && listener) {\n      listener({ action, location: history.location, delta: 0 });\n    }\n  }\n  function createURL(to) {\n    let base = window2.location.origin !== \"null\" ? window2.location.origin : window2.location.href;\n    let href = typeof to === \"string\" ? to : createPath(to);\n    href = href.replace(/ $/, \"%20\");\n    invariant(\n      base,\n      `No window.location.(origin|href) available to create URL for href: ${href}`\n    );\n    return new URL(href, base);\n  }\n  let history = {\n    get action() {\n      return action;\n    },\n    get location() {\n      return getLocation(window2, globalHistory);\n    },\n    listen(fn) {\n      if (listener) {\n        throw new Error(\"A history only accepts one active listener\");\n      }\n      window2.addEventListener(PopStateEventType, handlePop);\n      listener = fn;\n      return () => {\n        window2.removeEventListener(PopStateEventType, handlePop);\n        listener = null;\n      };\n    },\n    createHref(to) {\n      return createHref2(window2, to);\n    },\n    createURL,\n    encodeLocation(to) {\n      let url = createURL(to);\n      return {\n        pathname: url.pathname,\n        search: url.search,\n        hash: url.hash\n      };\n    },\n    push,\n    replace: replace2,\n    go(n) {\n      return globalHistory.go(n);\n    }\n  };\n  return history;\n}\n\n// lib/router/utils.ts\nvar immutableRouteKeys = /* @__PURE__ */ new Set([\n  \"lazy\",\n  \"caseSensitive\",\n  \"path\",\n  \"id\",\n  \"index\",\n  \"children\"\n]);\nfunction isIndexRoute(route) {\n  return route.index === true;\n}\nfunction convertRoutesToDataRoutes(routes, mapRouteProperties2, parentPath = [], manifest = {}) {\n  return routes.map((route, index) => {\n    let treePath = [...parentPath, String(index)];\n    let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n    invariant(\n      route.index !== true || !route.children,\n      `Cannot specify children on an index route`\n    );\n    invariant(\n      !manifest[id],\n      `Found a route id collision on id \"${id}\".  Route id's must be globally unique within Data Router usages`\n    );\n    if (isIndexRoute(route)) {\n      let indexRoute = {\n        ...route,\n        ...mapRouteProperties2(route),\n        id\n      };\n      manifest[id] = indexRoute;\n      return indexRoute;\n    } else {\n      let pathOrLayoutRoute = {\n        ...route,\n        ...mapRouteProperties2(route),\n        id,\n        children: void 0\n      };\n      manifest[id] = pathOrLayoutRoute;\n      if (route.children) {\n        pathOrLayoutRoute.children = convertRoutesToDataRoutes(\n          route.children,\n          mapRouteProperties2,\n          treePath,\n          manifest\n        );\n      }\n      return pathOrLayoutRoute;\n    }\n  });\n}\nfunction matchRoutes(routes, locationArg, basename = \"/\") {\n  return matchRoutesImpl(routes, locationArg, basename, false);\n}\nfunction matchRoutesImpl(routes, locationArg, basename, allowPartial) {\n  let location = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n  let pathname = stripBasename(location.pathname || \"/\", basename);\n  if (pathname == null) {\n    return null;\n  }\n  let branches = flattenRoutes(routes);\n  rankRouteBranches(branches);\n  let matches = null;\n  for (let i = 0; matches == null && i < branches.length; ++i) {\n    let decoded = decodePath(pathname);\n    matches = matchRouteBranch(\n      branches[i],\n      decoded,\n      allowPartial\n    );\n  }\n  return matches;\n}\nfunction convertRouteMatchToUiMatch(match, loaderData) {\n  let { route, pathname, params } = match;\n  return {\n    id: route.id,\n    pathname,\n    params,\n    data: loaderData[route.id],\n    handle: route.handle\n  };\n}\nfunction flattenRoutes(routes, branches = [], parentsMeta = [], parentPath = \"\") {\n  let flattenRoute = (route, index, relativePath) => {\n    let meta = {\n      relativePath: relativePath === void 0 ? route.path || \"\" : relativePath,\n      caseSensitive: route.caseSensitive === true,\n      childrenIndex: index,\n      route\n    };\n    if (meta.relativePath.startsWith(\"/\")) {\n      invariant(\n        meta.relativePath.startsWith(parentPath),\n        `Absolute route path \"${meta.relativePath}\" nested under path \"${parentPath}\" is not valid. An absolute child route path must start with the combined path of all its parent routes.`\n      );\n      meta.relativePath = meta.relativePath.slice(parentPath.length);\n    }\n    let path = joinPaths([parentPath, meta.relativePath]);\n    let routesMeta = parentsMeta.concat(meta);\n    if (route.children && route.children.length > 0) {\n      invariant(\n        // Our types know better, but runtime JS may not!\n        // @ts-expect-error\n        route.index !== true,\n        `Index routes must not have child routes. Please remove all child routes from route path \"${path}\".`\n      );\n      flattenRoutes(route.children, branches, routesMeta, path);\n    }\n    if (route.path == null && !route.index) {\n      return;\n    }\n    branches.push({\n      path,\n      score: computeScore(path, route.index),\n      routesMeta\n    });\n  };\n  routes.forEach((route, index) => {\n    if (route.path === \"\" || !route.path?.includes(\"?\")) {\n      flattenRoute(route, index);\n    } else {\n      for (let exploded of explodeOptionalSegments(route.path)) {\n        flattenRoute(route, index, exploded);\n      }\n    }\n  });\n  return branches;\n}\nfunction explodeOptionalSegments(path) {\n  let segments = path.split(\"/\");\n  if (segments.length === 0) return [];\n  let [first, ...rest] = segments;\n  let isOptional = first.endsWith(\"?\");\n  let required = first.replace(/\\?$/, \"\");\n  if (rest.length === 0) {\n    return isOptional ? [required, \"\"] : [required];\n  }\n  let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n  let result = [];\n  result.push(\n    ...restExploded.map(\n      (subpath) => subpath === \"\" ? required : [required, subpath].join(\"/\")\n    )\n  );\n  if (isOptional) {\n    result.push(...restExploded);\n  }\n  return result.map(\n    (exploded) => path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded\n  );\n}\nfunction rankRouteBranches(branches) {\n  branches.sort(\n    (a, b) => a.score !== b.score ? b.score - a.score : compareIndexes(\n      a.routesMeta.map((meta) => meta.childrenIndex),\n      b.routesMeta.map((meta) => meta.childrenIndex)\n    )\n  );\n}\nvar paramRe = /^:[\\w-]+$/;\nvar dynamicSegmentValue = 3;\nvar indexRouteValue = 2;\nvar emptySegmentValue = 1;\nvar staticSegmentValue = 10;\nvar splatPenalty = -2;\nvar isSplat = (s) => s === \"*\";\nfunction computeScore(path, index) {\n  let segments = path.split(\"/\");\n  let initialScore = segments.length;\n  if (segments.some(isSplat)) {\n    initialScore += splatPenalty;\n  }\n  if (index) {\n    initialScore += indexRouteValue;\n  }\n  return segments.filter((s) => !isSplat(s)).reduce(\n    (score, segment) => score + (paramRe.test(segment) ? dynamicSegmentValue : segment === \"\" ? emptySegmentValue : staticSegmentValue),\n    initialScore\n  );\n}\nfunction compareIndexes(a, b) {\n  let siblings = a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n  return siblings ? (\n    // If two routes are siblings, we should try to match the earlier sibling\n    // first. This allows people to have fine-grained control over the matching\n    // behavior by simply putting routes with identical paths in the order they\n    // want them tried.\n    a[a.length - 1] - b[b.length - 1]\n  ) : (\n    // Otherwise, it doesn't really make sense to rank non-siblings by index,\n    // so they sort equally.\n    0\n  );\n}\nfunction matchRouteBranch(branch, pathname, allowPartial = false) {\n  let { routesMeta } = branch;\n  let matchedParams = {};\n  let matchedPathname = \"/\";\n  let matches = [];\n  for (let i = 0; i < routesMeta.length; ++i) {\n    let meta = routesMeta[i];\n    let end = i === routesMeta.length - 1;\n    let remainingPathname = matchedPathname === \"/\" ? pathname : pathname.slice(matchedPathname.length) || \"/\";\n    let match = matchPath(\n      { path: meta.relativePath, caseSensitive: meta.caseSensitive, end },\n      remainingPathname\n    );\n    let route = meta.route;\n    if (!match && end && allowPartial && !routesMeta[routesMeta.length - 1].route.index) {\n      match = matchPath(\n        {\n          path: meta.relativePath,\n          caseSensitive: meta.caseSensitive,\n          end: false\n        },\n        remainingPathname\n      );\n    }\n    if (!match) {\n      return null;\n    }\n    Object.assign(matchedParams, match.params);\n    matches.push({\n      // TODO: Can this as be avoided?\n      params: matchedParams,\n      pathname: joinPaths([matchedPathname, match.pathname]),\n      pathnameBase: normalizePathname(\n        joinPaths([matchedPathname, match.pathnameBase])\n      ),\n      route\n    });\n    if (match.pathnameBase !== \"/\") {\n      matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n    }\n  }\n  return matches;\n}\nfunction generatePath(originalPath, params = {}) {\n  let path = originalPath;\n  if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n    warning(\n      false,\n      `Route path \"${path}\" will be treated as if it were \"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must always follow a \\`/\\` in the pattern. To get rid of this warning, please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n    );\n    path = path.replace(/\\*$/, \"/*\");\n  }\n  const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n  const stringify = (p) => p == null ? \"\" : typeof p === \"string\" ? p : String(p);\n  const segments = path.split(/\\/+/).map((segment, index, array) => {\n    const isLastSegment = index === array.length - 1;\n    if (isLastSegment && segment === \"*\") {\n      const star = \"*\";\n      return stringify(params[star]);\n    }\n    const keyMatch = segment.match(/^:([\\w-]+)(\\??)$/);\n    if (keyMatch) {\n      const [, key, optional] = keyMatch;\n      let param = params[key];\n      invariant(optional === \"?\" || param != null, `Missing \":${key}\" param`);\n      return stringify(param);\n    }\n    return segment.replace(/\\?$/g, \"\");\n  }).filter((segment) => !!segment);\n  return prefix + segments.join(\"/\");\n}\nfunction matchPath(pattern, pathname) {\n  if (typeof pattern === \"string\") {\n    pattern = { path: pattern, caseSensitive: false, end: true };\n  }\n  let [matcher, compiledParams] = compilePath(\n    pattern.path,\n    pattern.caseSensitive,\n    pattern.end\n  );\n  let match = pathname.match(matcher);\n  if (!match) return null;\n  let matchedPathname = match[0];\n  let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n  let captureGroups = match.slice(1);\n  let params = compiledParams.reduce(\n    (memo2, { paramName, isOptional }, index) => {\n      if (paramName === \"*\") {\n        let splatValue = captureGroups[index] || \"\";\n        pathnameBase = matchedPathname.slice(0, matchedPathname.length - splatValue.length).replace(/(.)\\/+$/, \"$1\");\n      }\n      const value = captureGroups[index];\n      if (isOptional && !value) {\n        memo2[paramName] = void 0;\n      } else {\n        memo2[paramName] = (value || \"\").replace(/%2F/g, \"/\");\n      }\n      return memo2;\n    },\n    {}\n  );\n  return {\n    params,\n    pathname: matchedPathname,\n    pathnameBase,\n    pattern\n  };\n}\nfunction compilePath(path, caseSensitive = false, end = true) {\n  warning(\n    path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"),\n    `Route path \"${path}\" will be treated as if it were \"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must always follow a \\`/\\` in the pattern. To get rid of this warning, please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n  );\n  let params = [];\n  let regexpSource = \"^\" + path.replace(/\\/*\\*?$/, \"\").replace(/^\\/*/, \"/\").replace(/[\\\\.*+^${}|()[\\]]/g, \"\\\\$&\").replace(\n    /\\/:([\\w-]+)(\\?)?/g,\n    (_, paramName, isOptional) => {\n      params.push({ paramName, isOptional: isOptional != null });\n      return isOptional ? \"/?([^\\\\/]+)?\" : \"/([^\\\\/]+)\";\n    }\n  );\n  if (path.endsWith(\"*\")) {\n    params.push({ paramName: \"*\" });\n    regexpSource += path === \"*\" || path === \"/*\" ? \"(.*)$\" : \"(?:\\\\/(.+)|\\\\/*)$\";\n  } else if (end) {\n    regexpSource += \"\\\\/*$\";\n  } else if (path !== \"\" && path !== \"/\") {\n    regexpSource += \"(?:(?=\\\\/|$))\";\n  } else {\n  }\n  let matcher = new RegExp(regexpSource, caseSensitive ? void 0 : \"i\");\n  return [matcher, params];\n}\nfunction decodePath(value) {\n  try {\n    return value.split(\"/\").map((v) => decodeURIComponent(v).replace(/\\//g, \"%2F\")).join(\"/\");\n  } catch (error) {\n    warning(\n      false,\n      `The URL path \"${value}\" could not be decoded because it is is a malformed URL segment. This is probably due to a bad percent encoding (${error}).`\n    );\n    return value;\n  }\n}\nfunction stripBasename(pathname, basename) {\n  if (basename === \"/\") return pathname;\n  if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n    return null;\n  }\n  let startIndex = basename.endsWith(\"/\") ? basename.length - 1 : basename.length;\n  let nextChar = pathname.charAt(startIndex);\n  if (nextChar && nextChar !== \"/\") {\n    return null;\n  }\n  return pathname.slice(startIndex) || \"/\";\n}\nfunction resolvePath(to, fromPathname = \"/\") {\n  let {\n    pathname: toPathname,\n    search = \"\",\n    hash = \"\"\n  } = typeof to === \"string\" ? parsePath(to) : to;\n  let pathname = toPathname ? toPathname.startsWith(\"/\") ? toPathname : resolvePathname(toPathname, fromPathname) : fromPathname;\n  return {\n    pathname,\n    search: normalizeSearch(search),\n    hash: normalizeHash(hash)\n  };\n}\nfunction resolvePathname(relativePath, fromPathname) {\n  let segments = fromPathname.replace(/\\/+$/, \"\").split(\"/\");\n  let relativeSegments = relativePath.split(\"/\");\n  relativeSegments.forEach((segment) => {\n    if (segment === \"..\") {\n      if (segments.length > 1) segments.pop();\n    } else if (segment !== \".\") {\n      segments.push(segment);\n    }\n  });\n  return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\nfunction getInvalidPathError(char, field, dest, path) {\n  return `Cannot include a '${char}' character in a manually specified \\`to.${field}\\` field [${JSON.stringify(\n    path\n  )}].  Please separate it out to the \\`to.${dest}\\` field. Alternatively you may provide the full path as a string in <Link to=\"...\"> and the router will parse it for you.`;\n}\nfunction getPathContributingMatches(matches) {\n  return matches.filter(\n    (match, index) => index === 0 || match.route.path && match.route.path.length > 0\n  );\n}\nfunction getResolveToMatches(matches) {\n  let pathMatches = getPathContributingMatches(matches);\n  return pathMatches.map(\n    (match, idx) => idx === pathMatches.length - 1 ? match.pathname : match.pathnameBase\n  );\n}\nfunction resolveTo(toArg, routePathnames, locationPathname, isPathRelative = false) {\n  let to;\n  if (typeof toArg === \"string\") {\n    to = parsePath(toArg);\n  } else {\n    to = { ...toArg };\n    invariant(\n      !to.pathname || !to.pathname.includes(\"?\"),\n      getInvalidPathError(\"?\", \"pathname\", \"search\", to)\n    );\n    invariant(\n      !to.pathname || !to.pathname.includes(\"#\"),\n      getInvalidPathError(\"#\", \"pathname\", \"hash\", to)\n    );\n    invariant(\n      !to.search || !to.search.includes(\"#\"),\n      getInvalidPathError(\"#\", \"search\", \"hash\", to)\n    );\n  }\n  let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n  let toPathname = isEmptyPath ? \"/\" : to.pathname;\n  let from;\n  if (toPathname == null) {\n    from = locationPathname;\n  } else {\n    let routePathnameIndex = routePathnames.length - 1;\n    if (!isPathRelative && toPathname.startsWith(\"..\")) {\n      let toSegments = toPathname.split(\"/\");\n      while (toSegments[0] === \"..\") {\n        toSegments.shift();\n        routePathnameIndex -= 1;\n      }\n      to.pathname = toSegments.join(\"/\");\n    }\n    from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n  }\n  let path = resolvePath(to, from);\n  let hasExplicitTrailingSlash = toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n  let hasCurrentTrailingSlash = (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n  if (!path.pathname.endsWith(\"/\") && (hasExplicitTrailingSlash || hasCurrentTrailingSlash)) {\n    path.pathname += \"/\";\n  }\n  return path;\n}\nvar joinPaths = (paths) => paths.join(\"/\").replace(/\\/\\/+/g, \"/\");\nvar normalizePathname = (pathname) => pathname.replace(/\\/+$/, \"\").replace(/^\\/*/, \"/\");\nvar normalizeSearch = (search) => !search || search === \"?\" ? \"\" : search.startsWith(\"?\") ? search : \"?\" + search;\nvar normalizeHash = (hash) => !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\nvar DataWithResponseInit = class {\n  constructor(data2, init) {\n    this.type = \"DataWithResponseInit\";\n    this.data = data2;\n    this.init = init || null;\n  }\n};\nfunction data(data2, init) {\n  return new DataWithResponseInit(\n    data2,\n    typeof init === \"number\" ? { status: init } : init\n  );\n}\nvar redirect = (url, init = 302) => {\n  let responseInit = init;\n  if (typeof responseInit === \"number\") {\n    responseInit = { status: responseInit };\n  } else if (typeof responseInit.status === \"undefined\") {\n    responseInit.status = 302;\n  }\n  let headers = new Headers(responseInit.headers);\n  headers.set(\"Location\", url);\n  return new Response(null, {\n    ...responseInit,\n    headers\n  });\n};\nvar redirectDocument = (url, init) => {\n  let response = redirect(url, init);\n  response.headers.set(\"X-Remix-Reload-Document\", \"true\");\n  return response;\n};\nvar replace = (url, init) => {\n  let response = redirect(url, init);\n  response.headers.set(\"X-Remix-Replace\", \"true\");\n  return response;\n};\nvar ErrorResponseImpl = class {\n  constructor(status, statusText, data2, internal = false) {\n    this.status = status;\n    this.statusText = statusText || \"\";\n    this.internal = internal;\n    if (data2 instanceof Error) {\n      this.data = data2.toString();\n      this.error = data2;\n    } else {\n      this.data = data2;\n    }\n  }\n};\nfunction isRouteErrorResponse(error) {\n  return error != null && typeof error.status === \"number\" && typeof error.statusText === \"string\" && typeof error.internal === \"boolean\" && \"data\" in error;\n}\n\n// lib/router/router.ts\nvar validMutationMethodsArr = [\n  \"POST\",\n  \"PUT\",\n  \"PATCH\",\n  \"DELETE\"\n];\nvar validMutationMethods = new Set(\n  validMutationMethodsArr\n);\nvar validRequestMethodsArr = [\n  \"GET\",\n  ...validMutationMethodsArr\n];\nvar validRequestMethods = new Set(validRequestMethodsArr);\nvar redirectStatusCodes = /* @__PURE__ */ new Set([301, 302, 303, 307, 308]);\nvar redirectPreserveMethodStatusCodes = /* @__PURE__ */ new Set([307, 308]);\nvar IDLE_NAVIGATION = {\n  state: \"idle\",\n  location: void 0,\n  formMethod: void 0,\n  formAction: void 0,\n  formEncType: void 0,\n  formData: void 0,\n  json: void 0,\n  text: void 0\n};\nvar IDLE_FETCHER = {\n  state: \"idle\",\n  data: void 0,\n  formMethod: void 0,\n  formAction: void 0,\n  formEncType: void 0,\n  formData: void 0,\n  json: void 0,\n  text: void 0\n};\nvar IDLE_BLOCKER = {\n  state: \"unblocked\",\n  proceed: void 0,\n  reset: void 0,\n  location: void 0\n};\nvar ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nvar defaultMapRouteProperties = (route) => ({\n  hasErrorBoundary: Boolean(route.hasErrorBoundary)\n});\nvar TRANSITIONS_STORAGE_KEY = \"remix-router-transitions\";\nvar ResetLoaderDataSymbol = Symbol(\"ResetLoaderData\");\nfunction createRouter(init) {\n  const routerWindow = init.window ? init.window : typeof window !== \"undefined\" ? window : void 0;\n  const isBrowser2 = typeof routerWindow !== \"undefined\" && typeof routerWindow.document !== \"undefined\" && typeof routerWindow.document.createElement !== \"undefined\";\n  invariant(\n    init.routes.length > 0,\n    \"You must provide a non-empty routes array to createRouter\"\n  );\n  let mapRouteProperties2 = init.mapRouteProperties || defaultMapRouteProperties;\n  let manifest = {};\n  let dataRoutes = convertRoutesToDataRoutes(\n    init.routes,\n    mapRouteProperties2,\n    void 0,\n    manifest\n  );\n  let inFlightDataRoutes;\n  let basename = init.basename || \"/\";\n  let dataStrategyImpl = init.dataStrategy || defaultDataStrategy;\n  let patchRoutesOnNavigationImpl = init.patchRoutesOnNavigation;\n  let future = {\n    ...init.future\n  };\n  let unlistenHistory = null;\n  let subscribers = /* @__PURE__ */ new Set();\n  let savedScrollPositions2 = null;\n  let getScrollRestorationKey2 = null;\n  let getScrollPosition = null;\n  let initialScrollRestored = init.hydrationData != null;\n  let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n  let initialErrors = null;\n  if (initialMatches == null && !patchRoutesOnNavigationImpl) {\n    let error = getInternalRouterError(404, {\n      pathname: init.history.location.pathname\n    });\n    let { matches, route } = getShortCircuitMatches(dataRoutes);\n    initialMatches = matches;\n    initialErrors = { [route.id]: error };\n  }\n  if (initialMatches && !init.hydrationData) {\n    let fogOfWar = checkFogOfWar(\n      initialMatches,\n      dataRoutes,\n      init.history.location.pathname\n    );\n    if (fogOfWar.active) {\n      initialMatches = null;\n    }\n  }\n  let initialized;\n  if (!initialMatches) {\n    initialized = false;\n    initialMatches = [];\n    let fogOfWar = checkFogOfWar(\n      null,\n      dataRoutes,\n      init.history.location.pathname\n    );\n    if (fogOfWar.active && fogOfWar.matches) {\n      initialMatches = fogOfWar.matches;\n    }\n  } else if (initialMatches.some((m) => m.route.lazy)) {\n    initialized = false;\n  } else if (!initialMatches.some((m) => m.route.loader)) {\n    initialized = true;\n  } else {\n    let loaderData = init.hydrationData ? init.hydrationData.loaderData : null;\n    let errors = init.hydrationData ? init.hydrationData.errors : null;\n    if (errors) {\n      let idx = initialMatches.findIndex(\n        (m) => errors[m.route.id] !== void 0\n      );\n      initialized = initialMatches.slice(0, idx + 1).every((m) => !shouldLoadRouteOnHydration(m.route, loaderData, errors));\n    } else {\n      initialized = initialMatches.every(\n        (m) => !shouldLoadRouteOnHydration(m.route, loaderData, errors)\n      );\n    }\n  }\n  let router;\n  let state = {\n    historyAction: init.history.action,\n    location: init.history.location,\n    matches: initialMatches,\n    initialized,\n    navigation: IDLE_NAVIGATION,\n    // Don't restore on initial updateState() if we were SSR'd\n    restoreScrollPosition: init.hydrationData != null ? false : null,\n    preventScrollReset: false,\n    revalidation: \"idle\",\n    loaderData: init.hydrationData && init.hydrationData.loaderData || {},\n    actionData: init.hydrationData && init.hydrationData.actionData || null,\n    errors: init.hydrationData && init.hydrationData.errors || initialErrors,\n    fetchers: /* @__PURE__ */ new Map(),\n    blockers: /* @__PURE__ */ new Map()\n  };\n  let pendingAction = \"POP\" /* Pop */;\n  let pendingPreventScrollReset = false;\n  let pendingNavigationController;\n  let pendingViewTransitionEnabled = false;\n  let appliedViewTransitions = /* @__PURE__ */ new Map();\n  let removePageHideEventListener = null;\n  let isUninterruptedRevalidation = false;\n  let isRevalidationRequired = false;\n  let cancelledFetcherLoads = /* @__PURE__ */ new Set();\n  let fetchControllers = /* @__PURE__ */ new Map();\n  let incrementingLoadId = 0;\n  let pendingNavigationLoadId = -1;\n  let fetchReloadIds = /* @__PURE__ */ new Map();\n  let fetchRedirectIds = /* @__PURE__ */ new Set();\n  let fetchLoadMatches = /* @__PURE__ */ new Map();\n  let activeFetchers = /* @__PURE__ */ new Map();\n  let fetchersQueuedForDeletion = /* @__PURE__ */ new Set();\n  let blockerFunctions = /* @__PURE__ */ new Map();\n  let unblockBlockerHistoryUpdate = void 0;\n  let pendingRevalidationDfd = null;\n  function initialize() {\n    unlistenHistory = init.history.listen(\n      ({ action: historyAction, location, delta }) => {\n        if (unblockBlockerHistoryUpdate) {\n          unblockBlockerHistoryUpdate();\n          unblockBlockerHistoryUpdate = void 0;\n          return;\n        }\n        warning(\n          blockerFunctions.size === 0 || delta != null,\n          \"You are trying to use a blocker on a POP navigation to a location that was not created by @remix-run/router. This will fail silently in production. This can happen if you are navigating outside the router via `window.history.pushState`/`window.location.hash` instead of using router navigation APIs.  This can also happen if you are using createHashRouter and the user manually changes the URL.\"\n        );\n        let blockerKey = shouldBlockNavigation({\n          currentLocation: state.location,\n          nextLocation: location,\n          historyAction\n        });\n        if (blockerKey && delta != null) {\n          let nextHistoryUpdatePromise = new Promise((resolve) => {\n            unblockBlockerHistoryUpdate = resolve;\n          });\n          init.history.go(delta * -1);\n          updateBlocker(blockerKey, {\n            state: \"blocked\",\n            location,\n            proceed() {\n              updateBlocker(blockerKey, {\n                state: \"proceeding\",\n                proceed: void 0,\n                reset: void 0,\n                location\n              });\n              nextHistoryUpdatePromise.then(() => init.history.go(delta));\n            },\n            reset() {\n              let blockers = new Map(state.blockers);\n              blockers.set(blockerKey, IDLE_BLOCKER);\n              updateState({ blockers });\n            }\n          });\n          return;\n        }\n        return startNavigation(historyAction, location);\n      }\n    );\n    if (isBrowser2) {\n      restoreAppliedTransitions(routerWindow, appliedViewTransitions);\n      let _saveAppliedTransitions = () => persistAppliedTransitions(routerWindow, appliedViewTransitions);\n      routerWindow.addEventListener(\"pagehide\", _saveAppliedTransitions);\n      removePageHideEventListener = () => routerWindow.removeEventListener(\"pagehide\", _saveAppliedTransitions);\n    }\n    if (!state.initialized) {\n      startNavigation(\"POP\" /* Pop */, state.location, {\n        initialHydration: true\n      });\n    }\n    return router;\n  }\n  function dispose() {\n    if (unlistenHistory) {\n      unlistenHistory();\n    }\n    if (removePageHideEventListener) {\n      removePageHideEventListener();\n    }\n    subscribers.clear();\n    pendingNavigationController && pendingNavigationController.abort();\n    state.fetchers.forEach((_, key) => deleteFetcher(key));\n    state.blockers.forEach((_, key) => deleteBlocker(key));\n  }\n  function subscribe(fn) {\n    subscribers.add(fn);\n    return () => subscribers.delete(fn);\n  }\n  function updateState(newState, opts = {}) {\n    state = {\n      ...state,\n      ...newState\n    };\n    let unmountedFetchers = [];\n    let mountedFetchers = [];\n    state.fetchers.forEach((fetcher, key) => {\n      if (fetcher.state === \"idle\") {\n        if (fetchersQueuedForDeletion.has(key)) {\n          unmountedFetchers.push(key);\n        } else {\n          mountedFetchers.push(key);\n        }\n      }\n    });\n    [...subscribers].forEach(\n      (subscriber) => subscriber(state, {\n        deletedFetchers: unmountedFetchers,\n        viewTransitionOpts: opts.viewTransitionOpts,\n        flushSync: opts.flushSync === true\n      })\n    );\n    unmountedFetchers.forEach((key) => deleteFetcher(key));\n    mountedFetchers.forEach((key) => state.fetchers.delete(key));\n  }\n  function completeNavigation(location, newState, { flushSync } = {}) {\n    let isActionReload = state.actionData != null && state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && state.navigation.state === \"loading\" && location.state?._isRedirect !== true;\n    let actionData;\n    if (newState.actionData) {\n      if (Object.keys(newState.actionData).length > 0) {\n        actionData = newState.actionData;\n      } else {\n        actionData = null;\n      }\n    } else if (isActionReload) {\n      actionData = state.actionData;\n    } else {\n      actionData = null;\n    }\n    let loaderData = newState.loaderData ? mergeLoaderData(\n      state.loaderData,\n      newState.loaderData,\n      newState.matches || [],\n      newState.errors\n    ) : state.loaderData;\n    let blockers = state.blockers;\n    if (blockers.size > 0) {\n      blockers = new Map(blockers);\n      blockers.forEach((_, k) => blockers.set(k, IDLE_BLOCKER));\n    }\n    let preventScrollReset = pendingPreventScrollReset === true || state.navigation.formMethod != null && isMutationMethod(state.navigation.formMethod) && location.state?._isRedirect !== true;\n    if (inFlightDataRoutes) {\n      dataRoutes = inFlightDataRoutes;\n      inFlightDataRoutes = void 0;\n    }\n    if (isUninterruptedRevalidation) {\n    } else if (pendingAction === \"POP\" /* Pop */) {\n    } else if (pendingAction === \"PUSH\" /* Push */) {\n      init.history.push(location, location.state);\n    } else if (pendingAction === \"REPLACE\" /* Replace */) {\n      init.history.replace(location, location.state);\n    }\n    let viewTransitionOpts;\n    if (pendingAction === \"POP\" /* Pop */) {\n      let priorPaths = appliedViewTransitions.get(state.location.pathname);\n      if (priorPaths && priorPaths.has(location.pathname)) {\n        viewTransitionOpts = {\n          currentLocation: state.location,\n          nextLocation: location\n        };\n      } else if (appliedViewTransitions.has(location.pathname)) {\n        viewTransitionOpts = {\n          currentLocation: location,\n          nextLocation: state.location\n        };\n      }\n    } else if (pendingViewTransitionEnabled) {\n      let toPaths = appliedViewTransitions.get(state.location.pathname);\n      if (toPaths) {\n        toPaths.add(location.pathname);\n      } else {\n        toPaths = /* @__PURE__ */ new Set([location.pathname]);\n        appliedViewTransitions.set(state.location.pathname, toPaths);\n      }\n      viewTransitionOpts = {\n        currentLocation: state.location,\n        nextLocation: location\n      };\n    }\n    updateState(\n      {\n        ...newState,\n        // matches, errors, fetchers go through as-is\n        actionData,\n        loaderData,\n        historyAction: pendingAction,\n        location,\n        initialized: true,\n        navigation: IDLE_NAVIGATION,\n        revalidation: \"idle\",\n        restoreScrollPosition: getSavedScrollPosition(\n          location,\n          newState.matches || state.matches\n        ),\n        preventScrollReset,\n        blockers\n      },\n      {\n        viewTransitionOpts,\n        flushSync: flushSync === true\n      }\n    );\n    pendingAction = \"POP\" /* Pop */;\n    pendingPreventScrollReset = false;\n    pendingViewTransitionEnabled = false;\n    isUninterruptedRevalidation = false;\n    isRevalidationRequired = false;\n    pendingRevalidationDfd?.resolve();\n    pendingRevalidationDfd = null;\n  }\n  async function navigate(to, opts) {\n    if (typeof to === \"number\") {\n      init.history.go(to);\n      return;\n    }\n    let normalizedPath = normalizeTo(\n      state.location,\n      state.matches,\n      basename,\n      to,\n      opts?.fromRouteId,\n      opts?.relative\n    );\n    let { path, submission, error } = normalizeNavigateOptions(\n      false,\n      normalizedPath,\n      opts\n    );\n    let currentLocation = state.location;\n    let nextLocation = createLocation(state.location, path, opts && opts.state);\n    nextLocation = {\n      ...nextLocation,\n      ...init.history.encodeLocation(nextLocation)\n    };\n    let userReplace = opts && opts.replace != null ? opts.replace : void 0;\n    let historyAction = \"PUSH\" /* Push */;\n    if (userReplace === true) {\n      historyAction = \"REPLACE\" /* Replace */;\n    } else if (userReplace === false) {\n    } else if (submission != null && isMutationMethod(submission.formMethod) && submission.formAction === state.location.pathname + state.location.search) {\n      historyAction = \"REPLACE\" /* Replace */;\n    }\n    let preventScrollReset = opts && \"preventScrollReset\" in opts ? opts.preventScrollReset === true : void 0;\n    let flushSync = (opts && opts.flushSync) === true;\n    let blockerKey = shouldBlockNavigation({\n      currentLocation,\n      nextLocation,\n      historyAction\n    });\n    if (blockerKey) {\n      updateBlocker(blockerKey, {\n        state: \"blocked\",\n        location: nextLocation,\n        proceed() {\n          updateBlocker(blockerKey, {\n            state: \"proceeding\",\n            proceed: void 0,\n            reset: void 0,\n            location: nextLocation\n          });\n          navigate(to, opts);\n        },\n        reset() {\n          let blockers = new Map(state.blockers);\n          blockers.set(blockerKey, IDLE_BLOCKER);\n          updateState({ blockers });\n        }\n      });\n      return;\n    }\n    await startNavigation(historyAction, nextLocation, {\n      submission,\n      // Send through the formData serialization error if we have one so we can\n      // render at the right error boundary after we match routes\n      pendingError: error,\n      preventScrollReset,\n      replace: opts && opts.replace,\n      enableViewTransition: opts && opts.viewTransition,\n      flushSync\n    });\n  }\n  function revalidate() {\n    if (!pendingRevalidationDfd) {\n      pendingRevalidationDfd = createDeferred();\n    }\n    interruptActiveLoads();\n    updateState({ revalidation: \"loading\" });\n    let promise = pendingRevalidationDfd.promise;\n    if (state.navigation.state === \"submitting\") {\n      return promise;\n    }\n    if (state.navigation.state === \"idle\") {\n      startNavigation(state.historyAction, state.location, {\n        startUninterruptedRevalidation: true\n      });\n      return promise;\n    }\n    startNavigation(\n      pendingAction || state.historyAction,\n      state.navigation.location,\n      {\n        overrideNavigation: state.navigation,\n        // Proxy through any rending view transition\n        enableViewTransition: pendingViewTransitionEnabled === true\n      }\n    );\n    return promise;\n  }\n  async function startNavigation(historyAction, location, opts) {\n    pendingNavigationController && pendingNavigationController.abort();\n    pendingNavigationController = null;\n    pendingAction = historyAction;\n    isUninterruptedRevalidation = (opts && opts.startUninterruptedRevalidation) === true;\n    saveScrollPosition(state.location, state.matches);\n    pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n    pendingViewTransitionEnabled = (opts && opts.enableViewTransition) === true;\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    let loadingNavigation = opts && opts.overrideNavigation;\n    let matches = matchRoutes(routesToUse, location, basename);\n    let flushSync = (opts && opts.flushSync) === true;\n    let fogOfWar = checkFogOfWar(matches, routesToUse, location.pathname);\n    if (fogOfWar.active && fogOfWar.matches) {\n      matches = fogOfWar.matches;\n    }\n    if (!matches) {\n      let { error, notFoundMatches, route } = handleNavigational404(\n        location.pathname\n      );\n      completeNavigation(\n        location,\n        {\n          matches: notFoundMatches,\n          loaderData: {},\n          errors: {\n            [route.id]: error\n          }\n        },\n        { flushSync }\n      );\n      return;\n    }\n    if (state.initialized && !isRevalidationRequired && isHashChangeOnly(state.location, location) && !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))) {\n      completeNavigation(location, { matches }, { flushSync });\n      return;\n    }\n    pendingNavigationController = new AbortController();\n    let request = createClientSideRequest(\n      init.history,\n      location,\n      pendingNavigationController.signal,\n      opts && opts.submission\n    );\n    let pendingActionResult;\n    if (opts && opts.pendingError) {\n      pendingActionResult = [\n        findNearestBoundary(matches).route.id,\n        { type: \"error\" /* error */, error: opts.pendingError }\n      ];\n    } else if (opts && opts.submission && isMutationMethod(opts.submission.formMethod)) {\n      let actionResult = await handleAction(\n        request,\n        location,\n        opts.submission,\n        matches,\n        fogOfWar.active,\n        { replace: opts.replace, flushSync }\n      );\n      if (actionResult.shortCircuited) {\n        return;\n      }\n      if (actionResult.pendingActionResult) {\n        let [routeId, result] = actionResult.pendingActionResult;\n        if (isErrorResult(result) && isRouteErrorResponse(result.error) && result.error.status === 404) {\n          pendingNavigationController = null;\n          completeNavigation(location, {\n            matches: actionResult.matches,\n            loaderData: {},\n            errors: {\n              [routeId]: result.error\n            }\n          });\n          return;\n        }\n      }\n      matches = actionResult.matches || matches;\n      pendingActionResult = actionResult.pendingActionResult;\n      loadingNavigation = getLoadingNavigation(location, opts.submission);\n      flushSync = false;\n      fogOfWar.active = false;\n      request = createClientSideRequest(\n        init.history,\n        request.url,\n        request.signal\n      );\n    }\n    let {\n      shortCircuited,\n      matches: updatedMatches,\n      loaderData,\n      errors\n    } = await handleLoaders(\n      request,\n      location,\n      matches,\n      fogOfWar.active,\n      loadingNavigation,\n      opts && opts.submission,\n      opts && opts.fetcherSubmission,\n      opts && opts.replace,\n      opts && opts.initialHydration === true,\n      flushSync,\n      pendingActionResult\n    );\n    if (shortCircuited) {\n      return;\n    }\n    pendingNavigationController = null;\n    completeNavigation(location, {\n      matches: updatedMatches || matches,\n      ...getActionDataForCommit(pendingActionResult),\n      loaderData,\n      errors\n    });\n  }\n  async function handleAction(request, location, submission, matches, isFogOfWar, opts = {}) {\n    interruptActiveLoads();\n    let navigation = getSubmittingNavigation(location, submission);\n    updateState({ navigation }, { flushSync: opts.flushSync === true });\n    if (isFogOfWar) {\n      let discoverResult = await discoverRoutes(\n        matches,\n        location.pathname,\n        request.signal\n      );\n      if (discoverResult.type === \"aborted\") {\n        return { shortCircuited: true };\n      } else if (discoverResult.type === \"error\") {\n        let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n        return {\n          matches: discoverResult.partialMatches,\n          pendingActionResult: [\n            boundaryId,\n            {\n              type: \"error\" /* error */,\n              error: discoverResult.error\n            }\n          ]\n        };\n      } else if (!discoverResult.matches) {\n        let { notFoundMatches, error, route } = handleNavigational404(\n          location.pathname\n        );\n        return {\n          matches: notFoundMatches,\n          pendingActionResult: [\n            route.id,\n            {\n              type: \"error\" /* error */,\n              error\n            }\n          ]\n        };\n      } else {\n        matches = discoverResult.matches;\n      }\n    }\n    let result;\n    let actionMatch = getTargetMatch(matches, location);\n    if (!actionMatch.route.action && !actionMatch.route.lazy) {\n      result = {\n        type: \"error\" /* error */,\n        error: getInternalRouterError(405, {\n          method: request.method,\n          pathname: location.pathname,\n          routeId: actionMatch.route.id\n        })\n      };\n    } else {\n      let results = await callDataStrategy(\n        \"action\",\n        state,\n        request,\n        [actionMatch],\n        matches,\n        null\n      );\n      result = results[actionMatch.route.id];\n      if (request.signal.aborted) {\n        return { shortCircuited: true };\n      }\n    }\n    if (isRedirectResult(result)) {\n      let replace2;\n      if (opts && opts.replace != null) {\n        replace2 = opts.replace;\n      } else {\n        let location2 = normalizeRedirectLocation(\n          result.response.headers.get(\"Location\"),\n          new URL(request.url),\n          basename\n        );\n        replace2 = location2 === state.location.pathname + state.location.search;\n      }\n      await startRedirectNavigation(request, result, true, {\n        submission,\n        replace: replace2\n      });\n      return { shortCircuited: true };\n    }\n    if (isErrorResult(result)) {\n      let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n      if ((opts && opts.replace) !== true) {\n        pendingAction = \"PUSH\" /* Push */;\n      }\n      return {\n        matches,\n        pendingActionResult: [boundaryMatch.route.id, result]\n      };\n    }\n    return {\n      matches,\n      pendingActionResult: [actionMatch.route.id, result]\n    };\n  }\n  async function handleLoaders(request, location, matches, isFogOfWar, overrideNavigation, submission, fetcherSubmission, replace2, initialHydration, flushSync, pendingActionResult) {\n    let loadingNavigation = overrideNavigation || getLoadingNavigation(location, submission);\n    let activeSubmission = submission || fetcherSubmission || getSubmissionFromNavigation(loadingNavigation);\n    let shouldUpdateNavigationState = !isUninterruptedRevalidation && !initialHydration;\n    if (isFogOfWar) {\n      if (shouldUpdateNavigationState) {\n        let actionData = getUpdatedActionData(pendingActionResult);\n        updateState(\n          {\n            navigation: loadingNavigation,\n            ...actionData !== void 0 ? { actionData } : {}\n          },\n          {\n            flushSync\n          }\n        );\n      }\n      let discoverResult = await discoverRoutes(\n        matches,\n        location.pathname,\n        request.signal\n      );\n      if (discoverResult.type === \"aborted\") {\n        return { shortCircuited: true };\n      } else if (discoverResult.type === \"error\") {\n        let boundaryId = findNearestBoundary(discoverResult.partialMatches).route.id;\n        return {\n          matches: discoverResult.partialMatches,\n          loaderData: {},\n          errors: {\n            [boundaryId]: discoverResult.error\n          }\n        };\n      } else if (!discoverResult.matches) {\n        let { error, notFoundMatches, route } = handleNavigational404(\n          location.pathname\n        );\n        return {\n          matches: notFoundMatches,\n          loaderData: {},\n          errors: {\n            [route.id]: error\n          }\n        };\n      } else {\n        matches = discoverResult.matches;\n      }\n    }\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n      init.history,\n      state,\n      matches,\n      activeSubmission,\n      location,\n      initialHydration === true,\n      isRevalidationRequired,\n      cancelledFetcherLoads,\n      fetchersQueuedForDeletion,\n      fetchLoadMatches,\n      fetchRedirectIds,\n      routesToUse,\n      basename,\n      pendingActionResult\n    );\n    pendingNavigationLoadId = ++incrementingLoadId;\n    if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n      let updatedFetchers2 = markFetchRedirectsDone();\n      completeNavigation(\n        location,\n        {\n          matches,\n          loaderData: {},\n          // Commit pending error if we're short circuiting\n          errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? { [pendingActionResult[0]]: pendingActionResult[1].error } : null,\n          ...getActionDataForCommit(pendingActionResult),\n          ...updatedFetchers2 ? { fetchers: new Map(state.fetchers) } : {}\n        },\n        { flushSync }\n      );\n      return { shortCircuited: true };\n    }\n    if (shouldUpdateNavigationState) {\n      let updates = {};\n      if (!isFogOfWar) {\n        updates.navigation = loadingNavigation;\n        let actionData = getUpdatedActionData(pendingActionResult);\n        if (actionData !== void 0) {\n          updates.actionData = actionData;\n        }\n      }\n      if (revalidatingFetchers.length > 0) {\n        updates.fetchers = getUpdatedRevalidatingFetchers(revalidatingFetchers);\n      }\n      updateState(updates, { flushSync });\n    }\n    revalidatingFetchers.forEach((rf) => {\n      abortFetcher(rf.key);\n      if (rf.controller) {\n        fetchControllers.set(rf.key, rf.controller);\n      }\n    });\n    let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach((f) => abortFetcher(f.key));\n    if (pendingNavigationController) {\n      pendingNavigationController.signal.addEventListener(\n        \"abort\",\n        abortPendingFetchRevalidations\n      );\n    }\n    let { loaderResults, fetcherResults } = await callLoadersAndMaybeResolveData(\n      state,\n      matches,\n      matchesToLoad,\n      revalidatingFetchers,\n      request\n    );\n    if (request.signal.aborted) {\n      return { shortCircuited: true };\n    }\n    if (pendingNavigationController) {\n      pendingNavigationController.signal.removeEventListener(\n        \"abort\",\n        abortPendingFetchRevalidations\n      );\n    }\n    revalidatingFetchers.forEach((rf) => fetchControllers.delete(rf.key));\n    let redirect2 = findRedirect(loaderResults);\n    if (redirect2) {\n      await startRedirectNavigation(request, redirect2.result, true, {\n        replace: replace2\n      });\n      return { shortCircuited: true };\n    }\n    redirect2 = findRedirect(fetcherResults);\n    if (redirect2) {\n      fetchRedirectIds.add(redirect2.key);\n      await startRedirectNavigation(request, redirect2.result, true, {\n        replace: replace2\n      });\n      return { shortCircuited: true };\n    }\n    let { loaderData, errors } = processLoaderData(\n      state,\n      matches,\n      loaderResults,\n      pendingActionResult,\n      revalidatingFetchers,\n      fetcherResults\n    );\n    if (initialHydration && state.errors) {\n      errors = { ...state.errors, ...errors };\n    }\n    let updatedFetchers = markFetchRedirectsDone();\n    let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n    let shouldUpdateFetchers = updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n    return {\n      matches,\n      loaderData,\n      errors,\n      ...shouldUpdateFetchers ? { fetchers: new Map(state.fetchers) } : {}\n    };\n  }\n  function getUpdatedActionData(pendingActionResult) {\n    if (pendingActionResult && !isErrorResult(pendingActionResult[1])) {\n      return {\n        [pendingActionResult[0]]: pendingActionResult[1].data\n      };\n    } else if (state.actionData) {\n      if (Object.keys(state.actionData).length === 0) {\n        return null;\n      } else {\n        return state.actionData;\n      }\n    }\n  }\n  function getUpdatedRevalidatingFetchers(revalidatingFetchers) {\n    revalidatingFetchers.forEach((rf) => {\n      let fetcher = state.fetchers.get(rf.key);\n      let revalidatingFetcher = getLoadingFetcher(\n        void 0,\n        fetcher ? fetcher.data : void 0\n      );\n      state.fetchers.set(rf.key, revalidatingFetcher);\n    });\n    return new Map(state.fetchers);\n  }\n  async function fetch2(key, routeId, href, opts) {\n    abortFetcher(key);\n    let flushSync = (opts && opts.flushSync) === true;\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    let normalizedPath = normalizeTo(\n      state.location,\n      state.matches,\n      basename,\n      href,\n      routeId,\n      opts?.relative\n    );\n    let matches = matchRoutes(routesToUse, normalizedPath, basename);\n    let fogOfWar = checkFogOfWar(matches, routesToUse, normalizedPath);\n    if (fogOfWar.active && fogOfWar.matches) {\n      matches = fogOfWar.matches;\n    }\n    if (!matches) {\n      setFetcherError(\n        key,\n        routeId,\n        getInternalRouterError(404, { pathname: normalizedPath }),\n        { flushSync }\n      );\n      return;\n    }\n    let { path, submission, error } = normalizeNavigateOptions(\n      true,\n      normalizedPath,\n      opts\n    );\n    if (error) {\n      setFetcherError(key, routeId, error, { flushSync });\n      return;\n    }\n    let match = getTargetMatch(matches, path);\n    let preventScrollReset = (opts && opts.preventScrollReset) === true;\n    if (submission && isMutationMethod(submission.formMethod)) {\n      await handleFetcherAction(\n        key,\n        routeId,\n        path,\n        match,\n        matches,\n        fogOfWar.active,\n        flushSync,\n        preventScrollReset,\n        submission\n      );\n      return;\n    }\n    fetchLoadMatches.set(key, { routeId, path });\n    await handleFetcherLoader(\n      key,\n      routeId,\n      path,\n      match,\n      matches,\n      fogOfWar.active,\n      flushSync,\n      preventScrollReset,\n      submission\n    );\n  }\n  async function handleFetcherAction(key, routeId, path, match, requestMatches, isFogOfWar, flushSync, preventScrollReset, submission) {\n    interruptActiveLoads();\n    fetchLoadMatches.delete(key);\n    function detectAndHandle405Error(m) {\n      if (!m.route.action && !m.route.lazy) {\n        let error = getInternalRouterError(405, {\n          method: submission.formMethod,\n          pathname: path,\n          routeId\n        });\n        setFetcherError(key, routeId, error, { flushSync });\n        return true;\n      }\n      return false;\n    }\n    if (!isFogOfWar && detectAndHandle405Error(match)) {\n      return;\n    }\n    let existingFetcher = state.fetchers.get(key);\n    updateFetcherState(key, getSubmittingFetcher(submission, existingFetcher), {\n      flushSync\n    });\n    let abortController = new AbortController();\n    let fetchRequest = createClientSideRequest(\n      init.history,\n      path,\n      abortController.signal,\n      submission\n    );\n    if (isFogOfWar) {\n      let discoverResult = await discoverRoutes(\n        requestMatches,\n        path,\n        fetchRequest.signal\n      );\n      if (discoverResult.type === \"aborted\") {\n        return;\n      } else if (discoverResult.type === \"error\") {\n        setFetcherError(key, routeId, discoverResult.error, { flushSync });\n        return;\n      } else if (!discoverResult.matches) {\n        setFetcherError(\n          key,\n          routeId,\n          getInternalRouterError(404, { pathname: path }),\n          { flushSync }\n        );\n        return;\n      } else {\n        requestMatches = discoverResult.matches;\n        match = getTargetMatch(requestMatches, path);\n        if (detectAndHandle405Error(match)) {\n          return;\n        }\n      }\n    }\n    fetchControllers.set(key, abortController);\n    let originatingLoadId = incrementingLoadId;\n    let actionResults = await callDataStrategy(\n      \"action\",\n      state,\n      fetchRequest,\n      [match],\n      requestMatches,\n      key\n    );\n    let actionResult = actionResults[match.route.id];\n    if (fetchRequest.signal.aborted) {\n      if (fetchControllers.get(key) === abortController) {\n        fetchControllers.delete(key);\n      }\n      return;\n    }\n    if (fetchersQueuedForDeletion.has(key)) {\n      if (isRedirectResult(actionResult) || isErrorResult(actionResult)) {\n        updateFetcherState(key, getDoneFetcher(void 0));\n        return;\n      }\n    } else {\n      if (isRedirectResult(actionResult)) {\n        fetchControllers.delete(key);\n        if (pendingNavigationLoadId > originatingLoadId) {\n          updateFetcherState(key, getDoneFetcher(void 0));\n          return;\n        } else {\n          fetchRedirectIds.add(key);\n          updateFetcherState(key, getLoadingFetcher(submission));\n          return startRedirectNavigation(fetchRequest, actionResult, false, {\n            fetcherSubmission: submission,\n            preventScrollReset\n          });\n        }\n      }\n      if (isErrorResult(actionResult)) {\n        setFetcherError(key, routeId, actionResult.error);\n        return;\n      }\n    }\n    let nextLocation = state.navigation.location || state.location;\n    let revalidationRequest = createClientSideRequest(\n      init.history,\n      nextLocation,\n      abortController.signal\n    );\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    let matches = state.navigation.state !== \"idle\" ? matchRoutes(routesToUse, state.navigation.location, basename) : state.matches;\n    invariant(matches, \"Didn't find any matches after fetcher action\");\n    let loadId = ++incrementingLoadId;\n    fetchReloadIds.set(key, loadId);\n    let loadFetcher = getLoadingFetcher(submission, actionResult.data);\n    state.fetchers.set(key, loadFetcher);\n    let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n      init.history,\n      state,\n      matches,\n      submission,\n      nextLocation,\n      false,\n      isRevalidationRequired,\n      cancelledFetcherLoads,\n      fetchersQueuedForDeletion,\n      fetchLoadMatches,\n      fetchRedirectIds,\n      routesToUse,\n      basename,\n      [match.route.id, actionResult]\n    );\n    revalidatingFetchers.filter((rf) => rf.key !== key).forEach((rf) => {\n      let staleKey = rf.key;\n      let existingFetcher2 = state.fetchers.get(staleKey);\n      let revalidatingFetcher = getLoadingFetcher(\n        void 0,\n        existingFetcher2 ? existingFetcher2.data : void 0\n      );\n      state.fetchers.set(staleKey, revalidatingFetcher);\n      abortFetcher(staleKey);\n      if (rf.controller) {\n        fetchControllers.set(staleKey, rf.controller);\n      }\n    });\n    updateState({ fetchers: new Map(state.fetchers) });\n    let abortPendingFetchRevalidations = () => revalidatingFetchers.forEach((rf) => abortFetcher(rf.key));\n    abortController.signal.addEventListener(\n      \"abort\",\n      abortPendingFetchRevalidations\n    );\n    let { loaderResults, fetcherResults } = await callLoadersAndMaybeResolveData(\n      state,\n      matches,\n      matchesToLoad,\n      revalidatingFetchers,\n      revalidationRequest\n    );\n    if (abortController.signal.aborted) {\n      return;\n    }\n    abortController.signal.removeEventListener(\n      \"abort\",\n      abortPendingFetchRevalidations\n    );\n    fetchReloadIds.delete(key);\n    fetchControllers.delete(key);\n    revalidatingFetchers.forEach((r) => fetchControllers.delete(r.key));\n    let redirect2 = findRedirect(loaderResults);\n    if (redirect2) {\n      return startRedirectNavigation(\n        revalidationRequest,\n        redirect2.result,\n        false,\n        { preventScrollReset }\n      );\n    }\n    redirect2 = findRedirect(fetcherResults);\n    if (redirect2) {\n      fetchRedirectIds.add(redirect2.key);\n      return startRedirectNavigation(\n        revalidationRequest,\n        redirect2.result,\n        false,\n        { preventScrollReset }\n      );\n    }\n    let { loaderData, errors } = processLoaderData(\n      state,\n      matches,\n      loaderResults,\n      void 0,\n      revalidatingFetchers,\n      fetcherResults\n    );\n    if (state.fetchers.has(key)) {\n      let doneFetcher = getDoneFetcher(actionResult.data);\n      state.fetchers.set(key, doneFetcher);\n    }\n    abortStaleFetchLoads(loadId);\n    if (state.navigation.state === \"loading\" && loadId > pendingNavigationLoadId) {\n      invariant(pendingAction, \"Expected pending action\");\n      pendingNavigationController && pendingNavigationController.abort();\n      completeNavigation(state.navigation.location, {\n        matches,\n        loaderData,\n        errors,\n        fetchers: new Map(state.fetchers)\n      });\n    } else {\n      updateState({\n        errors,\n        loaderData: mergeLoaderData(\n          state.loaderData,\n          loaderData,\n          matches,\n          errors\n        ),\n        fetchers: new Map(state.fetchers)\n      });\n      isRevalidationRequired = false;\n    }\n  }\n  async function handleFetcherLoader(key, routeId, path, match, matches, isFogOfWar, flushSync, preventScrollReset, submission) {\n    let existingFetcher = state.fetchers.get(key);\n    updateFetcherState(\n      key,\n      getLoadingFetcher(\n        submission,\n        existingFetcher ? existingFetcher.data : void 0\n      ),\n      { flushSync }\n    );\n    let abortController = new AbortController();\n    let fetchRequest = createClientSideRequest(\n      init.history,\n      path,\n      abortController.signal\n    );\n    if (isFogOfWar) {\n      let discoverResult = await discoverRoutes(\n        matches,\n        path,\n        fetchRequest.signal\n      );\n      if (discoverResult.type === \"aborted\") {\n        return;\n      } else if (discoverResult.type === \"error\") {\n        setFetcherError(key, routeId, discoverResult.error, { flushSync });\n        return;\n      } else if (!discoverResult.matches) {\n        setFetcherError(\n          key,\n          routeId,\n          getInternalRouterError(404, { pathname: path }),\n          { flushSync }\n        );\n        return;\n      } else {\n        matches = discoverResult.matches;\n        match = getTargetMatch(matches, path);\n      }\n    }\n    fetchControllers.set(key, abortController);\n    let originatingLoadId = incrementingLoadId;\n    let results = await callDataStrategy(\n      \"loader\",\n      state,\n      fetchRequest,\n      [match],\n      matches,\n      key\n    );\n    let result = results[match.route.id];\n    if (fetchControllers.get(key) === abortController) {\n      fetchControllers.delete(key);\n    }\n    if (fetchRequest.signal.aborted) {\n      return;\n    }\n    if (fetchersQueuedForDeletion.has(key)) {\n      updateFetcherState(key, getDoneFetcher(void 0));\n      return;\n    }\n    if (isRedirectResult(result)) {\n      if (pendingNavigationLoadId > originatingLoadId) {\n        updateFetcherState(key, getDoneFetcher(void 0));\n        return;\n      } else {\n        fetchRedirectIds.add(key);\n        await startRedirectNavigation(fetchRequest, result, false, {\n          preventScrollReset\n        });\n        return;\n      }\n    }\n    if (isErrorResult(result)) {\n      setFetcherError(key, routeId, result.error);\n      return;\n    }\n    updateFetcherState(key, getDoneFetcher(result.data));\n  }\n  async function startRedirectNavigation(request, redirect2, isNavigation, {\n    submission,\n    fetcherSubmission,\n    preventScrollReset,\n    replace: replace2\n  } = {}) {\n    if (redirect2.response.headers.has(\"X-Remix-Revalidate\")) {\n      isRevalidationRequired = true;\n    }\n    let location = redirect2.response.headers.get(\"Location\");\n    invariant(location, \"Expected a Location header on the redirect Response\");\n    location = normalizeRedirectLocation(\n      location,\n      new URL(request.url),\n      basename\n    );\n    let redirectLocation = createLocation(state.location, location, {\n      _isRedirect: true\n    });\n    if (isBrowser2) {\n      let isDocumentReload = false;\n      if (redirect2.response.headers.has(\"X-Remix-Reload-Document\")) {\n        isDocumentReload = true;\n      } else if (ABSOLUTE_URL_REGEX.test(location)) {\n        const url = init.history.createURL(location);\n        isDocumentReload = // Hard reload if it's an absolute URL to a new origin\n        url.origin !== routerWindow.location.origin || // Hard reload if it's an absolute URL that does not match our basename\n        stripBasename(url.pathname, basename) == null;\n      }\n      if (isDocumentReload) {\n        if (replace2) {\n          routerWindow.location.replace(location);\n        } else {\n          routerWindow.location.assign(location);\n        }\n        return;\n      }\n    }\n    pendingNavigationController = null;\n    let redirectNavigationType = replace2 === true || redirect2.response.headers.has(\"X-Remix-Replace\") ? \"REPLACE\" /* Replace */ : \"PUSH\" /* Push */;\n    let { formMethod, formAction, formEncType } = state.navigation;\n    if (!submission && !fetcherSubmission && formMethod && formAction && formEncType) {\n      submission = getSubmissionFromNavigation(state.navigation);\n    }\n    let activeSubmission = submission || fetcherSubmission;\n    if (redirectPreserveMethodStatusCodes.has(redirect2.response.status) && activeSubmission && isMutationMethod(activeSubmission.formMethod)) {\n      await startNavigation(redirectNavigationType, redirectLocation, {\n        submission: {\n          ...activeSubmission,\n          formAction: location\n        },\n        // Preserve these flags across redirects\n        preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n        enableViewTransition: isNavigation ? pendingViewTransitionEnabled : void 0\n      });\n    } else {\n      let overrideNavigation = getLoadingNavigation(\n        redirectLocation,\n        submission\n      );\n      await startNavigation(redirectNavigationType, redirectLocation, {\n        overrideNavigation,\n        // Send fetcher submissions through for shouldRevalidate\n        fetcherSubmission,\n        // Preserve these flags across redirects\n        preventScrollReset: preventScrollReset || pendingPreventScrollReset,\n        enableViewTransition: isNavigation ? pendingViewTransitionEnabled : void 0\n      });\n    }\n  }\n  async function callDataStrategy(type, state2, request, matchesToLoad, matches, fetcherKey) {\n    let results;\n    let dataResults = {};\n    try {\n      results = await callDataStrategyImpl(\n        dataStrategyImpl,\n        type,\n        state2,\n        request,\n        matchesToLoad,\n        matches,\n        fetcherKey,\n        manifest,\n        mapRouteProperties2\n      );\n    } catch (e) {\n      matchesToLoad.forEach((m) => {\n        dataResults[m.route.id] = {\n          type: \"error\" /* error */,\n          error: e\n        };\n      });\n      return dataResults;\n    }\n    for (let [routeId, result] of Object.entries(results)) {\n      if (isRedirectDataStrategyResult(result)) {\n        let response = result.result;\n        dataResults[routeId] = {\n          type: \"redirect\" /* redirect */,\n          response: normalizeRelativeRoutingRedirectResponse(\n            response,\n            request,\n            routeId,\n            matches,\n            basename\n          )\n        };\n      } else {\n        dataResults[routeId] = await convertDataStrategyResultToDataResult(\n          result\n        );\n      }\n    }\n    return dataResults;\n  }\n  async function callLoadersAndMaybeResolveData(state2, matches, matchesToLoad, fetchersToLoad, request) {\n    let loaderResultsPromise = callDataStrategy(\n      \"loader\",\n      state2,\n      request,\n      matchesToLoad,\n      matches,\n      null\n    );\n    let fetcherResultsPromise = Promise.all(\n      fetchersToLoad.map(async (f) => {\n        if (f.matches && f.match && f.controller) {\n          let results = await callDataStrategy(\n            \"loader\",\n            state2,\n            createClientSideRequest(init.history, f.path, f.controller.signal),\n            [f.match],\n            f.matches,\n            f.key\n          );\n          let result = results[f.match.route.id];\n          return { [f.key]: result };\n        } else {\n          return Promise.resolve({\n            [f.key]: {\n              type: \"error\" /* error */,\n              error: getInternalRouterError(404, {\n                pathname: f.path\n              })\n            }\n          });\n        }\n      })\n    );\n    let loaderResults = await loaderResultsPromise;\n    let fetcherResults = (await fetcherResultsPromise).reduce(\n      (acc, r) => Object.assign(acc, r),\n      {}\n    );\n    return {\n      loaderResults,\n      fetcherResults\n    };\n  }\n  function interruptActiveLoads() {\n    isRevalidationRequired = true;\n    fetchLoadMatches.forEach((_, key) => {\n      if (fetchControllers.has(key)) {\n        cancelledFetcherLoads.add(key);\n      }\n      abortFetcher(key);\n    });\n  }\n  function updateFetcherState(key, fetcher, opts = {}) {\n    state.fetchers.set(key, fetcher);\n    updateState(\n      { fetchers: new Map(state.fetchers) },\n      { flushSync: (opts && opts.flushSync) === true }\n    );\n  }\n  function setFetcherError(key, routeId, error, opts = {}) {\n    let boundaryMatch = findNearestBoundary(state.matches, routeId);\n    deleteFetcher(key);\n    updateState(\n      {\n        errors: {\n          [boundaryMatch.route.id]: error\n        },\n        fetchers: new Map(state.fetchers)\n      },\n      { flushSync: (opts && opts.flushSync) === true }\n    );\n  }\n  function getFetcher(key) {\n    activeFetchers.set(key, (activeFetchers.get(key) || 0) + 1);\n    if (fetchersQueuedForDeletion.has(key)) {\n      fetchersQueuedForDeletion.delete(key);\n    }\n    return state.fetchers.get(key) || IDLE_FETCHER;\n  }\n  function deleteFetcher(key) {\n    let fetcher = state.fetchers.get(key);\n    if (fetchControllers.has(key) && !(fetcher && fetcher.state === \"loading\" && fetchReloadIds.has(key))) {\n      abortFetcher(key);\n    }\n    fetchLoadMatches.delete(key);\n    fetchReloadIds.delete(key);\n    fetchRedirectIds.delete(key);\n    fetchersQueuedForDeletion.delete(key);\n    cancelledFetcherLoads.delete(key);\n    state.fetchers.delete(key);\n  }\n  function queueFetcherForDeletion(key) {\n    let count = (activeFetchers.get(key) || 0) - 1;\n    if (count <= 0) {\n      activeFetchers.delete(key);\n      fetchersQueuedForDeletion.add(key);\n    } else {\n      activeFetchers.set(key, count);\n    }\n    updateState({ fetchers: new Map(state.fetchers) });\n  }\n  function abortFetcher(key) {\n    let controller = fetchControllers.get(key);\n    if (controller) {\n      controller.abort();\n      fetchControllers.delete(key);\n    }\n  }\n  function markFetchersDone(keys) {\n    for (let key of keys) {\n      let fetcher = getFetcher(key);\n      let doneFetcher = getDoneFetcher(fetcher.data);\n      state.fetchers.set(key, doneFetcher);\n    }\n  }\n  function markFetchRedirectsDone() {\n    let doneKeys = [];\n    let updatedFetchers = false;\n    for (let key of fetchRedirectIds) {\n      let fetcher = state.fetchers.get(key);\n      invariant(fetcher, `Expected fetcher: ${key}`);\n      if (fetcher.state === \"loading\") {\n        fetchRedirectIds.delete(key);\n        doneKeys.push(key);\n        updatedFetchers = true;\n      }\n    }\n    markFetchersDone(doneKeys);\n    return updatedFetchers;\n  }\n  function abortStaleFetchLoads(landedId) {\n    let yeetedKeys = [];\n    for (let [key, id] of fetchReloadIds) {\n      if (id < landedId) {\n        let fetcher = state.fetchers.get(key);\n        invariant(fetcher, `Expected fetcher: ${key}`);\n        if (fetcher.state === \"loading\") {\n          abortFetcher(key);\n          fetchReloadIds.delete(key);\n          yeetedKeys.push(key);\n        }\n      }\n    }\n    markFetchersDone(yeetedKeys);\n    return yeetedKeys.length > 0;\n  }\n  function getBlocker(key, fn) {\n    let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n    if (blockerFunctions.get(key) !== fn) {\n      blockerFunctions.set(key, fn);\n    }\n    return blocker;\n  }\n  function deleteBlocker(key) {\n    state.blockers.delete(key);\n    blockerFunctions.delete(key);\n  }\n  function updateBlocker(key, newBlocker) {\n    let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n    invariant(\n      blocker.state === \"unblocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"blocked\" || blocker.state === \"blocked\" && newBlocker.state === \"proceeding\" || blocker.state === \"blocked\" && newBlocker.state === \"unblocked\" || blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\",\n      `Invalid blocker state transition: ${blocker.state} -> ${newBlocker.state}`\n    );\n    let blockers = new Map(state.blockers);\n    blockers.set(key, newBlocker);\n    updateState({ blockers });\n  }\n  function shouldBlockNavigation({\n    currentLocation,\n    nextLocation,\n    historyAction\n  }) {\n    if (blockerFunctions.size === 0) {\n      return;\n    }\n    if (blockerFunctions.size > 1) {\n      warning(false, \"A router only supports one blocker at a time\");\n    }\n    let entries = Array.from(blockerFunctions.entries());\n    let [blockerKey, blockerFunction] = entries[entries.length - 1];\n    let blocker = state.blockers.get(blockerKey);\n    if (blocker && blocker.state === \"proceeding\") {\n      return;\n    }\n    if (blockerFunction({ currentLocation, nextLocation, historyAction })) {\n      return blockerKey;\n    }\n  }\n  function handleNavigational404(pathname) {\n    let error = getInternalRouterError(404, { pathname });\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    let { matches, route } = getShortCircuitMatches(routesToUse);\n    return { notFoundMatches: matches, route, error };\n  }\n  function enableScrollRestoration(positions, getPosition, getKey) {\n    savedScrollPositions2 = positions;\n    getScrollPosition = getPosition;\n    getScrollRestorationKey2 = getKey || null;\n    if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n      initialScrollRestored = true;\n      let y = getSavedScrollPosition(state.location, state.matches);\n      if (y != null) {\n        updateState({ restoreScrollPosition: y });\n      }\n    }\n    return () => {\n      savedScrollPositions2 = null;\n      getScrollPosition = null;\n      getScrollRestorationKey2 = null;\n    };\n  }\n  function getScrollKey(location, matches) {\n    if (getScrollRestorationKey2) {\n      let key = getScrollRestorationKey2(\n        location,\n        matches.map((m) => convertRouteMatchToUiMatch(m, state.loaderData))\n      );\n      return key || location.key;\n    }\n    return location.key;\n  }\n  function saveScrollPosition(location, matches) {\n    if (savedScrollPositions2 && getScrollPosition) {\n      let key = getScrollKey(location, matches);\n      savedScrollPositions2[key] = getScrollPosition();\n    }\n  }\n  function getSavedScrollPosition(location, matches) {\n    if (savedScrollPositions2) {\n      let key = getScrollKey(location, matches);\n      let y = savedScrollPositions2[key];\n      if (typeof y === \"number\") {\n        return y;\n      }\n    }\n    return null;\n  }\n  function checkFogOfWar(matches, routesToUse, pathname) {\n    if (patchRoutesOnNavigationImpl) {\n      if (!matches) {\n        let fogMatches = matchRoutesImpl(\n          routesToUse,\n          pathname,\n          basename,\n          true\n        );\n        return { active: true, matches: fogMatches || [] };\n      } else {\n        if (Object.keys(matches[0].params).length > 0) {\n          let partialMatches = matchRoutesImpl(\n            routesToUse,\n            pathname,\n            basename,\n            true\n          );\n          return { active: true, matches: partialMatches };\n        }\n      }\n    }\n    return { active: false, matches: null };\n  }\n  async function discoverRoutes(matches, pathname, signal) {\n    if (!patchRoutesOnNavigationImpl) {\n      return { type: \"success\", matches };\n    }\n    let partialMatches = matches;\n    while (true) {\n      let isNonHMR = inFlightDataRoutes == null;\n      let routesToUse = inFlightDataRoutes || dataRoutes;\n      let localManifest = manifest;\n      try {\n        await patchRoutesOnNavigationImpl({\n          path: pathname,\n          matches: partialMatches,\n          patch: (routeId, children) => {\n            if (signal.aborted) return;\n            patchRoutesImpl(\n              routeId,\n              children,\n              routesToUse,\n              localManifest,\n              mapRouteProperties2\n            );\n          }\n        });\n      } catch (e) {\n        return { type: \"error\", error: e, partialMatches };\n      } finally {\n        if (isNonHMR && !signal.aborted) {\n          dataRoutes = [...dataRoutes];\n        }\n      }\n      if (signal.aborted) {\n        return { type: \"aborted\" };\n      }\n      let newMatches = matchRoutes(routesToUse, pathname, basename);\n      if (newMatches) {\n        return { type: \"success\", matches: newMatches };\n      }\n      let newPartialMatches = matchRoutesImpl(\n        routesToUse,\n        pathname,\n        basename,\n        true\n      );\n      if (!newPartialMatches || partialMatches.length === newPartialMatches.length && partialMatches.every(\n        (m, i) => m.route.id === newPartialMatches[i].route.id\n      )) {\n        return { type: \"success\", matches: null };\n      }\n      partialMatches = newPartialMatches;\n    }\n  }\n  function _internalSetRoutes(newRoutes) {\n    manifest = {};\n    inFlightDataRoutes = convertRoutesToDataRoutes(\n      newRoutes,\n      mapRouteProperties2,\n      void 0,\n      manifest\n    );\n  }\n  function patchRoutes(routeId, children) {\n    let isNonHMR = inFlightDataRoutes == null;\n    let routesToUse = inFlightDataRoutes || dataRoutes;\n    patchRoutesImpl(\n      routeId,\n      children,\n      routesToUse,\n      manifest,\n      mapRouteProperties2\n    );\n    if (isNonHMR) {\n      dataRoutes = [...dataRoutes];\n      updateState({});\n    }\n  }\n  router = {\n    get basename() {\n      return basename;\n    },\n    get future() {\n      return future;\n    },\n    get state() {\n      return state;\n    },\n    get routes() {\n      return dataRoutes;\n    },\n    get window() {\n      return routerWindow;\n    },\n    initialize,\n    subscribe,\n    enableScrollRestoration,\n    navigate,\n    fetch: fetch2,\n    revalidate,\n    // Passthrough to history-aware createHref used by useHref so we get proper\n    // hash-aware URLs in DOM paths\n    createHref: (to) => init.history.createHref(to),\n    encodeLocation: (to) => init.history.encodeLocation(to),\n    getFetcher,\n    deleteFetcher: queueFetcherForDeletion,\n    dispose,\n    getBlocker,\n    deleteBlocker,\n    patchRoutes,\n    _internalFetchControllers: fetchControllers,\n    // TODO: Remove setRoutes, it's temporary to avoid dealing with\n    // updating the tree while validating the update algorithm.\n    _internalSetRoutes\n  };\n  return router;\n}\nfunction createStaticHandler(routes, opts) {\n  invariant(\n    routes.length > 0,\n    \"You must provide a non-empty routes array to createStaticHandler\"\n  );\n  let manifest = {};\n  let basename = (opts ? opts.basename : null) || \"/\";\n  let mapRouteProperties2 = opts?.mapRouteProperties || defaultMapRouteProperties;\n  let dataRoutes = convertRoutesToDataRoutes(\n    routes,\n    mapRouteProperties2,\n    void 0,\n    manifest\n  );\n  async function query(request, {\n    requestContext,\n    skipLoaderErrorBubbling,\n    dataStrategy\n  } = {}) {\n    let url = new URL(request.url);\n    let method = request.method;\n    let location = createLocation(\"\", createPath(url), null, \"default\");\n    let matches = matchRoutes(dataRoutes, location, basename);\n    if (!isValidMethod(method) && method !== \"HEAD\") {\n      let error = getInternalRouterError(405, { method });\n      let { matches: methodNotAllowedMatches, route } = getShortCircuitMatches(dataRoutes);\n      return {\n        basename,\n        location,\n        matches: methodNotAllowedMatches,\n        loaderData: {},\n        actionData: null,\n        errors: {\n          [route.id]: error\n        },\n        statusCode: error.status,\n        loaderHeaders: {},\n        actionHeaders: {}\n      };\n    } else if (!matches) {\n      let error = getInternalRouterError(404, { pathname: location.pathname });\n      let { matches: notFoundMatches, route } = getShortCircuitMatches(dataRoutes);\n      return {\n        basename,\n        location,\n        matches: notFoundMatches,\n        loaderData: {},\n        actionData: null,\n        errors: {\n          [route.id]: error\n        },\n        statusCode: error.status,\n        loaderHeaders: {},\n        actionHeaders: {}\n      };\n    }\n    let result = await queryImpl(\n      request,\n      location,\n      matches,\n      requestContext,\n      dataStrategy || null,\n      skipLoaderErrorBubbling === true,\n      null\n    );\n    if (isResponse(result)) {\n      return result;\n    }\n    return { location, basename, ...result };\n  }\n  async function queryRoute(request, {\n    routeId,\n    requestContext,\n    dataStrategy\n  } = {}) {\n    let url = new URL(request.url);\n    let method = request.method;\n    let location = createLocation(\"\", createPath(url), null, \"default\");\n    let matches = matchRoutes(dataRoutes, location, basename);\n    if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n      throw getInternalRouterError(405, { method });\n    } else if (!matches) {\n      throw getInternalRouterError(404, { pathname: location.pathname });\n    }\n    let match = routeId ? matches.find((m) => m.route.id === routeId) : getTargetMatch(matches, location);\n    if (routeId && !match) {\n      throw getInternalRouterError(403, {\n        pathname: location.pathname,\n        routeId\n      });\n    } else if (!match) {\n      throw getInternalRouterError(404, { pathname: location.pathname });\n    }\n    let result = await queryImpl(\n      request,\n      location,\n      matches,\n      requestContext,\n      dataStrategy || null,\n      false,\n      match\n    );\n    if (isResponse(result)) {\n      return result;\n    }\n    let error = result.errors ? Object.values(result.errors)[0] : void 0;\n    if (error !== void 0) {\n      throw error;\n    }\n    if (result.actionData) {\n      return Object.values(result.actionData)[0];\n    }\n    if (result.loaderData) {\n      return Object.values(result.loaderData)[0];\n    }\n    return void 0;\n  }\n  async function queryImpl(request, location, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch) {\n    invariant(\n      request.signal,\n      \"query()/queryRoute() requests must contain an AbortController signal\"\n    );\n    try {\n      if (isMutationMethod(request.method)) {\n        let result2 = await submit(\n          request,\n          matches,\n          routeMatch || getTargetMatch(matches, location),\n          requestContext,\n          dataStrategy,\n          skipLoaderErrorBubbling,\n          routeMatch != null\n        );\n        return result2;\n      }\n      let result = await loadRouteData(\n        request,\n        matches,\n        requestContext,\n        dataStrategy,\n        skipLoaderErrorBubbling,\n        routeMatch\n      );\n      return isResponse(result) ? result : {\n        ...result,\n        actionData: null,\n        actionHeaders: {}\n      };\n    } catch (e) {\n      if (isDataStrategyResult(e) && isResponse(e.result)) {\n        if (e.type === \"error\" /* error */) {\n          throw e.result;\n        }\n        return e.result;\n      }\n      if (isRedirectResponse(e)) {\n        return e;\n      }\n      throw e;\n    }\n  }\n  async function submit(request, matches, actionMatch, requestContext, dataStrategy, skipLoaderErrorBubbling, isRouteRequest) {\n    let result;\n    if (!actionMatch.route.action && !actionMatch.route.lazy) {\n      let error = getInternalRouterError(405, {\n        method: request.method,\n        pathname: new URL(request.url).pathname,\n        routeId: actionMatch.route.id\n      });\n      if (isRouteRequest) {\n        throw error;\n      }\n      result = {\n        type: \"error\" /* error */,\n        error\n      };\n    } else {\n      let results = await callDataStrategy(\n        \"action\",\n        request,\n        [actionMatch],\n        matches,\n        isRouteRequest,\n        requestContext,\n        dataStrategy\n      );\n      result = results[actionMatch.route.id];\n      if (request.signal.aborted) {\n        throwStaticHandlerAbortedError(request, isRouteRequest);\n      }\n    }\n    if (isRedirectResult(result)) {\n      throw new Response(null, {\n        status: result.response.status,\n        headers: {\n          Location: result.response.headers.get(\"Location\")\n        }\n      });\n    }\n    if (isRouteRequest) {\n      if (isErrorResult(result)) {\n        throw result.error;\n      }\n      return {\n        matches: [actionMatch],\n        loaderData: {},\n        actionData: { [actionMatch.route.id]: result.data },\n        errors: null,\n        // Note: statusCode + headers are unused here since queryRoute will\n        // return the raw Response or value\n        statusCode: 200,\n        loaderHeaders: {},\n        actionHeaders: {}\n      };\n    }\n    let loaderRequest = new Request(request.url, {\n      headers: request.headers,\n      redirect: request.redirect,\n      signal: request.signal\n    });\n    if (isErrorResult(result)) {\n      let boundaryMatch = skipLoaderErrorBubbling ? actionMatch : findNearestBoundary(matches, actionMatch.route.id);\n      let context2 = await loadRouteData(\n        loaderRequest,\n        matches,\n        requestContext,\n        dataStrategy,\n        skipLoaderErrorBubbling,\n        null,\n        [boundaryMatch.route.id, result]\n      );\n      return {\n        ...context2,\n        statusCode: isRouteErrorResponse(result.error) ? result.error.status : result.statusCode != null ? result.statusCode : 500,\n        actionData: null,\n        actionHeaders: {\n          ...result.headers ? { [actionMatch.route.id]: result.headers } : {}\n        }\n      };\n    }\n    let context = await loadRouteData(\n      loaderRequest,\n      matches,\n      requestContext,\n      dataStrategy,\n      skipLoaderErrorBubbling,\n      null\n    );\n    return {\n      ...context,\n      actionData: {\n        [actionMatch.route.id]: result.data\n      },\n      // action status codes take precedence over loader status codes\n      ...result.statusCode ? { statusCode: result.statusCode } : {},\n      actionHeaders: result.headers ? { [actionMatch.route.id]: result.headers } : {}\n    };\n  }\n  async function loadRouteData(request, matches, requestContext, dataStrategy, skipLoaderErrorBubbling, routeMatch, pendingActionResult) {\n    let isRouteRequest = routeMatch != null;\n    if (isRouteRequest && !routeMatch?.route.loader && !routeMatch?.route.lazy) {\n      throw getInternalRouterError(400, {\n        method: request.method,\n        pathname: new URL(request.url).pathname,\n        routeId: routeMatch?.route.id\n      });\n    }\n    let requestMatches = routeMatch ? [routeMatch] : pendingActionResult && isErrorResult(pendingActionResult[1]) ? getLoaderMatchesUntilBoundary(matches, pendingActionResult[0]) : matches;\n    let matchesToLoad = requestMatches.filter(\n      (m) => m.route.loader || m.route.lazy\n    );\n    if (matchesToLoad.length === 0) {\n      return {\n        matches,\n        // Add a null for all matched routes for proper revalidation on the client\n        loaderData: matches.reduce(\n          (acc, m) => Object.assign(acc, { [m.route.id]: null }),\n          {}\n        ),\n        errors: pendingActionResult && isErrorResult(pendingActionResult[1]) ? {\n          [pendingActionResult[0]]: pendingActionResult[1].error\n        } : null,\n        statusCode: 200,\n        loaderHeaders: {}\n      };\n    }\n    let results = await callDataStrategy(\n      \"loader\",\n      request,\n      matchesToLoad,\n      matches,\n      isRouteRequest,\n      requestContext,\n      dataStrategy\n    );\n    if (request.signal.aborted) {\n      throwStaticHandlerAbortedError(request, isRouteRequest);\n    }\n    let context = processRouteLoaderData(\n      matches,\n      results,\n      pendingActionResult,\n      true,\n      skipLoaderErrorBubbling\n    );\n    let executedLoaders = new Set(\n      matchesToLoad.map((match) => match.route.id)\n    );\n    matches.forEach((match) => {\n      if (!executedLoaders.has(match.route.id)) {\n        context.loaderData[match.route.id] = null;\n      }\n    });\n    return {\n      ...context,\n      matches\n    };\n  }\n  async function callDataStrategy(type, request, matchesToLoad, matches, isRouteRequest, requestContext, dataStrategy) {\n    let results = await callDataStrategyImpl(\n      dataStrategy || defaultDataStrategy,\n      type,\n      null,\n      request,\n      matchesToLoad,\n      matches,\n      null,\n      manifest,\n      mapRouteProperties2,\n      requestContext\n    );\n    let dataResults = {};\n    await Promise.all(\n      matches.map(async (match) => {\n        if (!(match.route.id in results)) {\n          return;\n        }\n        let result = results[match.route.id];\n        if (isRedirectDataStrategyResult(result)) {\n          let response = result.result;\n          throw normalizeRelativeRoutingRedirectResponse(\n            response,\n            request,\n            match.route.id,\n            matches,\n            basename\n          );\n        }\n        if (isResponse(result.result) && isRouteRequest) {\n          throw result;\n        }\n        dataResults[match.route.id] = await convertDataStrategyResultToDataResult(result);\n      })\n    );\n    return dataResults;\n  }\n  return {\n    dataRoutes,\n    query,\n    queryRoute\n  };\n}\nfunction getStaticContextFromError(routes, context, error) {\n  let newContext = {\n    ...context,\n    statusCode: isRouteErrorResponse(error) ? error.status : 500,\n    errors: {\n      [context._deepestRenderedBoundaryId || routes[0].id]: error\n    }\n  };\n  return newContext;\n}\nfunction throwStaticHandlerAbortedError(request, isRouteRequest) {\n  if (request.signal.reason !== void 0) {\n    throw request.signal.reason;\n  }\n  let method = isRouteRequest ? \"queryRoute\" : \"query\";\n  throw new Error(\n    `${method}() call aborted without an \\`AbortSignal.reason\\`: ${request.method} ${request.url}`\n  );\n}\nfunction isSubmissionNavigation(opts) {\n  return opts != null && (\"formData\" in opts && opts.formData != null || \"body\" in opts && opts.body !== void 0);\n}\nfunction normalizeTo(location, matches, basename, to, fromRouteId, relative) {\n  let contextualMatches;\n  let activeRouteMatch;\n  if (fromRouteId) {\n    contextualMatches = [];\n    for (let match of matches) {\n      contextualMatches.push(match);\n      if (match.route.id === fromRouteId) {\n        activeRouteMatch = match;\n        break;\n      }\n    }\n  } else {\n    contextualMatches = matches;\n    activeRouteMatch = matches[matches.length - 1];\n  }\n  let path = resolveTo(\n    to ? to : \".\",\n    getResolveToMatches(contextualMatches),\n    stripBasename(location.pathname, basename) || location.pathname,\n    relative === \"path\"\n  );\n  if (to == null) {\n    path.search = location.search;\n    path.hash = location.hash;\n  }\n  if ((to == null || to === \"\" || to === \".\") && activeRouteMatch) {\n    let nakedIndex = hasNakedIndexQuery(path.search);\n    if (activeRouteMatch.route.index && !nakedIndex) {\n      path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n    } else if (!activeRouteMatch.route.index && nakedIndex) {\n      let params = new URLSearchParams(path.search);\n      let indexValues = params.getAll(\"index\");\n      params.delete(\"index\");\n      indexValues.filter((v) => v).forEach((v) => params.append(\"index\", v));\n      let qs = params.toString();\n      path.search = qs ? `?${qs}` : \"\";\n    }\n  }\n  if (basename !== \"/\") {\n    path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n  }\n  return createPath(path);\n}\nfunction normalizeNavigateOptions(isFetcher, path, opts) {\n  if (!opts || !isSubmissionNavigation(opts)) {\n    return { path };\n  }\n  if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n    return {\n      path,\n      error: getInternalRouterError(405, { method: opts.formMethod })\n    };\n  }\n  let getInvalidBodyError = () => ({\n    path,\n    error: getInternalRouterError(400, { type: \"invalid-body\" })\n  });\n  let rawFormMethod = opts.formMethod || \"get\";\n  let formMethod = rawFormMethod.toUpperCase();\n  let formAction = stripHashFromPath(path);\n  if (opts.body !== void 0) {\n    if (opts.formEncType === \"text/plain\") {\n      if (!isMutationMethod(formMethod)) {\n        return getInvalidBodyError();\n      }\n      let text = typeof opts.body === \"string\" ? opts.body : opts.body instanceof FormData || opts.body instanceof URLSearchParams ? (\n        // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#plain-text-form-data\n        Array.from(opts.body.entries()).reduce(\n          (acc, [name, value]) => `${acc}${name}=${value}\n`,\n          \"\"\n        )\n      ) : String(opts.body);\n      return {\n        path,\n        submission: {\n          formMethod,\n          formAction,\n          formEncType: opts.formEncType,\n          formData: void 0,\n          json: void 0,\n          text\n        }\n      };\n    } else if (opts.formEncType === \"application/json\") {\n      if (!isMutationMethod(formMethod)) {\n        return getInvalidBodyError();\n      }\n      try {\n        let json = typeof opts.body === \"string\" ? JSON.parse(opts.body) : opts.body;\n        return {\n          path,\n          submission: {\n            formMethod,\n            formAction,\n            formEncType: opts.formEncType,\n            formData: void 0,\n            json,\n            text: void 0\n          }\n        };\n      } catch (e) {\n        return getInvalidBodyError();\n      }\n    }\n  }\n  invariant(\n    typeof FormData === \"function\",\n    \"FormData is not available in this environment\"\n  );\n  let searchParams;\n  let formData;\n  if (opts.formData) {\n    searchParams = convertFormDataToSearchParams(opts.formData);\n    formData = opts.formData;\n  } else if (opts.body instanceof FormData) {\n    searchParams = convertFormDataToSearchParams(opts.body);\n    formData = opts.body;\n  } else if (opts.body instanceof URLSearchParams) {\n    searchParams = opts.body;\n    formData = convertSearchParamsToFormData(searchParams);\n  } else if (opts.body == null) {\n    searchParams = new URLSearchParams();\n    formData = new FormData();\n  } else {\n    try {\n      searchParams = new URLSearchParams(opts.body);\n      formData = convertSearchParamsToFormData(searchParams);\n    } catch (e) {\n      return getInvalidBodyError();\n    }\n  }\n  let submission = {\n    formMethod,\n    formAction,\n    formEncType: opts && opts.formEncType || \"application/x-www-form-urlencoded\",\n    formData,\n    json: void 0,\n    text: void 0\n  };\n  if (isMutationMethod(submission.formMethod)) {\n    return { path, submission };\n  }\n  let parsedPath = parsePath(path);\n  if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n    searchParams.append(\"index\", \"\");\n  }\n  parsedPath.search = `?${searchParams}`;\n  return { path: createPath(parsedPath), submission };\n}\nfunction getLoaderMatchesUntilBoundary(matches, boundaryId, includeBoundary = false) {\n  let index = matches.findIndex((m) => m.route.id === boundaryId);\n  if (index >= 0) {\n    return matches.slice(0, includeBoundary ? index + 1 : index);\n  }\n  return matches;\n}\nfunction getMatchesToLoad(history, state, matches, submission, location, initialHydration, isRevalidationRequired, cancelledFetcherLoads, fetchersQueuedForDeletion, fetchLoadMatches, fetchRedirectIds, routesToUse, basename, pendingActionResult) {\n  let actionResult = pendingActionResult ? isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : pendingActionResult[1].data : void 0;\n  let currentUrl = history.createURL(state.location);\n  let nextUrl = history.createURL(location);\n  let boundaryMatches = matches;\n  if (initialHydration && state.errors) {\n    boundaryMatches = getLoaderMatchesUntilBoundary(\n      matches,\n      Object.keys(state.errors)[0],\n      true\n    );\n  } else if (pendingActionResult && isErrorResult(pendingActionResult[1])) {\n    boundaryMatches = getLoaderMatchesUntilBoundary(\n      matches,\n      pendingActionResult[0]\n    );\n  }\n  let actionStatus = pendingActionResult ? pendingActionResult[1].statusCode : void 0;\n  let shouldSkipRevalidation = actionStatus && actionStatus >= 400;\n  let navigationMatches = boundaryMatches.filter((match, index) => {\n    let { route } = match;\n    if (route.lazy) {\n      return true;\n    }\n    if (route.loader == null) {\n      return false;\n    }\n    if (initialHydration) {\n      return shouldLoadRouteOnHydration(route, state.loaderData, state.errors);\n    }\n    if (isNewLoader(state.loaderData, state.matches[index], match)) {\n      return true;\n    }\n    let currentRouteMatch = state.matches[index];\n    let nextRouteMatch = match;\n    return shouldRevalidateLoader(match, {\n      currentUrl,\n      currentParams: currentRouteMatch.params,\n      nextUrl,\n      nextParams: nextRouteMatch.params,\n      ...submission,\n      actionResult,\n      actionStatus,\n      defaultShouldRevalidate: shouldSkipRevalidation ? false : (\n        // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n        isRevalidationRequired || currentUrl.pathname + currentUrl.search === nextUrl.pathname + nextUrl.search || // Search params affect all loaders\n        currentUrl.search !== nextUrl.search || isNewRouteInstance(currentRouteMatch, nextRouteMatch)\n      )\n    });\n  });\n  let revalidatingFetchers = [];\n  fetchLoadMatches.forEach((f, key) => {\n    if (initialHydration || !matches.some((m) => m.route.id === f.routeId) || fetchersQueuedForDeletion.has(key)) {\n      return;\n    }\n    let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n    if (!fetcherMatches) {\n      revalidatingFetchers.push({\n        key,\n        routeId: f.routeId,\n        path: f.path,\n        matches: null,\n        match: null,\n        controller: null\n      });\n      return;\n    }\n    let fetcher = state.fetchers.get(key);\n    let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n    let shouldRevalidate = false;\n    if (fetchRedirectIds.has(key)) {\n      shouldRevalidate = false;\n    } else if (cancelledFetcherLoads.has(key)) {\n      cancelledFetcherLoads.delete(key);\n      shouldRevalidate = true;\n    } else if (fetcher && fetcher.state !== \"idle\" && fetcher.data === void 0) {\n      shouldRevalidate = isRevalidationRequired;\n    } else {\n      shouldRevalidate = shouldRevalidateLoader(fetcherMatch, {\n        currentUrl,\n        currentParams: state.matches[state.matches.length - 1].params,\n        nextUrl,\n        nextParams: matches[matches.length - 1].params,\n        ...submission,\n        actionResult,\n        actionStatus,\n        defaultShouldRevalidate: shouldSkipRevalidation ? false : isRevalidationRequired\n      });\n    }\n    if (shouldRevalidate) {\n      revalidatingFetchers.push({\n        key,\n        routeId: f.routeId,\n        path: f.path,\n        matches: fetcherMatches,\n        match: fetcherMatch,\n        controller: new AbortController()\n      });\n    }\n  });\n  return [navigationMatches, revalidatingFetchers];\n}\nfunction shouldLoadRouteOnHydration(route, loaderData, errors) {\n  if (route.lazy) {\n    return true;\n  }\n  if (!route.loader) {\n    return false;\n  }\n  let hasData = loaderData != null && loaderData[route.id] !== void 0;\n  let hasError = errors != null && errors[route.id] !== void 0;\n  if (!hasData && hasError) {\n    return false;\n  }\n  if (typeof route.loader === \"function\" && route.loader.hydrate === true) {\n    return true;\n  }\n  return !hasData && !hasError;\n}\nfunction isNewLoader(currentLoaderData, currentMatch, match) {\n  let isNew = (\n    // [a] -> [a, b]\n    !currentMatch || // [a, b] -> [a, c]\n    match.route.id !== currentMatch.route.id\n  );\n  let isMissingData = !currentLoaderData.hasOwnProperty(match.route.id);\n  return isNew || isMissingData;\n}\nfunction isNewRouteInstance(currentMatch, match) {\n  let currentPath = currentMatch.route.path;\n  return (\n    // param change for this match, /users/123 -> /users/456\n    currentMatch.pathname !== match.pathname || // splat param changed, which is not present in match.path\n    // e.g. /files/images/avatar.jpg -> files/finances.xls\n    currentPath != null && currentPath.endsWith(\"*\") && currentMatch.params[\"*\"] !== match.params[\"*\"]\n  );\n}\nfunction shouldRevalidateLoader(loaderMatch, arg) {\n  if (loaderMatch.route.shouldRevalidate) {\n    let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n    if (typeof routeChoice === \"boolean\") {\n      return routeChoice;\n    }\n  }\n  return arg.defaultShouldRevalidate;\n}\nfunction patchRoutesImpl(routeId, children, routesToUse, manifest, mapRouteProperties2) {\n  let childrenToPatch;\n  if (routeId) {\n    let route = manifest[routeId];\n    invariant(\n      route,\n      `No route found to patch children into: routeId = ${routeId}`\n    );\n    if (!route.children) {\n      route.children = [];\n    }\n    childrenToPatch = route.children;\n  } else {\n    childrenToPatch = routesToUse;\n  }\n  let uniqueChildren = children.filter(\n    (newRoute) => !childrenToPatch.some(\n      (existingRoute) => isSameRoute(newRoute, existingRoute)\n    )\n  );\n  let newRoutes = convertRoutesToDataRoutes(\n    uniqueChildren,\n    mapRouteProperties2,\n    [routeId || \"_\", \"patch\", String(childrenToPatch?.length || \"0\")],\n    manifest\n  );\n  childrenToPatch.push(...newRoutes);\n}\nfunction isSameRoute(newRoute, existingRoute) {\n  if (\"id\" in newRoute && \"id\" in existingRoute && newRoute.id === existingRoute.id) {\n    return true;\n  }\n  if (!(newRoute.index === existingRoute.index && newRoute.path === existingRoute.path && newRoute.caseSensitive === existingRoute.caseSensitive)) {\n    return false;\n  }\n  if ((!newRoute.children || newRoute.children.length === 0) && (!existingRoute.children || existingRoute.children.length === 0)) {\n    return true;\n  }\n  return newRoute.children.every(\n    (aChild, i) => existingRoute.children?.some((bChild) => isSameRoute(aChild, bChild))\n  );\n}\nasync function loadLazyRouteModule(route, mapRouteProperties2, manifest) {\n  if (!route.lazy) {\n    return;\n  }\n  let lazyRoute = await route.lazy();\n  if (!route.lazy) {\n    return;\n  }\n  let routeToUpdate = manifest[route.id];\n  invariant(routeToUpdate, \"No route found in manifest\");\n  let routeUpdates = {};\n  for (let lazyRouteProperty in lazyRoute) {\n    let staticRouteValue = routeToUpdate[lazyRouteProperty];\n    let isPropertyStaticallyDefined = staticRouteValue !== void 0 && // This property isn't static since it should always be updated based\n    // on the route updates\n    lazyRouteProperty !== \"hasErrorBoundary\";\n    warning(\n      !isPropertyStaticallyDefined,\n      `Route \"${routeToUpdate.id}\" has a static property \"${lazyRouteProperty}\" defined but its lazy function is also returning a value for this property. The lazy route property \"${lazyRouteProperty}\" will be ignored.`\n    );\n    if (!isPropertyStaticallyDefined && !immutableRouteKeys.has(lazyRouteProperty)) {\n      routeUpdates[lazyRouteProperty] = lazyRoute[lazyRouteProperty];\n    }\n  }\n  Object.assign(routeToUpdate, routeUpdates);\n  Object.assign(routeToUpdate, {\n    // To keep things framework agnostic, we use the provided `mapRouteProperties`\n    // function to set the framework-aware properties (`element`/`hasErrorBoundary`)\n    // since the logic will differ between frameworks.\n    ...mapRouteProperties2(routeToUpdate),\n    lazy: void 0\n  });\n}\nasync function defaultDataStrategy({\n  matches\n}) {\n  let matchesToLoad = matches.filter((m) => m.shouldLoad);\n  let results = await Promise.all(matchesToLoad.map((m) => m.resolve()));\n  return results.reduce(\n    (acc, result, i) => Object.assign(acc, { [matchesToLoad[i].route.id]: result }),\n    {}\n  );\n}\nasync function callDataStrategyImpl(dataStrategyImpl, type, state, request, matchesToLoad, matches, fetcherKey, manifest, mapRouteProperties2, requestContext) {\n  let loadRouteDefinitionsPromises = matches.map(\n    (m) => m.route.lazy ? loadLazyRouteModule(m.route, mapRouteProperties2, manifest) : void 0\n  );\n  let dsMatches = matches.map((match, i) => {\n    let loadRoutePromise = loadRouteDefinitionsPromises[i];\n    let shouldLoad = matchesToLoad.some((m) => m.route.id === match.route.id);\n    let resolve = async (handlerOverride) => {\n      if (handlerOverride && request.method === \"GET\" && (match.route.lazy || match.route.loader)) {\n        shouldLoad = true;\n      }\n      return shouldLoad ? callLoaderOrAction(\n        type,\n        request,\n        match,\n        loadRoutePromise,\n        handlerOverride,\n        requestContext\n      ) : Promise.resolve({ type: \"data\" /* data */, result: void 0 });\n    };\n    return {\n      ...match,\n      shouldLoad,\n      resolve\n    };\n  });\n  let results = await dataStrategyImpl({\n    matches: dsMatches,\n    request,\n    params: matches[0].params,\n    fetcherKey,\n    context: requestContext\n  });\n  try {\n    await Promise.all(loadRouteDefinitionsPromises);\n  } catch (e) {\n  }\n  return results;\n}\nasync function callLoaderOrAction(type, request, match, loadRoutePromise, handlerOverride, staticContext) {\n  let result;\n  let onReject;\n  let runHandler = (handler) => {\n    let reject;\n    let abortPromise = new Promise((_, r) => reject = r);\n    onReject = () => reject();\n    request.signal.addEventListener(\"abort\", onReject);\n    let actualHandler = (ctx) => {\n      if (typeof handler !== \"function\") {\n        return Promise.reject(\n          new Error(\n            `You cannot call the handler for a route which defines a boolean \"${type}\" [routeId: ${match.route.id}]`\n          )\n        );\n      }\n      return handler(\n        {\n          request,\n          params: match.params,\n          context: staticContext\n        },\n        ...ctx !== void 0 ? [ctx] : []\n      );\n    };\n    let handlerPromise = (async () => {\n      try {\n        let val = await (handlerOverride ? handlerOverride((ctx) => actualHandler(ctx)) : actualHandler());\n        return { type: \"data\", result: val };\n      } catch (e) {\n        return { type: \"error\", result: e };\n      }\n    })();\n    return Promise.race([handlerPromise, abortPromise]);\n  };\n  try {\n    let handler = match.route[type];\n    if (loadRoutePromise) {\n      if (handler) {\n        let handlerError;\n        let [value] = await Promise.all([\n          // If the handler throws, don't let it immediately bubble out,\n          // since we need to let the lazy() execution finish so we know if this\n          // route has a boundary that can handle the error\n          runHandler(handler).catch((e) => {\n            handlerError = e;\n          }),\n          loadRoutePromise\n        ]);\n        if (handlerError !== void 0) {\n          throw handlerError;\n        }\n        result = value;\n      } else {\n        await loadRoutePromise;\n        handler = match.route[type];\n        if (handler) {\n          result = await runHandler(handler);\n        } else if (type === \"action\") {\n          let url = new URL(request.url);\n          let pathname = url.pathname + url.search;\n          throw getInternalRouterError(405, {\n            method: request.method,\n            pathname,\n            routeId: match.route.id\n          });\n        } else {\n          return { type: \"data\" /* data */, result: void 0 };\n        }\n      }\n    } else if (!handler) {\n      let url = new URL(request.url);\n      let pathname = url.pathname + url.search;\n      throw getInternalRouterError(404, {\n        pathname\n      });\n    } else {\n      result = await runHandler(handler);\n    }\n  } catch (e) {\n    return { type: \"error\" /* error */, result: e };\n  } finally {\n    if (onReject) {\n      request.signal.removeEventListener(\"abort\", onReject);\n    }\n  }\n  return result;\n}\nasync function convertDataStrategyResultToDataResult(dataStrategyResult) {\n  let { result, type } = dataStrategyResult;\n  if (isResponse(result)) {\n    let data2;\n    try {\n      let contentType = result.headers.get(\"Content-Type\");\n      if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n        if (result.body == null) {\n          data2 = null;\n        } else {\n          data2 = await result.json();\n        }\n      } else {\n        data2 = await result.text();\n      }\n    } catch (e) {\n      return { type: \"error\" /* error */, error: e };\n    }\n    if (type === \"error\" /* error */) {\n      return {\n        type: \"error\" /* error */,\n        error: new ErrorResponseImpl(result.status, result.statusText, data2),\n        statusCode: result.status,\n        headers: result.headers\n      };\n    }\n    return {\n      type: \"data\" /* data */,\n      data: data2,\n      statusCode: result.status,\n      headers: result.headers\n    };\n  }\n  if (type === \"error\" /* error */) {\n    if (isDataWithResponseInit(result)) {\n      if (result.data instanceof Error) {\n        return {\n          type: \"error\" /* error */,\n          error: result.data,\n          statusCode: result.init?.status\n        };\n      }\n      result = new ErrorResponseImpl(\n        result.init?.status || 500,\n        void 0,\n        result.data\n      );\n    }\n    return {\n      type: \"error\" /* error */,\n      error: result,\n      statusCode: isRouteErrorResponse(result) ? result.status : void 0\n    };\n  }\n  if (isDataWithResponseInit(result)) {\n    return {\n      type: \"data\" /* data */,\n      data: result.data,\n      statusCode: result.init?.status,\n      headers: result.init?.headers ? new Headers(result.init.headers) : void 0\n    };\n  }\n  return { type: \"data\" /* data */, data: result };\n}\nfunction normalizeRelativeRoutingRedirectResponse(response, request, routeId, matches, basename) {\n  let location = response.headers.get(\"Location\");\n  invariant(\n    location,\n    \"Redirects returned/thrown from loaders/actions must have a Location header\"\n  );\n  if (!ABSOLUTE_URL_REGEX.test(location)) {\n    let trimmedMatches = matches.slice(\n      0,\n      matches.findIndex((m) => m.route.id === routeId) + 1\n    );\n    location = normalizeTo(\n      new URL(request.url),\n      trimmedMatches,\n      basename,\n      location\n    );\n    response.headers.set(\"Location\", location);\n  }\n  return response;\n}\nfunction normalizeRedirectLocation(location, currentUrl, basename) {\n  if (ABSOLUTE_URL_REGEX.test(location)) {\n    let normalizedLocation = location;\n    let url = normalizedLocation.startsWith(\"//\") ? new URL(currentUrl.protocol + normalizedLocation) : new URL(normalizedLocation);\n    let isSameBasename = stripBasename(url.pathname, basename) != null;\n    if (url.origin === currentUrl.origin && isSameBasename) {\n      return url.pathname + url.search + url.hash;\n    }\n  }\n  return location;\n}\nfunction createClientSideRequest(history, location, signal, submission) {\n  let url = history.createURL(stripHashFromPath(location)).toString();\n  let init = { signal };\n  if (submission && isMutationMethod(submission.formMethod)) {\n    let { formMethod, formEncType } = submission;\n    init.method = formMethod.toUpperCase();\n    if (formEncType === \"application/json\") {\n      init.headers = new Headers({ \"Content-Type\": formEncType });\n      init.body = JSON.stringify(submission.json);\n    } else if (formEncType === \"text/plain\") {\n      init.body = submission.text;\n    } else if (formEncType === \"application/x-www-form-urlencoded\" && submission.formData) {\n      init.body = convertFormDataToSearchParams(submission.formData);\n    } else {\n      init.body = submission.formData;\n    }\n  }\n  return new Request(url, init);\n}\nfunction convertFormDataToSearchParams(formData) {\n  let searchParams = new URLSearchParams();\n  for (let [key, value] of formData.entries()) {\n    searchParams.append(key, typeof value === \"string\" ? value : value.name);\n  }\n  return searchParams;\n}\nfunction convertSearchParamsToFormData(searchParams) {\n  let formData = new FormData();\n  for (let [key, value] of searchParams.entries()) {\n    formData.append(key, value);\n  }\n  return formData;\n}\nfunction processRouteLoaderData(matches, results, pendingActionResult, isStaticHandler = false, skipLoaderErrorBubbling = false) {\n  let loaderData = {};\n  let errors = null;\n  let statusCode;\n  let foundError = false;\n  let loaderHeaders = {};\n  let pendingError = pendingActionResult && isErrorResult(pendingActionResult[1]) ? pendingActionResult[1].error : void 0;\n  matches.forEach((match) => {\n    if (!(match.route.id in results)) {\n      return;\n    }\n    let id = match.route.id;\n    let result = results[id];\n    invariant(\n      !isRedirectResult(result),\n      \"Cannot handle redirect results in processLoaderData\"\n    );\n    if (isErrorResult(result)) {\n      let error = result.error;\n      if (pendingError !== void 0) {\n        error = pendingError;\n        pendingError = void 0;\n      }\n      errors = errors || {};\n      if (skipLoaderErrorBubbling) {\n        errors[id] = error;\n      } else {\n        let boundaryMatch = findNearestBoundary(matches, id);\n        if (errors[boundaryMatch.route.id] == null) {\n          errors[boundaryMatch.route.id] = error;\n        }\n      }\n      if (!isStaticHandler) {\n        loaderData[id] = ResetLoaderDataSymbol;\n      }\n      if (!foundError) {\n        foundError = true;\n        statusCode = isRouteErrorResponse(result.error) ? result.error.status : 500;\n      }\n      if (result.headers) {\n        loaderHeaders[id] = result.headers;\n      }\n    } else {\n      loaderData[id] = result.data;\n      if (result.statusCode && result.statusCode !== 200 && !foundError) {\n        statusCode = result.statusCode;\n      }\n      if (result.headers) {\n        loaderHeaders[id] = result.headers;\n      }\n    }\n  });\n  if (pendingError !== void 0 && pendingActionResult) {\n    errors = { [pendingActionResult[0]]: pendingError };\n    loaderData[pendingActionResult[0]] = void 0;\n  }\n  return {\n    loaderData,\n    errors,\n    statusCode: statusCode || 200,\n    loaderHeaders\n  };\n}\nfunction processLoaderData(state, matches, results, pendingActionResult, revalidatingFetchers, fetcherResults) {\n  let { loaderData, errors } = processRouteLoaderData(\n    matches,\n    results,\n    pendingActionResult\n  );\n  revalidatingFetchers.forEach((rf) => {\n    let { key, match, controller } = rf;\n    let result = fetcherResults[key];\n    invariant(result, \"Did not find corresponding fetcher result\");\n    if (controller && controller.signal.aborted) {\n      return;\n    } else if (isErrorResult(result)) {\n      let boundaryMatch = findNearestBoundary(state.matches, match?.route.id);\n      if (!(errors && errors[boundaryMatch.route.id])) {\n        errors = {\n          ...errors,\n          [boundaryMatch.route.id]: result.error\n        };\n      }\n      state.fetchers.delete(key);\n    } else if (isRedirectResult(result)) {\n      invariant(false, \"Unhandled fetcher revalidation redirect\");\n    } else {\n      let doneFetcher = getDoneFetcher(result.data);\n      state.fetchers.set(key, doneFetcher);\n    }\n  });\n  return { loaderData, errors };\n}\nfunction mergeLoaderData(loaderData, newLoaderData, matches, errors) {\n  let mergedLoaderData = Object.entries(newLoaderData).filter(([, v]) => v !== ResetLoaderDataSymbol).reduce((merged, [k, v]) => {\n    merged[k] = v;\n    return merged;\n  }, {});\n  for (let match of matches) {\n    let id = match.route.id;\n    if (!newLoaderData.hasOwnProperty(id) && loaderData.hasOwnProperty(id) && match.route.loader) {\n      mergedLoaderData[id] = loaderData[id];\n    }\n    if (errors && errors.hasOwnProperty(id)) {\n      break;\n    }\n  }\n  return mergedLoaderData;\n}\nfunction getActionDataForCommit(pendingActionResult) {\n  if (!pendingActionResult) {\n    return {};\n  }\n  return isErrorResult(pendingActionResult[1]) ? {\n    // Clear out prior actionData on errors\n    actionData: {}\n  } : {\n    actionData: {\n      [pendingActionResult[0]]: pendingActionResult[1].data\n    }\n  };\n}\nfunction findNearestBoundary(matches, routeId) {\n  let eligibleMatches = routeId ? matches.slice(0, matches.findIndex((m) => m.route.id === routeId) + 1) : [...matches];\n  return eligibleMatches.reverse().find((m) => m.route.hasErrorBoundary === true) || matches[0];\n}\nfunction getShortCircuitMatches(routes) {\n  let route = routes.length === 1 ? routes[0] : routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n    id: `__shim-error-route__`\n  };\n  return {\n    matches: [\n      {\n        params: {},\n        pathname: \"\",\n        pathnameBase: \"\",\n        route\n      }\n    ],\n    route\n  };\n}\nfunction getInternalRouterError(status, {\n  pathname,\n  routeId,\n  method,\n  type,\n  message\n} = {}) {\n  let statusText = \"Unknown Server Error\";\n  let errorMessage = \"Unknown @remix-run/router error\";\n  if (status === 400) {\n    statusText = \"Bad Request\";\n    if (method && pathname && routeId) {\n      errorMessage = `You made a ${method} request to \"${pathname}\" but did not provide a \\`loader\\` for route \"${routeId}\", so there is no way to handle the request.`;\n    } else if (type === \"invalid-body\") {\n      errorMessage = \"Unable to encode submission body\";\n    }\n  } else if (status === 403) {\n    statusText = \"Forbidden\";\n    errorMessage = `Route \"${routeId}\" does not match URL \"${pathname}\"`;\n  } else if (status === 404) {\n    statusText = \"Not Found\";\n    errorMessage = `No route matches URL \"${pathname}\"`;\n  } else if (status === 405) {\n    statusText = \"Method Not Allowed\";\n    if (method && pathname && routeId) {\n      errorMessage = `You made a ${method.toUpperCase()} request to \"${pathname}\" but did not provide an \\`action\\` for route \"${routeId}\", so there is no way to handle the request.`;\n    } else if (method) {\n      errorMessage = `Invalid request method \"${method.toUpperCase()}\"`;\n    }\n  }\n  return new ErrorResponseImpl(\n    status || 500,\n    statusText,\n    new Error(errorMessage),\n    true\n  );\n}\nfunction findRedirect(results) {\n  let entries = Object.entries(results);\n  for (let i = entries.length - 1; i >= 0; i--) {\n    let [key, result] = entries[i];\n    if (isRedirectResult(result)) {\n      return { key, result };\n    }\n  }\n}\nfunction stripHashFromPath(path) {\n  let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n  return createPath({ ...parsedPath, hash: \"\" });\n}\nfunction isHashChangeOnly(a, b) {\n  if (a.pathname !== b.pathname || a.search !== b.search) {\n    return false;\n  }\n  if (a.hash === \"\") {\n    return b.hash !== \"\";\n  } else if (a.hash === b.hash) {\n    return true;\n  } else if (b.hash !== \"\") {\n    return true;\n  }\n  return false;\n}\nfunction isDataStrategyResult(result) {\n  return result != null && typeof result === \"object\" && \"type\" in result && \"result\" in result && (result.type === \"data\" /* data */ || result.type === \"error\" /* error */);\n}\nfunction isRedirectDataStrategyResult(result) {\n  return isResponse(result.result) && redirectStatusCodes.has(result.result.status);\n}\nfunction isErrorResult(result) {\n  return result.type === \"error\" /* error */;\n}\nfunction isRedirectResult(result) {\n  return (result && result.type) === \"redirect\" /* redirect */;\n}\nfunction isDataWithResponseInit(value) {\n  return typeof value === \"object\" && value != null && \"type\" in value && \"data\" in value && \"init\" in value && value.type === \"DataWithResponseInit\";\n}\nfunction isResponse(value) {\n  return value != null && typeof value.status === \"number\" && typeof value.statusText === \"string\" && typeof value.headers === \"object\" && typeof value.body !== \"undefined\";\n}\nfunction isRedirectStatusCode(statusCode) {\n  return redirectStatusCodes.has(statusCode);\n}\nfunction isRedirectResponse(result) {\n  return isResponse(result) && isRedirectStatusCode(result.status) && result.headers.has(\"Location\");\n}\nfunction isValidMethod(method) {\n  return validRequestMethods.has(method.toUpperCase());\n}\nfunction isMutationMethod(method) {\n  return validMutationMethods.has(method.toUpperCase());\n}\nfunction hasNakedIndexQuery(search) {\n  return new URLSearchParams(search).getAll(\"index\").some((v) => v === \"\");\n}\nfunction getTargetMatch(matches, location) {\n  let search = typeof location === \"string\" ? parsePath(location).search : location.search;\n  if (matches[matches.length - 1].route.index && hasNakedIndexQuery(search || \"\")) {\n    return matches[matches.length - 1];\n  }\n  let pathMatches = getPathContributingMatches(matches);\n  return pathMatches[pathMatches.length - 1];\n}\nfunction getSubmissionFromNavigation(navigation) {\n  let { formMethod, formAction, formEncType, text, formData, json } = navigation;\n  if (!formMethod || !formAction || !formEncType) {\n    return;\n  }\n  if (text != null) {\n    return {\n      formMethod,\n      formAction,\n      formEncType,\n      formData: void 0,\n      json: void 0,\n      text\n    };\n  } else if (formData != null) {\n    return {\n      formMethod,\n      formAction,\n      formEncType,\n      formData,\n      json: void 0,\n      text: void 0\n    };\n  } else if (json !== void 0) {\n    return {\n      formMethod,\n      formAction,\n      formEncType,\n      formData: void 0,\n      json,\n      text: void 0\n    };\n  }\n}\nfunction getLoadingNavigation(location, submission) {\n  if (submission) {\n    let navigation = {\n      state: \"loading\",\n      location,\n      formMethod: submission.formMethod,\n      formAction: submission.formAction,\n      formEncType: submission.formEncType,\n      formData: submission.formData,\n      json: submission.json,\n      text: submission.text\n    };\n    return navigation;\n  } else {\n    let navigation = {\n      state: \"loading\",\n      location,\n      formMethod: void 0,\n      formAction: void 0,\n      formEncType: void 0,\n      formData: void 0,\n      json: void 0,\n      text: void 0\n    };\n    return navigation;\n  }\n}\nfunction getSubmittingNavigation(location, submission) {\n  let navigation = {\n    state: \"submitting\",\n    location,\n    formMethod: submission.formMethod,\n    formAction: submission.formAction,\n    formEncType: submission.formEncType,\n    formData: submission.formData,\n    json: submission.json,\n    text: submission.text\n  };\n  return navigation;\n}\nfunction getLoadingFetcher(submission, data2) {\n  if (submission) {\n    let fetcher = {\n      state: \"loading\",\n      formMethod: submission.formMethod,\n      formAction: submission.formAction,\n      formEncType: submission.formEncType,\n      formData: submission.formData,\n      json: submission.json,\n      text: submission.text,\n      data: data2\n    };\n    return fetcher;\n  } else {\n    let fetcher = {\n      state: \"loading\",\n      formMethod: void 0,\n      formAction: void 0,\n      formEncType: void 0,\n      formData: void 0,\n      json: void 0,\n      text: void 0,\n      data: data2\n    };\n    return fetcher;\n  }\n}\nfunction getSubmittingFetcher(submission, existingFetcher) {\n  let fetcher = {\n    state: \"submitting\",\n    formMethod: submission.formMethod,\n    formAction: submission.formAction,\n    formEncType: submission.formEncType,\n    formData: submission.formData,\n    json: submission.json,\n    text: submission.text,\n    data: existingFetcher ? existingFetcher.data : void 0\n  };\n  return fetcher;\n}\nfunction getDoneFetcher(data2) {\n  let fetcher = {\n    state: \"idle\",\n    formMethod: void 0,\n    formAction: void 0,\n    formEncType: void 0,\n    formData: void 0,\n    json: void 0,\n    text: void 0,\n    data: data2\n  };\n  return fetcher;\n}\nfunction restoreAppliedTransitions(_window, transitions) {\n  try {\n    let sessionPositions = _window.sessionStorage.getItem(\n      TRANSITIONS_STORAGE_KEY\n    );\n    if (sessionPositions) {\n      let json = JSON.parse(sessionPositions);\n      for (let [k, v] of Object.entries(json || {})) {\n        if (v && Array.isArray(v)) {\n          transitions.set(k, new Set(v || []));\n        }\n      }\n    }\n  } catch (e) {\n  }\n}\nfunction persistAppliedTransitions(_window, transitions) {\n  if (transitions.size > 0) {\n    let json = {};\n    for (let [k, v] of transitions) {\n      json[k] = [...v];\n    }\n    try {\n      _window.sessionStorage.setItem(\n        TRANSITIONS_STORAGE_KEY,\n        JSON.stringify(json)\n      );\n    } catch (error) {\n      warning(\n        false,\n        `Failed to save applied view transitions in sessionStorage (${error}).`\n      );\n    }\n  }\n}\nfunction createDeferred() {\n  let resolve;\n  let reject;\n  let promise = new Promise((res, rej) => {\n    resolve = async (val) => {\n      res(val);\n      try {\n        await promise;\n      } catch (e) {\n      }\n    };\n    reject = async (error) => {\n      rej(error);\n      try {\n        await promise;\n      } catch (e) {\n      }\n    };\n  });\n  return {\n    promise,\n    //@ts-ignore\n    resolve,\n    //@ts-ignore\n    reject\n  };\n}\n\n// lib/components.tsx\nimport * as React3 from \"react\";\n\n// lib/context.ts\nimport * as React from \"react\";\nvar DataRouterContext = React.createContext(null);\nDataRouterContext.displayName = \"DataRouter\";\nvar DataRouterStateContext = React.createContext(null);\nDataRouterStateContext.displayName = \"DataRouterState\";\nvar ViewTransitionContext = React.createContext({\n  isTransitioning: false\n});\nViewTransitionContext.displayName = \"ViewTransition\";\nvar FetchersContext = React.createContext(\n  /* @__PURE__ */ new Map()\n);\nFetchersContext.displayName = \"Fetchers\";\nvar AwaitContext = React.createContext(null);\nAwaitContext.displayName = \"Await\";\nvar NavigationContext = React.createContext(\n  null\n);\nNavigationContext.displayName = \"Navigation\";\nvar LocationContext = React.createContext(\n  null\n);\nLocationContext.displayName = \"Location\";\nvar RouteContext = React.createContext({\n  outlet: null,\n  matches: [],\n  isDataRoute: false\n});\nRouteContext.displayName = \"Route\";\nvar RouteErrorContext = React.createContext(null);\nRouteErrorContext.displayName = \"RouteError\";\n\n// lib/hooks.tsx\nimport * as React2 from \"react\";\nvar ENABLE_DEV_WARNINGS = true;\nfunction useHref(to, { relative } = {}) {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of the\n    // router loaded. We can help them understand how to avoid that.\n    `useHref() may be used only in the context of a <Router> component.`\n  );\n  let { basename, navigator: navigator2 } = React2.useContext(NavigationContext);\n  let { hash, pathname, search } = useResolvedPath(to, { relative });\n  let joinedPathname = pathname;\n  if (basename !== \"/\") {\n    joinedPathname = pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n  }\n  return navigator2.createHref({ pathname: joinedPathname, search, hash });\n}\nfunction useInRouterContext() {\n  return React2.useContext(LocationContext) != null;\n}\nfunction useLocation() {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of the\n    // router loaded. We can help them understand how to avoid that.\n    `useLocation() may be used only in the context of a <Router> component.`\n  );\n  return React2.useContext(LocationContext).location;\n}\nfunction useNavigationType() {\n  return React2.useContext(LocationContext).navigationType;\n}\nfunction useMatch(pattern) {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of the\n    // router loaded. We can help them understand how to avoid that.\n    `useMatch() may be used only in the context of a <Router> component.`\n  );\n  let { pathname } = useLocation();\n  return React2.useMemo(\n    () => matchPath(pattern, decodePath(pathname)),\n    [pathname, pattern]\n  );\n}\nvar navigateEffectWarning = `You should call navigate() in a React.useEffect(), not when your component is first rendered.`;\nfunction useIsomorphicLayoutEffect(cb) {\n  let isStatic = React2.useContext(NavigationContext).static;\n  if (!isStatic) {\n    React2.useLayoutEffect(cb);\n  }\n}\nfunction useNavigate() {\n  let { isDataRoute } = React2.useContext(RouteContext);\n  return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\nfunction useNavigateUnstable() {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of the\n    // router loaded. We can help them understand how to avoid that.\n    `useNavigate() may be used only in the context of a <Router> component.`\n  );\n  let dataRouterContext = React2.useContext(DataRouterContext);\n  let { basename, navigator: navigator2 } = React2.useContext(NavigationContext);\n  let { matches } = React2.useContext(RouteContext);\n  let { pathname: locationPathname } = useLocation();\n  let routePathnamesJson = JSON.stringify(getResolveToMatches(matches));\n  let activeRef = React2.useRef(false);\n  useIsomorphicLayoutEffect(() => {\n    activeRef.current = true;\n  });\n  let navigate = React2.useCallback(\n    (to, options = {}) => {\n      warning(activeRef.current, navigateEffectWarning);\n      if (!activeRef.current) return;\n      if (typeof to === \"number\") {\n        navigator2.go(to);\n        return;\n      }\n      let path = resolveTo(\n        to,\n        JSON.parse(routePathnamesJson),\n        locationPathname,\n        options.relative === \"path\"\n      );\n      if (dataRouterContext == null && basename !== \"/\") {\n        path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n      }\n      (!!options.replace ? navigator2.replace : navigator2.push)(\n        path,\n        options.state,\n        options\n      );\n    },\n    [\n      basename,\n      navigator2,\n      routePathnamesJson,\n      locationPathname,\n      dataRouterContext\n    ]\n  );\n  return navigate;\n}\nvar OutletContext = React2.createContext(null);\nfunction useOutletContext() {\n  return React2.useContext(OutletContext);\n}\nfunction useOutlet(context) {\n  let outlet = React2.useContext(RouteContext).outlet;\n  if (outlet) {\n    return /* @__PURE__ */ React2.createElement(OutletContext.Provider, { value: context }, outlet);\n  }\n  return outlet;\n}\nfunction useParams() {\n  let { matches } = React2.useContext(RouteContext);\n  let routeMatch = matches[matches.length - 1];\n  return routeMatch ? routeMatch.params : {};\n}\nfunction useResolvedPath(to, { relative } = {}) {\n  let { matches } = React2.useContext(RouteContext);\n  let { pathname: locationPathname } = useLocation();\n  let routePathnamesJson = JSON.stringify(getResolveToMatches(matches));\n  return React2.useMemo(\n    () => resolveTo(\n      to,\n      JSON.parse(routePathnamesJson),\n      locationPathname,\n      relative === \"path\"\n    ),\n    [to, routePathnamesJson, locationPathname, relative]\n  );\n}\nfunction useRoutes(routes, locationArg) {\n  return useRoutesImpl(routes, locationArg);\n}\nfunction useRoutesImpl(routes, locationArg, dataRouterState, future) {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of the\n    // router loaded. We can help them understand how to avoid that.\n    `useRoutes() may be used only in the context of a <Router> component.`\n  );\n  let { navigator: navigator2 } = React2.useContext(NavigationContext);\n  let { matches: parentMatches } = React2.useContext(RouteContext);\n  let routeMatch = parentMatches[parentMatches.length - 1];\n  let parentParams = routeMatch ? routeMatch.params : {};\n  let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n  let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n  let parentRoute = routeMatch && routeMatch.route;\n  if (ENABLE_DEV_WARNINGS) {\n    let parentPath = parentRoute && parentRoute.path || \"\";\n    warningOnce(\n      parentPathname,\n      !parentRoute || parentPath.endsWith(\"*\") || parentPath.endsWith(\"*?\"),\n      `You rendered descendant <Routes> (or called \\`useRoutes()\\`) at \"${parentPathname}\" (under <Route path=\"${parentPath}\">) but the parent route path has no trailing \"*\". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render.\n\nPlease change the parent <Route path=\"${parentPath}\"> to <Route path=\"${parentPath === \"/\" ? \"*\" : `${parentPath}/*`}\">.`\n    );\n  }\n  let locationFromContext = useLocation();\n  let location;\n  if (locationArg) {\n    let parsedLocationArg = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n    invariant(\n      parentPathnameBase === \"/\" || parsedLocationArg.pathname?.startsWith(parentPathnameBase),\n      `When overriding the location using \\`<Routes location>\\` or \\`useRoutes(routes, location)\\`, the location pathname must begin with the portion of the URL pathname that was matched by all parent routes. The current pathname base is \"${parentPathnameBase}\" but pathname \"${parsedLocationArg.pathname}\" was given in the \\`location\\` prop.`\n    );\n    location = parsedLocationArg;\n  } else {\n    location = locationFromContext;\n  }\n  let pathname = location.pathname || \"/\";\n  let remainingPathname = pathname;\n  if (parentPathnameBase !== \"/\") {\n    let parentSegments = parentPathnameBase.replace(/^\\//, \"\").split(\"/\");\n    let segments = pathname.replace(/^\\//, \"\").split(\"/\");\n    remainingPathname = \"/\" + segments.slice(parentSegments.length).join(\"/\");\n  }\n  let matches = matchRoutes(routes, { pathname: remainingPathname });\n  if (ENABLE_DEV_WARNINGS) {\n    warning(\n      parentRoute || matches != null,\n      `No routes matched location \"${location.pathname}${location.search}${location.hash}\" `\n    );\n    warning(\n      matches == null || matches[matches.length - 1].route.element !== void 0 || matches[matches.length - 1].route.Component !== void 0 || matches[matches.length - 1].route.lazy !== void 0,\n      `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" does not have an element or Component. This means it will render an <Outlet /> with a null value by default resulting in an \"empty\" page.`\n    );\n  }\n  let renderedMatches = _renderMatches(\n    matches && matches.map(\n      (match) => Object.assign({}, match, {\n        params: Object.assign({}, parentParams, match.params),\n        pathname: joinPaths([\n          parentPathnameBase,\n          // Re-encode pathnames that were decoded inside matchRoutes\n          navigator2.encodeLocation ? navigator2.encodeLocation(match.pathname).pathname : match.pathname\n        ]),\n        pathnameBase: match.pathnameBase === \"/\" ? parentPathnameBase : joinPaths([\n          parentPathnameBase,\n          // Re-encode pathnames that were decoded inside matchRoutes\n          navigator2.encodeLocation ? navigator2.encodeLocation(match.pathnameBase).pathname : match.pathnameBase\n        ])\n      })\n    ),\n    parentMatches,\n    dataRouterState,\n    future\n  );\n  if (locationArg && renderedMatches) {\n    return /* @__PURE__ */ React2.createElement(\n      LocationContext.Provider,\n      {\n        value: {\n          location: {\n            pathname: \"/\",\n            search: \"\",\n            hash: \"\",\n            state: null,\n            key: \"default\",\n            ...location\n          },\n          navigationType: \"POP\" /* Pop */\n        }\n      },\n      renderedMatches\n    );\n  }\n  return renderedMatches;\n}\nfunction DefaultErrorComponent() {\n  let error = useRouteError();\n  let message = isRouteErrorResponse(error) ? `${error.status} ${error.statusText}` : error instanceof Error ? error.message : JSON.stringify(error);\n  let stack = error instanceof Error ? error.stack : null;\n  let lightgrey = \"rgba(200,200,200, 0.5)\";\n  let preStyles = { padding: \"0.5rem\", backgroundColor: lightgrey };\n  let codeStyles = { padding: \"2px 4px\", backgroundColor: lightgrey };\n  let devInfo = null;\n  if (ENABLE_DEV_WARNINGS) {\n    console.error(\n      \"Error handled by React Router default ErrorBoundary:\",\n      error\n    );\n    devInfo = /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(\"p\", null, \"\\u{1F4BF} Hey developer \\u{1F44B}\"), /* @__PURE__ */ React2.createElement(\"p\", null, \"You can provide a way better UX than this when your app throws errors by providing your own \", /* @__PURE__ */ React2.createElement(\"code\", { style: codeStyles }, \"ErrorBoundary\"), \" or\", \" \", /* @__PURE__ */ React2.createElement(\"code\", { style: codeStyles }, \"errorElement\"), \" prop on your route.\"));\n  }\n  return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(\"h2\", null, \"Unexpected Application Error!\"), /* @__PURE__ */ React2.createElement(\"h3\", { style: { fontStyle: \"italic\" } }, message), stack ? /* @__PURE__ */ React2.createElement(\"pre\", { style: preStyles }, stack) : null, devInfo);\n}\nvar defaultErrorElement = /* @__PURE__ */ React2.createElement(DefaultErrorComponent, null);\nvar RenderErrorBoundary = class extends React2.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      location: props.location,\n      revalidation: props.revalidation,\n      error: props.error\n    };\n  }\n  static getDerivedStateFromError(error) {\n    return { error };\n  }\n  static getDerivedStateFromProps(props, state) {\n    if (state.location !== props.location || state.revalidation !== \"idle\" && props.revalidation === \"idle\") {\n      return {\n        error: props.error,\n        location: props.location,\n        revalidation: props.revalidation\n      };\n    }\n    return {\n      error: props.error !== void 0 ? props.error : state.error,\n      location: state.location,\n      revalidation: props.revalidation || state.revalidation\n    };\n  }\n  componentDidCatch(error, errorInfo) {\n    console.error(\n      \"React Router caught the following error during render\",\n      error,\n      errorInfo\n    );\n  }\n  render() {\n    return this.state.error !== void 0 ? /* @__PURE__ */ React2.createElement(RouteContext.Provider, { value: this.props.routeContext }, /* @__PURE__ */ React2.createElement(\n      RouteErrorContext.Provider,\n      {\n        value: this.state.error,\n        children: this.props.component\n      }\n    )) : this.props.children;\n  }\n};\nfunction RenderedRoute({ routeContext, match, children }) {\n  let dataRouterContext = React2.useContext(DataRouterContext);\n  if (dataRouterContext && dataRouterContext.static && dataRouterContext.staticContext && (match.route.errorElement || match.route.ErrorBoundary)) {\n    dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n  }\n  return /* @__PURE__ */ React2.createElement(RouteContext.Provider, { value: routeContext }, children);\n}\nfunction _renderMatches(matches, parentMatches = [], dataRouterState = null, future = null) {\n  if (matches == null) {\n    if (!dataRouterState) {\n      return null;\n    }\n    if (dataRouterState.errors) {\n      matches = dataRouterState.matches;\n    } else if (parentMatches.length === 0 && !dataRouterState.initialized && dataRouterState.matches.length > 0) {\n      matches = dataRouterState.matches;\n    } else {\n      return null;\n    }\n  }\n  let renderedMatches = matches;\n  let errors = dataRouterState?.errors;\n  if (errors != null) {\n    let errorIndex = renderedMatches.findIndex(\n      (m) => m.route.id && errors?.[m.route.id] !== void 0\n    );\n    invariant(\n      errorIndex >= 0,\n      `Could not find a matching route for errors on route IDs: ${Object.keys(\n        errors\n      ).join(\",\")}`\n    );\n    renderedMatches = renderedMatches.slice(\n      0,\n      Math.min(renderedMatches.length, errorIndex + 1)\n    );\n  }\n  let renderFallback = false;\n  let fallbackIndex = -1;\n  if (dataRouterState) {\n    for (let i = 0; i < renderedMatches.length; i++) {\n      let match = renderedMatches[i];\n      if (match.route.HydrateFallback || match.route.hydrateFallbackElement) {\n        fallbackIndex = i;\n      }\n      if (match.route.id) {\n        let { loaderData, errors: errors2 } = dataRouterState;\n        let needsToRunLoader = match.route.loader && !loaderData.hasOwnProperty(match.route.id) && (!errors2 || errors2[match.route.id] === void 0);\n        if (match.route.lazy || needsToRunLoader) {\n          renderFallback = true;\n          if (fallbackIndex >= 0) {\n            renderedMatches = renderedMatches.slice(0, fallbackIndex + 1);\n          } else {\n            renderedMatches = [renderedMatches[0]];\n          }\n          break;\n        }\n      }\n    }\n  }\n  return renderedMatches.reduceRight((outlet, match, index) => {\n    let error;\n    let shouldRenderHydrateFallback = false;\n    let errorElement = null;\n    let hydrateFallbackElement = null;\n    if (dataRouterState) {\n      error = errors && match.route.id ? errors[match.route.id] : void 0;\n      errorElement = match.route.errorElement || defaultErrorElement;\n      if (renderFallback) {\n        if (fallbackIndex < 0 && index === 0) {\n          warningOnce(\n            \"route-fallback\",\n            false,\n            \"No `HydrateFallback` element provided to render during initial hydration\"\n          );\n          shouldRenderHydrateFallback = true;\n          hydrateFallbackElement = null;\n        } else if (fallbackIndex === index) {\n          shouldRenderHydrateFallback = true;\n          hydrateFallbackElement = match.route.hydrateFallbackElement || null;\n        }\n      }\n    }\n    let matches2 = parentMatches.concat(renderedMatches.slice(0, index + 1));\n    let getChildren = () => {\n      let children;\n      if (error) {\n        children = errorElement;\n      } else if (shouldRenderHydrateFallback) {\n        children = hydrateFallbackElement;\n      } else if (match.route.Component) {\n        children = /* @__PURE__ */ React2.createElement(match.route.Component, null);\n      } else if (match.route.element) {\n        children = match.route.element;\n      } else {\n        children = outlet;\n      }\n      return /* @__PURE__ */ React2.createElement(\n        RenderedRoute,\n        {\n          match,\n          routeContext: {\n            outlet,\n            matches: matches2,\n            isDataRoute: dataRouterState != null\n          },\n          children\n        }\n      );\n    };\n    return dataRouterState && (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? /* @__PURE__ */ React2.createElement(\n      RenderErrorBoundary,\n      {\n        location: dataRouterState.location,\n        revalidation: dataRouterState.revalidation,\n        component: errorElement,\n        error,\n        children: getChildren(),\n        routeContext: { outlet: null, matches: matches2, isDataRoute: true }\n      }\n    ) : getChildren();\n  }, null);\n}\nfunction getDataRouterConsoleError(hookName) {\n  return `${hookName} must be used within a data router.  See https://reactrouter.com/en/main/routers/picking-a-router.`;\n}\nfunction useDataRouterContext(hookName) {\n  let ctx = React2.useContext(DataRouterContext);\n  invariant(ctx, getDataRouterConsoleError(hookName));\n  return ctx;\n}\nfunction useDataRouterState(hookName) {\n  let state = React2.useContext(DataRouterStateContext);\n  invariant(state, getDataRouterConsoleError(hookName));\n  return state;\n}\nfunction useRouteContext(hookName) {\n  let route = React2.useContext(RouteContext);\n  invariant(route, getDataRouterConsoleError(hookName));\n  return route;\n}\nfunction useCurrentRouteId(hookName) {\n  let route = useRouteContext(hookName);\n  let thisRoute = route.matches[route.matches.length - 1];\n  invariant(\n    thisRoute.route.id,\n    `${hookName} can only be used on routes that contain a unique \"id\"`\n  );\n  return thisRoute.route.id;\n}\nfunction useRouteId() {\n  return useCurrentRouteId(\"useRouteId\" /* UseRouteId */);\n}\nfunction useNavigation() {\n  let state = useDataRouterState(\"useNavigation\" /* UseNavigation */);\n  return state.navigation;\n}\nfunction useRevalidator() {\n  let dataRouterContext = useDataRouterContext(\"useRevalidator\" /* UseRevalidator */);\n  let state = useDataRouterState(\"useRevalidator\" /* UseRevalidator */);\n  return React2.useMemo(\n    () => ({\n      async revalidate() {\n        await dataRouterContext.router.revalidate();\n      },\n      state: state.revalidation\n    }),\n    [dataRouterContext.router, state.revalidation]\n  );\n}\nfunction useMatches() {\n  let { matches, loaderData } = useDataRouterState(\n    \"useMatches\" /* UseMatches */\n  );\n  return React2.useMemo(\n    () => matches.map((m) => convertRouteMatchToUiMatch(m, loaderData)),\n    [matches, loaderData]\n  );\n}\nfunction useLoaderData() {\n  let state = useDataRouterState(\"useLoaderData\" /* UseLoaderData */);\n  let routeId = useCurrentRouteId(\"useLoaderData\" /* UseLoaderData */);\n  return state.loaderData[routeId];\n}\nfunction useRouteLoaderData(routeId) {\n  let state = useDataRouterState(\"useRouteLoaderData\" /* UseRouteLoaderData */);\n  return state.loaderData[routeId];\n}\nfunction useActionData() {\n  let state = useDataRouterState(\"useActionData\" /* UseActionData */);\n  let routeId = useCurrentRouteId(\"useLoaderData\" /* UseLoaderData */);\n  return state.actionData ? state.actionData[routeId] : void 0;\n}\nfunction useRouteError() {\n  let error = React2.useContext(RouteErrorContext);\n  let state = useDataRouterState(\"useRouteError\" /* UseRouteError */);\n  let routeId = useCurrentRouteId(\"useRouteError\" /* UseRouteError */);\n  if (error !== void 0) {\n    return error;\n  }\n  return state.errors?.[routeId];\n}\nfunction useAsyncValue() {\n  let value = React2.useContext(AwaitContext);\n  return value?._data;\n}\nfunction useAsyncError() {\n  let value = React2.useContext(AwaitContext);\n  return value?._error;\n}\nvar blockerId = 0;\nfunction useBlocker(shouldBlock) {\n  let { router, basename } = useDataRouterContext(\"useBlocker\" /* UseBlocker */);\n  let state = useDataRouterState(\"useBlocker\" /* UseBlocker */);\n  let [blockerKey, setBlockerKey] = React2.useState(\"\");\n  let blockerFunction = React2.useCallback(\n    (arg) => {\n      if (typeof shouldBlock !== \"function\") {\n        return !!shouldBlock;\n      }\n      if (basename === \"/\") {\n        return shouldBlock(arg);\n      }\n      let { currentLocation, nextLocation, historyAction } = arg;\n      return shouldBlock({\n        currentLocation: {\n          ...currentLocation,\n          pathname: stripBasename(currentLocation.pathname, basename) || currentLocation.pathname\n        },\n        nextLocation: {\n          ...nextLocation,\n          pathname: stripBasename(nextLocation.pathname, basename) || nextLocation.pathname\n        },\n        historyAction\n      });\n    },\n    [basename, shouldBlock]\n  );\n  React2.useEffect(() => {\n    let key = String(++blockerId);\n    setBlockerKey(key);\n    return () => router.deleteBlocker(key);\n  }, [router]);\n  React2.useEffect(() => {\n    if (blockerKey !== \"\") {\n      router.getBlocker(blockerKey, blockerFunction);\n    }\n  }, [router, blockerKey, blockerFunction]);\n  return blockerKey && state.blockers.has(blockerKey) ? state.blockers.get(blockerKey) : IDLE_BLOCKER;\n}\nfunction useNavigateStable() {\n  let { router } = useDataRouterContext(\"useNavigate\" /* UseNavigateStable */);\n  let id = useCurrentRouteId(\"useNavigate\" /* UseNavigateStable */);\n  let activeRef = React2.useRef(false);\n  useIsomorphicLayoutEffect(() => {\n    activeRef.current = true;\n  });\n  let navigate = React2.useCallback(\n    async (to, options = {}) => {\n      warning(activeRef.current, navigateEffectWarning);\n      if (!activeRef.current) return;\n      if (typeof to === \"number\") {\n        router.navigate(to);\n      } else {\n        await router.navigate(to, { fromRouteId: id, ...options });\n      }\n    },\n    [router, id]\n  );\n  return navigate;\n}\nvar alreadyWarned = {};\nfunction warningOnce(key, cond, message) {\n  if (!cond && !alreadyWarned[key]) {\n    alreadyWarned[key] = true;\n    warning(false, message);\n  }\n}\n\n// lib/server-runtime/warnings.ts\nvar alreadyWarned2 = {};\nfunction warnOnce(condition, message) {\n  if (!condition && !alreadyWarned2[message]) {\n    alreadyWarned2[message] = true;\n    console.warn(message);\n  }\n}\n\n// lib/components.tsx\nvar ENABLE_DEV_WARNINGS2 = true;\nfunction mapRouteProperties(route) {\n  let updates = {\n    // Note: this check also occurs in createRoutesFromChildren so update\n    // there if you change this -- please and thank you!\n    hasErrorBoundary: route.hasErrorBoundary || route.ErrorBoundary != null || route.errorElement != null\n  };\n  if (route.Component) {\n    if (ENABLE_DEV_WARNINGS2) {\n      if (route.element) {\n        warning(\n          false,\n          \"You should not include both `Component` and `element` on your route - `Component` will be used.\"\n        );\n      }\n    }\n    Object.assign(updates, {\n      element: React3.createElement(route.Component),\n      Component: void 0\n    });\n  }\n  if (route.HydrateFallback) {\n    if (ENABLE_DEV_WARNINGS2) {\n      if (route.hydrateFallbackElement) {\n        warning(\n          false,\n          \"You should not include both `HydrateFallback` and `hydrateFallbackElement` on your route - `HydrateFallback` will be used.\"\n        );\n      }\n    }\n    Object.assign(updates, {\n      hydrateFallbackElement: React3.createElement(route.HydrateFallback),\n      HydrateFallback: void 0\n    });\n  }\n  if (route.ErrorBoundary) {\n    if (ENABLE_DEV_WARNINGS2) {\n      if (route.errorElement) {\n        warning(\n          false,\n          \"You should not include both `ErrorBoundary` and `errorElement` on your route - `ErrorBoundary` will be used.\"\n        );\n      }\n    }\n    Object.assign(updates, {\n      errorElement: React3.createElement(route.ErrorBoundary),\n      ErrorBoundary: void 0\n    });\n  }\n  return updates;\n}\nfunction createMemoryRouter(routes, opts) {\n  return createRouter({\n    basename: opts?.basename,\n    future: opts?.future,\n    history: createMemoryHistory({\n      initialEntries: opts?.initialEntries,\n      initialIndex: opts?.initialIndex\n    }),\n    hydrationData: opts?.hydrationData,\n    routes,\n    mapRouteProperties,\n    dataStrategy: opts?.dataStrategy,\n    patchRoutesOnNavigation: opts?.patchRoutesOnNavigation\n  }).initialize();\n}\nvar Deferred = class {\n  constructor() {\n    this.status = \"pending\";\n    this.promise = new Promise((resolve, reject) => {\n      this.resolve = (value) => {\n        if (this.status === \"pending\") {\n          this.status = \"resolved\";\n          resolve(value);\n        }\n      };\n      this.reject = (reason) => {\n        if (this.status === \"pending\") {\n          this.status = \"rejected\";\n          reject(reason);\n        }\n      };\n    });\n  }\n};\nfunction RouterProvider({\n  router,\n  flushSync: reactDomFlushSyncImpl\n}) {\n  let [state, setStateImpl] = React3.useState(router.state);\n  let [pendingState, setPendingState] = React3.useState();\n  let [vtContext, setVtContext] = React3.useState({\n    isTransitioning: false\n  });\n  let [renderDfd, setRenderDfd] = React3.useState();\n  let [transition, setTransition] = React3.useState();\n  let [interruption, setInterruption] = React3.useState();\n  let fetcherData = React3.useRef(/* @__PURE__ */ new Map());\n  let setState = React3.useCallback(\n    (newState, { deletedFetchers, flushSync, viewTransitionOpts }) => {\n      deletedFetchers.forEach((key) => fetcherData.current.delete(key));\n      newState.fetchers.forEach((fetcher, key) => {\n        if (fetcher.data !== void 0) {\n          fetcherData.current.set(key, fetcher.data);\n        }\n      });\n      warnOnce(\n        flushSync === false || reactDomFlushSyncImpl != null,\n        'You provided the `flushSync` option to a router update, but you are not using the `<RouterProvider>` from `react-router/dom` so `ReactDOM.flushSync()` is unavailable.  Please update your app to `import { RouterProvider } from \"react-router/dom\"` and ensure you have `react-dom` installed as a dependency to use the `flushSync` option.'\n      );\n      let isViewTransitionAvailable = router.window != null && router.window.document != null && typeof router.window.document.startViewTransition === \"function\";\n      warnOnce(\n        viewTransitionOpts == null || isViewTransitionAvailable,\n        \"You provided the `viewTransition` option to a router update, but you do not appear to be running in a DOM environment as `window.startViewTransition` is not available.\"\n      );\n      if (!viewTransitionOpts || !isViewTransitionAvailable) {\n        if (reactDomFlushSyncImpl && flushSync) {\n          reactDomFlushSyncImpl(() => setStateImpl(newState));\n        } else {\n          React3.startTransition(() => setStateImpl(newState));\n        }\n        return;\n      }\n      if (reactDomFlushSyncImpl && flushSync) {\n        reactDomFlushSyncImpl(() => {\n          if (transition) {\n            renderDfd && renderDfd.resolve();\n            transition.skipTransition();\n          }\n          setVtContext({\n            isTransitioning: true,\n            flushSync: true,\n            currentLocation: viewTransitionOpts.currentLocation,\n            nextLocation: viewTransitionOpts.nextLocation\n          });\n        });\n        let t = router.window.document.startViewTransition(() => {\n          reactDomFlushSyncImpl(() => setStateImpl(newState));\n        });\n        t.finished.finally(() => {\n          reactDomFlushSyncImpl(() => {\n            setRenderDfd(void 0);\n            setTransition(void 0);\n            setPendingState(void 0);\n            setVtContext({ isTransitioning: false });\n          });\n        });\n        reactDomFlushSyncImpl(() => setTransition(t));\n        return;\n      }\n      if (transition) {\n        renderDfd && renderDfd.resolve();\n        transition.skipTransition();\n        setInterruption({\n          state: newState,\n          currentLocation: viewTransitionOpts.currentLocation,\n          nextLocation: viewTransitionOpts.nextLocation\n        });\n      } else {\n        setPendingState(newState);\n        setVtContext({\n          isTransitioning: true,\n          flushSync: false,\n          currentLocation: viewTransitionOpts.currentLocation,\n          nextLocation: viewTransitionOpts.nextLocation\n        });\n      }\n    },\n    [router.window, reactDomFlushSyncImpl, transition, renderDfd]\n  );\n  React3.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n  React3.useEffect(() => {\n    if (vtContext.isTransitioning && !vtContext.flushSync) {\n      setRenderDfd(new Deferred());\n    }\n  }, [vtContext]);\n  React3.useEffect(() => {\n    if (renderDfd && pendingState && router.window) {\n      let newState = pendingState;\n      let renderPromise = renderDfd.promise;\n      let transition2 = router.window.document.startViewTransition(async () => {\n        React3.startTransition(() => setStateImpl(newState));\n        await renderPromise;\n      });\n      transition2.finished.finally(() => {\n        setRenderDfd(void 0);\n        setTransition(void 0);\n        setPendingState(void 0);\n        setVtContext({ isTransitioning: false });\n      });\n      setTransition(transition2);\n    }\n  }, [pendingState, renderDfd, router.window]);\n  React3.useEffect(() => {\n    if (renderDfd && pendingState && state.location.key === pendingState.location.key) {\n      renderDfd.resolve();\n    }\n  }, [renderDfd, transition, state.location, pendingState]);\n  React3.useEffect(() => {\n    if (!vtContext.isTransitioning && interruption) {\n      setPendingState(interruption.state);\n      setVtContext({\n        isTransitioning: true,\n        flushSync: false,\n        currentLocation: interruption.currentLocation,\n        nextLocation: interruption.nextLocation\n      });\n      setInterruption(void 0);\n    }\n  }, [vtContext.isTransitioning, interruption]);\n  let navigator2 = React3.useMemo(() => {\n    return {\n      createHref: router.createHref,\n      encodeLocation: router.encodeLocation,\n      go: (n) => router.navigate(n),\n      push: (to, state2, opts) => router.navigate(to, {\n        state: state2,\n        preventScrollReset: opts?.preventScrollReset\n      }),\n      replace: (to, state2, opts) => router.navigate(to, {\n        replace: true,\n        state: state2,\n        preventScrollReset: opts?.preventScrollReset\n      })\n    };\n  }, [router]);\n  let basename = router.basename || \"/\";\n  let dataRouterContext = React3.useMemo(\n    () => ({\n      router,\n      navigator: navigator2,\n      static: false,\n      basename\n    }),\n    [router, navigator2, basename]\n  );\n  return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ React3.createElement(DataRouterContext.Provider, { value: dataRouterContext }, /* @__PURE__ */ React3.createElement(DataRouterStateContext.Provider, { value: state }, /* @__PURE__ */ React3.createElement(FetchersContext.Provider, { value: fetcherData.current }, /* @__PURE__ */ React3.createElement(ViewTransitionContext.Provider, { value: vtContext }, /* @__PURE__ */ React3.createElement(\n    Router,\n    {\n      basename,\n      location: state.location,\n      navigationType: state.historyAction,\n      navigator: navigator2\n    },\n    /* @__PURE__ */ React3.createElement(\n      MemoizedDataRoutes,\n      {\n        routes: router.routes,\n        future: router.future,\n        state\n      }\n    )\n  ))))), null);\n}\nvar MemoizedDataRoutes = React3.memo(DataRoutes);\nfunction DataRoutes({\n  routes,\n  future,\n  state\n}) {\n  return useRoutesImpl(routes, void 0, state, future);\n}\nfunction MemoryRouter({\n  basename,\n  children,\n  initialEntries,\n  initialIndex\n}) {\n  let historyRef = React3.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createMemoryHistory({\n      initialEntries,\n      initialIndex,\n      v5Compat: true\n    });\n  }\n  let history = historyRef.current;\n  let [state, setStateImpl] = React3.useState({\n    action: history.action,\n    location: history.location\n  });\n  let setState = React3.useCallback(\n    (newState) => {\n      React3.startTransition(() => setStateImpl(newState));\n    },\n    [setStateImpl]\n  );\n  React3.useLayoutEffect(() => history.listen(setState), [history, setState]);\n  return /* @__PURE__ */ React3.createElement(\n    Router,\n    {\n      basename,\n      children,\n      location: state.location,\n      navigationType: state.action,\n      navigator: history\n    }\n  );\n}\nfunction Navigate({\n  to,\n  replace: replace2,\n  state,\n  relative\n}) {\n  invariant(\n    useInRouterContext(),\n    // TODO: This error is probably because they somehow have 2 versions of\n    // the router loaded. We can help them understand how to avoid that.\n    `<Navigate> may be used only in the context of a <Router> component.`\n  );\n  let { static: isStatic } = React3.useContext(NavigationContext);\n  warning(\n    !isStatic,\n    `<Navigate> must not be used on the initial render in a <StaticRouter>. This is a no-op, but you should modify your code so the <Navigate> is only ever rendered in response to some user interaction or state change.`\n  );\n  let { matches } = React3.useContext(RouteContext);\n  let { pathname: locationPathname } = useLocation();\n  let navigate = useNavigate();\n  let path = resolveTo(\n    to,\n    getResolveToMatches(matches),\n    locationPathname,\n    relative === \"path\"\n  );\n  let jsonPath = JSON.stringify(path);\n  React3.useEffect(() => {\n    navigate(JSON.parse(jsonPath), { replace: replace2, state, relative });\n  }, [navigate, jsonPath, relative, replace2, state]);\n  return null;\n}\nfunction Outlet(props) {\n  return useOutlet(props.context);\n}\nfunction Route(_props) {\n  invariant(\n    false,\n    `A <Route> is only ever to be used as the child of <Routes> element, never rendered directly. Please wrap your <Route> in a <Routes>.`\n  );\n}\nfunction Router({\n  basename: basenameProp = \"/\",\n  children = null,\n  location: locationProp,\n  navigationType = \"POP\" /* Pop */,\n  navigator: navigator2,\n  static: staticProp = false\n}) {\n  invariant(\n    !useInRouterContext(),\n    `You cannot render a <Router> inside another <Router>. You should never have more than one in your app.`\n  );\n  let basename = basenameProp.replace(/^\\/*/, \"/\");\n  let navigationContext = React3.useMemo(\n    () => ({\n      basename,\n      navigator: navigator2,\n      static: staticProp,\n      future: {}\n    }),\n    [basename, navigator2, staticProp]\n  );\n  if (typeof locationProp === \"string\") {\n    locationProp = parsePath(locationProp);\n  }\n  let {\n    pathname = \"/\",\n    search = \"\",\n    hash = \"\",\n    state = null,\n    key = \"default\"\n  } = locationProp;\n  let locationContext = React3.useMemo(() => {\n    let trailingPathname = stripBasename(pathname, basename);\n    if (trailingPathname == null) {\n      return null;\n    }\n    return {\n      location: {\n        pathname: trailingPathname,\n        search,\n        hash,\n        state,\n        key\n      },\n      navigationType\n    };\n  }, [basename, pathname, search, hash, state, key, navigationType]);\n  warning(\n    locationContext != null,\n    `<Router basename=\"${basename}\"> is not able to match the URL \"${pathname}${search}${hash}\" because it does not start with the basename, so the <Router> won't render anything.`\n  );\n  if (locationContext == null) {\n    return null;\n  }\n  return /* @__PURE__ */ React3.createElement(NavigationContext.Provider, { value: navigationContext }, /* @__PURE__ */ React3.createElement(LocationContext.Provider, { children, value: locationContext }));\n}\nfunction Routes({\n  children,\n  location\n}) {\n  return useRoutes(createRoutesFromChildren(children), location);\n}\nfunction Await({\n  children,\n  errorElement,\n  resolve\n}) {\n  return /* @__PURE__ */ React3.createElement(AwaitErrorBoundary, { resolve, errorElement }, /* @__PURE__ */ React3.createElement(ResolveAwait, null, children));\n}\nvar AwaitErrorBoundary = class extends React3.Component {\n  constructor(props) {\n    super(props);\n    this.state = { error: null };\n  }\n  static getDerivedStateFromError(error) {\n    return { error };\n  }\n  componentDidCatch(error, errorInfo) {\n    console.error(\n      \"<Await> caught the following error during render\",\n      error,\n      errorInfo\n    );\n  }\n  render() {\n    let { children, errorElement, resolve } = this.props;\n    let promise = null;\n    let status = 0 /* pending */;\n    if (!(resolve instanceof Promise)) {\n      status = 1 /* success */;\n      promise = Promise.resolve();\n      Object.defineProperty(promise, \"_tracked\", { get: () => true });\n      Object.defineProperty(promise, \"_data\", { get: () => resolve });\n    } else if (this.state.error) {\n      status = 2 /* error */;\n      let renderError = this.state.error;\n      promise = Promise.reject().catch(() => {\n      });\n      Object.defineProperty(promise, \"_tracked\", { get: () => true });\n      Object.defineProperty(promise, \"_error\", { get: () => renderError });\n    } else if (resolve._tracked) {\n      promise = resolve;\n      status = \"_error\" in promise ? 2 /* error */ : \"_data\" in promise ? 1 /* success */ : 0 /* pending */;\n    } else {\n      status = 0 /* pending */;\n      Object.defineProperty(resolve, \"_tracked\", { get: () => true });\n      promise = resolve.then(\n        (data2) => Object.defineProperty(resolve, \"_data\", { get: () => data2 }),\n        (error) => Object.defineProperty(resolve, \"_error\", { get: () => error })\n      );\n    }\n    if (status === 2 /* error */ && !errorElement) {\n      throw promise._error;\n    }\n    if (status === 2 /* error */) {\n      return /* @__PURE__ */ React3.createElement(AwaitContext.Provider, { value: promise, children: errorElement });\n    }\n    if (status === 1 /* success */) {\n      return /* @__PURE__ */ React3.createElement(AwaitContext.Provider, { value: promise, children });\n    }\n    throw promise;\n  }\n};\nfunction ResolveAwait({\n  children\n}) {\n  let data2 = useAsyncValue();\n  let toRender = typeof children === \"function\" ? children(data2) : children;\n  return /* @__PURE__ */ React3.createElement(React3.Fragment, null, toRender);\n}\nfunction createRoutesFromChildren(children, parentPath = []) {\n  let routes = [];\n  React3.Children.forEach(children, (element, index) => {\n    if (!React3.isValidElement(element)) {\n      return;\n    }\n    let treePath = [...parentPath, index];\n    if (element.type === React3.Fragment) {\n      routes.push.apply(\n        routes,\n        createRoutesFromChildren(element.props.children, treePath)\n      );\n      return;\n    }\n    invariant(\n      element.type === Route,\n      `[${typeof element.type === \"string\" ? element.type : element.type.name}] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment>`\n    );\n    invariant(\n      !element.props.index || !element.props.children,\n      \"An index route cannot have child routes.\"\n    );\n    let route = {\n      id: element.props.id || treePath.join(\"-\"),\n      caseSensitive: element.props.caseSensitive,\n      element: element.props.element,\n      Component: element.props.Component,\n      index: element.props.index,\n      path: element.props.path,\n      loader: element.props.loader,\n      action: element.props.action,\n      hydrateFallbackElement: element.props.hydrateFallbackElement,\n      HydrateFallback: element.props.HydrateFallback,\n      errorElement: element.props.errorElement,\n      ErrorBoundary: element.props.ErrorBoundary,\n      hasErrorBoundary: element.props.hasErrorBoundary === true || element.props.ErrorBoundary != null || element.props.errorElement != null,\n      shouldRevalidate: element.props.shouldRevalidate,\n      handle: element.props.handle,\n      lazy: element.props.lazy\n    };\n    if (element.props.children) {\n      route.children = createRoutesFromChildren(\n        element.props.children,\n        treePath\n      );\n    }\n    routes.push(route);\n  });\n  return routes;\n}\nvar createRoutesFromElements = createRoutesFromChildren;\nfunction renderMatches(matches) {\n  return _renderMatches(matches);\n}\n\n// lib/dom/lib.tsx\nimport * as React10 from \"react\";\n\n// lib/dom/dom.ts\nvar defaultMethod = \"get\";\nvar defaultEncType = \"application/x-www-form-urlencoded\";\nfunction isHtmlElement(object) {\n  return object != null && typeof object.tagName === \"string\";\n}\nfunction isButtonElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\nfunction isFormElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\nfunction isInputElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\nfunction isModifiedEvent(event) {\n  return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\nfunction shouldProcessLinkClick(event, target) {\n  return event.button === 0 && // Ignore everything but left clicks\n  (!target || target === \"_self\") && // Let browser handle \"target=_blank\" etc.\n  !isModifiedEvent(event);\n}\nfunction createSearchParams(init = \"\") {\n  return new URLSearchParams(\n    typeof init === \"string\" || Array.isArray(init) || init instanceof URLSearchParams ? init : Object.keys(init).reduce((memo2, key) => {\n      let value = init[key];\n      return memo2.concat(\n        Array.isArray(value) ? value.map((v) => [key, v]) : [[key, value]]\n      );\n    }, [])\n  );\n}\nfunction getSearchParamsForLocation(locationSearch, defaultSearchParams) {\n  let searchParams = createSearchParams(locationSearch);\n  if (defaultSearchParams) {\n    defaultSearchParams.forEach((_, key) => {\n      if (!searchParams.has(key)) {\n        defaultSearchParams.getAll(key).forEach((value) => {\n          searchParams.append(key, value);\n        });\n      }\n    });\n  }\n  return searchParams;\n}\nvar _formDataSupportsSubmitter = null;\nfunction isFormDataSubmitterSupported() {\n  if (_formDataSupportsSubmitter === null) {\n    try {\n      new FormData(\n        document.createElement(\"form\"),\n        // @ts-expect-error if FormData supports the submitter parameter, this will throw\n        0\n      );\n      _formDataSupportsSubmitter = false;\n    } catch (e) {\n      _formDataSupportsSubmitter = true;\n    }\n  }\n  return _formDataSupportsSubmitter;\n}\nvar supportedFormEncTypes = /* @__PURE__ */ new Set([\n  \"application/x-www-form-urlencoded\",\n  \"multipart/form-data\",\n  \"text/plain\"\n]);\nfunction getFormEncType(encType) {\n  if (encType != null && !supportedFormEncTypes.has(encType)) {\n    warning(\n      false,\n      `\"${encType}\" is not a valid \\`encType\\` for \\`<Form>\\`/\\`<fetcher.Form>\\` and will default to \"${defaultEncType}\"`\n    );\n    return null;\n  }\n  return encType;\n}\nfunction getFormSubmissionInfo(target, basename) {\n  let method;\n  let action;\n  let encType;\n  let formData;\n  let body;\n  if (isFormElement(target)) {\n    let attr = target.getAttribute(\"action\");\n    action = attr ? stripBasename(attr, basename) : null;\n    method = target.getAttribute(\"method\") || defaultMethod;\n    encType = getFormEncType(target.getAttribute(\"enctype\")) || defaultEncType;\n    formData = new FormData(target);\n  } else if (isButtonElement(target) || isInputElement(target) && (target.type === \"submit\" || target.type === \"image\")) {\n    let form = target.form;\n    if (form == null) {\n      throw new Error(\n        `Cannot submit a <button> or <input type=\"submit\"> without a <form>`\n      );\n    }\n    let attr = target.getAttribute(\"formaction\") || form.getAttribute(\"action\");\n    action = attr ? stripBasename(attr, basename) : null;\n    method = target.getAttribute(\"formmethod\") || form.getAttribute(\"method\") || defaultMethod;\n    encType = getFormEncType(target.getAttribute(\"formenctype\")) || getFormEncType(form.getAttribute(\"enctype\")) || defaultEncType;\n    formData = new FormData(form, target);\n    if (!isFormDataSubmitterSupported()) {\n      let { name, type, value } = target;\n      if (type === \"image\") {\n        let prefix = name ? `${name}.` : \"\";\n        formData.append(`${prefix}x`, \"0\");\n        formData.append(`${prefix}y`, \"0\");\n      } else if (name) {\n        formData.append(name, value);\n      }\n    }\n  } else if (isHtmlElement(target)) {\n    throw new Error(\n      `Cannot submit element that is not <form>, <button>, or <input type=\"submit|image\">`\n    );\n  } else {\n    method = defaultMethod;\n    action = null;\n    encType = defaultEncType;\n    body = target;\n  }\n  if (formData && encType === \"text/plain\") {\n    body = formData;\n    formData = void 0;\n  }\n  return { action, method: method.toLowerCase(), encType, formData, body };\n}\n\n// lib/dom/ssr/components.tsx\nimport * as React9 from \"react\";\n\n// lib/dom/ssr/invariant.ts\nfunction invariant2(value, message) {\n  if (value === false || value === null || typeof value === \"undefined\") {\n    throw new Error(message);\n  }\n}\n\n// lib/dom/ssr/routeModules.ts\nasync function loadRouteModule(route, routeModulesCache) {\n  if (route.id in routeModulesCache) {\n    return routeModulesCache[route.id];\n  }\n  try {\n    let routeModule = await import(\n      /* @vite-ignore */\n      /* webpackIgnore: true */\n      route.module\n    );\n    routeModulesCache[route.id] = routeModule;\n    return routeModule;\n  } catch (error) {\n    console.error(\n      `Error loading route module \\`${route.module}\\`, reloading page...`\n    );\n    console.error(error);\n    if (window.__reactRouterContext && window.__reactRouterContext.isSpaMode && // @ts-expect-error\n    import.meta.hot) {\n      throw error;\n    }\n    window.location.reload();\n    return new Promise(() => {\n    });\n  }\n}\n\n// lib/dom/ssr/links.ts\nfunction getKeyedLinksForMatches(matches, routeModules, manifest) {\n  let descriptors = matches.map((match) => {\n    let module = routeModules[match.route.id];\n    let route = manifest.routes[match.route.id];\n    return [\n      route && route.css ? route.css.map((href) => ({ rel: \"stylesheet\", href })) : [],\n      module?.links?.() || []\n    ];\n  }).flat(2);\n  let preloads = getCurrentPageModulePreloadHrefs(matches, manifest);\n  return dedupeLinkDescriptors(descriptors, preloads);\n}\nasync function prefetchStyleLinks(route, routeModule) {\n  if (!route.css && !routeModule.links || !isPreloadSupported()) return;\n  let descriptors = [];\n  if (route.css) {\n    descriptors.push(...route.css.map((href) => ({ rel: \"stylesheet\", href })));\n  }\n  if (routeModule.links) {\n    descriptors.push(...routeModule.links());\n  }\n  if (descriptors.length === 0) return;\n  let styleLinks = [];\n  for (let descriptor of descriptors) {\n    if (!isPageLinkDescriptor(descriptor) && descriptor.rel === \"stylesheet\") {\n      styleLinks.push({\n        ...descriptor,\n        rel: \"preload\",\n        as: \"style\"\n      });\n    }\n  }\n  let matchingLinks = styleLinks.filter(\n    (link) => (!link.media || window.matchMedia(link.media).matches) && !document.querySelector(`link[rel=\"stylesheet\"][href=\"${link.href}\"]`)\n  );\n  await Promise.all(matchingLinks.map(prefetchStyleLink));\n}\nasync function prefetchStyleLink(descriptor) {\n  return new Promise((resolve) => {\n    let link = document.createElement(\"link\");\n    Object.assign(link, descriptor);\n    function removeLink() {\n      if (document.head.contains(link)) {\n        document.head.removeChild(link);\n      }\n    }\n    link.onload = () => {\n      removeLink();\n      resolve();\n    };\n    link.onerror = () => {\n      removeLink();\n      resolve();\n    };\n    document.head.appendChild(link);\n  });\n}\nfunction isPageLinkDescriptor(object) {\n  return object != null && typeof object.page === \"string\";\n}\nfunction isHtmlLinkDescriptor(object) {\n  if (object == null) {\n    return false;\n  }\n  if (object.href == null) {\n    return object.rel === \"preload\" && typeof object.imageSrcSet === \"string\" && typeof object.imageSizes === \"string\";\n  }\n  return typeof object.rel === \"string\" && typeof object.href === \"string\";\n}\nasync function getKeyedPrefetchLinks(matches, manifest, routeModules) {\n  let links = await Promise.all(\n    matches.map(async (match) => {\n      let route = manifest.routes[match.route.id];\n      if (route) {\n        let mod = await loadRouteModule(route, routeModules);\n        return mod.links ? mod.links() : [];\n      }\n      return [];\n    })\n  );\n  return dedupeLinkDescriptors(\n    links.flat(1).filter(isHtmlLinkDescriptor).filter((link) => link.rel === \"stylesheet\" || link.rel === \"preload\").map(\n      (link) => link.rel === \"stylesheet\" ? { ...link, rel: \"prefetch\", as: \"style\" } : { ...link, rel: \"prefetch\" }\n    )\n  );\n}\nfunction getNewMatchesForLinks(page, nextMatches, currentMatches, manifest, location, mode) {\n  let isNew = (match, index) => {\n    if (!currentMatches[index]) return true;\n    return match.route.id !== currentMatches[index].route.id;\n  };\n  let matchPathChanged = (match, index) => {\n    return (\n      // param change, /users/123 -> /users/456\n      currentMatches[index].pathname !== match.pathname || // splat param changed, which is not present in match.path\n      // e.g. /files/images/avatar.jpg -> files/finances.xls\n      currentMatches[index].route.path?.endsWith(\"*\") && currentMatches[index].params[\"*\"] !== match.params[\"*\"]\n    );\n  };\n  if (mode === \"assets\") {\n    return nextMatches.filter(\n      (match, index) => isNew(match, index) || matchPathChanged(match, index)\n    );\n  }\n  if (mode === \"data\") {\n    return nextMatches.filter((match, index) => {\n      let manifestRoute = manifest.routes[match.route.id];\n      if (!manifestRoute || !manifestRoute.hasLoader) {\n        return false;\n      }\n      if (isNew(match, index) || matchPathChanged(match, index)) {\n        return true;\n      }\n      if (match.route.shouldRevalidate) {\n        let routeChoice = match.route.shouldRevalidate({\n          currentUrl: new URL(\n            location.pathname + location.search + location.hash,\n            window.origin\n          ),\n          currentParams: currentMatches[0]?.params || {},\n          nextUrl: new URL(page, window.origin),\n          nextParams: match.params,\n          defaultShouldRevalidate: true\n        });\n        if (typeof routeChoice === \"boolean\") {\n          return routeChoice;\n        }\n      }\n      return true;\n    });\n  }\n  return [];\n}\nfunction getModuleLinkHrefs(matches, manifestPatch) {\n  return dedupeHrefs(\n    matches.map((match) => {\n      let route = manifestPatch.routes[match.route.id];\n      if (!route) return [];\n      let hrefs = [route.module];\n      if (route.imports) {\n        hrefs = hrefs.concat(route.imports);\n      }\n      return hrefs;\n    }).flat(1)\n  );\n}\nfunction getCurrentPageModulePreloadHrefs(matches, manifest) {\n  return dedupeHrefs(\n    matches.map((match) => {\n      let route = manifest.routes[match.route.id];\n      if (!route) return [];\n      let hrefs = [route.module];\n      if (route.imports) {\n        hrefs = hrefs.concat(route.imports);\n      }\n      return hrefs;\n    }).flat(1)\n  );\n}\nfunction dedupeHrefs(hrefs) {\n  return [...new Set(hrefs)];\n}\nfunction sortKeys(obj) {\n  let sorted = {};\n  let keys = Object.keys(obj).sort();\n  for (let key of keys) {\n    sorted[key] = obj[key];\n  }\n  return sorted;\n}\nfunction dedupeLinkDescriptors(descriptors, preloads) {\n  let set = /* @__PURE__ */ new Set();\n  let preloadsSet = new Set(preloads);\n  return descriptors.reduce((deduped, descriptor) => {\n    let alreadyModulePreload = preloads && !isPageLinkDescriptor(descriptor) && descriptor.as === \"script\" && descriptor.href && preloadsSet.has(descriptor.href);\n    if (alreadyModulePreload) {\n      return deduped;\n    }\n    let key = JSON.stringify(sortKeys(descriptor));\n    if (!set.has(key)) {\n      set.add(key);\n      deduped.push({ key, link: descriptor });\n    }\n    return deduped;\n  }, []);\n}\nvar _isPreloadSupported;\nfunction isPreloadSupported() {\n  if (_isPreloadSupported !== void 0) {\n    return _isPreloadSupported;\n  }\n  let el = document.createElement(\"link\");\n  _isPreloadSupported = el.relList.supports(\"preload\");\n  el = null;\n  return _isPreloadSupported;\n}\n\n// lib/dom/ssr/markup.ts\nvar ESCAPE_LOOKUP = {\n  \"&\": \"\\\\u0026\",\n  \">\": \"\\\\u003e\",\n  \"<\": \"\\\\u003c\",\n  \"\\u2028\": \"\\\\u2028\",\n  \"\\u2029\": \"\\\\u2029\"\n};\nvar ESCAPE_REGEX = /[&><\\u2028\\u2029]/g;\nfunction escapeHtml(html) {\n  return html.replace(ESCAPE_REGEX, (match) => ESCAPE_LOOKUP[match]);\n}\nfunction createHtml(html) {\n  return { __html: html };\n}\n\n// lib/dom/ssr/single-fetch.tsx\nimport * as React4 from \"react\";\nimport { decode } from \"turbo-stream\";\n\n// lib/dom/ssr/data.ts\nasync function createRequestInit(request) {\n  let init = { signal: request.signal };\n  if (request.method !== \"GET\") {\n    init.method = request.method;\n    let contentType = request.headers.get(\"Content-Type\");\n    if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n      init.headers = { \"Content-Type\": contentType };\n      init.body = JSON.stringify(await request.json());\n    } else if (contentType && /\\btext\\/plain\\b/.test(contentType)) {\n      init.headers = { \"Content-Type\": contentType };\n      init.body = await request.text();\n    } else if (contentType && /\\bapplication\\/x-www-form-urlencoded\\b/.test(contentType)) {\n      init.body = new URLSearchParams(await request.text());\n    } else {\n      init.body = await request.formData();\n    }\n  }\n  return init;\n}\n\n// lib/dom/ssr/single-fetch.tsx\nvar SingleFetchRedirectSymbol = Symbol(\"SingleFetchRedirect\");\nfunction StreamTransfer({\n  context,\n  identifier,\n  reader,\n  textDecoder,\n  nonce\n}) {\n  if (!context.renderMeta || !context.renderMeta.didRenderScripts) {\n    return null;\n  }\n  if (!context.renderMeta.streamCache) {\n    context.renderMeta.streamCache = {};\n  }\n  let { streamCache } = context.renderMeta;\n  let promise = streamCache[identifier];\n  if (!promise) {\n    promise = streamCache[identifier] = reader.read().then((result) => {\n      streamCache[identifier].result = {\n        done: result.done,\n        value: textDecoder.decode(result.value, { stream: true })\n      };\n    }).catch((e) => {\n      streamCache[identifier].error = e;\n    });\n  }\n  if (promise.error) {\n    throw promise.error;\n  }\n  if (promise.result === void 0) {\n    throw promise;\n  }\n  let { done, value } = promise.result;\n  let scriptTag = value ? /* @__PURE__ */ React4.createElement(\n    \"script\",\n    {\n      nonce,\n      dangerouslySetInnerHTML: {\n        __html: `window.__reactRouterContext.streamController.enqueue(${escapeHtml(\n          JSON.stringify(value)\n        )});`\n      }\n    }\n  ) : null;\n  if (done) {\n    return /* @__PURE__ */ React4.createElement(React4.Fragment, null, scriptTag, /* @__PURE__ */ React4.createElement(\n      \"script\",\n      {\n        nonce,\n        dangerouslySetInnerHTML: {\n          __html: `window.__reactRouterContext.streamController.close();`\n        }\n      }\n    ));\n  } else {\n    return /* @__PURE__ */ React4.createElement(React4.Fragment, null, scriptTag, /* @__PURE__ */ React4.createElement(React4.Suspense, null, /* @__PURE__ */ React4.createElement(\n      StreamTransfer,\n      {\n        context,\n        identifier: identifier + 1,\n        reader,\n        textDecoder,\n        nonce\n      }\n    )));\n  }\n}\nfunction getSingleFetchDataStrategy(manifest, routeModules, getRouter) {\n  return async ({ request, matches, fetcherKey }) => {\n    if (request.method !== \"GET\") {\n      return singleFetchActionStrategy(request, matches);\n    }\n    if (fetcherKey) {\n      return singleFetchLoaderFetcherStrategy(request, matches);\n    }\n    return singleFetchLoaderNavigationStrategy(\n      manifest,\n      routeModules,\n      getRouter(),\n      request,\n      matches\n    );\n  };\n}\nasync function singleFetchActionStrategy(request, matches) {\n  let actionMatch = matches.find((m) => m.shouldLoad);\n  invariant2(actionMatch, \"No action match found\");\n  let actionStatus = void 0;\n  let result = await actionMatch.resolve(async (handler) => {\n    let result2 = await handler(async () => {\n      let url = singleFetchUrl(request.url);\n      let init = await createRequestInit(request);\n      let { data: data2, status } = await fetchAndDecode(url, init);\n      actionStatus = status;\n      return unwrapSingleFetchResult(\n        data2,\n        actionMatch.route.id\n      );\n    });\n    return result2;\n  });\n  if (isResponse(result.result) || isRouteErrorResponse(result.result)) {\n    return { [actionMatch.route.id]: result };\n  }\n  return {\n    [actionMatch.route.id]: {\n      type: result.type,\n      result: data(result.result, actionStatus)\n    }\n  };\n}\nasync function singleFetchLoaderNavigationStrategy(manifest, routeModules, router, request, matches) {\n  let routesParams = /* @__PURE__ */ new Set();\n  let foundOptOutRoute = false;\n  let routeDfds = matches.map(() => createDeferred2());\n  let routesLoadedPromise = Promise.all(routeDfds.map((d) => d.promise));\n  let singleFetchDfd = createDeferred2();\n  let url = stripIndexParam(singleFetchUrl(request.url));\n  let init = await createRequestInit(request);\n  let results = {};\n  let resolvePromise = Promise.all(\n    matches.map(\n      async (m, i) => m.resolve(async (handler) => {\n        routeDfds[i].resolve();\n        let manifestRoute = manifest.routes[m.route.id];\n        if (!m.shouldLoad) {\n          if (!router.state.initialized) {\n            return;\n          }\n          if (m.route.id in router.state.loaderData && manifestRoute && manifestRoute.hasLoader && routeModules[m.route.id]?.shouldRevalidate) {\n            foundOptOutRoute = true;\n            return;\n          }\n        }\n        if (manifestRoute && manifestRoute.hasClientLoader) {\n          if (manifestRoute.hasLoader) {\n            foundOptOutRoute = true;\n          }\n          try {\n            let result = await fetchSingleLoader(\n              handler,\n              url,\n              init,\n              m.route.id\n            );\n            results[m.route.id] = { type: \"data\", result };\n          } catch (e) {\n            results[m.route.id] = { type: \"error\", result: e };\n          }\n          return;\n        }\n        if (manifestRoute && manifestRoute.hasLoader) {\n          routesParams.add(m.route.id);\n        }\n        try {\n          let result = await handler(async () => {\n            let data2 = await singleFetchDfd.promise;\n            return unwrapSingleFetchResults(data2, m.route.id);\n          });\n          results[m.route.id] = {\n            type: \"data\",\n            result\n          };\n        } catch (e) {\n          results[m.route.id] = {\n            type: \"error\",\n            result: e\n          };\n        }\n      })\n    )\n  );\n  await routesLoadedPromise;\n  if ((!router.state.initialized || routesParams.size === 0) && !window.__reactRouterHdrActive) {\n    singleFetchDfd.resolve({});\n  } else {\n    try {\n      if (foundOptOutRoute && routesParams.size > 0) {\n        url.searchParams.set(\n          \"_routes\",\n          matches.filter((m) => routesParams.has(m.route.id)).map((m) => m.route.id).join(\",\")\n        );\n      }\n      let data2 = await fetchAndDecode(url, init);\n      singleFetchDfd.resolve(data2.data);\n    } catch (e) {\n      singleFetchDfd.reject(e);\n    }\n  }\n  await resolvePromise;\n  return results;\n}\nasync function singleFetchLoaderFetcherStrategy(request, matches) {\n  let fetcherMatch = matches.find((m) => m.shouldLoad);\n  invariant2(fetcherMatch, \"No fetcher match found\");\n  let result = await fetcherMatch.resolve(async (handler) => {\n    let url = stripIndexParam(singleFetchUrl(request.url));\n    let init = await createRequestInit(request);\n    return fetchSingleLoader(handler, url, init, fetcherMatch.route.id);\n  });\n  return { [fetcherMatch.route.id]: result };\n}\nfunction fetchSingleLoader(handler, url, init, routeId) {\n  return handler(async () => {\n    let singleLoaderUrl = new URL(url);\n    singleLoaderUrl.searchParams.set(\"_routes\", routeId);\n    let { data: data2 } = await fetchAndDecode(singleLoaderUrl, init);\n    return unwrapSingleFetchResults(data2, routeId);\n  });\n}\nfunction stripIndexParam(url) {\n  let indexValues = url.searchParams.getAll(\"index\");\n  url.searchParams.delete(\"index\");\n  let indexValuesToKeep = [];\n  for (let indexValue of indexValues) {\n    if (indexValue) {\n      indexValuesToKeep.push(indexValue);\n    }\n  }\n  for (let toKeep of indexValuesToKeep) {\n    url.searchParams.append(\"index\", toKeep);\n  }\n  return url;\n}\nfunction singleFetchUrl(reqUrl) {\n  let url = typeof reqUrl === \"string\" ? new URL(\n    reqUrl,\n    // This can be called during the SSR flow via PrefetchPageLinksImpl so\n    // don't assume window is available\n    typeof window === \"undefined\" ? \"server://singlefetch/\" : window.location.origin\n  ) : reqUrl;\n  if (url.pathname === \"/\") {\n    url.pathname = \"_root.data\";\n  } else {\n    url.pathname = `${url.pathname.replace(/\\/$/, \"\")}.data`;\n  }\n  return url;\n}\nasync function fetchAndDecode(url, init) {\n  let res = await fetch(url, init);\n  if (res.status === 404 && !res.headers.has(\"X-Remix-Response\")) {\n    throw new ErrorResponseImpl(404, \"Not Found\", true);\n  }\n  invariant2(res.body, \"No response body to decode\");\n  try {\n    let decoded = await decodeViaTurboStream(res.body, window);\n    return { status: res.status, data: decoded.value };\n  } catch (e) {\n    throw new Error(\"Unable to decode turbo-stream response\");\n  }\n}\nfunction decodeViaTurboStream(body, global2) {\n  return decode(body, {\n    plugins: [\n      (type, ...rest) => {\n        if (type === \"SanitizedError\") {\n          let [name, message, stack] = rest;\n          let Constructor = Error;\n          if (name && name in global2 && typeof global2[name] === \"function\") {\n            Constructor = global2[name];\n          }\n          let error = new Constructor(message);\n          error.stack = stack;\n          return { value: error };\n        }\n        if (type === \"ErrorResponse\") {\n          let [data2, status, statusText] = rest;\n          return {\n            value: new ErrorResponseImpl(status, statusText, data2)\n          };\n        }\n        if (type === \"SingleFetchRedirect\") {\n          return { value: { [SingleFetchRedirectSymbol]: rest[0] } };\n        }\n        if (type === \"SingleFetchClassInstance\") {\n          return { value: rest[0] };\n        }\n        if (type === \"SingleFetchFallback\") {\n          return { value: void 0 };\n        }\n      }\n    ]\n  });\n}\nfunction unwrapSingleFetchResults(results, routeId) {\n  let redirect2 = results[SingleFetchRedirectSymbol];\n  if (redirect2) {\n    return unwrapSingleFetchResult(redirect2, routeId);\n  }\n  return results[routeId] !== void 0 ? unwrapSingleFetchResult(results[routeId], routeId) : null;\n}\nfunction unwrapSingleFetchResult(result, routeId) {\n  if (\"error\" in result) {\n    throw result.error;\n  } else if (\"redirect\" in result) {\n    let headers = {};\n    if (result.revalidate) {\n      headers[\"X-Remix-Revalidate\"] = \"yes\";\n    }\n    if (result.reload) {\n      headers[\"X-Remix-Reload-Document\"] = \"yes\";\n    }\n    if (result.replace) {\n      headers[\"X-Remix-Replace\"] = \"yes\";\n    }\n    throw redirect(result.redirect, { status: result.status, headers });\n  } else if (\"data\" in result) {\n    return result.data;\n  } else {\n    throw new Error(`No response found for routeId \"${routeId}\"`);\n  }\n}\nfunction createDeferred2() {\n  let resolve;\n  let reject;\n  let promise = new Promise((res, rej) => {\n    resolve = async (val) => {\n      res(val);\n      try {\n        await promise;\n      } catch (e) {\n      }\n    };\n    reject = async (error) => {\n      rej(error);\n      try {\n        await promise;\n      } catch (e) {\n      }\n    };\n  });\n  return {\n    promise,\n    //@ts-ignore\n    resolve,\n    //@ts-ignore\n    reject\n  };\n}\n\n// lib/dom/ssr/fog-of-war.ts\nimport * as React8 from \"react\";\n\n// lib/dom/ssr/routes.tsx\nimport * as React7 from \"react\";\n\n// lib/dom/ssr/errorBoundaries.tsx\nimport * as React5 from \"react\";\nvar RemixErrorBoundary = class extends React5.Component {\n  constructor(props) {\n    super(props);\n    this.state = { error: props.error || null, location: props.location };\n  }\n  static getDerivedStateFromError(error) {\n    return { error };\n  }\n  static getDerivedStateFromProps(props, state) {\n    if (state.location !== props.location) {\n      return { error: props.error || null, location: props.location };\n    }\n    return { error: props.error || state.error, location: state.location };\n  }\n  render() {\n    if (this.state.error) {\n      return /* @__PURE__ */ React5.createElement(\n        RemixRootDefaultErrorBoundary,\n        {\n          error: this.state.error,\n          isOutsideRemixApp: true\n        }\n      );\n    } else {\n      return this.props.children;\n    }\n  }\n};\nfunction RemixRootDefaultErrorBoundary({\n  error,\n  isOutsideRemixApp\n}) {\n  console.error(error);\n  let heyDeveloper = /* @__PURE__ */ React5.createElement(\n    \"script\",\n    {\n      dangerouslySetInnerHTML: {\n        __html: `\n        console.log(\n          \"\\u{1F4BF} Hey developer \\u{1F44B}. You can provide a way better UX than this when your app throws errors. Check out https://remix.run/guides/errors for more information.\"\n        );\n      `\n      }\n    }\n  );\n  if (isRouteErrorResponse(error)) {\n    return /* @__PURE__ */ React5.createElement(BoundaryShell, { title: \"Unhandled Thrown Response!\" }, /* @__PURE__ */ React5.createElement(\"h1\", { style: { fontSize: \"24px\" } }, error.status, \" \", error.statusText), heyDeveloper);\n  }\n  let errorInstance;\n  if (error instanceof Error) {\n    errorInstance = error;\n  } else {\n    let errorString = error == null ? \"Unknown Error\" : typeof error === \"object\" && \"toString\" in error ? error.toString() : JSON.stringify(error);\n    errorInstance = new Error(errorString);\n  }\n  return /* @__PURE__ */ React5.createElement(\n    BoundaryShell,\n    {\n      title: \"Application Error!\",\n      isOutsideRemixApp\n    },\n    /* @__PURE__ */ React5.createElement(\"h1\", { style: { fontSize: \"24px\" } }, \"Application Error\"),\n    /* @__PURE__ */ React5.createElement(\n      \"pre\",\n      {\n        style: {\n          padding: \"2rem\",\n          background: \"hsla(10, 50%, 50%, 0.1)\",\n          color: \"red\",\n          overflow: \"auto\"\n        }\n      },\n      errorInstance.stack\n    ),\n    heyDeveloper\n  );\n}\nfunction BoundaryShell({\n  title,\n  renderScripts,\n  isOutsideRemixApp,\n  children\n}) {\n  let { routeModules } = useFrameworkContext();\n  if (routeModules.root?.Layout && !isOutsideRemixApp) {\n    return children;\n  }\n  return /* @__PURE__ */ React5.createElement(\"html\", { lang: \"en\" }, /* @__PURE__ */ React5.createElement(\"head\", null, /* @__PURE__ */ React5.createElement(\"meta\", { charSet: \"utf-8\" }), /* @__PURE__ */ React5.createElement(\n    \"meta\",\n    {\n      name: \"viewport\",\n      content: \"width=device-width,initial-scale=1,viewport-fit=cover\"\n    }\n  ), /* @__PURE__ */ React5.createElement(\"title\", null, title)), /* @__PURE__ */ React5.createElement(\"body\", null, /* @__PURE__ */ React5.createElement(\"main\", { style: { fontFamily: \"system-ui, sans-serif\", padding: \"2rem\" } }, children, renderScripts ? /* @__PURE__ */ React5.createElement(Scripts, null) : null)));\n}\n\n// lib/dom/ssr/fallback.tsx\nimport * as React6 from \"react\";\nfunction RemixRootDefaultHydrateFallback() {\n  return /* @__PURE__ */ React6.createElement(BoundaryShell, { title: \"Loading...\", renderScripts: true }, /* @__PURE__ */ React6.createElement(\n    \"script\",\n    {\n      dangerouslySetInnerHTML: {\n        __html: `\n              console.log(\n                \"\\u{1F4BF} Hey developer \\u{1F44B}. You can provide a way better UX than this \" +\n                \"when your app is loading JS modules and/or running \\`clientLoader\\` \" +\n                \"functions. Check out https://remix.run/route/hydrate-fallback \" +\n                \"for more information.\"\n              );\n            `\n      }\n    }\n  ));\n}\n\n// lib/dom/ssr/routes.tsx\nfunction groupRoutesByParentId(manifest) {\n  let routes = {};\n  Object.values(manifest).forEach((route) => {\n    if (route) {\n      let parentId = route.parentId || \"\";\n      if (!routes[parentId]) {\n        routes[parentId] = [];\n      }\n      routes[parentId].push(route);\n    }\n  });\n  return routes;\n}\nfunction getRouteComponents(route, routeModule, isSpaMode) {\n  let Component4 = getRouteModuleComponent(routeModule);\n  let HydrateFallback = routeModule.HydrateFallback && (!isSpaMode || route.id === \"root\") ? routeModule.HydrateFallback : route.id === \"root\" ? RemixRootDefaultHydrateFallback : void 0;\n  let ErrorBoundary = routeModule.ErrorBoundary ? routeModule.ErrorBoundary : route.id === \"root\" ? () => /* @__PURE__ */ React7.createElement(RemixRootDefaultErrorBoundary, { error: useRouteError() }) : void 0;\n  if (route.id === \"root\" && routeModule.Layout) {\n    return {\n      ...Component4 ? {\n        element: /* @__PURE__ */ React7.createElement(routeModule.Layout, null, /* @__PURE__ */ React7.createElement(Component4, null))\n      } : { Component: Component4 },\n      ...ErrorBoundary ? {\n        errorElement: /* @__PURE__ */ React7.createElement(routeModule.Layout, null, /* @__PURE__ */ React7.createElement(ErrorBoundary, null))\n      } : { ErrorBoundary },\n      ...HydrateFallback ? {\n        hydrateFallbackElement: /* @__PURE__ */ React7.createElement(routeModule.Layout, null, /* @__PURE__ */ React7.createElement(HydrateFallback, null))\n      } : { HydrateFallback }\n    };\n  }\n  return { Component: Component4, ErrorBoundary, HydrateFallback };\n}\nfunction createServerRoutes(manifest, routeModules, future, isSpaMode, parentId = \"\", routesByParentId = groupRoutesByParentId(manifest), spaModeLazyPromise = Promise.resolve({ Component: () => null })) {\n  return (routesByParentId[parentId] || []).map((route) => {\n    let routeModule = routeModules[route.id];\n    invariant2(\n      routeModule,\n      \"No `routeModule` available to create server routes\"\n    );\n    let dataRoute = {\n      ...getRouteComponents(route, routeModule, isSpaMode),\n      caseSensitive: route.caseSensitive,\n      id: route.id,\n      index: route.index,\n      path: route.path,\n      handle: routeModule.handle,\n      // For SPA Mode, all routes are lazy except root.  However we tell the\n      // router root is also lazy here too since we don't need a full\n      // implementation - we just need a `lazy` prop to tell the RR rendering\n      // where to stop which is always at the root route in SPA mode\n      lazy: isSpaMode ? () => spaModeLazyPromise : void 0,\n      // For partial hydration rendering, we need to indicate when the route\n      // has a loader/clientLoader, but it won't ever be called during the static\n      // render, so just give it a no-op function so we can render down to the\n      // proper fallback\n      loader: route.hasLoader || route.hasClientLoader ? () => null : void 0\n      // We don't need action/shouldRevalidate on these routes since they're\n      // for a static render\n    };\n    let children = createServerRoutes(\n      manifest,\n      routeModules,\n      future,\n      isSpaMode,\n      route.id,\n      routesByParentId,\n      spaModeLazyPromise\n    );\n    if (children.length > 0) dataRoute.children = children;\n    return dataRoute;\n  });\n}\nfunction createClientRoutesWithHMRRevalidationOptOut(needsRevalidation, manifest, routeModulesCache, initialState, future, isSpaMode) {\n  return createClientRoutes(\n    manifest,\n    routeModulesCache,\n    initialState,\n    isSpaMode,\n    \"\",\n    groupRoutesByParentId(manifest),\n    needsRevalidation\n  );\n}\nfunction preventInvalidServerHandlerCall(type, route, isSpaMode) {\n  if (isSpaMode) {\n    let fn2 = type === \"action\" ? \"serverAction()\" : \"serverLoader()\";\n    let msg2 = `You cannot call ${fn2} in SPA Mode (routeId: \"${route.id}\")`;\n    console.error(msg2);\n    throw new ErrorResponseImpl(400, \"Bad Request\", new Error(msg2), true);\n  }\n  let fn = type === \"action\" ? \"serverAction()\" : \"serverLoader()\";\n  let msg = `You are trying to call ${fn} on a route that does not have a server ${type} (routeId: \"${route.id}\")`;\n  if (type === \"loader\" && !route.hasLoader || type === \"action\" && !route.hasAction) {\n    console.error(msg);\n    throw new ErrorResponseImpl(400, \"Bad Request\", new Error(msg), true);\n  }\n}\nfunction noActionDefinedError(type, routeId) {\n  let article = type === \"clientAction\" ? \"a\" : \"an\";\n  let msg = `Route \"${routeId}\" does not have ${article} ${type}, but you are trying to submit to it. To fix this, please add ${article} \\`${type}\\` function to the route`;\n  console.error(msg);\n  throw new ErrorResponseImpl(405, \"Method Not Allowed\", new Error(msg), true);\n}\nfunction createClientRoutes(manifest, routeModulesCache, initialState, isSpaMode, parentId = \"\", routesByParentId = groupRoutesByParentId(manifest), needsRevalidation) {\n  return (routesByParentId[parentId] || []).map((route) => {\n    let routeModule = routeModulesCache[route.id];\n    function fetchServerHandler(singleFetch) {\n      invariant2(\n        typeof singleFetch === \"function\",\n        \"No single fetch function available for route handler\"\n      );\n      return singleFetch();\n    }\n    function fetchServerLoader(singleFetch) {\n      if (!route.hasLoader) return Promise.resolve(null);\n      return fetchServerHandler(singleFetch);\n    }\n    function fetchServerAction(singleFetch) {\n      if (!route.hasAction) {\n        throw noActionDefinedError(\"action\", route.id);\n      }\n      return fetchServerHandler(singleFetch);\n    }\n    async function prefetchStylesAndCallHandler(handler) {\n      let cachedModule = routeModulesCache[route.id];\n      let linkPrefetchPromise = cachedModule ? prefetchStyleLinks(route, cachedModule) : Promise.resolve();\n      try {\n        return handler();\n      } finally {\n        await linkPrefetchPromise;\n      }\n    }\n    let dataRoute = {\n      id: route.id,\n      index: route.index,\n      path: route.path\n    };\n    if (routeModule) {\n      Object.assign(dataRoute, {\n        ...dataRoute,\n        ...getRouteComponents(route, routeModule, isSpaMode),\n        handle: routeModule.handle,\n        shouldRevalidate: getShouldRevalidateFunction(\n          routeModule,\n          route.id,\n          needsRevalidation\n        )\n      });\n      let hasInitialData = initialState && initialState.loaderData && route.id in initialState.loaderData;\n      let initialData = hasInitialData ? initialState?.loaderData?.[route.id] : void 0;\n      let hasInitialError = initialState && initialState.errors && route.id in initialState.errors;\n      let initialError = hasInitialError ? initialState?.errors?.[route.id] : void 0;\n      let isHydrationRequest = needsRevalidation == null && (routeModule.clientLoader?.hydrate === true || !route.hasLoader);\n      dataRoute.loader = async ({ request, params }, singleFetch) => {\n        try {\n          let result = await prefetchStylesAndCallHandler(async () => {\n            invariant2(\n              routeModule,\n              \"No `routeModule` available for critical-route loader\"\n            );\n            if (!routeModule.clientLoader) {\n              if (isSpaMode) return null;\n              return fetchServerLoader(singleFetch);\n            }\n            return routeModule.clientLoader({\n              request,\n              params,\n              async serverLoader() {\n                preventInvalidServerHandlerCall(\"loader\", route, isSpaMode);\n                if (isHydrationRequest) {\n                  if (hasInitialData) {\n                    return initialData;\n                  }\n                  if (hasInitialError) {\n                    throw initialError;\n                  }\n                }\n                return fetchServerLoader(singleFetch);\n              }\n            });\n          });\n          return result;\n        } finally {\n          isHydrationRequest = false;\n        }\n      };\n      dataRoute.loader.hydrate = shouldHydrateRouteLoader(\n        route,\n        routeModule,\n        isSpaMode\n      );\n      dataRoute.action = ({ request, params }, singleFetch) => {\n        return prefetchStylesAndCallHandler(async () => {\n          invariant2(\n            routeModule,\n            \"No `routeModule` available for critical-route action\"\n          );\n          if (!routeModule.clientAction) {\n            if (isSpaMode) {\n              throw noActionDefinedError(\"clientAction\", route.id);\n            }\n            return fetchServerAction(singleFetch);\n          }\n          return routeModule.clientAction({\n            request,\n            params,\n            async serverAction() {\n              preventInvalidServerHandlerCall(\"action\", route, isSpaMode);\n              return fetchServerAction(singleFetch);\n            }\n          });\n        });\n      };\n    } else {\n      if (!route.hasClientLoader) {\n        dataRoute.loader = ({ request }, singleFetch) => prefetchStylesAndCallHandler(() => {\n          if (isSpaMode) return Promise.resolve(null);\n          return fetchServerLoader(singleFetch);\n        });\n      }\n      if (!route.hasClientAction) {\n        dataRoute.action = ({ request }, singleFetch) => prefetchStylesAndCallHandler(() => {\n          if (isSpaMode) {\n            throw noActionDefinedError(\"clientAction\", route.id);\n          }\n          return fetchServerAction(singleFetch);\n        });\n      }\n      dataRoute.lazy = async () => {\n        let mod = await loadRouteModuleWithBlockingLinks(\n          route,\n          routeModulesCache\n        );\n        let lazyRoute = { ...mod };\n        if (mod.clientLoader) {\n          let clientLoader = mod.clientLoader;\n          lazyRoute.loader = (args, singleFetch) => clientLoader({\n            ...args,\n            async serverLoader() {\n              preventInvalidServerHandlerCall(\"loader\", route, isSpaMode);\n              return fetchServerLoader(singleFetch);\n            }\n          });\n        }\n        if (mod.clientAction) {\n          let clientAction = mod.clientAction;\n          lazyRoute.action = (args, singleFetch) => clientAction({\n            ...args,\n            async serverAction() {\n              preventInvalidServerHandlerCall(\"action\", route, isSpaMode);\n              return fetchServerAction(singleFetch);\n            }\n          });\n        }\n        return {\n          ...lazyRoute.loader ? { loader: lazyRoute.loader } : {},\n          ...lazyRoute.action ? { action: lazyRoute.action } : {},\n          hasErrorBoundary: lazyRoute.hasErrorBoundary,\n          shouldRevalidate: getShouldRevalidateFunction(\n            lazyRoute,\n            route.id,\n            needsRevalidation\n          ),\n          handle: lazyRoute.handle,\n          // No need to wrap these in layout since the root route is never\n          // loaded via route.lazy()\n          Component: lazyRoute.Component,\n          ErrorBoundary: lazyRoute.ErrorBoundary\n        };\n      };\n    }\n    let children = createClientRoutes(\n      manifest,\n      routeModulesCache,\n      initialState,\n      isSpaMode,\n      route.id,\n      routesByParentId,\n      needsRevalidation\n    );\n    if (children.length > 0) dataRoute.children = children;\n    return dataRoute;\n  });\n}\nfunction getShouldRevalidateFunction(route, routeId, needsRevalidation) {\n  if (needsRevalidation) {\n    return wrapShouldRevalidateForHdr(\n      routeId,\n      route.shouldRevalidate,\n      needsRevalidation\n    );\n  }\n  if (route.shouldRevalidate) {\n    let fn = route.shouldRevalidate;\n    return (opts) => fn({ ...opts, defaultShouldRevalidate: true });\n  }\n  return route.shouldRevalidate;\n}\nfunction wrapShouldRevalidateForHdr(routeId, routeShouldRevalidate, needsRevalidation) {\n  let handledRevalidation = false;\n  return (arg) => {\n    if (!handledRevalidation) {\n      handledRevalidation = true;\n      return needsRevalidation.has(routeId);\n    }\n    return routeShouldRevalidate ? routeShouldRevalidate(arg) : arg.defaultShouldRevalidate;\n  };\n}\nasync function loadRouteModuleWithBlockingLinks(route, routeModules) {\n  let routeModule = await loadRouteModule(route, routeModules);\n  await prefetchStyleLinks(route, routeModule);\n  return {\n    Component: getRouteModuleComponent(routeModule),\n    ErrorBoundary: routeModule.ErrorBoundary,\n    clientAction: routeModule.clientAction,\n    clientLoader: routeModule.clientLoader,\n    handle: routeModule.handle,\n    links: routeModule.links,\n    meta: routeModule.meta,\n    shouldRevalidate: routeModule.shouldRevalidate\n  };\n}\nfunction getRouteModuleComponent(routeModule) {\n  if (routeModule.default == null) return void 0;\n  let isEmptyObject = typeof routeModule.default === \"object\" && Object.keys(routeModule.default).length === 0;\n  if (!isEmptyObject) {\n    return routeModule.default;\n  }\n}\nfunction shouldHydrateRouteLoader(route, routeModule, isSpaMode) {\n  return isSpaMode && route.id !== \"root\" || routeModule.clientLoader != null && (routeModule.clientLoader.hydrate === true || route.hasLoader !== true);\n}\n\n// lib/dom/ssr/fog-of-war.ts\nvar nextPaths = /* @__PURE__ */ new Set();\nvar discoveredPathsMaxSize = 1e3;\nvar discoveredPaths = /* @__PURE__ */ new Set();\nvar URL_LIMIT = 7680;\nfunction isFogOfWarEnabled(isSpaMode) {\n  return !isSpaMode;\n}\nfunction getPartialManifest(manifest, router) {\n  let routeIds = new Set(router.state.matches.map((m) => m.route.id));\n  let segments = router.state.location.pathname.split(\"/\").filter(Boolean);\n  let paths = [\"/\"];\n  segments.pop();\n  while (segments.length > 0) {\n    paths.push(`/${segments.join(\"/\")}`);\n    segments.pop();\n  }\n  paths.forEach((path) => {\n    let matches = matchRoutes(router.routes, path, router.basename);\n    if (matches) {\n      matches.forEach((m) => routeIds.add(m.route.id));\n    }\n  });\n  let initialRoutes = [...routeIds].reduce(\n    (acc, id) => Object.assign(acc, { [id]: manifest.routes[id] }),\n    {}\n  );\n  return {\n    ...manifest,\n    routes: initialRoutes\n  };\n}\nfunction getPatchRoutesOnNavigationFunction(manifest, routeModules, isSpaMode, basename) {\n  if (!isFogOfWarEnabled(isSpaMode)) {\n    return void 0;\n  }\n  return async ({ path, patch }) => {\n    if (discoveredPaths.has(path)) {\n      return;\n    }\n    await fetchAndApplyManifestPatches(\n      [path],\n      manifest,\n      routeModules,\n      isSpaMode,\n      basename,\n      patch\n    );\n  };\n}\nfunction useFogOFWarDiscovery(router, manifest, routeModules, isSpaMode) {\n  React8.useEffect(() => {\n    if (!isFogOfWarEnabled(isSpaMode) || navigator.connection?.saveData === true) {\n      return;\n    }\n    function registerElement(el) {\n      let path = el.tagName === \"FORM\" ? el.getAttribute(\"action\") : el.getAttribute(\"href\");\n      if (!path) {\n        return;\n      }\n      let url = new URL(path, window.location.origin);\n      if (!discoveredPaths.has(url.pathname)) {\n        nextPaths.add(url.pathname);\n      }\n    }\n    async function fetchPatches() {\n      let lazyPaths = Array.from(nextPaths.keys()).filter((path) => {\n        if (discoveredPaths.has(path)) {\n          nextPaths.delete(path);\n          return false;\n        }\n        return true;\n      });\n      if (lazyPaths.length === 0) {\n        return;\n      }\n      try {\n        await fetchAndApplyManifestPatches(\n          lazyPaths,\n          manifest,\n          routeModules,\n          isSpaMode,\n          router.basename,\n          router.patchRoutes\n        );\n      } catch (e) {\n        console.error(\"Failed to fetch manifest patches\", e);\n      }\n    }\n    document.body.querySelectorAll(\"a[data-discover], form[data-discover]\").forEach((el) => registerElement(el));\n    fetchPatches();\n    let debouncedFetchPatches = debounce(fetchPatches, 100);\n    function isElement(node) {\n      return node.nodeType === Node.ELEMENT_NODE;\n    }\n    let observer = new MutationObserver((records) => {\n      let elements = /* @__PURE__ */ new Set();\n      records.forEach((r) => {\n        [r.target, ...r.addedNodes].forEach((node) => {\n          if (!isElement(node)) return;\n          if (node.tagName === \"A\" && node.getAttribute(\"data-discover\")) {\n            elements.add(node);\n          } else if (node.tagName === \"FORM\" && node.getAttribute(\"data-discover\")) {\n            elements.add(node);\n          }\n          if (node.tagName !== \"A\") {\n            node.querySelectorAll(\"a[data-discover], form[data-discover]\").forEach((el) => elements.add(el));\n          }\n        });\n      });\n      elements.forEach((el) => registerElement(el));\n      debouncedFetchPatches();\n    });\n    observer.observe(document.documentElement, {\n      subtree: true,\n      childList: true,\n      attributes: true,\n      attributeFilter: [\"data-discover\", \"href\", \"action\"]\n    });\n    return () => observer.disconnect();\n  }, [isSpaMode, manifest, routeModules, router]);\n}\nasync function fetchAndApplyManifestPatches(paths, manifest, routeModules, isSpaMode, basename, patchRoutes) {\n  let manifestPath = `${basename != null ? basename : \"/\"}/__manifest`.replace(\n    /\\/+/g,\n    \"/\"\n  );\n  let url = new URL(manifestPath, window.location.origin);\n  paths.sort().forEach((path) => url.searchParams.append(\"p\", path));\n  url.searchParams.set(\"version\", manifest.version);\n  if (url.toString().length > URL_LIMIT) {\n    nextPaths.clear();\n    return;\n  }\n  let res = await fetch(url);\n  if (!res.ok) {\n    throw new Error(`${res.status} ${res.statusText}`);\n  } else if (res.status >= 400) {\n    throw new Error(await res.text());\n  }\n  let serverPatches = await res.json();\n  let knownRoutes = new Set(Object.keys(manifest.routes));\n  let patches = Object.values(serverPatches).reduce((acc, route) => {\n    if (route && !knownRoutes.has(route.id)) {\n      acc[route.id] = route;\n    }\n    return acc;\n  }, {});\n  Object.assign(manifest.routes, patches);\n  paths.forEach((p) => addToFifoQueue(p, discoveredPaths));\n  let parentIds = /* @__PURE__ */ new Set();\n  Object.values(patches).forEach((patch) => {\n    if (patch && (!patch.parentId || !patches[patch.parentId])) {\n      parentIds.add(patch.parentId);\n    }\n  });\n  parentIds.forEach(\n    (parentId) => patchRoutes(\n      parentId || null,\n      createClientRoutes(patches, routeModules, null, isSpaMode, parentId)\n    )\n  );\n}\nfunction addToFifoQueue(path, queue) {\n  if (queue.size >= discoveredPathsMaxSize) {\n    let first = queue.values().next().value;\n    queue.delete(first);\n  }\n  queue.add(path);\n}\nfunction debounce(callback, wait) {\n  let timeoutId;\n  return (...args) => {\n    window.clearTimeout(timeoutId);\n    timeoutId = window.setTimeout(() => callback(...args), wait);\n  };\n}\n\n// lib/dom/ssr/components.tsx\nfunction useDataRouterContext2() {\n  let context = React9.useContext(DataRouterContext);\n  invariant2(\n    context,\n    \"You must render this element inside a <DataRouterContext.Provider> element\"\n  );\n  return context;\n}\nfunction useDataRouterStateContext() {\n  let context = React9.useContext(DataRouterStateContext);\n  invariant2(\n    context,\n    \"You must render this element inside a <DataRouterStateContext.Provider> element\"\n  );\n  return context;\n}\nvar FrameworkContext = React9.createContext(void 0);\nFrameworkContext.displayName = \"FrameworkContext\";\nfunction useFrameworkContext() {\n  let context = React9.useContext(FrameworkContext);\n  invariant2(\n    context,\n    \"You must render this element inside a <HydratedRouter> element\"\n  );\n  return context;\n}\nfunction usePrefetchBehavior(prefetch, theirElementProps) {\n  let frameworkContext = React9.useContext(FrameworkContext);\n  let [maybePrefetch, setMaybePrefetch] = React9.useState(false);\n  let [shouldPrefetch, setShouldPrefetch] = React9.useState(false);\n  let { onFocus, onBlur, onMouseEnter, onMouseLeave, onTouchStart } = theirElementProps;\n  let ref = React9.useRef(null);\n  React9.useEffect(() => {\n    if (prefetch === \"render\") {\n      setShouldPrefetch(true);\n    }\n    if (prefetch === \"viewport\") {\n      let callback = (entries) => {\n        entries.forEach((entry) => {\n          setShouldPrefetch(entry.isIntersecting);\n        });\n      };\n      let observer = new IntersectionObserver(callback, { threshold: 0.5 });\n      if (ref.current) observer.observe(ref.current);\n      return () => {\n        observer.disconnect();\n      };\n    }\n  }, [prefetch]);\n  React9.useEffect(() => {\n    if (maybePrefetch) {\n      let id = setTimeout(() => {\n        setShouldPrefetch(true);\n      }, 100);\n      return () => {\n        clearTimeout(id);\n      };\n    }\n  }, [maybePrefetch]);\n  let setIntent = () => {\n    setMaybePrefetch(true);\n  };\n  let cancelIntent = () => {\n    setMaybePrefetch(false);\n    setShouldPrefetch(false);\n  };\n  if (!frameworkContext) {\n    return [false, ref, {}];\n  }\n  if (prefetch !== \"intent\") {\n    return [shouldPrefetch, ref, {}];\n  }\n  return [\n    shouldPrefetch,\n    ref,\n    {\n      onFocus: composeEventHandlers(onFocus, setIntent),\n      onBlur: composeEventHandlers(onBlur, cancelIntent),\n      onMouseEnter: composeEventHandlers(onMouseEnter, setIntent),\n      onMouseLeave: composeEventHandlers(onMouseLeave, cancelIntent),\n      onTouchStart: composeEventHandlers(onTouchStart, setIntent)\n    }\n  ];\n}\nfunction composeEventHandlers(theirHandler, ourHandler) {\n  return (event) => {\n    theirHandler && theirHandler(event);\n    if (!event.defaultPrevented) {\n      ourHandler(event);\n    }\n  };\n}\nfunction getActiveMatches(matches, errors, isSpaMode) {\n  if (isSpaMode && !isHydrated) {\n    return [matches[0]];\n  }\n  if (errors) {\n    let errorIdx = matches.findIndex((m) => errors[m.route.id] !== void 0);\n    return matches.slice(0, errorIdx + 1);\n  }\n  return matches;\n}\nfunction Links() {\n  let { isSpaMode, manifest, routeModules, criticalCss } = useFrameworkContext();\n  let { errors, matches: routerMatches } = useDataRouterStateContext();\n  let matches = getActiveMatches(routerMatches, errors, isSpaMode);\n  let keyedLinks = React9.useMemo(\n    () => getKeyedLinksForMatches(matches, routeModules, manifest),\n    [matches, routeModules, manifest]\n  );\n  return /* @__PURE__ */ React9.createElement(React9.Fragment, null, criticalCss ? /* @__PURE__ */ React9.createElement(\"style\", { dangerouslySetInnerHTML: { __html: criticalCss } }) : null, keyedLinks.map(\n    ({ key, link }) => isPageLinkDescriptor(link) ? /* @__PURE__ */ React9.createElement(PrefetchPageLinks, { key, ...link }) : /* @__PURE__ */ React9.createElement(\"link\", { key, ...link })\n  ));\n}\nfunction PrefetchPageLinks({\n  page,\n  ...dataLinkProps\n}) {\n  let { router } = useDataRouterContext2();\n  let matches = React9.useMemo(\n    () => matchRoutes(router.routes, page, router.basename),\n    [router.routes, page, router.basename]\n  );\n  if (!matches) {\n    return null;\n  }\n  return /* @__PURE__ */ React9.createElement(PrefetchPageLinksImpl, { page, matches, ...dataLinkProps });\n}\nfunction useKeyedPrefetchLinks(matches) {\n  let { manifest, routeModules } = useFrameworkContext();\n  let [keyedPrefetchLinks, setKeyedPrefetchLinks] = React9.useState([]);\n  React9.useEffect(() => {\n    let interrupted = false;\n    void getKeyedPrefetchLinks(matches, manifest, routeModules).then(\n      (links) => {\n        if (!interrupted) {\n          setKeyedPrefetchLinks(links);\n        }\n      }\n    );\n    return () => {\n      interrupted = true;\n    };\n  }, [matches, manifest, routeModules]);\n  return keyedPrefetchLinks;\n}\nfunction PrefetchPageLinksImpl({\n  page,\n  matches: nextMatches,\n  ...linkProps\n}) {\n  let location = useLocation();\n  let { manifest, routeModules } = useFrameworkContext();\n  let { loaderData, matches } = useDataRouterStateContext();\n  let newMatchesForData = React9.useMemo(\n    () => getNewMatchesForLinks(\n      page,\n      nextMatches,\n      matches,\n      manifest,\n      location,\n      \"data\"\n    ),\n    [page, nextMatches, matches, manifest, location]\n  );\n  let newMatchesForAssets = React9.useMemo(\n    () => getNewMatchesForLinks(\n      page,\n      nextMatches,\n      matches,\n      manifest,\n      location,\n      \"assets\"\n    ),\n    [page, nextMatches, matches, manifest, location]\n  );\n  let dataHrefs = React9.useMemo(() => {\n    if (page === location.pathname + location.search + location.hash) {\n      return [];\n    }\n    let routesParams = /* @__PURE__ */ new Set();\n    let foundOptOutRoute = false;\n    nextMatches.forEach((m) => {\n      let manifestRoute = manifest.routes[m.route.id];\n      if (!manifestRoute || !manifestRoute.hasLoader) {\n        return;\n      }\n      if (!newMatchesForData.some((m2) => m2.route.id === m.route.id) && m.route.id in loaderData && routeModules[m.route.id]?.shouldRevalidate) {\n        foundOptOutRoute = true;\n      } else if (manifestRoute.hasClientLoader) {\n        foundOptOutRoute = true;\n      } else {\n        routesParams.add(m.route.id);\n      }\n    });\n    if (routesParams.size === 0) {\n      return [];\n    }\n    let url = singleFetchUrl(page);\n    if (foundOptOutRoute && routesParams.size > 0) {\n      url.searchParams.set(\n        \"_routes\",\n        nextMatches.filter((m) => routesParams.has(m.route.id)).map((m) => m.route.id).join(\",\")\n      );\n    }\n    return [url.pathname + url.search];\n  }, [\n    loaderData,\n    location,\n    manifest,\n    newMatchesForData,\n    nextMatches,\n    page,\n    routeModules\n  ]);\n  let moduleHrefs = React9.useMemo(\n    () => getModuleLinkHrefs(newMatchesForAssets, manifest),\n    [newMatchesForAssets, manifest]\n  );\n  let keyedPrefetchLinks = useKeyedPrefetchLinks(newMatchesForAssets);\n  return /* @__PURE__ */ React9.createElement(React9.Fragment, null, dataHrefs.map((href) => /* @__PURE__ */ React9.createElement(\"link\", { key: href, rel: \"prefetch\", as: \"fetch\", href, ...linkProps })), moduleHrefs.map((href) => /* @__PURE__ */ React9.createElement(\"link\", { key: href, rel: \"modulepreload\", href, ...linkProps })), keyedPrefetchLinks.map(({ key, link }) => (\n    // these don't spread `linkProps` because they are full link descriptors\n    // already with their own props\n    /* @__PURE__ */ React9.createElement(\"link\", { key, ...link })\n  )));\n}\nfunction Meta() {\n  let { isSpaMode, routeModules } = useFrameworkContext();\n  let {\n    errors,\n    matches: routerMatches,\n    loaderData\n  } = useDataRouterStateContext();\n  let location = useLocation();\n  let _matches = getActiveMatches(routerMatches, errors, isSpaMode);\n  let error = null;\n  if (errors) {\n    error = errors[_matches[_matches.length - 1].route.id];\n  }\n  let meta = [];\n  let leafMeta = null;\n  let matches = [];\n  for (let i = 0; i < _matches.length; i++) {\n    let _match = _matches[i];\n    let routeId = _match.route.id;\n    let data2 = loaderData[routeId];\n    let params = _match.params;\n    let routeModule = routeModules[routeId];\n    let routeMeta = [];\n    let match = {\n      id: routeId,\n      data: data2,\n      meta: [],\n      params: _match.params,\n      pathname: _match.pathname,\n      handle: _match.route.handle,\n      error\n    };\n    matches[i] = match;\n    if (routeModule?.meta) {\n      routeMeta = typeof routeModule.meta === \"function\" ? routeModule.meta({\n        data: data2,\n        params,\n        location,\n        matches,\n        error\n      }) : Array.isArray(routeModule.meta) ? [...routeModule.meta] : routeModule.meta;\n    } else if (leafMeta) {\n      routeMeta = [...leafMeta];\n    }\n    routeMeta = routeMeta || [];\n    if (!Array.isArray(routeMeta)) {\n      throw new Error(\n        \"The route at \" + _match.route.path + \" returns an invalid value. All route meta functions must return an array of meta objects.\\n\\nTo reference the meta function API, see https://remix.run/route/meta\"\n      );\n    }\n    match.meta = routeMeta;\n    matches[i] = match;\n    meta = [...routeMeta];\n    leafMeta = meta;\n  }\n  return /* @__PURE__ */ React9.createElement(React9.Fragment, null, meta.flat().map((metaProps) => {\n    if (!metaProps) {\n      return null;\n    }\n    if (\"tagName\" in metaProps) {\n      let { tagName, ...rest } = metaProps;\n      if (!isValidMetaTag(tagName)) {\n        console.warn(\n          `A meta object uses an invalid tagName: ${tagName}. Expected either 'link' or 'meta'`\n        );\n        return null;\n      }\n      let Comp = tagName;\n      return /* @__PURE__ */ React9.createElement(Comp, { key: JSON.stringify(rest), ...rest });\n    }\n    if (\"title\" in metaProps) {\n      return /* @__PURE__ */ React9.createElement(\"title\", { key: \"title\" }, String(metaProps.title));\n    }\n    if (\"charset\" in metaProps) {\n      metaProps.charSet ?? (metaProps.charSet = metaProps.charset);\n      delete metaProps.charset;\n    }\n    if (\"charSet\" in metaProps && metaProps.charSet != null) {\n      return typeof metaProps.charSet === \"string\" ? /* @__PURE__ */ React9.createElement(\"meta\", { key: \"charSet\", charSet: metaProps.charSet }) : null;\n    }\n    if (\"script:ld+json\" in metaProps) {\n      try {\n        let json = JSON.stringify(metaProps[\"script:ld+json\"]);\n        return /* @__PURE__ */ React9.createElement(\n          \"script\",\n          {\n            key: `script:ld+json:${json}`,\n            type: \"application/ld+json\",\n            dangerouslySetInnerHTML: { __html: json }\n          }\n        );\n      } catch (err) {\n        return null;\n      }\n    }\n    return /* @__PURE__ */ React9.createElement(\"meta\", { key: JSON.stringify(metaProps), ...metaProps });\n  }));\n}\nfunction isValidMetaTag(tagName) {\n  return typeof tagName === \"string\" && /^(meta|link)$/.test(tagName);\n}\nvar isHydrated = false;\nfunction Scripts(props) {\n  let { manifest, serverHandoffString, isSpaMode, renderMeta } = useFrameworkContext();\n  let { router, static: isStatic, staticContext } = useDataRouterContext2();\n  let { matches: routerMatches } = useDataRouterStateContext();\n  let enableFogOfWar = isFogOfWarEnabled(isSpaMode);\n  if (renderMeta) {\n    renderMeta.didRenderScripts = true;\n  }\n  let matches = getActiveMatches(routerMatches, null, isSpaMode);\n  React9.useEffect(() => {\n    isHydrated = true;\n  }, []);\n  let initialScripts = React9.useMemo(() => {\n    let streamScript = \"window.__reactRouterContext.stream = new ReadableStream({start(controller){window.__reactRouterContext.streamController = controller;}}).pipeThrough(new TextEncoderStream());\";\n    let contextScript = staticContext ? `window.__reactRouterContext = ${serverHandoffString};${streamScript}` : \" \";\n    let routeModulesScript = !isStatic ? \" \" : `${manifest.hmr?.runtime ? `import ${JSON.stringify(manifest.hmr.runtime)};` : \"\"}${!enableFogOfWar ? `import ${JSON.stringify(manifest.url)}` : \"\"};\n${matches.map(\n      (match, index) => `import * as route${index} from ${JSON.stringify(\n        manifest.routes[match.route.id].module\n      )};`\n    ).join(\"\\n\")}\n  ${enableFogOfWar ? (\n      // Inline a minimal manifest with the SSR matches\n      `window.__reactRouterManifest = ${JSON.stringify(\n        getPartialManifest(manifest, router),\n        null,\n        2\n      )};`\n    ) : \"\"}\n  window.__reactRouterRouteModules = {${matches.map((match, index) => `${JSON.stringify(match.route.id)}:route${index}`).join(\",\")}};\n\nimport(${JSON.stringify(manifest.entry.module)});`;\n    return /* @__PURE__ */ React9.createElement(React9.Fragment, null, /* @__PURE__ */ React9.createElement(\n      \"script\",\n      {\n        ...props,\n        suppressHydrationWarning: true,\n        dangerouslySetInnerHTML: createHtml(contextScript),\n        type: void 0\n      }\n    ), /* @__PURE__ */ React9.createElement(\n      \"script\",\n      {\n        ...props,\n        suppressHydrationWarning: true,\n        dangerouslySetInnerHTML: createHtml(routeModulesScript),\n        type: \"module\",\n        async: true\n      }\n    ));\n  }, []);\n  let routePreloads = matches.map((match) => {\n    let route = manifest.routes[match.route.id];\n    return route ? (route.imports || []).concat([route.module]) : [];\n  }).flat(1);\n  let preloads = isHydrated ? [] : manifest.entry.imports.concat(routePreloads);\n  return isHydrated ? null : /* @__PURE__ */ React9.createElement(React9.Fragment, null, !enableFogOfWar ? /* @__PURE__ */ React9.createElement(\n    \"link\",\n    {\n      rel: \"modulepreload\",\n      href: manifest.url,\n      crossOrigin: props.crossOrigin\n    }\n  ) : null, /* @__PURE__ */ React9.createElement(\n    \"link\",\n    {\n      rel: \"modulepreload\",\n      href: manifest.entry.module,\n      crossOrigin: props.crossOrigin\n    }\n  ), dedupe(preloads).map((path) => /* @__PURE__ */ React9.createElement(\n    \"link\",\n    {\n      key: path,\n      rel: \"modulepreload\",\n      href: path,\n      crossOrigin: props.crossOrigin\n    }\n  )), initialScripts);\n}\nfunction dedupe(array) {\n  return [...new Set(array)];\n}\nfunction mergeRefs(...refs) {\n  return (value) => {\n    refs.forEach((ref) => {\n      if (typeof ref === \"function\") {\n        ref(value);\n      } else if (ref != null) {\n        ref.current = value;\n      }\n    });\n  };\n}\n\n// lib/dom/lib.tsx\nvar isBrowser = typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\";\ntry {\n  if (isBrowser) {\n    window.__reactRouterVersion = \"7.1.1\";\n  }\n} catch (e) {\n}\nfunction createBrowserRouter(routes, opts) {\n  return createRouter({\n    basename: opts?.basename,\n    future: opts?.future,\n    history: createBrowserHistory({ window: opts?.window }),\n    hydrationData: opts?.hydrationData || parseHydrationData(),\n    routes,\n    mapRouteProperties,\n    dataStrategy: opts?.dataStrategy,\n    patchRoutesOnNavigation: opts?.patchRoutesOnNavigation,\n    window: opts?.window\n  }).initialize();\n}\nfunction createHashRouter(routes, opts) {\n  return createRouter({\n    basename: opts?.basename,\n    future: opts?.future,\n    history: createHashHistory({ window: opts?.window }),\n    hydrationData: opts?.hydrationData || parseHydrationData(),\n    routes,\n    mapRouteProperties,\n    dataStrategy: opts?.dataStrategy,\n    patchRoutesOnNavigation: opts?.patchRoutesOnNavigation,\n    window: opts?.window\n  }).initialize();\n}\nfunction parseHydrationData() {\n  let state = window?.__staticRouterHydrationData;\n  if (state && state.errors) {\n    state = {\n      ...state,\n      errors: deserializeErrors(state.errors)\n    };\n  }\n  return state;\n}\nfunction deserializeErrors(errors) {\n  if (!errors) return null;\n  let entries = Object.entries(errors);\n  let serialized = {};\n  for (let [key, val] of entries) {\n    if (val && val.__type === \"RouteErrorResponse\") {\n      serialized[key] = new ErrorResponseImpl(\n        val.status,\n        val.statusText,\n        val.data,\n        val.internal === true\n      );\n    } else if (val && val.__type === \"Error\") {\n      if (val.__subType) {\n        let ErrorConstructor = window[val.__subType];\n        if (typeof ErrorConstructor === \"function\") {\n          try {\n            let error = new ErrorConstructor(val.message);\n            error.stack = \"\";\n            serialized[key] = error;\n          } catch (e) {\n          }\n        }\n      }\n      if (serialized[key] == null) {\n        let error = new Error(val.message);\n        error.stack = \"\";\n        serialized[key] = error;\n      }\n    } else {\n      serialized[key] = val;\n    }\n  }\n  return serialized;\n}\nfunction BrowserRouter({\n  basename,\n  children,\n  window: window2\n}) {\n  let historyRef = React10.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createBrowserHistory({ window: window2, v5Compat: true });\n  }\n  let history = historyRef.current;\n  let [state, setStateImpl] = React10.useState({\n    action: history.action,\n    location: history.location\n  });\n  let setState = React10.useCallback(\n    (newState) => {\n      React10.startTransition(() => setStateImpl(newState));\n    },\n    [setStateImpl]\n  );\n  React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n  return /* @__PURE__ */ React10.createElement(\n    Router,\n    {\n      basename,\n      children,\n      location: state.location,\n      navigationType: state.action,\n      navigator: history\n    }\n  );\n}\nfunction HashRouter({ basename, children, window: window2 }) {\n  let historyRef = React10.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createHashHistory({ window: window2, v5Compat: true });\n  }\n  let history = historyRef.current;\n  let [state, setStateImpl] = React10.useState({\n    action: history.action,\n    location: history.location\n  });\n  let setState = React10.useCallback(\n    (newState) => {\n      React10.startTransition(() => setStateImpl(newState));\n    },\n    [setStateImpl]\n  );\n  React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n  return /* @__PURE__ */ React10.createElement(\n    Router,\n    {\n      basename,\n      children,\n      location: state.location,\n      navigationType: state.action,\n      navigator: history\n    }\n  );\n}\nfunction HistoryRouter({\n  basename,\n  children,\n  history\n}) {\n  let [state, setStateImpl] = React10.useState({\n    action: history.action,\n    location: history.location\n  });\n  let setState = React10.useCallback(\n    (newState) => {\n      React10.startTransition(() => setStateImpl(newState));\n    },\n    [setStateImpl]\n  );\n  React10.useLayoutEffect(() => history.listen(setState), [history, setState]);\n  return /* @__PURE__ */ React10.createElement(\n    Router,\n    {\n      basename,\n      children,\n      location: state.location,\n      navigationType: state.action,\n      navigator: history\n    }\n  );\n}\nHistoryRouter.displayName = \"unstable_HistoryRouter\";\nvar ABSOLUTE_URL_REGEX2 = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nvar Link = React10.forwardRef(\n  function LinkWithRef({\n    onClick,\n    discover = \"render\",\n    prefetch = \"none\",\n    relative,\n    reloadDocument,\n    replace: replace2,\n    state,\n    target,\n    to,\n    preventScrollReset,\n    viewTransition,\n    ...rest\n  }, forwardedRef) {\n    let { basename } = React10.useContext(NavigationContext);\n    let isAbsolute = typeof to === \"string\" && ABSOLUTE_URL_REGEX2.test(to);\n    let absoluteHref;\n    let isExternal = false;\n    if (typeof to === \"string\" && isAbsolute) {\n      absoluteHref = to;\n      if (isBrowser) {\n        try {\n          let currentUrl = new URL(window.location.href);\n          let targetUrl = to.startsWith(\"//\") ? new URL(currentUrl.protocol + to) : new URL(to);\n          let path = stripBasename(targetUrl.pathname, basename);\n          if (targetUrl.origin === currentUrl.origin && path != null) {\n            to = path + targetUrl.search + targetUrl.hash;\n          } else {\n            isExternal = true;\n          }\n        } catch (e) {\n          warning(\n            false,\n            `<Link to=\"${to}\"> contains an invalid URL which will probably break when clicked - please update to a valid URL path.`\n          );\n        }\n      }\n    }\n    let href = useHref(to, { relative });\n    let [shouldPrefetch, prefetchRef, prefetchHandlers] = usePrefetchBehavior(\n      prefetch,\n      rest\n    );\n    let internalOnClick = useLinkClickHandler(to, {\n      replace: replace2,\n      state,\n      target,\n      preventScrollReset,\n      relative,\n      viewTransition\n    });\n    function handleClick(event) {\n      if (onClick) onClick(event);\n      if (!event.defaultPrevented) {\n        internalOnClick(event);\n      }\n    }\n    let link = (\n      // eslint-disable-next-line jsx-a11y/anchor-has-content\n      /* @__PURE__ */ React10.createElement(\n        \"a\",\n        {\n          ...rest,\n          ...prefetchHandlers,\n          href: absoluteHref || href,\n          onClick: isExternal || reloadDocument ? onClick : handleClick,\n          ref: mergeRefs(forwardedRef, prefetchRef),\n          target,\n          \"data-discover\": !isAbsolute && discover === \"render\" ? \"true\" : void 0\n        }\n      )\n    );\n    return shouldPrefetch && !isAbsolute ? /* @__PURE__ */ React10.createElement(React10.Fragment, null, link, /* @__PURE__ */ React10.createElement(PrefetchPageLinks, { page: href })) : link;\n  }\n);\nLink.displayName = \"Link\";\nvar NavLink = React10.forwardRef(\n  function NavLinkWithRef({\n    \"aria-current\": ariaCurrentProp = \"page\",\n    caseSensitive = false,\n    className: classNameProp = \"\",\n    end = false,\n    style: styleProp,\n    to,\n    viewTransition,\n    children,\n    ...rest\n  }, ref) {\n    let path = useResolvedPath(to, { relative: rest.relative });\n    let location = useLocation();\n    let routerState = React10.useContext(DataRouterStateContext);\n    let { navigator: navigator2, basename } = React10.useContext(NavigationContext);\n    let isTransitioning = routerState != null && // Conditional usage is OK here because the usage of a data router is static\n    // eslint-disable-next-line react-hooks/rules-of-hooks\n    useViewTransitionState(path) && viewTransition === true;\n    let toPathname = navigator2.encodeLocation ? navigator2.encodeLocation(path).pathname : path.pathname;\n    let locationPathname = location.pathname;\n    let nextLocationPathname = routerState && routerState.navigation && routerState.navigation.location ? routerState.navigation.location.pathname : null;\n    if (!caseSensitive) {\n      locationPathname = locationPathname.toLowerCase();\n      nextLocationPathname = nextLocationPathname ? nextLocationPathname.toLowerCase() : null;\n      toPathname = toPathname.toLowerCase();\n    }\n    if (nextLocationPathname && basename) {\n      nextLocationPathname = stripBasename(nextLocationPathname, basename) || nextLocationPathname;\n    }\n    const endSlashPosition = toPathname !== \"/\" && toPathname.endsWith(\"/\") ? toPathname.length - 1 : toPathname.length;\n    let isActive = locationPathname === toPathname || !end && locationPathname.startsWith(toPathname) && locationPathname.charAt(endSlashPosition) === \"/\";\n    let isPending = nextLocationPathname != null && (nextLocationPathname === toPathname || !end && nextLocationPathname.startsWith(toPathname) && nextLocationPathname.charAt(toPathname.length) === \"/\");\n    let renderProps = {\n      isActive,\n      isPending,\n      isTransitioning\n    };\n    let ariaCurrent = isActive ? ariaCurrentProp : void 0;\n    let className;\n    if (typeof classNameProp === \"function\") {\n      className = classNameProp(renderProps);\n    } else {\n      className = [\n        classNameProp,\n        isActive ? \"active\" : null,\n        isPending ? \"pending\" : null,\n        isTransitioning ? \"transitioning\" : null\n      ].filter(Boolean).join(\" \");\n    }\n    let style = typeof styleProp === \"function\" ? styleProp(renderProps) : styleProp;\n    return /* @__PURE__ */ React10.createElement(\n      Link,\n      {\n        ...rest,\n        \"aria-current\": ariaCurrent,\n        className,\n        ref,\n        style,\n        to,\n        viewTransition\n      },\n      typeof children === \"function\" ? children(renderProps) : children\n    );\n  }\n);\nNavLink.displayName = \"NavLink\";\nvar Form = React10.forwardRef(\n  ({\n    discover = \"render\",\n    fetcherKey,\n    navigate,\n    reloadDocument,\n    replace: replace2,\n    state,\n    method = defaultMethod,\n    action,\n    onSubmit,\n    relative,\n    preventScrollReset,\n    viewTransition,\n    ...props\n  }, forwardedRef) => {\n    let submit = useSubmit();\n    let formAction = useFormAction(action, { relative });\n    let formMethod = method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n    let isAbsolute = typeof action === \"string\" && ABSOLUTE_URL_REGEX2.test(action);\n    let submitHandler = (event) => {\n      onSubmit && onSubmit(event);\n      if (event.defaultPrevented) return;\n      event.preventDefault();\n      let submitter = event.nativeEvent.submitter;\n      let submitMethod = submitter?.getAttribute(\"formmethod\") || method;\n      submit(submitter || event.currentTarget, {\n        fetcherKey,\n        method: submitMethod,\n        navigate,\n        replace: replace2,\n        state,\n        relative,\n        preventScrollReset,\n        viewTransition\n      });\n    };\n    return /* @__PURE__ */ React10.createElement(\n      \"form\",\n      {\n        ref: forwardedRef,\n        method: formMethod,\n        action: formAction,\n        onSubmit: reloadDocument ? onSubmit : submitHandler,\n        ...props,\n        \"data-discover\": !isAbsolute && discover === \"render\" ? \"true\" : void 0\n      }\n    );\n  }\n);\nForm.displayName = \"Form\";\nfunction ScrollRestoration({\n  getKey,\n  storageKey,\n  ...props\n}) {\n  let remixContext = React10.useContext(FrameworkContext);\n  let { basename } = React10.useContext(NavigationContext);\n  let location = useLocation();\n  let matches = useMatches();\n  useScrollRestoration({ getKey, storageKey });\n  let ssrKey = React10.useMemo(\n    () => {\n      if (!remixContext || !getKey) return null;\n      let userKey = getScrollRestorationKey(\n        location,\n        matches,\n        basename,\n        getKey\n      );\n      return userKey !== location.key ? userKey : null;\n    },\n    // Nah, we only need this the first time for the SSR render\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    []\n  );\n  if (!remixContext || remixContext.isSpaMode) {\n    return null;\n  }\n  let restoreScroll = ((storageKey2, restoreKey) => {\n    if (!window.history.state || !window.history.state.key) {\n      let key = Math.random().toString(32).slice(2);\n      window.history.replaceState({ key }, \"\");\n    }\n    try {\n      let positions = JSON.parse(sessionStorage.getItem(storageKey2) || \"{}\");\n      let storedY = positions[restoreKey || window.history.state.key];\n      if (typeof storedY === \"number\") {\n        window.scrollTo(0, storedY);\n      }\n    } catch (error) {\n      console.error(error);\n      sessionStorage.removeItem(storageKey2);\n    }\n  }).toString();\n  return /* @__PURE__ */ React10.createElement(\n    \"script\",\n    {\n      ...props,\n      suppressHydrationWarning: true,\n      dangerouslySetInnerHTML: {\n        __html: `(${restoreScroll})(${JSON.stringify(\n          storageKey || SCROLL_RESTORATION_STORAGE_KEY\n        )}, ${JSON.stringify(ssrKey)})`\n      }\n    }\n  );\n}\nScrollRestoration.displayName = \"ScrollRestoration\";\nfunction getDataRouterConsoleError2(hookName) {\n  return `${hookName} must be used within a data router.  See https://reactrouter.com/en/main/routers/picking-a-router.`;\n}\nfunction useDataRouterContext3(hookName) {\n  let ctx = React10.useContext(DataRouterContext);\n  invariant(ctx, getDataRouterConsoleError2(hookName));\n  return ctx;\n}\nfunction useDataRouterState2(hookName) {\n  let state = React10.useContext(DataRouterStateContext);\n  invariant(state, getDataRouterConsoleError2(hookName));\n  return state;\n}\nfunction useLinkClickHandler(to, {\n  target,\n  replace: replaceProp,\n  state,\n  preventScrollReset,\n  relative,\n  viewTransition\n} = {}) {\n  let navigate = useNavigate();\n  let location = useLocation();\n  let path = useResolvedPath(to, { relative });\n  return React10.useCallback(\n    (event) => {\n      if (shouldProcessLinkClick(event, target)) {\n        event.preventDefault();\n        let replace2 = replaceProp !== void 0 ? replaceProp : createPath(location) === createPath(path);\n        navigate(to, {\n          replace: replace2,\n          state,\n          preventScrollReset,\n          relative,\n          viewTransition\n        });\n      }\n    },\n    [\n      location,\n      navigate,\n      path,\n      replaceProp,\n      state,\n      target,\n      to,\n      preventScrollReset,\n      relative,\n      viewTransition\n    ]\n  );\n}\nfunction useSearchParams(defaultInit) {\n  warning(\n    typeof URLSearchParams !== \"undefined\",\n    `You cannot use the \\`useSearchParams\\` hook in a browser that does not support the URLSearchParams API. If you need to support Internet Explorer 11, we recommend you load a polyfill such as https://github.com/ungap/url-search-params.`\n  );\n  let defaultSearchParamsRef = React10.useRef(createSearchParams(defaultInit));\n  let hasSetSearchParamsRef = React10.useRef(false);\n  let location = useLocation();\n  let searchParams = React10.useMemo(\n    () => (\n      // Only merge in the defaults if we haven't yet called setSearchParams.\n      // Once we call that we want those to take precedence, otherwise you can't\n      // remove a param with setSearchParams({}) if it has an initial value\n      getSearchParamsForLocation(\n        location.search,\n        hasSetSearchParamsRef.current ? null : defaultSearchParamsRef.current\n      )\n    ),\n    [location.search]\n  );\n  let navigate = useNavigate();\n  let setSearchParams = React10.useCallback(\n    (nextInit, navigateOptions) => {\n      const newSearchParams = createSearchParams(\n        typeof nextInit === \"function\" ? nextInit(searchParams) : nextInit\n      );\n      hasSetSearchParamsRef.current = true;\n      navigate(\"?\" + newSearchParams, navigateOptions);\n    },\n    [navigate, searchParams]\n  );\n  return [searchParams, setSearchParams];\n}\nvar fetcherId = 0;\nvar getUniqueFetcherId = () => `__${String(++fetcherId)}__`;\nfunction useSubmit() {\n  let { router } = useDataRouterContext3(\"useSubmit\" /* UseSubmit */);\n  let { basename } = React10.useContext(NavigationContext);\n  let currentRouteId = useRouteId();\n  return React10.useCallback(\n    async (target, options = {}) => {\n      let { action, method, encType, formData, body } = getFormSubmissionInfo(\n        target,\n        basename\n      );\n      if (options.navigate === false) {\n        let key = options.fetcherKey || getUniqueFetcherId();\n        await router.fetch(key, currentRouteId, options.action || action, {\n          preventScrollReset: options.preventScrollReset,\n          formData,\n          body,\n          formMethod: options.method || method,\n          formEncType: options.encType || encType,\n          flushSync: options.flushSync\n        });\n      } else {\n        await router.navigate(options.action || action, {\n          preventScrollReset: options.preventScrollReset,\n          formData,\n          body,\n          formMethod: options.method || method,\n          formEncType: options.encType || encType,\n          replace: options.replace,\n          state: options.state,\n          fromRouteId: currentRouteId,\n          flushSync: options.flushSync,\n          viewTransition: options.viewTransition\n        });\n      }\n    },\n    [router, basename, currentRouteId]\n  );\n}\nfunction useFormAction(action, { relative } = {}) {\n  let { basename } = React10.useContext(NavigationContext);\n  let routeContext = React10.useContext(RouteContext);\n  invariant(routeContext, \"useFormAction must be used inside a RouteContext\");\n  let [match] = routeContext.matches.slice(-1);\n  let path = { ...useResolvedPath(action ? action : \".\", { relative }) };\n  let location = useLocation();\n  if (action == null) {\n    path.search = location.search;\n    let params = new URLSearchParams(path.search);\n    let indexValues = params.getAll(\"index\");\n    let hasNakedIndexParam = indexValues.some((v) => v === \"\");\n    if (hasNakedIndexParam) {\n      params.delete(\"index\");\n      indexValues.filter((v) => v).forEach((v) => params.append(\"index\", v));\n      let qs = params.toString();\n      path.search = qs ? `?${qs}` : \"\";\n    }\n  }\n  if ((!action || action === \".\") && match.route.index) {\n    path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n  }\n  if (basename !== \"/\") {\n    path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n  }\n  return createPath(path);\n}\nfunction useFetcher({\n  key\n} = {}) {\n  let { router } = useDataRouterContext3(\"useFetcher\" /* UseFetcher */);\n  let state = useDataRouterState2(\"useFetcher\" /* UseFetcher */);\n  let fetcherData = React10.useContext(FetchersContext);\n  let route = React10.useContext(RouteContext);\n  let routeId = route.matches[route.matches.length - 1]?.route.id;\n  invariant(fetcherData, `useFetcher must be used inside a FetchersContext`);\n  invariant(route, `useFetcher must be used inside a RouteContext`);\n  invariant(\n    routeId != null,\n    `useFetcher can only be used on routes that contain a unique \"id\"`\n  );\n  let defaultKey = React10.useId();\n  let [fetcherKey, setFetcherKey] = React10.useState(key || defaultKey);\n  if (key && key !== fetcherKey) {\n    setFetcherKey(key);\n  }\n  React10.useEffect(() => {\n    router.getFetcher(fetcherKey);\n    return () => router.deleteFetcher(fetcherKey);\n  }, [router, fetcherKey]);\n  let load = React10.useCallback(\n    async (href, opts) => {\n      invariant(routeId, \"No routeId available for fetcher.load()\");\n      await router.fetch(fetcherKey, routeId, href, opts);\n    },\n    [fetcherKey, routeId, router]\n  );\n  let submitImpl = useSubmit();\n  let submit = React10.useCallback(\n    async (target, opts) => {\n      await submitImpl(target, {\n        ...opts,\n        navigate: false,\n        fetcherKey\n      });\n    },\n    [fetcherKey, submitImpl]\n  );\n  let FetcherForm = React10.useMemo(() => {\n    let FetcherForm2 = React10.forwardRef(\n      (props, ref) => {\n        return /* @__PURE__ */ React10.createElement(Form, { ...props, navigate: false, fetcherKey, ref });\n      }\n    );\n    FetcherForm2.displayName = \"fetcher.Form\";\n    return FetcherForm2;\n  }, [fetcherKey]);\n  let fetcher = state.fetchers.get(fetcherKey) || IDLE_FETCHER;\n  let data2 = fetcherData.get(fetcherKey);\n  let fetcherWithComponents = React10.useMemo(\n    () => ({\n      Form: FetcherForm,\n      submit,\n      load,\n      ...fetcher,\n      data: data2\n    }),\n    [FetcherForm, submit, load, fetcher, data2]\n  );\n  return fetcherWithComponents;\n}\nfunction useFetchers() {\n  let state = useDataRouterState2(\"useFetchers\" /* UseFetchers */);\n  return Array.from(state.fetchers.entries()).map(([key, fetcher]) => ({\n    ...fetcher,\n    key\n  }));\n}\nvar SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nvar savedScrollPositions = {};\nfunction getScrollRestorationKey(location, matches, basename, getKey) {\n  let key = null;\n  if (getKey) {\n    if (basename !== \"/\") {\n      key = getKey(\n        {\n          ...location,\n          pathname: stripBasename(location.pathname, basename) || location.pathname\n        },\n        matches\n      );\n    } else {\n      key = getKey(location, matches);\n    }\n  }\n  if (key == null) {\n    key = location.key;\n  }\n  return key;\n}\nfunction useScrollRestoration({\n  getKey,\n  storageKey\n} = {}) {\n  let { router } = useDataRouterContext3(\"useScrollRestoration\" /* UseScrollRestoration */);\n  let { restoreScrollPosition, preventScrollReset } = useDataRouterState2(\n    \"useScrollRestoration\" /* UseScrollRestoration */\n  );\n  let { basename } = React10.useContext(NavigationContext);\n  let location = useLocation();\n  let matches = useMatches();\n  let navigation = useNavigation();\n  React10.useEffect(() => {\n    window.history.scrollRestoration = \"manual\";\n    return () => {\n      window.history.scrollRestoration = \"auto\";\n    };\n  }, []);\n  usePageHide(\n    React10.useCallback(() => {\n      if (navigation.state === \"idle\") {\n        let key = getScrollRestorationKey(location, matches, basename, getKey);\n        savedScrollPositions[key] = window.scrollY;\n      }\n      try {\n        sessionStorage.setItem(\n          storageKey || SCROLL_RESTORATION_STORAGE_KEY,\n          JSON.stringify(savedScrollPositions)\n        );\n      } catch (error) {\n        warning(\n          false,\n          `Failed to save scroll positions in sessionStorage, <ScrollRestoration /> will not work properly (${error}).`\n        );\n      }\n      window.history.scrollRestoration = \"auto\";\n    }, [navigation.state, getKey, basename, location, matches, storageKey])\n  );\n  if (typeof document !== \"undefined\") {\n    React10.useLayoutEffect(() => {\n      try {\n        let sessionPositions = sessionStorage.getItem(\n          storageKey || SCROLL_RESTORATION_STORAGE_KEY\n        );\n        if (sessionPositions) {\n          savedScrollPositions = JSON.parse(sessionPositions);\n        }\n      } catch (e) {\n      }\n    }, [storageKey]);\n    React10.useLayoutEffect(() => {\n      let disableScrollRestoration = router?.enableScrollRestoration(\n        savedScrollPositions,\n        () => window.scrollY,\n        getKey ? (location2, matches2) => getScrollRestorationKey(location2, matches2, basename, getKey) : void 0\n      );\n      return () => disableScrollRestoration && disableScrollRestoration();\n    }, [router, basename, getKey]);\n    React10.useLayoutEffect(() => {\n      if (restoreScrollPosition === false) {\n        return;\n      }\n      if (typeof restoreScrollPosition === \"number\") {\n        window.scrollTo(0, restoreScrollPosition);\n        return;\n      }\n      if (location.hash) {\n        let el = document.getElementById(\n          decodeURIComponent(location.hash.slice(1))\n        );\n        if (el) {\n          el.scrollIntoView();\n          return;\n        }\n      }\n      if (preventScrollReset === true) {\n        return;\n      }\n      window.scrollTo(0, 0);\n    }, [location, restoreScrollPosition, preventScrollReset]);\n  }\n}\nfunction useBeforeUnload(callback, options) {\n  let { capture } = options || {};\n  React10.useEffect(() => {\n    let opts = capture != null ? { capture } : void 0;\n    window.addEventListener(\"beforeunload\", callback, opts);\n    return () => {\n      window.removeEventListener(\"beforeunload\", callback, opts);\n    };\n  }, [callback, capture]);\n}\nfunction usePageHide(callback, options) {\n  let { capture } = options || {};\n  React10.useEffect(() => {\n    let opts = capture != null ? { capture } : void 0;\n    window.addEventListener(\"pagehide\", callback, opts);\n    return () => {\n      window.removeEventListener(\"pagehide\", callback, opts);\n    };\n  }, [callback, capture]);\n}\nfunction usePrompt({\n  when,\n  message\n}) {\n  let blocker = useBlocker(when);\n  React10.useEffect(() => {\n    if (blocker.state === \"blocked\") {\n      let proceed = window.confirm(message);\n      if (proceed) {\n        setTimeout(blocker.proceed, 0);\n      } else {\n        blocker.reset();\n      }\n    }\n  }, [blocker, message]);\n  React10.useEffect(() => {\n    if (blocker.state === \"blocked\" && !when) {\n      blocker.reset();\n    }\n  }, [blocker, when]);\n}\nfunction useViewTransitionState(to, opts = {}) {\n  let vtContext = React10.useContext(ViewTransitionContext);\n  invariant(\n    vtContext != null,\n    \"`useViewTransitionState` must be used within `react-router-dom`'s `RouterProvider`.  Did you accidentally import `RouterProvider` from `react-router`?\"\n  );\n  let { basename } = useDataRouterContext3(\n    \"useViewTransitionState\" /* useViewTransitionState */\n  );\n  let path = useResolvedPath(to, { relative: opts.relative });\n  if (!vtContext.isTransitioning) {\n    return false;\n  }\n  let currentPath = stripBasename(vtContext.currentLocation.pathname, basename) || vtContext.currentLocation.pathname;\n  let nextPath = stripBasename(vtContext.nextLocation.pathname, basename) || vtContext.nextLocation.pathname;\n  return matchPath(path.pathname, nextPath) != null || matchPath(path.pathname, currentPath) != null;\n}\n\n// lib/dom/server.tsx\nimport * as React11 from \"react\";\nfunction StaticRouter({\n  basename,\n  children,\n  location: locationProp = \"/\"\n}) {\n  if (typeof locationProp === \"string\") {\n    locationProp = parsePath(locationProp);\n  }\n  let action = \"POP\" /* Pop */;\n  let location = {\n    pathname: locationProp.pathname || \"/\",\n    search: locationProp.search || \"\",\n    hash: locationProp.hash || \"\",\n    state: locationProp.state != null ? locationProp.state : null,\n    key: locationProp.key || \"default\"\n  };\n  let staticNavigator = getStatelessNavigator();\n  return /* @__PURE__ */ React11.createElement(\n    Router,\n    {\n      basename,\n      children,\n      location,\n      navigationType: action,\n      navigator: staticNavigator,\n      static: true\n    }\n  );\n}\nfunction StaticRouterProvider({\n  context,\n  router,\n  hydrate = true,\n  nonce\n}) {\n  invariant(\n    router && context,\n    \"You must provide `router` and `context` to <StaticRouterProvider>\"\n  );\n  let dataRouterContext = {\n    router,\n    navigator: getStatelessNavigator(),\n    static: true,\n    staticContext: context,\n    basename: context.basename || \"/\"\n  };\n  let fetchersContext = /* @__PURE__ */ new Map();\n  let hydrateScript = \"\";\n  if (hydrate !== false) {\n    let data2 = {\n      loaderData: context.loaderData,\n      actionData: context.actionData,\n      errors: serializeErrors(context.errors)\n    };\n    let json = htmlEscape(JSON.stringify(JSON.stringify(data2)));\n    hydrateScript = `window.__staticRouterHydrationData = JSON.parse(${json});`;\n  }\n  let { state } = dataRouterContext.router;\n  return /* @__PURE__ */ React11.createElement(React11.Fragment, null, /* @__PURE__ */ React11.createElement(DataRouterContext.Provider, { value: dataRouterContext }, /* @__PURE__ */ React11.createElement(DataRouterStateContext.Provider, { value: state }, /* @__PURE__ */ React11.createElement(FetchersContext.Provider, { value: fetchersContext }, /* @__PURE__ */ React11.createElement(ViewTransitionContext.Provider, { value: { isTransitioning: false } }, /* @__PURE__ */ React11.createElement(\n    Router,\n    {\n      basename: dataRouterContext.basename,\n      location: state.location,\n      navigationType: state.historyAction,\n      navigator: dataRouterContext.navigator,\n      static: dataRouterContext.static\n    },\n    /* @__PURE__ */ React11.createElement(\n      DataRoutes2,\n      {\n        routes: router.routes,\n        future: router.future,\n        state\n      }\n    )\n  ))))), hydrateScript ? /* @__PURE__ */ React11.createElement(\n    \"script\",\n    {\n      suppressHydrationWarning: true,\n      nonce,\n      dangerouslySetInnerHTML: { __html: hydrateScript }\n    }\n  ) : null);\n}\nfunction DataRoutes2({\n  routes,\n  future,\n  state\n}) {\n  return useRoutesImpl(routes, void 0, state, future);\n}\nfunction serializeErrors(errors) {\n  if (!errors) return null;\n  let entries = Object.entries(errors);\n  let serialized = {};\n  for (let [key, val] of entries) {\n    if (isRouteErrorResponse(val)) {\n      serialized[key] = { ...val, __type: \"RouteErrorResponse\" };\n    } else if (val instanceof Error) {\n      serialized[key] = {\n        message: val.message,\n        __type: \"Error\",\n        // If this is a subclass (i.e., ReferenceError), send up the type so we\n        // can re-create the same type during hydration.\n        ...val.name !== \"Error\" ? {\n          __subType: val.name\n        } : {}\n      };\n    } else {\n      serialized[key] = val;\n    }\n  }\n  return serialized;\n}\nfunction getStatelessNavigator() {\n  return {\n    createHref,\n    encodeLocation,\n    push(to) {\n      throw new Error(\n        `You cannot use navigator.push() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${JSON.stringify(to)})\\` somewhere in your app.`\n      );\n    },\n    replace(to) {\n      throw new Error(\n        `You cannot use navigator.replace() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${JSON.stringify(to)}, { replace: true })\\` somewhere in your app.`\n      );\n    },\n    go(delta) {\n      throw new Error(\n        `You cannot use navigator.go() on the server because it is a stateless environment. This error was probably triggered when you did a \\`navigate(${delta})\\` somewhere in your app.`\n      );\n    },\n    back() {\n      throw new Error(\n        `You cannot use navigator.back() on the server because it is a stateless environment.`\n      );\n    },\n    forward() {\n      throw new Error(\n        `You cannot use navigator.forward() on the server because it is a stateless environment.`\n      );\n    }\n  };\n}\nfunction createStaticHandler2(routes, opts) {\n  return createStaticHandler(routes, {\n    ...opts,\n    mapRouteProperties\n  });\n}\nfunction createStaticRouter(routes, context, opts = {}) {\n  let manifest = {};\n  let dataRoutes = convertRoutesToDataRoutes(\n    routes,\n    mapRouteProperties,\n    void 0,\n    manifest\n  );\n  let matches = context.matches.map((match) => {\n    let route = manifest[match.route.id] || match.route;\n    return {\n      ...match,\n      route\n    };\n  });\n  let msg = (method) => `You cannot use router.${method}() on the server because it is a stateless environment`;\n  return {\n    get basename() {\n      return context.basename;\n    },\n    get future() {\n      return {\n        ...opts?.future\n      };\n    },\n    get state() {\n      return {\n        historyAction: \"POP\" /* Pop */,\n        location: context.location,\n        matches,\n        loaderData: context.loaderData,\n        actionData: context.actionData,\n        errors: context.errors,\n        initialized: true,\n        navigation: IDLE_NAVIGATION,\n        restoreScrollPosition: null,\n        preventScrollReset: false,\n        revalidation: \"idle\",\n        fetchers: /* @__PURE__ */ new Map(),\n        blockers: /* @__PURE__ */ new Map()\n      };\n    },\n    get routes() {\n      return dataRoutes;\n    },\n    get window() {\n      return void 0;\n    },\n    initialize() {\n      throw msg(\"initialize\");\n    },\n    subscribe() {\n      throw msg(\"subscribe\");\n    },\n    enableScrollRestoration() {\n      throw msg(\"enableScrollRestoration\");\n    },\n    navigate() {\n      throw msg(\"navigate\");\n    },\n    fetch() {\n      throw msg(\"fetch\");\n    },\n    revalidate() {\n      throw msg(\"revalidate\");\n    },\n    createHref,\n    encodeLocation,\n    getFetcher() {\n      return IDLE_FETCHER;\n    },\n    deleteFetcher() {\n      throw msg(\"deleteFetcher\");\n    },\n    dispose() {\n      throw msg(\"dispose\");\n    },\n    getBlocker() {\n      return IDLE_BLOCKER;\n    },\n    deleteBlocker() {\n      throw msg(\"deleteBlocker\");\n    },\n    patchRoutes() {\n      throw msg(\"patchRoutes\");\n    },\n    _internalFetchControllers: /* @__PURE__ */ new Map(),\n    _internalSetRoutes() {\n      throw msg(\"_internalSetRoutes\");\n    }\n  };\n}\nfunction createHref(to) {\n  return typeof to === \"string\" ? to : createPath(to);\n}\nfunction encodeLocation(to) {\n  let href = typeof to === \"string\" ? to : createPath(to);\n  href = href.replace(/ $/, \"%20\");\n  let encoded = ABSOLUTE_URL_REGEX3.test(href) ? new URL(href) : new URL(href, \"http://localhost\");\n  return {\n    pathname: encoded.pathname,\n    search: encoded.search,\n    hash: encoded.hash\n  };\n}\nvar ABSOLUTE_URL_REGEX3 = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\nvar ESCAPE_LOOKUP2 = {\n  \"&\": \"\\\\u0026\",\n  \">\": \"\\\\u003e\",\n  \"<\": \"\\\\u003c\",\n  \"\\u2028\": \"\\\\u2028\",\n  \"\\u2029\": \"\\\\u2029\"\n};\nvar ESCAPE_REGEX2 = /[&><\\u2028\\u2029]/g;\nfunction htmlEscape(str) {\n  return str.replace(ESCAPE_REGEX2, (match) => ESCAPE_LOOKUP2[match]);\n}\n\n// lib/dom/ssr/server.tsx\nimport * as React12 from \"react\";\nfunction ServerRouter({\n  context,\n  url,\n  nonce\n}) {\n  if (typeof url === \"string\") {\n    url = new URL(url);\n  }\n  let { manifest, routeModules, criticalCss, serverHandoffString } = context;\n  let routes = createServerRoutes(\n    manifest.routes,\n    routeModules,\n    context.future,\n    context.isSpaMode\n  );\n  context.staticHandlerContext.loaderData = {\n    ...context.staticHandlerContext.loaderData\n  };\n  for (let match of context.staticHandlerContext.matches) {\n    let routeId = match.route.id;\n    let route = routeModules[routeId];\n    let manifestRoute = context.manifest.routes[routeId];\n    if (route && manifestRoute && shouldHydrateRouteLoader(manifestRoute, route, context.isSpaMode) && (route.HydrateFallback || !manifestRoute.hasLoader)) {\n      delete context.staticHandlerContext.loaderData[routeId];\n    }\n  }\n  let router = createStaticRouter(routes, context.staticHandlerContext);\n  return /* @__PURE__ */ React12.createElement(React12.Fragment, null, /* @__PURE__ */ React12.createElement(\n    FrameworkContext.Provider,\n    {\n      value: {\n        manifest,\n        routeModules,\n        criticalCss,\n        serverHandoffString,\n        future: context.future,\n        isSpaMode: context.isSpaMode,\n        serializeError: context.serializeError,\n        renderMeta: context.renderMeta\n      }\n    },\n    /* @__PURE__ */ React12.createElement(RemixErrorBoundary, { location: router.state.location }, /* @__PURE__ */ React12.createElement(\n      StaticRouterProvider,\n      {\n        router,\n        context: context.staticHandlerContext,\n        hydrate: false\n      }\n    ))\n  ), context.serverHandoffStream ? /* @__PURE__ */ React12.createElement(React12.Suspense, null, /* @__PURE__ */ React12.createElement(\n    StreamTransfer,\n    {\n      context,\n      identifier: 0,\n      reader: context.serverHandoffStream.getReader(),\n      textDecoder: new TextDecoder(),\n      nonce\n    }\n  )) : null);\n}\n\n// lib/dom/ssr/routes-test-stub.tsx\nimport * as React13 from \"react\";\nfunction createRoutesStub(routes, context = {}) {\n  return function RoutesTestStub({\n    initialEntries,\n    initialIndex,\n    hydrationData,\n    future\n  }) {\n    let routerRef = React13.useRef();\n    let remixContextRef = React13.useRef();\n    if (routerRef.current == null) {\n      remixContextRef.current = {\n        future: {},\n        manifest: {\n          routes: {},\n          entry: { imports: [], module: \"\" },\n          url: \"\",\n          version: \"\"\n        },\n        routeModules: {},\n        isSpaMode: false\n      };\n      let patched = processRoutes(\n        // @ts-expect-error loader/action context types don't match :/\n        convertRoutesToDataRoutes(routes, (r) => r),\n        context,\n        remixContextRef.current.manifest,\n        remixContextRef.current.routeModules\n      );\n      routerRef.current = createMemoryRouter(patched, {\n        initialEntries,\n        initialIndex,\n        hydrationData\n      });\n    }\n    return /* @__PURE__ */ React13.createElement(FrameworkContext.Provider, { value: remixContextRef.current }, /* @__PURE__ */ React13.createElement(RouterProvider, { router: routerRef.current }));\n  };\n}\nfunction processRoutes(routes, context, manifest, routeModules, parentId) {\n  return routes.map((route) => {\n    if (!route.id) {\n      throw new Error(\n        \"Expected a route.id in @remix-run/testing processRoutes() function\"\n      );\n    }\n    let { loader, action } = route;\n    let newRoute = {\n      id: route.id,\n      path: route.path,\n      index: route.index,\n      Component: route.Component,\n      HydrateFallback: route.HydrateFallback,\n      ErrorBoundary: route.ErrorBoundary,\n      action: action ? (args) => action({ ...args, context }) : void 0,\n      loader: loader ? (args) => loader({ ...args, context }) : void 0,\n      handle: route.handle,\n      shouldRevalidate: route.shouldRevalidate\n    };\n    let entryRoute = {\n      id: route.id,\n      path: route.path,\n      index: route.index,\n      parentId,\n      hasAction: route.action != null,\n      hasLoader: route.loader != null,\n      // When testing routes, you should just be stubbing loader/action, not\n      // trying to re-implement the full loader/clientLoader/SSR/hydration flow.\n      // That is better tested via E2E tests.\n      hasClientAction: false,\n      hasClientLoader: false,\n      hasErrorBoundary: route.ErrorBoundary != null,\n      module: \"build/stub-path-to-module.js\"\n      // any need for this?\n    };\n    manifest.routes[newRoute.id] = entryRoute;\n    routeModules[route.id] = {\n      default: route.Component || Outlet,\n      ErrorBoundary: route.ErrorBoundary || void 0,\n      handle: route.handle,\n      links: route.links,\n      meta: route.meta,\n      shouldRevalidate: route.shouldRevalidate\n    };\n    if (route.children) {\n      newRoute.children = processRoutes(\n        route.children,\n        context,\n        manifest,\n        routeModules,\n        newRoute.id\n      );\n    }\n    return newRoute;\n  });\n}\n\n// lib/server-runtime/cookies.ts\nimport { parse, serialize } from \"cookie\";\n\n// lib/server-runtime/crypto.ts\nvar encoder = new TextEncoder();\nvar sign = async (value, secret) => {\n  let data2 = encoder.encode(value);\n  let key = await createKey2(secret, [\"sign\"]);\n  let signature = await crypto.subtle.sign(\"HMAC\", key, data2);\n  let hash = btoa(String.fromCharCode(...new Uint8Array(signature))).replace(\n    /=+$/,\n    \"\"\n  );\n  return value + \".\" + hash;\n};\nvar unsign = async (cookie, secret) => {\n  let index = cookie.lastIndexOf(\".\");\n  let value = cookie.slice(0, index);\n  let hash = cookie.slice(index + 1);\n  let data2 = encoder.encode(value);\n  let key = await createKey2(secret, [\"verify\"]);\n  let signature = byteStringToUint8Array(atob(hash));\n  let valid = await crypto.subtle.verify(\"HMAC\", key, signature, data2);\n  return valid ? value : false;\n};\nvar createKey2 = async (secret, usages) => crypto.subtle.importKey(\n  \"raw\",\n  encoder.encode(secret),\n  { name: \"HMAC\", hash: \"SHA-256\" },\n  false,\n  usages\n);\nfunction byteStringToUint8Array(byteString) {\n  let array = new Uint8Array(byteString.length);\n  for (let i = 0; i < byteString.length; i++) {\n    array[i] = byteString.charCodeAt(i);\n  }\n  return array;\n}\n\n// lib/server-runtime/cookies.ts\nvar createCookie = (name, cookieOptions = {}) => {\n  let { secrets = [], ...options } = {\n    path: \"/\",\n    sameSite: \"lax\",\n    ...cookieOptions\n  };\n  warnOnceAboutExpiresCookie(name, options.expires);\n  return {\n    get name() {\n      return name;\n    },\n    get isSigned() {\n      return secrets.length > 0;\n    },\n    get expires() {\n      return typeof options.maxAge !== \"undefined\" ? new Date(Date.now() + options.maxAge * 1e3) : options.expires;\n    },\n    async parse(cookieHeader, parseOptions) {\n      if (!cookieHeader) return null;\n      let cookies = parse(cookieHeader, { ...options, ...parseOptions });\n      if (name in cookies) {\n        let value = cookies[name];\n        if (typeof value === \"string\" && value !== \"\") {\n          let decoded = await decodeCookieValue(value, secrets);\n          return decoded;\n        } else {\n          return \"\";\n        }\n      } else {\n        return null;\n      }\n    },\n    async serialize(value, serializeOptions) {\n      return serialize(\n        name,\n        value === \"\" ? \"\" : await encodeCookieValue(value, secrets),\n        {\n          ...options,\n          ...serializeOptions\n        }\n      );\n    }\n  };\n};\nvar isCookie = (object) => {\n  return object != null && typeof object.name === \"string\" && typeof object.isSigned === \"boolean\" && typeof object.parse === \"function\" && typeof object.serialize === \"function\";\n};\nasync function encodeCookieValue(value, secrets) {\n  let encoded = encodeData(value);\n  if (secrets.length > 0) {\n    encoded = await sign(encoded, secrets[0]);\n  }\n  return encoded;\n}\nasync function decodeCookieValue(value, secrets) {\n  if (secrets.length > 0) {\n    for (let secret of secrets) {\n      let unsignedValue = await unsign(value, secret);\n      if (unsignedValue !== false) {\n        return decodeData(unsignedValue);\n      }\n    }\n    return null;\n  }\n  return decodeData(value);\n}\nfunction encodeData(value) {\n  return btoa(myUnescape(encodeURIComponent(JSON.stringify(value))));\n}\nfunction decodeData(value) {\n  try {\n    return JSON.parse(decodeURIComponent(myEscape(atob(value))));\n  } catch (error) {\n    return {};\n  }\n}\nfunction myEscape(value) {\n  let str = value.toString();\n  let result = \"\";\n  let index = 0;\n  let chr, code;\n  while (index < str.length) {\n    chr = str.charAt(index++);\n    if (/[\\w*+\\-./@]/.exec(chr)) {\n      result += chr;\n    } else {\n      code = chr.charCodeAt(0);\n      if (code < 256) {\n        result += \"%\" + hex(code, 2);\n      } else {\n        result += \"%u\" + hex(code, 4).toUpperCase();\n      }\n    }\n  }\n  return result;\n}\nfunction hex(code, length) {\n  let result = code.toString(16);\n  while (result.length < length) result = \"0\" + result;\n  return result;\n}\nfunction myUnescape(value) {\n  let str = value.toString();\n  let result = \"\";\n  let index = 0;\n  let chr, part;\n  while (index < str.length) {\n    chr = str.charAt(index++);\n    if (chr === \"%\") {\n      if (str.charAt(index) === \"u\") {\n        part = str.slice(index + 1, index + 5);\n        if (/^[\\da-f]{4}$/i.exec(part)) {\n          result += String.fromCharCode(parseInt(part, 16));\n          index += 5;\n          continue;\n        }\n      } else {\n        part = str.slice(index, index + 2);\n        if (/^[\\da-f]{2}$/i.exec(part)) {\n          result += String.fromCharCode(parseInt(part, 16));\n          index += 2;\n          continue;\n        }\n      }\n    }\n    result += chr;\n  }\n  return result;\n}\nfunction warnOnceAboutExpiresCookie(name, expires) {\n  warnOnce(\n    !expires,\n    `The \"${name}\" cookie has an \"expires\" property set. This will cause the expires value to not be updated when the session is committed. Instead, you should set the expires value when serializing the cookie. You can use \\`commitSession(session, { expires })\\` if using a session storage object, or \\`cookie.serialize(\"value\", { expires })\\` if you're using the cookie directly.`\n  );\n}\n\n// lib/server-runtime/entry.ts\nfunction createEntryRouteModules(manifest) {\n  return Object.keys(manifest).reduce((memo2, routeId) => {\n    let route = manifest[routeId];\n    if (route) {\n      memo2[routeId] = route.module;\n    }\n    return memo2;\n  }, {});\n}\n\n// lib/server-runtime/mode.ts\nvar ServerMode = /* @__PURE__ */ ((ServerMode2) => {\n  ServerMode2[\"Development\"] = \"development\";\n  ServerMode2[\"Production\"] = \"production\";\n  ServerMode2[\"Test\"] = \"test\";\n  return ServerMode2;\n})(ServerMode || {});\nfunction isServerMode(value) {\n  return value === \"development\" /* Development */ || value === \"production\" /* Production */ || value === \"test\" /* Test */;\n}\n\n// lib/server-runtime/errors.ts\nfunction sanitizeError(error, serverMode) {\n  if (error instanceof Error && serverMode !== \"development\" /* Development */) {\n    let sanitized = new Error(\"Unexpected Server Error\");\n    sanitized.stack = void 0;\n    return sanitized;\n  }\n  return error;\n}\nfunction sanitizeErrors(errors, serverMode) {\n  return Object.entries(errors).reduce((acc, [routeId, error]) => {\n    return Object.assign(acc, { [routeId]: sanitizeError(error, serverMode) });\n  }, {});\n}\nfunction serializeError(error, serverMode) {\n  let sanitized = sanitizeError(error, serverMode);\n  return {\n    message: sanitized.message,\n    stack: sanitized.stack\n  };\n}\nfunction serializeErrors2(errors, serverMode) {\n  if (!errors) return null;\n  let entries = Object.entries(errors);\n  let serialized = {};\n  for (let [key, val] of entries) {\n    if (isRouteErrorResponse(val)) {\n      serialized[key] = { ...val, __type: \"RouteErrorResponse\" };\n    } else if (val instanceof Error) {\n      let sanitized = sanitizeError(val, serverMode);\n      serialized[key] = {\n        message: sanitized.message,\n        stack: sanitized.stack,\n        __type: \"Error\",\n        // If this is a subclass (i.e., ReferenceError), send up the type so we\n        // can re-create the same type during hydration.  This will only apply\n        // in dev mode since all production errors are sanitized to normal\n        // Error instances\n        ...sanitized.name !== \"Error\" ? {\n          __subType: sanitized.name\n        } : {}\n      };\n    } else {\n      serialized[key] = val;\n    }\n  }\n  return serialized;\n}\n\n// lib/server-runtime/routeMatching.ts\nfunction matchServerRoutes(routes, pathname, basename) {\n  let matches = matchRoutes(\n    routes,\n    pathname,\n    basename\n  );\n  if (!matches) return null;\n  return matches.map((match) => ({\n    params: match.params,\n    pathname: match.pathname,\n    route: match.route\n  }));\n}\n\n// lib/server-runtime/data.ts\nasync function callRouteHandler(handler, args) {\n  let result = await handler({\n    request: stripRoutesParam(stripIndexParam2(args.request)),\n    params: args.params,\n    context: args.context\n  });\n  if (isDataWithResponseInit(result) && result.init && result.init.status && isRedirectStatusCode(result.init.status)) {\n    throw new Response(null, result.init);\n  }\n  return result;\n}\nfunction stripIndexParam2(request) {\n  let url = new URL(request.url);\n  let indexValues = url.searchParams.getAll(\"index\");\n  url.searchParams.delete(\"index\");\n  let indexValuesToKeep = [];\n  for (let indexValue of indexValues) {\n    if (indexValue) {\n      indexValuesToKeep.push(indexValue);\n    }\n  }\n  for (let toKeep of indexValuesToKeep) {\n    url.searchParams.append(\"index\", toKeep);\n  }\n  let init = {\n    method: request.method,\n    body: request.body,\n    headers: request.headers,\n    signal: request.signal\n  };\n  if (init.body) {\n    init.duplex = \"half\";\n  }\n  return new Request(url.href, init);\n}\nfunction stripRoutesParam(request) {\n  let url = new URL(request.url);\n  url.searchParams.delete(\"_routes\");\n  let init = {\n    method: request.method,\n    body: request.body,\n    headers: request.headers,\n    signal: request.signal\n  };\n  if (init.body) {\n    init.duplex = \"half\";\n  }\n  return new Request(url.href, init);\n}\n\n// lib/server-runtime/invariant.ts\nfunction invariant3(value, message) {\n  if (value === false || value === null || typeof value === \"undefined\") {\n    console.error(\n      \"The following error is a bug in React Router; please open an issue! https://github.com/remix-run/react-router/issues/new/choose\"\n    );\n    throw new Error(message);\n  }\n}\n\n// lib/server-runtime/routes.ts\nfunction groupRoutesByParentId2(manifest) {\n  let routes = {};\n  Object.values(manifest).forEach((route) => {\n    if (route) {\n      let parentId = route.parentId || \"\";\n      if (!routes[parentId]) {\n        routes[parentId] = [];\n      }\n      routes[parentId].push(route);\n    }\n  });\n  return routes;\n}\nfunction createRoutes(manifest, parentId = \"\", routesByParentId = groupRoutesByParentId2(manifest)) {\n  return (routesByParentId[parentId] || []).map((route) => ({\n    ...route,\n    children: createRoutes(manifest, route.id, routesByParentId)\n  }));\n}\nfunction createStaticHandlerDataRoutes(manifest, future, parentId = \"\", routesByParentId = groupRoutesByParentId2(manifest)) {\n  return (routesByParentId[parentId] || []).map((route) => {\n    let commonRoute = {\n      // Always include root due to default boundaries\n      hasErrorBoundary: route.id === \"root\" || route.module.ErrorBoundary != null,\n      id: route.id,\n      path: route.path,\n      // Need to use RR's version in the param typed here to permit the optional\n      // context even though we know it'll always be provided in remix\n      loader: route.module.loader ? async (args) => {\n        if (args.request.headers.has(\"X-React-Router-Prerender-Data\")) {\n          const preRenderedData = args.request.headers.get(\n            \"X-React-Router-Prerender-Data\"\n          );\n          let encoded = preRenderedData ? decodeURI(preRenderedData) : preRenderedData;\n          invariant3(encoded, \"Missing prerendered data for route\");\n          let uint8array = new TextEncoder().encode(encoded);\n          let stream = new ReadableStream({\n            start(controller) {\n              controller.enqueue(uint8array);\n              controller.close();\n            }\n          });\n          let decoded = await decodeViaTurboStream(stream, global);\n          let data2 = decoded.value;\n          invariant3(\n            data2 && route.id in data2,\n            \"Unable to decode prerendered data\"\n          );\n          let result = data2[route.id];\n          invariant3(\"data\" in result, \"Unable to process prerendered data\");\n          return result.data;\n        }\n        let val = await callRouteHandler(route.module.loader, args);\n        return val;\n      } : void 0,\n      action: route.module.action ? (args) => callRouteHandler(route.module.action, args) : void 0,\n      handle: route.module.handle\n    };\n    return route.index ? {\n      index: true,\n      ...commonRoute\n    } : {\n      caseSensitive: route.caseSensitive,\n      children: createStaticHandlerDataRoutes(\n        manifest,\n        future,\n        route.id,\n        routesByParentId\n      ),\n      ...commonRoute\n    };\n  });\n}\n\n// lib/server-runtime/markup.ts\nvar ESCAPE_LOOKUP3 = {\n  \"&\": \"\\\\u0026\",\n  \">\": \"\\\\u003e\",\n  \"<\": \"\\\\u003c\",\n  \"\\u2028\": \"\\\\u2028\",\n  \"\\u2029\": \"\\\\u2029\"\n};\nvar ESCAPE_REGEX3 = /[&><\\u2028\\u2029]/g;\nfunction escapeHtml2(html) {\n  return html.replace(ESCAPE_REGEX3, (match) => ESCAPE_LOOKUP3[match]);\n}\n\n// lib/server-runtime/serverHandoff.ts\nfunction createServerHandoffString(serverHandoff) {\n  return escapeHtml2(JSON.stringify(serverHandoff));\n}\n\n// lib/server-runtime/dev.ts\nvar globalDevServerHooksKey = \"__reactRouterDevServerHooks\";\nfunction setDevServerHooks(devServerHooks) {\n  globalThis[globalDevServerHooksKey] = devServerHooks;\n}\nfunction getDevServerHooks() {\n  return globalThis[globalDevServerHooksKey];\n}\n\n// lib/server-runtime/single-fetch.ts\nimport { encode } from \"turbo-stream\";\n\n// lib/server-runtime/headers.ts\nimport { splitCookiesString } from \"set-cookie-parser\";\nfunction getDocumentHeaders(build, context) {\n  let boundaryIdx = context.errors ? context.matches.findIndex((m) => context.errors[m.route.id]) : -1;\n  let matches = boundaryIdx >= 0 ? context.matches.slice(0, boundaryIdx + 1) : context.matches;\n  let errorHeaders;\n  if (boundaryIdx >= 0) {\n    let { actionHeaders, actionData, loaderHeaders, loaderData } = context;\n    context.matches.slice(boundaryIdx).some((match) => {\n      let id = match.route.id;\n      if (actionHeaders[id] && (!actionData || !actionData.hasOwnProperty(id))) {\n        errorHeaders = actionHeaders[id];\n      } else if (loaderHeaders[id] && !loaderData.hasOwnProperty(id)) {\n        errorHeaders = loaderHeaders[id];\n      }\n      return errorHeaders != null;\n    });\n  }\n  return matches.reduce((parentHeaders, match, idx) => {\n    let { id } = match.route;\n    let route = build.routes[id];\n    invariant3(route, `Route with id \"${id}\" not found in build`);\n    let routeModule = route.module;\n    let loaderHeaders = context.loaderHeaders[id] || new Headers();\n    let actionHeaders = context.actionHeaders[id] || new Headers();\n    let includeErrorHeaders = errorHeaders != null && idx === matches.length - 1;\n    let includeErrorCookies = includeErrorHeaders && errorHeaders !== loaderHeaders && errorHeaders !== actionHeaders;\n    if (routeModule.headers == null) {\n      let headers2 = new Headers(parentHeaders);\n      if (includeErrorCookies) {\n        prependCookies(errorHeaders, headers2);\n      }\n      prependCookies(actionHeaders, headers2);\n      prependCookies(loaderHeaders, headers2);\n      return headers2;\n    }\n    let headers = new Headers(\n      routeModule.headers ? typeof routeModule.headers === \"function\" ? routeModule.headers({\n        loaderHeaders,\n        parentHeaders,\n        actionHeaders,\n        errorHeaders: includeErrorHeaders ? errorHeaders : void 0\n      }) : routeModule.headers : void 0\n    );\n    if (includeErrorCookies) {\n      prependCookies(errorHeaders, headers);\n    }\n    prependCookies(actionHeaders, headers);\n    prependCookies(loaderHeaders, headers);\n    prependCookies(parentHeaders, headers);\n    return headers;\n  }, new Headers());\n}\nfunction prependCookies(parentHeaders, childHeaders) {\n  let parentSetCookieString = parentHeaders.get(\"Set-Cookie\");\n  if (parentSetCookieString) {\n    let cookies = splitCookiesString(parentSetCookieString);\n    cookies.forEach((cookie) => {\n      childHeaders.append(\"Set-Cookie\", cookie);\n    });\n  }\n}\n\n// lib/server-runtime/single-fetch.ts\nvar SINGLE_FETCH_REDIRECT_STATUS = 202;\nfunction getSingleFetchDataStrategy2({\n  isActionDataRequest,\n  loadRouteIds\n} = {}) {\n  return async ({ request, matches }) => {\n    if (isActionDataRequest && request.method === \"GET\") {\n      return {};\n    }\n    let matchesToLoad = loadRouteIds ? matches.filter((m) => loadRouteIds.includes(m.route.id)) : matches;\n    let results = await Promise.all(\n      matchesToLoad.map((match) => match.resolve())\n    );\n    return results.reduce(\n      (acc, result, i) => Object.assign(acc, { [matchesToLoad[i].route.id]: result }),\n      {}\n    );\n  };\n}\nasync function singleFetchAction(build, serverMode, staticHandler, request, handlerUrl, loadContext, handleError) {\n  try {\n    let handlerRequest = new Request(handlerUrl, {\n      method: request.method,\n      body: request.body,\n      headers: request.headers,\n      signal: request.signal,\n      ...request.body ? { duplex: \"half\" } : void 0\n    });\n    let result = await staticHandler.query(handlerRequest, {\n      requestContext: loadContext,\n      skipLoaderErrorBubbling: true,\n      dataStrategy: getSingleFetchDataStrategy2({\n        isActionDataRequest: true\n      })\n    });\n    if (isResponse(result)) {\n      return {\n        result: getSingleFetchRedirect(\n          result.status,\n          result.headers,\n          build.basename\n        ),\n        headers: result.headers,\n        status: SINGLE_FETCH_REDIRECT_STATUS\n      };\n    }\n    let context = result;\n    let headers = getDocumentHeaders(build, context);\n    if (isRedirectStatusCode(context.statusCode) && headers.has(\"Location\")) {\n      return {\n        result: getSingleFetchRedirect(\n          context.statusCode,\n          headers,\n          build.basename\n        ),\n        headers,\n        status: SINGLE_FETCH_REDIRECT_STATUS\n      };\n    }\n    if (context.errors) {\n      Object.values(context.errors).forEach((err) => {\n        if (!isRouteErrorResponse(err) || err.error) {\n          handleError(err);\n        }\n      });\n      context.errors = sanitizeErrors(context.errors, serverMode);\n    }\n    let singleFetchResult;\n    if (context.errors) {\n      singleFetchResult = { error: Object.values(context.errors)[0] };\n    } else {\n      singleFetchResult = { data: Object.values(context.actionData || {})[0] };\n    }\n    return {\n      result: singleFetchResult,\n      headers,\n      status: context.statusCode\n    };\n  } catch (error) {\n    handleError(error);\n    return {\n      result: { error },\n      headers: new Headers(),\n      status: 500\n    };\n  }\n}\nasync function singleFetchLoaders(build, serverMode, staticHandler, request, handlerUrl, loadContext, handleError) {\n  try {\n    let handlerRequest = new Request(handlerUrl, {\n      headers: request.headers,\n      signal: request.signal\n    });\n    let loadRouteIds = new URL(request.url).searchParams.get(\"_routes\")?.split(\",\") || void 0;\n    let result = await staticHandler.query(handlerRequest, {\n      requestContext: loadContext,\n      skipLoaderErrorBubbling: true,\n      dataStrategy: getSingleFetchDataStrategy2({\n        loadRouteIds\n      })\n    });\n    if (isResponse(result)) {\n      return {\n        result: {\n          [SingleFetchRedirectSymbol]: getSingleFetchRedirect(\n            result.status,\n            result.headers,\n            build.basename\n          )\n        },\n        headers: result.headers,\n        status: SINGLE_FETCH_REDIRECT_STATUS\n      };\n    }\n    let context = result;\n    let headers = getDocumentHeaders(build, context);\n    if (isRedirectStatusCode(context.statusCode) && headers.has(\"Location\")) {\n      return {\n        result: {\n          [SingleFetchRedirectSymbol]: getSingleFetchRedirect(\n            context.statusCode,\n            headers,\n            build.basename\n          )\n        },\n        headers,\n        status: SINGLE_FETCH_REDIRECT_STATUS\n      };\n    }\n    if (context.errors) {\n      Object.values(context.errors).forEach((err) => {\n        if (!isRouteErrorResponse(err) || err.error) {\n          handleError(err);\n        }\n      });\n      context.errors = sanitizeErrors(context.errors, serverMode);\n    }\n    let results = {};\n    let loadedMatches = loadRouteIds ? context.matches.filter(\n      (m) => m.route.loader && loadRouteIds.includes(m.route.id)\n    ) : context.matches;\n    loadedMatches.forEach((m) => {\n      let { id } = m.route;\n      if (context.errors && context.errors.hasOwnProperty(id)) {\n        results[id] = { error: context.errors[id] };\n      } else if (context.loaderData.hasOwnProperty(id)) {\n        results[id] = { data: context.loaderData[id] };\n      }\n    });\n    return {\n      result: results,\n      headers,\n      status: context.statusCode\n    };\n  } catch (error) {\n    handleError(error);\n    return {\n      result: { root: { error } },\n      headers: new Headers(),\n      status: 500\n    };\n  }\n}\nfunction getSingleFetchRedirect(status, headers, basename) {\n  let redirect2 = headers.get(\"Location\");\n  if (basename) {\n    redirect2 = stripBasename(redirect2, basename) || redirect2;\n  }\n  return {\n    redirect: redirect2,\n    status,\n    revalidate: (\n      // Technically X-Remix-Revalidate isn't needed here - that was an implementation\n      // detail of ?_data requests as our way to tell the front end to revalidate when\n      // we didn't have a response body to include that information in.\n      // With single fetch, we tell the front end via this revalidate boolean field.\n      // However, we're respecting it for now because it may be something folks have\n      // used in their own responses\n      // TODO(v3): Consider removing or making this official public API\n      headers.has(\"X-Remix-Revalidate\") || headers.has(\"Set-Cookie\")\n    ),\n    reload: headers.has(\"X-Remix-Reload-Document\"),\n    replace: headers.has(\"X-Remix-Replace\")\n  };\n}\nfunction encodeViaTurboStream(data2, requestSignal, streamTimeout, serverMode) {\n  let controller = new AbortController();\n  let timeoutId = setTimeout(\n    () => controller.abort(new Error(\"Server Timeout\")),\n    typeof streamTimeout === \"number\" ? streamTimeout : 4950\n  );\n  requestSignal.addEventListener(\"abort\", () => clearTimeout(timeoutId));\n  return encode(data2, {\n    signal: controller.signal,\n    plugins: [\n      (value) => {\n        if (value instanceof Error) {\n          let { name, message, stack } = serverMode === \"production\" /* Production */ ? sanitizeError(value, serverMode) : value;\n          return [\"SanitizedError\", name, message, stack];\n        }\n        if (value instanceof ErrorResponseImpl) {\n          let { data: data3, status, statusText } = value;\n          return [\"ErrorResponse\", data3, status, statusText];\n        }\n        if (value && typeof value === \"object\" && SingleFetchRedirectSymbol in value) {\n          return [\"SingleFetchRedirect\", value[SingleFetchRedirectSymbol]];\n        }\n      }\n    ],\n    postPlugins: [\n      (value) => {\n        if (!value) return;\n        if (typeof value !== \"object\") return;\n        return [\n          \"SingleFetchClassInstance\",\n          Object.fromEntries(Object.entries(value))\n        ];\n      },\n      () => [\"SingleFetchFallback\"]\n    ]\n  });\n}\n\n// lib/server-runtime/server.ts\nfunction derive(build, mode) {\n  let routes = createRoutes(build.routes);\n  let dataRoutes = createStaticHandlerDataRoutes(build.routes, build.future);\n  let serverMode = isServerMode(mode) ? mode : \"production\" /* Production */;\n  let staticHandler = createStaticHandler(dataRoutes, {\n    basename: build.basename\n  });\n  let errorHandler = build.entry.module.handleError || ((error, { request }) => {\n    if (serverMode !== \"test\" /* Test */ && !request.signal.aborted) {\n      console.error(\n        // @ts-expect-error This is \"private\" from users but intended for internal use\n        isRouteErrorResponse(error) && error.error ? error.error : error\n      );\n    }\n  });\n  return {\n    routes,\n    dataRoutes,\n    serverMode,\n    staticHandler,\n    errorHandler\n  };\n}\nvar createRequestHandler = (build, mode) => {\n  let _build;\n  let routes;\n  let serverMode;\n  let staticHandler;\n  let errorHandler;\n  return async function requestHandler(request, loadContext = {}) {\n    _build = typeof build === \"function\" ? await build() : build;\n    if (typeof build === \"function\") {\n      let derived = derive(_build, mode);\n      routes = derived.routes;\n      serverMode = derived.serverMode;\n      staticHandler = derived.staticHandler;\n      errorHandler = derived.errorHandler;\n    } else if (!routes || !serverMode || !staticHandler || !errorHandler) {\n      let derived = derive(_build, mode);\n      routes = derived.routes;\n      serverMode = derived.serverMode;\n      staticHandler = derived.staticHandler;\n      errorHandler = derived.errorHandler;\n    }\n    let url = new URL(request.url);\n    let params = {};\n    let handleError = (error) => {\n      if (mode === \"development\" /* Development */) {\n        getDevServerHooks()?.processRequestError?.(error);\n      }\n      errorHandler(error, {\n        context: loadContext,\n        params,\n        request\n      });\n    };\n    let manifestUrl = `${_build.basename ?? \"/\"}/__manifest`.replace(\n      /\\/+/g,\n      \"/\"\n    );\n    if (url.pathname === manifestUrl) {\n      try {\n        let res = await handleManifestRequest(_build, routes, url);\n        return res;\n      } catch (e) {\n        handleError(e);\n        return new Response(\"Unknown Server Error\", { status: 500 });\n      }\n    }\n    let matches = matchServerRoutes(routes, url.pathname, _build.basename);\n    if (matches && matches.length > 0) {\n      Object.assign(params, matches[0].params);\n    }\n    let response;\n    if (url.pathname.endsWith(\".data\")) {\n      let handlerUrl = new URL(request.url);\n      handlerUrl.pathname = handlerUrl.pathname.replace(/\\.data$/, \"\").replace(/^\\/_root$/, \"/\");\n      let singleFetchMatches = matchServerRoutes(\n        routes,\n        handlerUrl.pathname,\n        _build.basename\n      );\n      response = await handleSingleFetchRequest(\n        serverMode,\n        _build,\n        staticHandler,\n        request,\n        handlerUrl,\n        loadContext,\n        handleError\n      );\n      if (_build.entry.module.handleDataRequest) {\n        response = await _build.entry.module.handleDataRequest(response, {\n          context: loadContext,\n          params: singleFetchMatches ? singleFetchMatches[0].params : {},\n          request\n        });\n        if (isRedirectResponse(response)) {\n          let result = getSingleFetchRedirect(\n            response.status,\n            response.headers,\n            _build.basename\n          );\n          if (request.method === \"GET\") {\n            result = {\n              [SingleFetchRedirectSymbol]: result\n            };\n          }\n          let headers = new Headers(response.headers);\n          headers.set(\"Content-Type\", \"text/x-script\");\n          return new Response(\n            encodeViaTurboStream(\n              result,\n              request.signal,\n              _build.entry.module.streamTimeout,\n              serverMode\n            ),\n            {\n              status: SINGLE_FETCH_REDIRECT_STATUS,\n              headers\n            }\n          );\n        }\n      }\n    } else if (matches && matches[matches.length - 1].route.module.default == null && matches[matches.length - 1].route.module.ErrorBoundary == null) {\n      response = await handleResourceRequest(\n        serverMode,\n        staticHandler,\n        matches.slice(-1)[0].route.id,\n        request,\n        loadContext,\n        handleError\n      );\n    } else {\n      let criticalCss = mode === \"development\" /* Development */ ? await getDevServerHooks()?.getCriticalCss?.(_build, url.pathname) : void 0;\n      response = await handleDocumentRequest(\n        serverMode,\n        _build,\n        staticHandler,\n        request,\n        loadContext,\n        handleError,\n        criticalCss\n      );\n    }\n    if (request.method === \"HEAD\") {\n      return new Response(null, {\n        headers: response.headers,\n        status: response.status,\n        statusText: response.statusText\n      });\n    }\n    return response;\n  };\n};\nasync function handleManifestRequest(build, routes, url) {\n  let patches = {};\n  if (url.searchParams.has(\"p\")) {\n    for (let path of url.searchParams.getAll(\"p\")) {\n      let matches = matchServerRoutes(routes, path, build.basename);\n      if (matches) {\n        for (let match of matches) {\n          let routeId = match.route.id;\n          let route = build.assets.routes[routeId];\n          if (route) {\n            patches[routeId] = route;\n          }\n        }\n      }\n    }\n    return Response.json(patches, {\n      headers: {\n        \"Cache-Control\": \"public, max-age=31536000, immutable\"\n      }\n    });\n  }\n  return new Response(\"Invalid Request\", { status: 400 });\n}\nasync function handleSingleFetchRequest(serverMode, build, staticHandler, request, handlerUrl, loadContext, handleError) {\n  let { result, headers, status } = request.method !== \"GET\" ? await singleFetchAction(\n    build,\n    serverMode,\n    staticHandler,\n    request,\n    handlerUrl,\n    loadContext,\n    handleError\n  ) : await singleFetchLoaders(\n    build,\n    serverMode,\n    staticHandler,\n    request,\n    handlerUrl,\n    loadContext,\n    handleError\n  );\n  let resultHeaders = new Headers(headers);\n  resultHeaders.set(\"X-Remix-Response\", \"yes\");\n  if (status === 304) {\n    return new Response(null, { status: 304, headers: resultHeaders });\n  }\n  resultHeaders.set(\"Content-Type\", \"text/x-script\");\n  return new Response(\n    encodeViaTurboStream(\n      result,\n      request.signal,\n      build.entry.module.streamTimeout,\n      serverMode\n    ),\n    {\n      status: status || 200,\n      headers: resultHeaders\n    }\n  );\n}\nasync function handleDocumentRequest(serverMode, build, staticHandler, request, loadContext, handleError, criticalCss) {\n  let context;\n  try {\n    context = await staticHandler.query(request, {\n      requestContext: loadContext\n    });\n  } catch (error) {\n    handleError(error);\n    return new Response(null, { status: 500 });\n  }\n  if (isResponse(context)) {\n    return context;\n  }\n  let headers = getDocumentHeaders(build, context);\n  if (context.statusCode === 304) {\n    return new Response(null, { status: 304, headers });\n  }\n  if (context.errors) {\n    Object.values(context.errors).forEach((err) => {\n      if (!isRouteErrorResponse(err) || err.error) {\n        handleError(err);\n      }\n    });\n    context.errors = sanitizeErrors(context.errors, serverMode);\n  }\n  let state = {\n    loaderData: context.loaderData,\n    actionData: context.actionData,\n    errors: serializeErrors2(context.errors, serverMode)\n  };\n  let entryContext = {\n    manifest: build.assets,\n    routeModules: createEntryRouteModules(build.routes),\n    staticHandlerContext: context,\n    criticalCss,\n    serverHandoffString: createServerHandoffString({\n      basename: build.basename,\n      criticalCss,\n      future: build.future,\n      isSpaMode: build.isSpaMode\n    }),\n    serverHandoffStream: encodeViaTurboStream(\n      state,\n      request.signal,\n      build.entry.module.streamTimeout,\n      serverMode\n    ),\n    renderMeta: {},\n    future: build.future,\n    isSpaMode: build.isSpaMode,\n    serializeError: (err) => serializeError(err, serverMode)\n  };\n  let handleDocumentRequestFunction = build.entry.module.default;\n  try {\n    return await handleDocumentRequestFunction(\n      request,\n      context.statusCode,\n      headers,\n      entryContext,\n      loadContext\n    );\n  } catch (error) {\n    handleError(error);\n    let errorForSecondRender = error;\n    if (isResponse(error)) {\n      try {\n        let data2 = await unwrapResponse(error);\n        errorForSecondRender = new ErrorResponseImpl(\n          error.status,\n          error.statusText,\n          data2\n        );\n      } catch (e) {\n      }\n    }\n    context = getStaticContextFromError(\n      staticHandler.dataRoutes,\n      context,\n      errorForSecondRender\n    );\n    if (context.errors) {\n      context.errors = sanitizeErrors(context.errors, serverMode);\n    }\n    let state2 = {\n      loaderData: context.loaderData,\n      actionData: context.actionData,\n      errors: serializeErrors2(context.errors, serverMode)\n    };\n    entryContext = {\n      ...entryContext,\n      staticHandlerContext: context,\n      serverHandoffString: createServerHandoffString({\n        basename: build.basename,\n        future: build.future,\n        isSpaMode: build.isSpaMode\n      }),\n      serverHandoffStream: encodeViaTurboStream(\n        state2,\n        request.signal,\n        build.entry.module.streamTimeout,\n        serverMode\n      ),\n      renderMeta: {}\n    };\n    try {\n      return await handleDocumentRequestFunction(\n        request,\n        context.statusCode,\n        headers,\n        entryContext,\n        loadContext\n      );\n    } catch (error2) {\n      handleError(error2);\n      return returnLastResortErrorResponse(error2, serverMode);\n    }\n  }\n}\nasync function handleResourceRequest(serverMode, staticHandler, routeId, request, loadContext, handleError) {\n  try {\n    let response = await staticHandler.queryRoute(request, {\n      routeId,\n      requestContext: loadContext\n    });\n    invariant3(\n      isResponse(response),\n      \"Expected a Response to be returned from resource route handler\"\n    );\n    return response;\n  } catch (error) {\n    if (isResponse(error)) {\n      error.headers.set(\"X-Remix-Catch\", \"yes\");\n      return error;\n    }\n    if (isRouteErrorResponse(error)) {\n      if (error) {\n        handleError(error);\n      }\n      return errorResponseToJson(error, serverMode);\n    }\n    handleError(error);\n    return returnLastResortErrorResponse(error, serverMode);\n  }\n}\nfunction errorResponseToJson(errorResponse, serverMode) {\n  return Response.json(\n    serializeError(\n      // @ts-expect-error This is \"private\" from users but intended for internal use\n      errorResponse.error || new Error(\"Unexpected Server Error\"),\n      serverMode\n    ),\n    {\n      status: errorResponse.status,\n      statusText: errorResponse.statusText,\n      headers: {\n        \"X-Remix-Error\": \"yes\"\n      }\n    }\n  );\n}\nfunction returnLastResortErrorResponse(error, serverMode) {\n  let message = \"Unexpected Server Error\";\n  if (serverMode !== \"production\" /* Production */) {\n    message += `\n\n${String(error)}`;\n  }\n  return new Response(message, {\n    status: 500,\n    headers: {\n      \"Content-Type\": \"text/plain\"\n    }\n  });\n}\nfunction unwrapResponse(response) {\n  let contentType = response.headers.get(\"Content-Type\");\n  return contentType && /\\bapplication\\/json\\b/.test(contentType) ? response.body == null ? null : response.json() : response.text();\n}\n\n// lib/server-runtime/sessions.ts\nfunction flash(name) {\n  return `__flash_${name}__`;\n}\nvar createSession = (initialData = {}, id = \"\") => {\n  let map = new Map(Object.entries(initialData));\n  return {\n    get id() {\n      return id;\n    },\n    get data() {\n      return Object.fromEntries(map);\n    },\n    has(name) {\n      return map.has(name) || map.has(flash(name));\n    },\n    get(name) {\n      if (map.has(name)) return map.get(name);\n      let flashName = flash(name);\n      if (map.has(flashName)) {\n        let value = map.get(flashName);\n        map.delete(flashName);\n        return value;\n      }\n      return void 0;\n    },\n    set(name, value) {\n      map.set(name, value);\n    },\n    flash(name, value) {\n      map.set(flash(name), value);\n    },\n    unset(name) {\n      map.delete(name);\n    }\n  };\n};\nvar isSession = (object) => {\n  return object != null && typeof object.id === \"string\" && typeof object.data !== \"undefined\" && typeof object.has === \"function\" && typeof object.get === \"function\" && typeof object.set === \"function\" && typeof object.flash === \"function\" && typeof object.unset === \"function\";\n};\nfunction createSessionStorage({\n  cookie: cookieArg,\n  createData,\n  readData,\n  updateData,\n  deleteData\n}) {\n  let cookie = isCookie(cookieArg) ? cookieArg : createCookie(cookieArg?.name || \"__session\", cookieArg);\n  warnOnceAboutSigningSessionCookie(cookie);\n  return {\n    async getSession(cookieHeader, options) {\n      let id = cookieHeader && await cookie.parse(cookieHeader, options);\n      let data2 = id && await readData(id);\n      return createSession(data2 || {}, id || \"\");\n    },\n    async commitSession(session, options) {\n      let { id, data: data2 } = session;\n      let expires = options?.maxAge != null ? new Date(Date.now() + options.maxAge * 1e3) : options?.expires != null ? options.expires : cookie.expires;\n      if (id) {\n        await updateData(id, data2, expires);\n      } else {\n        id = await createData(data2, expires);\n      }\n      return cookie.serialize(id, options);\n    },\n    async destroySession(session, options) {\n      await deleteData(session.id);\n      return cookie.serialize(\"\", {\n        ...options,\n        maxAge: void 0,\n        expires: /* @__PURE__ */ new Date(0)\n      });\n    }\n  };\n}\nfunction warnOnceAboutSigningSessionCookie(cookie) {\n  warnOnce(\n    cookie.isSigned,\n    `The \"${cookie.name}\" cookie is not signed, but session cookies should be signed to prevent tampering on the client before they are sent back to the server. See https://remix.run/utils/cookies#signing-cookies for more information.`\n  );\n}\n\n// lib/server-runtime/sessions/cookieStorage.ts\nfunction createCookieSessionStorage({ cookie: cookieArg } = {}) {\n  let cookie = isCookie(cookieArg) ? cookieArg : createCookie(cookieArg?.name || \"__session\", cookieArg);\n  warnOnceAboutSigningSessionCookie(cookie);\n  return {\n    async getSession(cookieHeader, options) {\n      return createSession(\n        cookieHeader && await cookie.parse(cookieHeader, options) || {}\n      );\n    },\n    async commitSession(session, options) {\n      let serializedCookie = await cookie.serialize(session.data, options);\n      if (serializedCookie.length > 4096) {\n        throw new Error(\n          \"Cookie length will exceed browser maximum. Length: \" + serializedCookie.length\n        );\n      }\n      return serializedCookie;\n    },\n    async destroySession(_session, options) {\n      return cookie.serialize(\"\", {\n        ...options,\n        maxAge: void 0,\n        expires: /* @__PURE__ */ new Date(0)\n      });\n    }\n  };\n}\n\n// lib/server-runtime/sessions/memoryStorage.ts\nfunction createMemorySessionStorage({ cookie } = {}) {\n  let map = /* @__PURE__ */ new Map();\n  return createSessionStorage({\n    cookie,\n    async createData(data2, expires) {\n      let id = Math.random().toString(36).substring(2, 10);\n      map.set(id, { data: data2, expires });\n      return id;\n    },\n    async readData(id) {\n      if (map.has(id)) {\n        let { data: data2, expires } = map.get(id);\n        if (!expires || expires > /* @__PURE__ */ new Date()) {\n          return data2;\n        }\n        if (expires) map.delete(id);\n      }\n      return null;\n    },\n    async updateData(id, data2, expires) {\n      map.set(id, { data: data2, expires });\n    },\n    async deleteData(id) {\n      map.delete(id);\n    }\n  });\n}\n\n// lib/dom/ssr/errors.ts\nfunction deserializeErrors2(errors) {\n  if (!errors) return null;\n  let entries = Object.entries(errors);\n  let serialized = {};\n  for (let [key, val] of entries) {\n    if (val && val.__type === \"RouteErrorResponse\") {\n      serialized[key] = new ErrorResponseImpl(\n        val.status,\n        val.statusText,\n        val.data,\n        val.internal === true\n      );\n    } else if (val && val.__type === \"Error\") {\n      if (val.__subType) {\n        let ErrorConstructor = window[val.__subType];\n        if (typeof ErrorConstructor === \"function\") {\n          try {\n            let error = new ErrorConstructor(val.message);\n            error.stack = val.stack;\n            serialized[key] = error;\n          } catch (e) {\n          }\n        }\n      }\n      if (serialized[key] == null) {\n        let error = new Error(val.message);\n        error.stack = val.stack;\n        serialized[key] = error;\n      }\n    } else {\n      serialized[key] = val;\n    }\n  }\n  return serialized;\n}\n\nexport {\n  Action,\n  createBrowserHistory,\n  invariant,\n  createPath,\n  parsePath,\n  matchRoutes,\n  generatePath,\n  matchPath,\n  resolvePath,\n  data,\n  redirect,\n  redirectDocument,\n  replace,\n  ErrorResponseImpl,\n  isRouteErrorResponse,\n  IDLE_NAVIGATION,\n  IDLE_FETCHER,\n  IDLE_BLOCKER,\n  createRouter,\n  DataRouterContext,\n  DataRouterStateContext,\n  ViewTransitionContext,\n  FetchersContext,\n  NavigationContext,\n  LocationContext,\n  RouteContext,\n  useHref,\n  useInRouterContext,\n  useLocation,\n  useNavigationType,\n  useMatch,\n  useNavigate,\n  useOutletContext,\n  useOutlet,\n  useParams,\n  useResolvedPath,\n  useRoutes,\n  useNavigation,\n  useRevalidator,\n  useMatches,\n  useLoaderData,\n  useRouteLoaderData,\n  useActionData,\n  useRouteError,\n  useAsyncValue,\n  useAsyncError,\n  useBlocker,\n  mapRouteProperties,\n  createMemoryRouter,\n  RouterProvider,\n  MemoryRouter,\n  Navigate,\n  Outlet,\n  Route,\n  Router,\n  Routes,\n  Await,\n  createRoutesFromChildren,\n  createRoutesFromElements,\n  renderMatches,\n  createSearchParams,\n  SingleFetchRedirectSymbol,\n  getSingleFetchDataStrategy,\n  decodeViaTurboStream,\n  RemixErrorBoundary,\n  createClientRoutesWithHMRRevalidationOptOut,\n  createClientRoutes,\n  shouldHydrateRouteLoader,\n  getPatchRoutesOnNavigationFunction,\n  useFogOFWarDiscovery,\n  FrameworkContext,\n  Links,\n  PrefetchPageLinks,\n  Meta,\n  Scripts,\n  createBrowserRouter,\n  createHashRouter,\n  BrowserRouter,\n  HashRouter,\n  HistoryRouter,\n  Link,\n  NavLink,\n  Form,\n  ScrollRestoration,\n  useLinkClickHandler,\n  useSearchParams,\n  useSubmit,\n  useFormAction,\n  useFetcher,\n  useFetchers,\n  useScrollRestoration,\n  useBeforeUnload,\n  usePrompt,\n  useViewTransitionState,\n  StaticRouter,\n  StaticRouterProvider,\n  createStaticHandler2 as createStaticHandler,\n  createStaticRouter,\n  ServerRouter,\n  createRoutesStub,\n  createCookie,\n  isCookie,\n  ServerMode,\n  setDevServerHooks,\n  createRequestHandler,\n  createSession,\n  isSession,\n  createSessionStorage,\n  createCookieSessionStorage,\n  createMemorySessionStorage,\n  deserializeErrors2 as deserializeErrors\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 Firebase constants.  Some of these (@defines) can be overridden at compile-time.\n */\n\nexport const CONSTANTS = {\n  /**\n   * @define {boolean} Whether this is the client Node.js SDK.\n   */\n  NODE_CLIENT: false,\n  /**\n   * @define {boolean} Whether this is the Admin Node.js SDK.\n   */\n  NODE_ADMIN: false,\n\n  /**\n   * Firebase SDK Version\n   */\n  SDK_VERSION: '${JSCORE_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\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_()\n// TODO(dlarocque): Define this as a class, since we no longer target ES5.\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 new DecodeBase64StringError();\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 * An error encountered while decoding base64 string.\n */\nexport class DecodeBase64StringError extends Error {\n  readonly name = 'DecodeBase64StringError';\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 encoding (without \".\" padding in the end).\n * e.g. Used in JSON Web Token (JWT) parts.\n */\nexport const base64urlEncodeWithoutPadding = function (str: string): string {\n  // Use base64url encoding and remove padding in the end (dot characters).\n  return base64Encode(str).replace(/\\./g, '');\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 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { getGlobal } from './global';\n\n/**\n * Keys for experimental properties on the `FirebaseDefaults` object.\n * @public\n */\nexport type ExperimentalKey = 'authTokenSyncURL' | 'authIdTokenMaxAge';\n\n/**\n * An object that can be injected into the environment as __FIREBASE_DEFAULTS__,\n * either as a property of globalThis, a shell environment variable, or a\n * cookie.\n *\n * This object can be used to automatically configure and initialize\n * a Firebase app as well as any emulators.\n *\n * @public\n */\nexport interface FirebaseDefaults {\n  config?: Record<string, string>;\n  emulatorHosts?: Record<string, string>;\n  _authTokenSyncURL?: string;\n  _authIdTokenMaxAge?: number;\n  /**\n   * Override Firebase's runtime environment detection and\n   * force the SDK to act as if it were in the specified environment.\n   */\n  forceEnvironment?: 'browser' | 'node';\n  [key: string]: unknown;\n}\n\ndeclare global {\n  // Need `var` for this to work.\n  // eslint-disable-next-line no-var\n  var __FIREBASE_DEFAULTS__: FirebaseDefaults | undefined;\n}\n\nconst getDefaultsFromGlobal = (): FirebaseDefaults | undefined =>\n  getGlobal().__FIREBASE_DEFAULTS__;\n\n/**\n * Attempt to read defaults from a JSON string provided to\n * process(.)env(.)__FIREBASE_DEFAULTS__ or a JSON file whose path is in\n * process(.)env(.)__FIREBASE_DEFAULTS_PATH__\n * The dots are in parens because certain compilers (Vite?) cannot\n * handle seeing that variable in comments.\n * See https://github.com/firebase/firebase-js-sdk/issues/6838\n */\nconst getDefaultsFromEnvVariable = (): FirebaseDefaults | undefined => {\n  if (typeof process === 'undefined' || typeof process.env === 'undefined') {\n    return;\n  }\n  const defaultsJsonString = process.env.__FIREBASE_DEFAULTS__;\n  if (defaultsJsonString) {\n    return JSON.parse(defaultsJsonString);\n  }\n};\n\nconst getDefaultsFromCookie = (): FirebaseDefaults | undefined => {\n  if (typeof document === 'undefined') {\n    return;\n  }\n  let match;\n  try {\n    match = document.cookie.match(/__FIREBASE_DEFAULTS__=([^;]+)/);\n  } catch (e) {\n    // Some environments such as Angular Universal SSR have a\n    // `document` object but error on accessing `document.cookie`.\n    return;\n  }\n  const decoded = match && base64Decode(match[1]);\n  return decoded && JSON.parse(decoded);\n};\n\n/**\n * Get the __FIREBASE_DEFAULTS__ object. It checks in order:\n * (1) if such an object exists as a property of `globalThis`\n * (2) if such an object was provided on a shell environment variable\n * (3) if such an object exists in a cookie\n * @public\n */\nexport const getDefaults = (): FirebaseDefaults | undefined => {\n  try {\n    return (\n      getDefaultsFromGlobal() ||\n      getDefaultsFromEnvVariable() ||\n      getDefaultsFromCookie()\n    );\n  } catch (e) {\n    /**\n     * Catch-all for being unable to get __FIREBASE_DEFAULTS__ due\n     * to any environment case we have not accounted for. Log to\n     * info instead of swallowing so we can find these unknown cases\n     * and add paths for them if needed.\n     */\n    console.info(`Unable to get __FIREBASE_DEFAULTS__ due to: ${e}`);\n    return;\n  }\n};\n\n/**\n * Returns emulator host stored in the __FIREBASE_DEFAULTS__ object\n * for the given product.\n * @returns a URL host formatted like `127.0.0.1:9999` or `[::1]:4000` if available\n * @public\n */\nexport const getDefaultEmulatorHost = (\n  productName: string\n): string | undefined => getDefaults()?.emulatorHosts?.[productName];\n\n/**\n * Returns emulator hostname and port stored in the __FIREBASE_DEFAULTS__ object\n * for the given product.\n * @returns a pair of hostname and port like `[\"::1\", 4000]` if available\n * @public\n */\nexport const getDefaultEmulatorHostnameAndPort = (\n  productName: string\n): [hostname: string, port: number] | undefined => {\n  const host = getDefaultEmulatorHost(productName);\n  if (!host) {\n    return undefined;\n  }\n  const separatorIndex = host.lastIndexOf(':'); // Finding the last since IPv6 addr also has colons.\n  if (separatorIndex <= 0 || separatorIndex + 1 === host.length) {\n    throw new Error(`Invalid host ${host} with no separate hostname and port!`);\n  }\n  // eslint-disable-next-line no-restricted-globals\n  const port = parseInt(host.substring(separatorIndex + 1), 10);\n  if (host[0] === '[') {\n    // Bracket-quoted `[ipv6addr]:port` => return \"ipv6addr\" (without brackets).\n    return [host.substring(1, separatorIndex - 1), port];\n  } else {\n    return [host.substring(0, separatorIndex), port];\n  }\n};\n\n/**\n * Returns Firebase app config stored in the __FIREBASE_DEFAULTS__ object.\n * @public\n */\nexport const getDefaultAppConfig = (): Record<string, string> | undefined =>\n  getDefaults()?.config;\n\n/**\n * Returns an experimental setting on the __FIREBASE_DEFAULTS__ object (properties\n * prefixed by \"_\")\n * @public\n */\nexport const getExperimentalSetting = <T extends ExperimentalKey>(\n  name: T\n): FirebaseDefaults[`_${T}`] =>\n  getDefaults()?.[`_${name}`] as FirebaseDefaults[`_${T}`];\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * Polyfill for `globalThis` object.\n * @returns the `globalThis` object for the given environment.\n * @public\n */\nexport function getGlobal(): typeof globalThis {\n  if (typeof self !== 'undefined') {\n    return self;\n  }\n  if (typeof window !== 'undefined') {\n    return window;\n  }\n  if (typeof global !== 'undefined') {\n    return global;\n  }\n  throw new Error('Unable to locate global object.');\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 promisified 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 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { base64urlEncodeWithoutPadding } from './crypt';\n\n// Firebase Auth tokens contain snake_case claims following the JWT standard / convention.\n/* eslint-disable camelcase */\n\nexport type FirebaseSignInProvider =\n  | 'custom'\n  | 'email'\n  | 'password'\n  | 'phone'\n  | 'anonymous'\n  | 'google.com'\n  | 'facebook.com'\n  | 'github.com'\n  | 'twitter.com'\n  | 'microsoft.com'\n  | 'apple.com';\n\ninterface FirebaseIdToken {\n  // Always set to https://securetoken.google.com/PROJECT_ID\n  iss: string;\n\n  // Always set to PROJECT_ID\n  aud: string;\n\n  // The user's unique ID\n  sub: string;\n\n  // The token issue time, in seconds since epoch\n  iat: number;\n\n  // The token expiry time, normally 'iat' + 3600\n  exp: number;\n\n  // The user's unique ID. Must be equal to 'sub'\n  user_id: string;\n\n  // The time the user authenticated, normally 'iat'\n  auth_time: number;\n\n  // The sign in provider, only set when the provider is 'anonymous'\n  provider_id?: 'anonymous';\n\n  // The user's primary email\n  email?: string;\n\n  // The user's email verification status\n  email_verified?: boolean;\n\n  // The user's primary phone number\n  phone_number?: string;\n\n  // The user's display name\n  name?: string;\n\n  // The user's profile photo URL\n  picture?: string;\n\n  // Information on all identities linked to this user\n  firebase: {\n    // The primary sign-in provider\n    sign_in_provider: FirebaseSignInProvider;\n\n    // A map of providers to the user's list of unique identifiers from\n    // each provider\n    identities?: { [provider in FirebaseSignInProvider]?: string[] };\n  };\n\n  // Custom claims set by the developer\n  [claim: string]: unknown;\n\n  uid?: never; // Try to catch a common mistake of \"uid\" (should be \"sub\" instead).\n}\n\nexport type EmulatorMockTokenOptions = ({ user_id: string } | { sub: string }) &\n  Partial<FirebaseIdToken>;\n\nexport function createMockUserToken(\n  token: EmulatorMockTokenOptions,\n  projectId?: string\n): string {\n  if (token.uid) {\n    throw new Error(\n      'The \"uid\" field is no longer supported by mockUserToken. Please use \"sub\" instead for Firebase Auth User ID.'\n    );\n  }\n  // Unsecured JWTs use \"none\" as the algorithm.\n  const header = {\n    alg: 'none',\n    type: 'JWT'\n  };\n\n  const project = projectId || 'demo-project';\n  const iat = token.iat || 0;\n  const sub = token.sub || token.user_id;\n  if (!sub) {\n    throw new Error(\"mockUserToken must contain 'sub' or 'user_id' field!\");\n  }\n\n  const payload: FirebaseIdToken = {\n    // Set all required fields to decent defaults\n    iss: `https://securetoken.google.com/${project}`,\n    aud: project,\n    iat,\n    exp: iat + 3600,\n    auth_time: iat,\n    sub,\n    user_id: sub,\n    firebase: {\n      sign_in_provider: 'custom',\n      identities: {}\n    },\n\n    // Override with user options\n    ...token\n  };\n\n  // Unsecured JWTs use the empty string as a signature.\n  const signature = '';\n  return [\n    base64urlEncodeWithoutPadding(JSON.stringify(header)),\n    base64urlEncodeWithoutPadding(JSON.stringify(payload)),\n    signature\n  ].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 { CONSTANTS } from './constants';\nimport { getDefaults } from './defaults';\n\n/**\n * Type placeholder for `WorkerGlobalScope` from `webworker`\n */\ndeclare class WorkerGlobalScope {}\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 or specified.\n */\n// Node detection logic from: https://github.com/iliakan/detect-node/\nexport function isNode(): boolean {\n  const forceEnvironment = getDefaults()?.forceEnvironment;\n  if (forceEnvironment === 'node') {\n    return true;\n  } else if (forceEnvironment === 'browser') {\n    return false;\n  }\n\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 * Note: This will return true for certain test frameworks that are incompletely\n * mimicking a browser, and should not lead to assuming all browser APIs are\n * available.\n */\nexport function isBrowser(): boolean {\n  return typeof window !== 'undefined' || isWebWorker();\n}\n\n/**\n * Detect Web Worker context.\n */\nexport function isWebWorker(): boolean {\n  return (\n    typeof WorkerGlobalScope !== 'undefined' &&\n    typeof self !== 'undefined' &&\n    self instanceof WorkerGlobalScope\n  );\n}\n\n/**\n * Detect Cloudflare Worker context.\n */\nexport function isCloudflareWorker(): boolean {\n  return (\n    typeof navigator !== 'undefined' &&\n    navigator.userAgent === 'Cloudflare-Workers'\n  );\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 &&\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  try {\n    return typeof indexedDB === 'object';\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * This method validates browser/sw context for indexedDB by opening a dummy indexedDB database and reject\n * if errors occur during the database open operation.\n *\n * @throws exception if current browser/sw context can't run idb.open (ex: Safari iframe, Firefox\n * private browsing)\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 = self.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          self.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 (typeof navigator === 'undefined' || !navigator.cookieEnabled) {\n    return false;\n  }\n  return 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/**\n * @fileoverview Standardized Firebase Error.\n *\n * Usage:\n *\n *   // TypeScript string literals for type-safe codes\n *   type Err =\n *     'unknown' |\n *     'object-not-found'\n *     ;\n *\n *   // Closure enum for type-safe error codes\n *   // at-enum {string}\n *   var Err = {\n *     UNKNOWN: 'unknown',\n *     OBJECT_NOT_FOUND: 'object-not-found',\n *   }\n *\n *   let errors: Map<Err, string> = {\n *     'generic-error': \"Unknown error\",\n *     'file-not-found': \"Could not find file: {$file}\",\n *   };\n *\n *   // Type-safe function - must pass a valid error code as param.\n *   let error = new ErrorFactory<Err>('service', 'Service', errors);\n *\n *   ...\n *   throw error.create(Err.GENERIC);\n *   ...\n *   throw error.create(Err.FILE_NOT_FOUND, {'file': fileName});\n *   ...\n *   // Service: Could not file file: foo.txt (service/file-not-found).\n *\n *   catch (e) {\n *     assert(e.message === \"Could not find file: foo.txt.\");\n *     if ((e as FirebaseError)?.code === 'service/file-not-found') {\n *       console.log(\"Could not read file: \" + e['file']);\n *     }\n *   }\n */\n\nexport type ErrorMap<ErrorCode extends string> = {\n  readonly [K in ErrorCode]: string;\n};\n\nconst ERROR_NAME = 'FirebaseError';\n\nexport interface StringLike {\n  toString(): string;\n}\n\nexport interface ErrorData {\n  [key: string]: unknown;\n}\n\n// Based on code from:\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error#Custom_Error_Types\nexport class FirebaseError extends Error {\n  /** The custom name for all FirebaseErrors. */\n  readonly name: string = ERROR_NAME;\n\n  constructor(\n    /** The error code for this error. */\n    readonly code: string,\n    message: string,\n    /** Custom data for this error. */\n    public customData?: Record<string, unknown>\n  ) {\n    super(message);\n\n    // Fix For ES5\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    // TODO(dlarocque): Replace this with `new.target`: https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html#support-for-newtarget\n    //                   which we can now use since we no longer target ES5.\n    Object.setPrototypeOf(this, FirebaseError.prototype);\n\n    // Maintains proper stack trace for where our error was thrown.\n    // Only available on V8.\n    if (Error.captureStackTrace) {\n      Error.captureStackTrace(this, ErrorFactory.prototype.create);\n    }\n  }\n}\n\nexport class ErrorFactory<\n  ErrorCode extends string,\n  ErrorParams extends { readonly [K in ErrorCode]?: ErrorData } = {}\n> {\n  constructor(\n    private readonly service: string,\n    private readonly serviceName: string,\n    private readonly errors: ErrorMap<ErrorCode>\n  ) {}\n\n  create<K extends ErrorCode>(\n    code: K,\n    ...data: K extends keyof ErrorParams ? [ErrorParams[K]] : []\n  ): FirebaseError {\n    const customData = (data[0] as ErrorData) || {};\n    const fullCode = `${this.service}/${code}`;\n    const template = this.errors[code];\n\n    const message = template ? replaceTemplate(template, customData) : 'Error';\n    // Service Name: Error message (service/code).\n    const fullMessage = `${this.serviceName}: ${message} (${fullCode}).`;\n\n    const error = new FirebaseError(fullCode, fullMessage, customData);\n\n    return error;\n  }\n}\n\nfunction replaceTemplate(template: string, data: ErrorData): string {\n  return template.replace(PATTERN, (_, key) => {\n    const value = data[key];\n    return value != null ? String(value) : `<${key}?>`;\n  });\n}\n\nconst PATTERN = /\\{\\$([^}]+)}/g;\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/**\n * Deep equal two objects. Support Arrays and Objects.\n */\nexport function deepEqual(a: object, b: object): boolean {\n  if (a === b) {\n    return true;\n  }\n\n  const aKeys = Object.keys(a);\n  const bKeys = Object.keys(b);\n  for (const k of aKeys) {\n    if (!bKeys.includes(k)) {\n      return false;\n    }\n\n    const aProp = (a as Record<string, unknown>)[k];\n    const bProp = (b as Record<string, unknown>)[k];\n    if (isObject(aProp) && isObject(bProp)) {\n      if (!deepEqual(aProp, bProp)) {\n        return false;\n      }\n    } else if (aProp !== bProp) {\n      return false;\n    }\n  }\n\n  for (const k of bKeys) {\n    if (!aKeys.includes(k)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nfunction isObject(thing: unknown): thing is object {\n  return thing !== null && typeof thing === 'object';\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 */\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 synchronously 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 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 interface Compat<T> {\n  _delegate: T;\n}\n\nexport function getModularInstance<ExpService>(\n  service: Compat<ExpService> | ExpService\n): ExpService {\n  if (service && (service as Compat<ExpService>)._delegate) {\n    return (service as Compat<ExpService>)._delegate;\n  } else {\n    return service as ExpService;\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 */\nimport {\n  InstantiationMode,\n  InstanceFactory,\n  ComponentType,\n  Dictionary,\n  Name,\n  onInstanceCreatedCallback\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  onInstanceCreated: onInstanceCreatedCallback<T> | null = null;\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  setInstanceCreatedCallback(callback: onInstanceCreatedCallback<T>): this {\n    this.onInstanceCreated = callback;\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\nexport const DEFAULT_ENTRY_NAME = '[DEFAULT]';\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 {\n  InitializeOptions,\n  InstantiationMode,\n  Name,\n  NameServiceMapping,\n  OnInitCallBack\n} 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  private readonly instancesOptions: Map<string, Record<string, unknown>> =\n    new Map();\n  private onInitCallbacks: Map<string, Set<OnInitCallBack<T>>> = 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 multiple instances of a service\n   * if this.component.multipleInstances is true.\n   */\n  get(identifier?: string): 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\n      if (\n        this.isInitialized(normalizedIdentifier) ||\n        this.shouldAutoInitialize()\n      ) {\n        // initialize the service if it can be auto-initialized\n        try {\n          const instance = this.getOrInitializeService({\n            instanceIdentifier: normalizedIdentifier\n          });\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\n    return this.instancesDeferred.get(normalizedIdentifier)!.promise;\n  }\n\n  /**\n   *\n   * @param options.identifier A provider can provide multiple 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    // if multipleInstances is not supported, use the default name\n    const normalizedIdentifier = this.normalizeInstanceIdentifier(\n      options?.identifier\n    );\n    const optional = options?.optional ?? false;\n\n    if (\n      this.isInitialized(normalizedIdentifier) ||\n      this.shouldAutoInitialize()\n    ) {\n      try {\n        return this.getOrInitializeService({\n          instanceIdentifier: normalizedIdentifier\n        });\n      } catch (e) {\n        if (optional) {\n          return null;\n        } else {\n          throw e;\n        }\n      }\n    } else {\n      // In case a component is not initialized and should/cannot be auto-initialized at the moment, return null if the optional flag is set, or throw\n      if (optional) {\n        return null;\n      } else {\n        throw Error(`Service ${this.name} is not available`);\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\n    // return early without attempting to initialize the component if the component requires explicit initialization (calling `Provider.initialize()`)\n    if (!this.shouldAutoInitialize()) {\n      return;\n    }\n\n    // if the service is eager, initialize the default instance\n    if (isComponentEager(component)) {\n      try {\n        this.getOrInitializeService({ instanceIdentifier: 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 =\n        this.normalizeInstanceIdentifier(instanceIdentifier);\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({\n          instanceIdentifier: normalizedIdentifier\n        })!;\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.instancesOptions.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  getOptions(identifier: string = DEFAULT_ENTRY_NAME): Record<string, unknown> {\n    return this.instancesOptions.get(identifier) || {};\n  }\n\n  initialize(opts: InitializeOptions = {}): NameServiceMapping[T] {\n    const { options = {} } = opts;\n    const normalizedIdentifier = this.normalizeInstanceIdentifier(\n      opts.instanceIdentifier\n    );\n    if (this.isInitialized(normalizedIdentifier)) {\n      throw Error(\n        `${this.name}(${normalizedIdentifier}) has already been initialized`\n      );\n    }\n\n    if (!this.isComponentSet()) {\n      throw Error(`Component ${this.name} has not been registered yet`);\n    }\n\n    const instance = this.getOrInitializeService({\n      instanceIdentifier: normalizedIdentifier,\n      options\n    })!;\n\n    // resolve any pending promise waiting for the service instance\n    for (const [\n      instanceIdentifier,\n      instanceDeferred\n    ] of this.instancesDeferred.entries()) {\n      const normalizedDeferredIdentifier =\n        this.normalizeInstanceIdentifier(instanceIdentifier);\n      if (normalizedIdentifier === normalizedDeferredIdentifier) {\n        instanceDeferred.resolve(instance);\n      }\n    }\n\n    return instance;\n  }\n\n  /**\n   *\n   * @param callback - a function that will be invoked  after the provider has been initialized by calling provider.initialize().\n   * The function is invoked SYNCHRONOUSLY, so it should not execute any longrunning tasks in order to not block the program.\n   *\n   * @param identifier An optional instance identifier\n   * @returns a function to unregister the callback\n   */\n  onInit(callback: OnInitCallBack<T>, identifier?: string): () => void {\n    const normalizedIdentifier = this.normalizeInstanceIdentifier(identifier);\n    const existingCallbacks =\n      this.onInitCallbacks.get(normalizedIdentifier) ??\n      new Set<OnInitCallBack<T>>();\n    existingCallbacks.add(callback);\n    this.onInitCallbacks.set(normalizedIdentifier, existingCallbacks);\n\n    const existingInstance = this.instances.get(normalizedIdentifier);\n    if (existingInstance) {\n      callback(existingInstance, normalizedIdentifier);\n    }\n\n    return () => {\n      existingCallbacks.delete(callback);\n    };\n  }\n\n  /**\n   * Invoke onInit callbacks synchronously\n   * @param instance the service instance`\n   */\n  private invokeOnInitCallbacks(\n    instance: NameServiceMapping[T],\n    identifier: string\n  ): void {\n    const callbacks = this.onInitCallbacks.get(identifier);\n    if (!callbacks) {\n      return;\n    }\n    for (const callback of callbacks) {\n      try {\n        callback(instance, identifier);\n      } catch {\n        // ignore errors in the onInit callback\n      }\n    }\n  }\n\n  private getOrInitializeService({\n    instanceIdentifier,\n    options = {}\n  }: {\n    instanceIdentifier: string;\n    options?: Record<string, unknown>;\n  }): NameServiceMapping[T] | null {\n    let instance = this.instances.get(instanceIdentifier);\n    if (!instance && this.component) {\n      instance = this.component.instanceFactory(this.container, {\n        instanceIdentifier: normalizeIdentifierForFactory(instanceIdentifier),\n        options\n      });\n      this.instances.set(instanceIdentifier, instance);\n      this.instancesOptions.set(instanceIdentifier, options);\n\n      /**\n       * Invoke onInit listeners.\n       * Note this.component.onInstanceCreated is different, which is used by the component creator,\n       * while onInit listeners are registered by consumers of the provider.\n       */\n      this.invokeOnInitCallbacks(instance, instanceIdentifier);\n\n      /**\n       * Order is important\n       * onInstanceCreated() should be called after this.instances.set(instanceIdentifier, instance); which\n       * makes `isInitialized()` return true.\n       */\n      if (this.component.onInstanceCreated) {\n        try {\n          this.component.onInstanceCreated(\n            this.container,\n            instanceIdentifier,\n            instance\n          );\n        } catch {\n          // ignore errors in the onInstanceCreatedCallback\n        }\n      }\n    }\n\n    return instance || null;\n  }\n\n  private normalizeInstanceIdentifier(\n    identifier: string = DEFAULT_ENTRY_NAME\n  ): 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  private shouldAutoInitialize(): boolean {\n    return (\n      !!this.component &&\n      this.component.instantiationMode !== InstantiationMode.EXPLICIT\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<T extends Name>(component: Component<T>): 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 unknown 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 as unknown as Provider<Name>);\n\n    return provider as Provider<T>;\n  }\n\n  getProviders(): Array<Provider<Name>> {\n    return Array.from(this.providers.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\nexport type LogLevelString =\n  | 'debug'\n  | 'verbose'\n  | 'info'\n  | 'warn'\n  | 'error'\n  | 'silent';\n\nexport interface LogOptions {\n  level: LogLevelString;\n}\n\nexport type LogCallback = (callbackParams: LogCallbackParams) => void;\n\nexport interface LogCallbackParams {\n  level: LogLevelString;\n  message: string;\n  args: unknown[];\n  type: string;\n}\n\n/**\n * A container for all of the Logger instances\n */\nexport const instances: Logger[] = [];\n\n/**\n * The JS SDK supports 5 log levels and also allows a user the ability to\n * silence the logs altogether.\n *\n * The order is a follows:\n * DEBUG < VERBOSE < INFO < WARN < ERROR\n *\n * All of the log types above the current log level will be captured (i.e. if\n * you set the log level to `INFO`, errors will still be logged, but `DEBUG` and\n * `VERBOSE` logs will not)\n */\nexport enum LogLevel {\n  DEBUG,\n  VERBOSE,\n  INFO,\n  WARN,\n  ERROR,\n  SILENT\n}\n\nconst levelStringToEnum: { [key in LogLevelString]: LogLevel } = {\n  'debug': LogLevel.DEBUG,\n  'verbose': LogLevel.VERBOSE,\n  'info': LogLevel.INFO,\n  'warn': LogLevel.WARN,\n  'error': LogLevel.ERROR,\n  'silent': LogLevel.SILENT\n};\n\n/**\n * The default log level\n */\nconst defaultLogLevel: LogLevel = LogLevel.INFO;\n\n/**\n * We allow users the ability to pass their own log handler. We will pass the\n * type of log, the current log level, and any other arguments passed (i.e. the\n * messages that the user wants to log) to this function.\n */\nexport type LogHandler = (\n  loggerInstance: Logger,\n  logType: LogLevel,\n  ...args: unknown[]\n) => void;\n\n/**\n * By default, `console.debug` is not displayed in the developer console (in\n * chrome). To avoid forcing users to have to opt-in to these logs twice\n * (i.e. once for firebase, and once in the console), we are sending `DEBUG`\n * logs to the `console.log` function.\n */\nconst ConsoleMethod = {\n  [LogLevel.DEBUG]: 'log',\n  [LogLevel.VERBOSE]: 'log',\n  [LogLevel.INFO]: 'info',\n  [LogLevel.WARN]: 'warn',\n  [LogLevel.ERROR]: 'error'\n};\n\n/**\n * The default log handler will forward DEBUG, VERBOSE, INFO, WARN, and ERROR\n * messages on to their corresponding console counterparts (if the log method\n * is supported by the current log level)\n */\nconst defaultLogHandler: LogHandler = (instance, logType, ...args): void => {\n  if (logType < instance.logLevel) {\n    return;\n  }\n  const now = new Date().toISOString();\n  const method = ConsoleMethod[logType as keyof typeof ConsoleMethod];\n  if (method) {\n    console[method as 'log' | 'info' | 'warn' | 'error'](\n      `[${now}]  ${instance.name}:`,\n      ...args\n    );\n  } else {\n    throw new Error(\n      `Attempted to log a message with an invalid logType (value: ${logType})`\n    );\n  }\n};\n\nexport class Logger {\n  /**\n   * Gives you an instance of a Logger to capture messages according to\n   * Firebase's logging scheme.\n   *\n   * @param name The name that the logs will be associated with\n   */\n  constructor(public name: string) {\n    /**\n     * Capture the current instance for later use\n     */\n    instances.push(this);\n  }\n\n  /**\n   * The log level of the given Logger instance.\n   */\n  private _logLevel = defaultLogLevel;\n\n  get logLevel(): LogLevel {\n    return this._logLevel;\n  }\n\n  set logLevel(val: LogLevel) {\n    if (!(val in LogLevel)) {\n      throw new TypeError(`Invalid value \"${val}\" assigned to \\`logLevel\\``);\n    }\n    this._logLevel = val;\n  }\n\n  // Workaround for setter/getter having to be the same type.\n  setLogLevel(val: LogLevel | LogLevelString): void {\n    this._logLevel = typeof val === 'string' ? levelStringToEnum[val] : val;\n  }\n\n  /**\n   * The main (internal) log handler for the Logger instance.\n   * Can be set to a new function in internal package code but not by user.\n   */\n  private _logHandler: LogHandler = defaultLogHandler;\n  get logHandler(): LogHandler {\n    return this._logHandler;\n  }\n  set logHandler(val: LogHandler) {\n    if (typeof val !== 'function') {\n      throw new TypeError('Value assigned to `logHandler` must be a function');\n    }\n    this._logHandler = val;\n  }\n\n  /**\n   * The optional, additional, user-defined log handler for the Logger instance.\n   */\n  private _userLogHandler: LogHandler | null = null;\n  get userLogHandler(): LogHandler | null {\n    return this._userLogHandler;\n  }\n  set userLogHandler(val: LogHandler | null) {\n    this._userLogHandler = val;\n  }\n\n  /**\n   * The functions below are all based on the `console` interface\n   */\n\n  debug(...args: unknown[]): void {\n    this._userLogHandler && this._userLogHandler(this, LogLevel.DEBUG, ...args);\n    this._logHandler(this, LogLevel.DEBUG, ...args);\n  }\n  log(...args: unknown[]): void {\n    this._userLogHandler &&\n      this._userLogHandler(this, LogLevel.VERBOSE, ...args);\n    this._logHandler(this, LogLevel.VERBOSE, ...args);\n  }\n  info(...args: unknown[]): void {\n    this._userLogHandler && this._userLogHandler(this, LogLevel.INFO, ...args);\n    this._logHandler(this, LogLevel.INFO, ...args);\n  }\n  warn(...args: unknown[]): void {\n    this._userLogHandler && this._userLogHandler(this, LogLevel.WARN, ...args);\n    this._logHandler(this, LogLevel.WARN, ...args);\n  }\n  error(...args: unknown[]): void {\n    this._userLogHandler && this._userLogHandler(this, LogLevel.ERROR, ...args);\n    this._logHandler(this, LogLevel.ERROR, ...args);\n  }\n}\n\nexport function setLogLevel(level: LogLevelString | LogLevel): void {\n  instances.forEach(inst => {\n    inst.setLogLevel(level);\n  });\n}\n\nexport function setUserLogHandler(\n  logCallback: LogCallback | null,\n  options?: LogOptions\n): void {\n  for (const instance of instances) {\n    let customLogLevel: LogLevel | null = null;\n    if (options && options.level) {\n      customLogLevel = levelStringToEnum[options.level];\n    }\n    if (logCallback === null) {\n      instance.userLogHandler = null;\n    } else {\n      instance.userLogHandler = (\n        instance: Logger,\n        level: LogLevel,\n        ...args: unknown[]\n      ) => {\n        const message = args\n          .map(arg => {\n            if (arg == null) {\n              return null;\n            } else if (typeof arg === 'string') {\n              return arg;\n            } else if (typeof arg === 'number' || typeof arg === 'boolean') {\n              return arg.toString();\n            } else if (arg instanceof Error) {\n              return arg.message;\n            } else {\n              try {\n                return JSON.stringify(arg);\n              } catch (ignored) {\n                return null;\n              }\n            }\n          })\n          .filter(arg => arg)\n          .join(' ');\n        if (level >= (customLogLevel ?? instance.logLevel)) {\n          logCallback({\n            level: LogLevel[level].toLowerCase() as LogLevelString,\n            message,\n            args,\n            type: instance.name\n          });\n        }\n      };\n    }\n  }\n}\n","const instanceOfAny = (object, constructors) => constructors.some((c) => object instanceof c);\n\nlet idbProxyableTypes;\nlet cursorAdvanceMethods;\n// This is a function to prevent it throwing up in node environments.\nfunction getIdbProxyableTypes() {\n    return (idbProxyableTypes ||\n        (idbProxyableTypes = [\n            IDBDatabase,\n            IDBObjectStore,\n            IDBIndex,\n            IDBCursor,\n            IDBTransaction,\n        ]));\n}\n// This is a function to prevent it throwing up in node environments.\nfunction getCursorAdvanceMethods() {\n    return (cursorAdvanceMethods ||\n        (cursorAdvanceMethods = [\n            IDBCursor.prototype.advance,\n            IDBCursor.prototype.continue,\n            IDBCursor.prototype.continuePrimaryKey,\n        ]));\n}\nconst cursorRequestMap = new WeakMap();\nconst transactionDoneMap = new WeakMap();\nconst transactionStoreNamesMap = new WeakMap();\nconst transformCache = new WeakMap();\nconst reverseTransformCache = new WeakMap();\nfunction promisifyRequest(request) {\n    const promise = new Promise((resolve, reject) => {\n        const unlisten = () => {\n            request.removeEventListener('success', success);\n            request.removeEventListener('error', error);\n        };\n        const success = () => {\n            resolve(wrap(request.result));\n            unlisten();\n        };\n        const error = () => {\n            reject(request.error);\n            unlisten();\n        };\n        request.addEventListener('success', success);\n        request.addEventListener('error', error);\n    });\n    promise\n        .then((value) => {\n        // Since cursoring reuses the IDBRequest (*sigh*), we cache it for later retrieval\n        // (see wrapFunction).\n        if (value instanceof IDBCursor) {\n            cursorRequestMap.set(value, request);\n        }\n        // Catching to avoid \"Uncaught Promise exceptions\"\n    })\n        .catch(() => { });\n    // This mapping exists in reverseTransformCache but doesn't doesn't exist in transformCache. This\n    // is because we create many promises from a single IDBRequest.\n    reverseTransformCache.set(promise, request);\n    return promise;\n}\nfunction cacheDonePromiseForTransaction(tx) {\n    // Early bail if we've already created a done promise for this transaction.\n    if (transactionDoneMap.has(tx))\n        return;\n    const done = new Promise((resolve, reject) => {\n        const unlisten = () => {\n            tx.removeEventListener('complete', complete);\n            tx.removeEventListener('error', error);\n            tx.removeEventListener('abort', error);\n        };\n        const complete = () => {\n            resolve();\n            unlisten();\n        };\n        const error = () => {\n            reject(tx.error || new DOMException('AbortError', 'AbortError'));\n            unlisten();\n        };\n        tx.addEventListener('complete', complete);\n        tx.addEventListener('error', error);\n        tx.addEventListener('abort', error);\n    });\n    // Cache it for later retrieval.\n    transactionDoneMap.set(tx, done);\n}\nlet idbProxyTraps = {\n    get(target, prop, receiver) {\n        if (target instanceof IDBTransaction) {\n            // Special handling for transaction.done.\n            if (prop === 'done')\n                return transactionDoneMap.get(target);\n            // Polyfill for objectStoreNames because of Edge.\n            if (prop === 'objectStoreNames') {\n                return target.objectStoreNames || transactionStoreNamesMap.get(target);\n            }\n            // Make tx.store return the only store in the transaction, or undefined if there are many.\n            if (prop === 'store') {\n                return receiver.objectStoreNames[1]\n                    ? undefined\n                    : receiver.objectStore(receiver.objectStoreNames[0]);\n            }\n        }\n        // Else transform whatever we get back.\n        return wrap(target[prop]);\n    },\n    set(target, prop, value) {\n        target[prop] = value;\n        return true;\n    },\n    has(target, prop) {\n        if (target instanceof IDBTransaction &&\n            (prop === 'done' || prop === 'store')) {\n            return true;\n        }\n        return prop in target;\n    },\n};\nfunction replaceTraps(callback) {\n    idbProxyTraps = callback(idbProxyTraps);\n}\nfunction wrapFunction(func) {\n    // Due to expected object equality (which is enforced by the caching in `wrap`), we\n    // only create one new func per func.\n    // Edge doesn't support objectStoreNames (booo), so we polyfill it here.\n    if (func === IDBDatabase.prototype.transaction &&\n        !('objectStoreNames' in IDBTransaction.prototype)) {\n        return function (storeNames, ...args) {\n            const tx = func.call(unwrap(this), storeNames, ...args);\n            transactionStoreNamesMap.set(tx, storeNames.sort ? storeNames.sort() : [storeNames]);\n            return wrap(tx);\n        };\n    }\n    // Cursor methods are special, as the behaviour is a little more different to standard IDB. In\n    // IDB, you advance the cursor and wait for a new 'success' on the IDBRequest that gave you the\n    // cursor. It's kinda like a promise that can resolve with many values. That doesn't make sense\n    // with real promises, so each advance methods returns a new promise for the cursor object, or\n    // undefined if the end of the cursor has been reached.\n    if (getCursorAdvanceMethods().includes(func)) {\n        return function (...args) {\n            // Calling the original function with the proxy as 'this' causes ILLEGAL INVOCATION, so we use\n            // the original object.\n            func.apply(unwrap(this), args);\n            return wrap(cursorRequestMap.get(this));\n        };\n    }\n    return function (...args) {\n        // Calling the original function with the proxy as 'this' causes ILLEGAL INVOCATION, so we use\n        // the original object.\n        return wrap(func.apply(unwrap(this), args));\n    };\n}\nfunction transformCachableValue(value) {\n    if (typeof value === 'function')\n        return wrapFunction(value);\n    // This doesn't return, it just creates a 'done' promise for the transaction,\n    // which is later returned for transaction.done (see idbObjectHandler).\n    if (value instanceof IDBTransaction)\n        cacheDonePromiseForTransaction(value);\n    if (instanceOfAny(value, getIdbProxyableTypes()))\n        return new Proxy(value, idbProxyTraps);\n    // Return the same value back if we're not going to transform it.\n    return value;\n}\nfunction wrap(value) {\n    // We sometimes generate multiple promises from a single IDBRequest (eg when cursoring), because\n    // IDB is weird and a single IDBRequest can yield many responses, so these can't be cached.\n    if (value instanceof IDBRequest)\n        return promisifyRequest(value);\n    // If we've already transformed this value before, reuse the transformed value.\n    // This is faster, but it also provides object equality.\n    if (transformCache.has(value))\n        return transformCache.get(value);\n    const newValue = transformCachableValue(value);\n    // Not all types are transformed.\n    // These may be primitive types, so they can't be WeakMap keys.\n    if (newValue !== value) {\n        transformCache.set(value, newValue);\n        reverseTransformCache.set(newValue, value);\n    }\n    return newValue;\n}\nconst unwrap = (value) => reverseTransformCache.get(value);\n\nexport { reverseTransformCache as a, instanceOfAny as i, replaceTraps as r, unwrap as u, wrap as w };\n","import { w as wrap, r as replaceTraps } from './wrap-idb-value.js';\nexport { u as unwrap, w as wrap } from './wrap-idb-value.js';\n\n/**\n * Open a database.\n *\n * @param name Name of the database.\n * @param version Schema version.\n * @param callbacks Additional callbacks.\n */\nfunction openDB(name, version, { blocked, upgrade, blocking, terminated } = {}) {\n    const request = indexedDB.open(name, version);\n    const openPromise = wrap(request);\n    if (upgrade) {\n        request.addEventListener('upgradeneeded', (event) => {\n            upgrade(wrap(request.result), event.oldVersion, event.newVersion, wrap(request.transaction), event);\n        });\n    }\n    if (blocked) {\n        request.addEventListener('blocked', (event) => blocked(\n        // Casting due to https://github.com/microsoft/TypeScript-DOM-lib-generator/pull/1405\n        event.oldVersion, event.newVersion, event));\n    }\n    openPromise\n        .then((db) => {\n        if (terminated)\n            db.addEventListener('close', () => terminated());\n        if (blocking) {\n            db.addEventListener('versionchange', (event) => blocking(event.oldVersion, event.newVersion, event));\n        }\n    })\n        .catch(() => { });\n    return openPromise;\n}\n/**\n * Delete a database.\n *\n * @param name Name of the database.\n */\nfunction deleteDB(name, { blocked } = {}) {\n    const request = indexedDB.deleteDatabase(name);\n    if (blocked) {\n        request.addEventListener('blocked', (event) => blocked(\n        // Casting due to https://github.com/microsoft/TypeScript-DOM-lib-generator/pull/1405\n        event.oldVersion, event));\n    }\n    return wrap(request).then(() => undefined);\n}\n\nconst readMethods = ['get', 'getKey', 'getAll', 'getAllKeys', 'count'];\nconst writeMethods = ['put', 'add', 'delete', 'clear'];\nconst cachedMethods = new Map();\nfunction getMethod(target, prop) {\n    if (!(target instanceof IDBDatabase &&\n        !(prop in target) &&\n        typeof prop === 'string')) {\n        return;\n    }\n    if (cachedMethods.get(prop))\n        return cachedMethods.get(prop);\n    const targetFuncName = prop.replace(/FromIndex$/, '');\n    const useIndex = prop !== targetFuncName;\n    const isWrite = writeMethods.includes(targetFuncName);\n    if (\n    // Bail if the target doesn't exist on the target. Eg, getAll isn't in Edge.\n    !(targetFuncName in (useIndex ? IDBIndex : IDBObjectStore).prototype) ||\n        !(isWrite || readMethods.includes(targetFuncName))) {\n        return;\n    }\n    const method = async function (storeName, ...args) {\n        // isWrite ? 'readwrite' : undefined gzipps better, but fails in Edge :(\n        const tx = this.transaction(storeName, isWrite ? 'readwrite' : 'readonly');\n        let target = tx.store;\n        if (useIndex)\n            target = target.index(args.shift());\n        // Must reject if op rejects.\n        // If it's a write operation, must reject if tx.done rejects.\n        // Must reject with op rejection first.\n        // Must resolve with op value.\n        // Must handle both promises (no unhandled rejections)\n        return (await Promise.all([\n            target[targetFuncName](...args),\n            isWrite && tx.done,\n        ]))[0];\n    };\n    cachedMethods.set(prop, method);\n    return method;\n}\nreplaceTraps((oldTraps) => ({\n    ...oldTraps,\n    get: (target, prop, receiver) => getMethod(target, prop) || oldTraps.get(target, prop, receiver),\n    has: (target, prop) => !!getMethod(target, prop) || oldTraps.has(target, prop),\n}));\n\nexport { deleteDB, openDB };\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';\nimport { PlatformLoggerService, VersionService } from './types';\n\nexport class PlatformLoggerServiceImpl implements 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() as VersionService;\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(provider: Provider<Name>): boolean {\n  const component = provider.getComponent();\n  return component?.type === ComponentType.VERSION;\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/app');\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 { name as appName } from '../package.json';\nimport { name as appCompatName } from '../../app-compat/package.json';\nimport { name as analyticsCompatName } from '../../../packages/analytics-compat/package.json';\nimport { name as analyticsName } from '../../../packages/analytics/package.json';\nimport { name as appCheckCompatName } from '../../../packages/app-check-compat/package.json';\nimport { name as appCheckName } from '../../../packages/app-check/package.json';\nimport { name as authName } from '../../../packages/auth/package.json';\nimport { name as authCompatName } from '../../../packages/auth-compat/package.json';\nimport { name as databaseName } from '../../../packages/database/package.json';\nimport { name as dataconnectName } from '../../../packages/data-connect/package.json';\nimport { name as databaseCompatName } from '../../../packages/database-compat/package.json';\nimport { name as functionsName } from '../../../packages/functions/package.json';\nimport { name as functionsCompatName } from '../../../packages/functions-compat/package.json';\nimport { name as installationsName } from '../../../packages/installations/package.json';\nimport { name as installationsCompatName } from '../../../packages/installations-compat/package.json';\nimport { name as messagingName } from '../../../packages/messaging/package.json';\nimport { name as messagingCompatName } from '../../../packages/messaging-compat/package.json';\nimport { name as performanceName } from '../../../packages/performance/package.json';\nimport { name as performanceCompatName } from '../../../packages/performance-compat/package.json';\nimport { name as remoteConfigName } from '../../../packages/remote-config/package.json';\nimport { name as remoteConfigCompatName } from '../../../packages/remote-config-compat/package.json';\nimport { name as storageName } from '../../../packages/storage/package.json';\nimport { name as storageCompatName } from '../../../packages/storage-compat/package.json';\nimport { name as firestoreName } from '../../../packages/firestore/package.json';\nimport { name as vertexName } from '../../../packages/vertexai/package.json';\nimport { name as firestoreCompatName } from '../../../packages/firestore-compat/package.json';\nimport { name as packageName } from '../../../packages/firebase/package.json';\n\n/**\n * The default app name\n *\n * @internal\n */\nexport const DEFAULT_ENTRY_NAME = '[DEFAULT]';\n\nexport const PLATFORM_LOG_STRING = {\n  [appName]: 'fire-core',\n  [appCompatName]: 'fire-core-compat',\n  [analyticsName]: 'fire-analytics',\n  [analyticsCompatName]: 'fire-analytics-compat',\n  [appCheckName]: 'fire-app-check',\n  [appCheckCompatName]: 'fire-app-check-compat',\n  [authName]: 'fire-auth',\n  [authCompatName]: 'fire-auth-compat',\n  [databaseName]: 'fire-rtdb',\n  [dataconnectName]: 'fire-data-connect',\n  [databaseCompatName]: 'fire-rtdb-compat',\n  [functionsName]: 'fire-fn',\n  [functionsCompatName]: 'fire-fn-compat',\n  [installationsName]: 'fire-iid',\n  [installationsCompatName]: 'fire-iid-compat',\n  [messagingName]: 'fire-fcm',\n  [messagingCompatName]: 'fire-fcm-compat',\n  [performanceName]: 'fire-perf',\n  [performanceCompatName]: 'fire-perf-compat',\n  [remoteConfigName]: 'fire-rc',\n  [remoteConfigCompatName]: 'fire-rc-compat',\n  [storageName]: 'fire-gcs',\n  [storageCompatName]: 'fire-gcs-compat',\n  [firestoreName]: 'fire-fst',\n  [firestoreCompatName]: 'fire-fst-compat',\n  [vertexName]: 'fire-vertex',\n  'fire-js': 'fire-js', // Platform identifier for JS SDK.\n  [packageName]: 'fire-js-all'\n} as const;\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  FirebaseServerApp\n} from './public-types';\nimport { Component, Provider, Name } from '@firebase/component';\nimport { logger } from './logger';\nimport { DEFAULT_ENTRY_NAME } from './constants';\nimport { FirebaseAppImpl } from './firebaseApp';\nimport { FirebaseServerAppImpl } from './firebaseServerApp';\n\n/**\n * @internal\n */\nexport const _apps = new Map<string, FirebaseApp>();\n\n/**\n * @internal\n */\nexport const _serverApps = new Map<string, FirebaseServerApp>();\n\n/**\n * Registered components.\n *\n * @internal\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const _components = new Map<string, Component<any>>();\n\n/**\n * @param component - the component being added to this app's container\n *\n * @internal\n */\nexport function _addComponent<T extends Name>(\n  app: FirebaseApp,\n  component: Component<T>\n): void {\n  try {\n    (app as FirebaseAppImpl).container.addComponent(component);\n  } catch (e) {\n    logger.debug(\n      `Component ${component.name} failed to register with FirebaseApp ${app.name}`,\n      e\n    );\n  }\n}\n\n/**\n *\n * @internal\n */\nexport function _addOrOverwriteComponent(\n  app: FirebaseApp,\n  component: Component\n): void {\n  (app as FirebaseAppImpl).container.addOrOverwriteComponent(component);\n}\n\n/**\n *\n * @param component - the component to register\n * @returns whether or not the component is registered successfully\n *\n * @internal\n */\nexport function _registerComponent<T extends Name>(\n  component: Component<T>\n): boolean {\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 false;\n  }\n\n  _components.set(componentName, component);\n\n  // add the component to existing app instances\n  for (const app of _apps.values()) {\n    _addComponent(app as FirebaseAppImpl, component);\n  }\n\n  for (const serverApp of _serverApps.values()) {\n    _addComponent(serverApp as FirebaseServerAppImpl, component);\n  }\n\n  return true;\n}\n\n/**\n *\n * @param app - FirebaseApp instance\n * @param name - service name\n *\n * @returns the provider for the service with the matching name\n *\n * @internal\n */\nexport function _getProvider<T extends Name>(\n  app: FirebaseApp,\n  name: T\n): Provider<T> {\n  const heartbeatController = (app as FirebaseAppImpl).container\n    .getProvider('heartbeat')\n    .getImmediate({ optional: true });\n  if (heartbeatController) {\n    void heartbeatController.triggerHeartbeat();\n  }\n  return (app as FirebaseAppImpl).container.getProvider(name);\n}\n\n/**\n *\n * @param app - FirebaseApp instance\n * @param name - service name\n * @param instanceIdentifier - service instance identifier in case the service supports multiple instances\n *\n * @internal\n */\nexport function _removeServiceInstance<T extends Name>(\n  app: FirebaseApp,\n  name: T,\n  instanceIdentifier: string = DEFAULT_ENTRY_NAME\n): void {\n  _getProvider(app, name).clearInstance(instanceIdentifier);\n}\n\n/**\n *\n * @param obj - an object of type FirebaseApp or FirebaseOptions.\n *\n * @returns true if the provide object is of type FirebaseApp.\n *\n * @internal\n */\nexport function _isFirebaseApp(\n  obj: FirebaseApp | FirebaseOptions\n): obj is FirebaseApp {\n  return (obj as FirebaseApp).options !== undefined;\n}\n\n/**\n *\n * @param obj - an object of type FirebaseApp.\n *\n * @returns true if the provided object is of type FirebaseServerAppImpl.\n *\n * @internal\n */\nexport function _isFirebaseServerApp(\n  obj: FirebaseApp | FirebaseServerApp\n): obj is FirebaseServerApp {\n  return (obj as FirebaseServerApp).settings !== undefined;\n}\n\n/**\n * Test only\n *\n * @internal\n */\nexport function _clearComponents(): void {\n  _components.clear();\n}\n\n/**\n * Exported in order to be used in app-compat package\n */\nexport { DEFAULT_ENTRY_NAME as _DEFAULT_ENTRY_NAME };\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, ErrorMap } from '@firebase/util';\n\nexport const enum AppError {\n  NO_APP = 'no-app',\n  BAD_APP_NAME = 'bad-app-name',\n  DUPLICATE_APP = 'duplicate-app',\n  APP_DELETED = 'app-deleted',\n  SERVER_APP_DELETED = 'server-app-deleted',\n  NO_OPTIONS = 'no-options',\n  INVALID_APP_ARGUMENT = 'invalid-app-argument',\n  INVALID_LOG_ARGUMENT = 'invalid-log-argument',\n  IDB_OPEN = 'idb-open',\n  IDB_GET = 'idb-get',\n  IDB_WRITE = 'idb-set',\n  IDB_DELETE = 'idb-delete',\n  FINALIZATION_REGISTRY_NOT_SUPPORTED = 'finalization-registry-not-supported',\n  INVALID_SERVER_APP_ENVIRONMENT = 'invalid-server-app-environment'\n}\n\nconst ERRORS: ErrorMap<AppError> = {\n  [AppError.NO_APP]:\n    \"No Firebase App '{$appName}' has been created - \" +\n    'call initializeApp() first',\n  [AppError.BAD_APP_NAME]: \"Illegal App name: '{$appName}'\",\n  [AppError.DUPLICATE_APP]:\n    \"Firebase App named '{$appName}' already exists with different options or config\",\n  [AppError.APP_DELETED]: \"Firebase App named '{$appName}' already deleted\",\n  [AppError.SERVER_APP_DELETED]: 'Firebase Server App has been deleted',\n  [AppError.NO_OPTIONS]:\n    'Need to provide options, when not being deployed to hosting via source.',\n  [AppError.INVALID_APP_ARGUMENT]:\n    'firebase.{$appName}() takes either no argument or a ' +\n    'Firebase App instance.',\n  [AppError.INVALID_LOG_ARGUMENT]:\n    'First argument to `onLog` must be null or a function.',\n  [AppError.IDB_OPEN]:\n    'Error thrown when opening IndexedDB. Original error: {$originalErrorMessage}.',\n  [AppError.IDB_GET]:\n    'Error thrown when reading from IndexedDB. Original error: {$originalErrorMessage}.',\n  [AppError.IDB_WRITE]:\n    'Error thrown when writing to IndexedDB. Original error: {$originalErrorMessage}.',\n  [AppError.IDB_DELETE]:\n    'Error thrown when deleting from IndexedDB. Original error: {$originalErrorMessage}.',\n  [AppError.FINALIZATION_REGISTRY_NOT_SUPPORTED]:\n    'FirebaseServerApp deleteOnDeref field defined but the JS runtime does not support FinalizationRegistry.',\n  [AppError.INVALID_SERVER_APP_ENVIRONMENT]:\n    'FirebaseServerApp is not for use in browser environments.'\n};\n\ninterface ErrorParams {\n  [AppError.NO_APP]: { appName: string };\n  [AppError.BAD_APP_NAME]: { appName: string };\n  [AppError.DUPLICATE_APP]: { appName: string };\n  [AppError.APP_DELETED]: { appName: string };\n  [AppError.INVALID_APP_ARGUMENT]: { appName: string };\n  [AppError.IDB_OPEN]: { originalErrorMessage?: string };\n  [AppError.IDB_GET]: { originalErrorMessage?: string };\n  [AppError.IDB_WRITE]: { originalErrorMessage?: string };\n  [AppError.IDB_DELETE]: { originalErrorMessage?: string };\n  [AppError.FINALIZATION_REGISTRY_NOT_SUPPORTED]: { appName?: string };\n}\n\nexport const ERROR_FACTORY = new ErrorFactory<AppError, ErrorParams>(\n  'app',\n  'Firebase',\n  ERRORS\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  FirebaseApp,\n  FirebaseOptions,\n  FirebaseAppSettings\n} from './public-types';\nimport {\n  ComponentContainer,\n  Component,\n  ComponentType\n} from '@firebase/component';\nimport { ERROR_FACTORY, AppError } from './errors';\n\nexport class FirebaseAppImpl implements FirebaseApp {\n  protected readonly _options: FirebaseOptions;\n  protected readonly _name: string;\n  /**\n   * Original config values passed in as a constructor parameter.\n   * It is only used to compare with another config object to support idempotent initializeApp().\n   *\n   * Updating automaticDataCollectionEnabled on the App instance will not change its value in _config.\n   */\n  private readonly _config: Required<FirebaseAppSettings>;\n  private _automaticDataCollectionEnabled: boolean;\n  protected _isDeleted = false;\n  private readonly _container: ComponentContainer;\n\n  constructor(\n    options: FirebaseOptions,\n    config: Required<FirebaseAppSettings>,\n    container: ComponentContainer\n  ) {\n    this._options = { ...options };\n    this._config = { ...config };\n    this._name = config.name;\n    this._automaticDataCollectionEnabled =\n      config.automaticDataCollectionEnabled;\n    this._container = container;\n    this.container.addComponent(\n      new Component('app', () => this, ComponentType.PUBLIC)\n    );\n  }\n\n  get automaticDataCollectionEnabled(): boolean {\n    this.checkDestroyed();\n    return this._automaticDataCollectionEnabled;\n  }\n\n  set automaticDataCollectionEnabled(val: boolean) {\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  get config(): Required<FirebaseAppSettings> {\n    this.checkDestroyed();\n    return this._config;\n  }\n\n  get container(): ComponentContainer {\n    return this._container;\n  }\n\n  get isDeleted(): boolean {\n    return this._isDeleted;\n  }\n\n  set isDeleted(val: boolean) {\n    this._isDeleted = val;\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  protected checkDestroyed(): void {\n    if (this.isDeleted) {\n      throw ERROR_FACTORY.create(AppError.APP_DELETED, { appName: this._name });\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 {\n  FirebaseApp,\n  FirebaseServerApp,\n  FirebaseOptions,\n  FirebaseAppSettings,\n  FirebaseServerAppSettings\n} from './public-types';\nimport { DEFAULT_ENTRY_NAME, PLATFORM_LOG_STRING } from './constants';\nimport { ERROR_FACTORY, AppError } from './errors';\nimport {\n  ComponentContainer,\n  Component,\n  Name,\n  ComponentType\n} from '@firebase/component';\nimport { version } from '../../firebase/package.json';\nimport { FirebaseAppImpl } from './firebaseApp';\nimport { FirebaseServerAppImpl } from './firebaseServerApp';\nimport {\n  _apps,\n  _components,\n  _isFirebaseApp,\n  _registerComponent,\n  _serverApps\n} from './internal';\nimport { logger } from './logger';\nimport {\n  LogLevelString,\n  setLogLevel as setLogLevelImpl,\n  LogCallback,\n  LogOptions,\n  setUserLogHandler\n} from '@firebase/logger';\nimport {\n  deepEqual,\n  getDefaultAppConfig,\n  isBrowser,\n  isWebWorker\n} from '@firebase/util';\n\nexport { FirebaseError } from '@firebase/util';\n\n/**\n * The current SDK version.\n *\n * @public\n */\nexport const SDK_VERSION = version;\n\n/**\n * Creates and initializes a {@link @firebase/app#FirebaseApp} instance.\n *\n * See\n * {@link\n *   https://firebase.google.com/docs/web/setup#add_firebase_to_your_app\n *   | Add Firebase to your app} and\n * {@link\n *   https://firebase.google.com/docs/web/setup#multiple-projects\n *   | Initialize multiple projects} for detailed documentation.\n *\n * @example\n * ```javascript\n *\n * // Initialize default app\n * // Retrieve your own options values by adding a web app on\n * // https://console.firebase.google.com\n * initializeApp({\n *   apiKey: \"AIza....\",                             // Auth / General Use\n *   authDomain: \"YOUR_APP.firebaseapp.com\",         // Auth with popup/redirect\n *   databaseURL: \"https://YOUR_APP.firebaseio.com\", // Realtime Database\n *   storageBucket: \"YOUR_APP.appspot.com\",          // Storage\n *   messagingSenderId: \"123456789\"                  // Cloud Messaging\n * });\n * ```\n *\n * @example\n * ```javascript\n *\n * // Initialize another app\n * const otherApp = initializeApp({\n *   databaseURL: \"https://<OTHER_DATABASE_NAME>.firebaseio.com\",\n *   storageBucket: \"<OTHER_STORAGE_BUCKET>.appspot.com\"\n * }, \"otherApp\");\n * ```\n *\n * @param options - Options to configure the app's services.\n * @param name - Optional name of the app to initialize. If no name\n *   is provided, the default is `\"[DEFAULT]\"`.\n *\n * @returns The initialized app.\n *\n * @public\n */\nexport function initializeApp(\n  options: FirebaseOptions,\n  name?: string\n): FirebaseApp;\n/**\n * Creates and initializes a FirebaseApp instance.\n *\n * @param options - Options to configure the app's services.\n * @param config - FirebaseApp Configuration\n *\n * @public\n */\nexport function initializeApp(\n  options: FirebaseOptions,\n  config?: FirebaseAppSettings\n): FirebaseApp;\n/**\n * Creates and initializes a FirebaseApp instance.\n *\n * @public\n */\nexport function initializeApp(): FirebaseApp;\nexport function initializeApp(\n  _options?: FirebaseOptions,\n  rawConfig = {}\n): FirebaseApp {\n  let options = _options;\n\n  if (typeof rawConfig !== 'object') {\n    const name = rawConfig;\n    rawConfig = { name };\n  }\n\n  const config: Required<FirebaseAppSettings> = {\n    name: DEFAULT_ENTRY_NAME,\n    automaticDataCollectionEnabled: false,\n    ...rawConfig\n  };\n  const name = config.name;\n\n  if (typeof name !== 'string' || !name) {\n    throw ERROR_FACTORY.create(AppError.BAD_APP_NAME, {\n      appName: String(name)\n    });\n  }\n\n  options ||= getDefaultAppConfig();\n\n  if (!options) {\n    throw ERROR_FACTORY.create(AppError.NO_OPTIONS);\n  }\n\n  const existingApp = _apps.get(name) as FirebaseAppImpl;\n  if (existingApp) {\n    // return the existing app if options and config deep equal the ones in the existing app.\n    if (\n      deepEqual(options, existingApp.options) &&\n      deepEqual(config, existingApp.config)\n    ) {\n      return existingApp;\n    } else {\n      throw ERROR_FACTORY.create(AppError.DUPLICATE_APP, { appName: name });\n    }\n  }\n\n  const container = new ComponentContainer(name);\n  for (const component of _components.values()) {\n    container.addComponent(component);\n  }\n\n  const newApp = new FirebaseAppImpl(options, config, container);\n\n  _apps.set(name, newApp);\n\n  return newApp;\n}\n\n/**\n * Creates and initializes a {@link @firebase/app#FirebaseServerApp} instance.\n *\n * The `FirebaseServerApp` is similar to `FirebaseApp`, but is intended for execution in\n * server side rendering environments only. Initialization will fail if invoked from a\n * browser environment.\n *\n * See\n * {@link\n *   https://firebase.google.com/docs/web/setup#add_firebase_to_your_app\n *   | Add Firebase to your app} and\n * {@link\n *   https://firebase.google.com/docs/web/setup#multiple-projects\n *   | Initialize multiple projects} for detailed documentation.\n *\n * @example\n * ```javascript\n *\n * // Initialize an instance of `FirebaseServerApp`.\n * // Retrieve your own options values by adding a web app on\n * // https://console.firebase.google.com\n * initializeServerApp({\n *     apiKey: \"AIza....\",                             // Auth / General Use\n *     authDomain: \"YOUR_APP.firebaseapp.com\",         // Auth with popup/redirect\n *     databaseURL: \"https://YOUR_APP.firebaseio.com\", // Realtime Database\n *     storageBucket: \"YOUR_APP.appspot.com\",          // Storage\n *     messagingSenderId: \"123456789\"                  // Cloud Messaging\n *   },\n *   {\n *    authIdToken: \"Your Auth ID Token\"\n *   });\n * ```\n *\n * @param options - `Firebase.AppOptions` to configure the app's services, or a\n *   a `FirebaseApp` instance which contains the `AppOptions` within.\n * @param config - `FirebaseServerApp` configuration.\n *\n * @returns The initialized `FirebaseServerApp`.\n *\n * @public\n */\nexport function initializeServerApp(\n  options: FirebaseOptions | FirebaseApp,\n  config: FirebaseServerAppSettings\n): FirebaseServerApp;\n\nexport function initializeServerApp(\n  _options: FirebaseOptions | FirebaseApp,\n  _serverAppConfig: FirebaseServerAppSettings\n): FirebaseServerApp {\n  if (isBrowser() && !isWebWorker()) {\n    // FirebaseServerApp isn't designed to be run in browsers.\n    throw ERROR_FACTORY.create(AppError.INVALID_SERVER_APP_ENVIRONMENT);\n  }\n\n  if (_serverAppConfig.automaticDataCollectionEnabled === undefined) {\n    _serverAppConfig.automaticDataCollectionEnabled = false;\n  }\n\n  let appOptions: FirebaseOptions;\n  if (_isFirebaseApp(_options)) {\n    appOptions = _options.options;\n  } else {\n    appOptions = _options;\n  }\n\n  // Build an app name based on a hash of the configuration options.\n  const nameObj = {\n    ..._serverAppConfig,\n    ...appOptions\n  };\n\n  // However, Do not mangle the name based on releaseOnDeref, since it will vary between the\n  // construction of FirebaseServerApp instances. For example, if the object is the request headers.\n  if (nameObj.releaseOnDeref !== undefined) {\n    delete nameObj.releaseOnDeref;\n  }\n\n  const hashCode = (s: string): number => {\n    return [...s].reduce(\n      (hash, c) => (Math.imul(31, hash) + c.charCodeAt(0)) | 0,\n      0\n    );\n  };\n\n  if (_serverAppConfig.releaseOnDeref !== undefined) {\n    if (typeof FinalizationRegistry === 'undefined') {\n      throw ERROR_FACTORY.create(\n        AppError.FINALIZATION_REGISTRY_NOT_SUPPORTED,\n        {}\n      );\n    }\n  }\n\n  const nameString = '' + hashCode(JSON.stringify(nameObj));\n  const existingApp = _serverApps.get(nameString) as FirebaseServerApp;\n  if (existingApp) {\n    (existingApp as FirebaseServerAppImpl).incRefCount(\n      _serverAppConfig.releaseOnDeref\n    );\n    return existingApp;\n  }\n\n  const container = new ComponentContainer(nameString);\n  for (const component of _components.values()) {\n    container.addComponent(component);\n  }\n\n  const newApp = new FirebaseServerAppImpl(\n    appOptions,\n    _serverAppConfig,\n    nameString,\n    container\n  );\n\n  _serverApps.set(nameString, newApp);\n\n  return newApp;\n}\n\n/**\n * Retrieves a {@link @firebase/app#FirebaseApp} instance.\n *\n * When called with no arguments, the default app is returned. When an app name\n * is provided, the app corresponding to that name is returned.\n *\n * An exception is thrown if the app being retrieved has not yet been\n * initialized.\n *\n * @example\n * ```javascript\n * // Return the default app\n * const app = getApp();\n * ```\n *\n * @example\n * ```javascript\n * // Return a named app\n * const otherApp = getApp(\"otherApp\");\n * ```\n *\n * @param name - Optional name of the app to return. If no name is\n *   provided, the default is `\"[DEFAULT]\"`.\n *\n * @returns The app corresponding to the provided app name.\n *   If no app name is provided, the default app is returned.\n *\n * @public\n */\nexport function getApp(name: string = DEFAULT_ENTRY_NAME): FirebaseApp {\n  const app = _apps.get(name);\n  if (!app && name === DEFAULT_ENTRY_NAME && getDefaultAppConfig()) {\n    return initializeApp();\n  }\n  if (!app) {\n    throw ERROR_FACTORY.create(AppError.NO_APP, { appName: name });\n  }\n\n  return app;\n}\n\n/**\n * A (read-only) array of all initialized apps.\n * @public\n */\nexport function getApps(): FirebaseApp[] {\n  return Array.from(_apps.values());\n}\n\n/**\n * Renders this app unusable and frees the resources of all associated\n * services.\n *\n * @example\n * ```javascript\n * deleteApp(app)\n *   .then(function() {\n *     console.log(\"App deleted successfully\");\n *   })\n *   .catch(function(error) {\n *     console.log(\"Error deleting app:\", error);\n *   });\n * ```\n *\n * @public\n */\nexport async function deleteApp(app: FirebaseApp): Promise<void> {\n  let cleanupProviders = false;\n  const name = app.name;\n  if (_apps.has(name)) {\n    cleanupProviders = true;\n    _apps.delete(name);\n  } else if (_serverApps.has(name)) {\n    const firebaseServerApp = app as FirebaseServerAppImpl;\n    if (firebaseServerApp.decRefCount() <= 0) {\n      _serverApps.delete(name);\n      cleanupProviders = true;\n    }\n  }\n\n  if (cleanupProviders) {\n    await Promise.all(\n      (app as FirebaseAppImpl).container\n        .getProviders()\n        .map(provider => provider.delete())\n    );\n    (app as FirebaseAppImpl).isDeleted = true;\n  }\n}\n\n/**\n * Registers a library's name and version for platform logging purposes.\n * @param library - Name of 1p or 3p library (e.g. firestore, angularfire)\n * @param version - Current version of that library.\n * @param variant - Bundle variant, e.g., node, rn, etc.\n *\n * @public\n */\nexport 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/**\n * Sets log handler for all Firebase SDKs.\n * @param logCallback - An optional custom log handler that executes user code whenever\n * the Firebase SDK makes a logging call.\n *\n * @public\n */\nexport function onLog(\n  logCallback: LogCallback | null,\n  options?: LogOptions\n): 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/**\n * Sets log level for all Firebase SDKs.\n *\n * All of the log types above the current log level are captured (i.e. if\n * you set the log level to `info`, errors are logged, but `debug` and\n * `verbose` logs are not).\n *\n * @public\n */\nexport function setLogLevel(logLevel: LogLevelString): void {\n  setLogLevelImpl(logLevel);\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { DBSchema, openDB, IDBPDatabase } from 'idb';\nimport { AppError, ERROR_FACTORY } from './errors';\nimport { FirebaseApp } from './public-types';\nimport { HeartbeatsInIndexedDB } from './types';\nimport { logger } from './logger';\n\nconst DB_NAME = 'firebase-heartbeat-database';\nconst DB_VERSION = 1;\nconst STORE_NAME = 'firebase-heartbeat-store';\n\ninterface AppDB extends DBSchema {\n  'firebase-heartbeat-store': {\n    key: string;\n    value: HeartbeatsInIndexedDB;\n  };\n}\n\nlet dbPromise: Promise<IDBPDatabase<AppDB>> | null = null;\nfunction getDbPromise(): Promise<IDBPDatabase<AppDB>> {\n  if (!dbPromise) {\n    dbPromise = openDB<AppDB>(DB_NAME, DB_VERSION, {\n      upgrade: (db, oldVersion) => {\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 (oldVersion) {\n          case 0:\n            try {\n              db.createObjectStore(STORE_NAME);\n            } catch (e) {\n              // Safari/iOS browsers throw occasional exceptions on\n              // db.createObjectStore() that may be a bug. Avoid blocking\n              // the rest of the app functionality.\n              console.warn(e);\n            }\n        }\n      }\n    }).catch(e => {\n      throw ERROR_FACTORY.create(AppError.IDB_OPEN, {\n        originalErrorMessage: e.message\n      });\n    });\n  }\n  return dbPromise;\n}\n\nexport async function readHeartbeatsFromIndexedDB(\n  app: FirebaseApp\n): Promise<HeartbeatsInIndexedDB | undefined> {\n  try {\n    const db = await getDbPromise();\n    const tx = db.transaction(STORE_NAME);\n    const result = await tx.objectStore(STORE_NAME).get(computeKey(app));\n    // We already have the value but tx.done can throw,\n    // so we need to await it here to catch errors\n    await tx.done;\n    return result;\n  } catch (e) {\n    if (e instanceof FirebaseError) {\n      logger.warn(e.message);\n    } else {\n      const idbGetError = ERROR_FACTORY.create(AppError.IDB_GET, {\n        originalErrorMessage: (e as Error)?.message\n      });\n      logger.warn(idbGetError.message);\n    }\n  }\n}\n\nexport async function writeHeartbeatsToIndexedDB(\n  app: FirebaseApp,\n  heartbeatObject: HeartbeatsInIndexedDB\n): Promise<void> {\n  try {\n    const db = await getDbPromise();\n    const tx = db.transaction(STORE_NAME, 'readwrite');\n    const objectStore = tx.objectStore(STORE_NAME);\n    await objectStore.put(heartbeatObject, computeKey(app));\n    await tx.done;\n  } catch (e) {\n    if (e instanceof FirebaseError) {\n      logger.warn(e.message);\n    } else {\n      const idbGetError = ERROR_FACTORY.create(AppError.IDB_WRITE, {\n        originalErrorMessage: (e as Error)?.message\n      });\n      logger.warn(idbGetError.message);\n    }\n  }\n}\n\nfunction computeKey(app: FirebaseApp): string {\n  return `${app.name}!${app.options.appId}`;\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { ComponentContainer } from '@firebase/component';\nimport {\n  base64urlEncodeWithoutPadding,\n  isIndexedDBAvailable,\n  validateIndexedDBOpenable\n} from '@firebase/util';\nimport {\n  readHeartbeatsFromIndexedDB,\n  writeHeartbeatsToIndexedDB\n} from './indexeddb';\nimport { FirebaseApp } from './public-types';\nimport {\n  HeartbeatsByUserAgent,\n  HeartbeatService,\n  HeartbeatsInIndexedDB,\n  HeartbeatStorage,\n  SingleDateHeartbeat\n} from './types';\nimport { logger } from './logger';\n\nconst MAX_HEADER_BYTES = 1024;\n// 30 days\nconst STORED_HEARTBEAT_RETENTION_MAX_MILLIS = 30 * 24 * 60 * 60 * 1000;\n\nexport class HeartbeatServiceImpl implements HeartbeatService {\n  /**\n   * The persistence layer for heartbeats\n   * Leave public for easier testing.\n   */\n  _storage: HeartbeatStorageImpl;\n\n  /**\n   * In-memory cache for heartbeats, used by getHeartbeatsHeader() to generate\n   * the header string.\n   * Stores one record per date. This will be consolidated into the standard\n   * format of one record per user agent string before being sent as a header.\n   * Populated from indexedDB when the controller is instantiated and should\n   * be kept in sync with indexedDB.\n   * Leave public for easier testing.\n   */\n  _heartbeatsCache: HeartbeatsInIndexedDB | null = null;\n\n  /**\n   * the initialization promise for populating heartbeatCache.\n   * If getHeartbeatsHeader() is called before the promise resolves\n   * (heartbeatsCache == null), it should wait for this promise\n   * Leave public for easier testing.\n   */\n  _heartbeatsCachePromise: Promise<HeartbeatsInIndexedDB>;\n  constructor(private readonly container: ComponentContainer) {\n    const app = this.container.getProvider('app').getImmediate();\n    this._storage = new HeartbeatStorageImpl(app);\n    this._heartbeatsCachePromise = this._storage.read().then(result => {\n      this._heartbeatsCache = result;\n      return result;\n    });\n  }\n\n  /**\n   * Called to report a heartbeat. The function will generate\n   * a HeartbeatsByUserAgent object, update heartbeatsCache, and persist it\n   * to IndexedDB.\n   * Note that we only store one heartbeat per day. So if a heartbeat for today is\n   * already logged, subsequent calls to this function in the same day will be ignored.\n   */\n  async triggerHeartbeat(): Promise<void> {\n    try {\n      const platformLogger = this.container\n        .getProvider('platform-logger')\n        .getImmediate();\n\n      // This is the \"Firebase user agent\" string from the platform logger\n      // service, not the browser user agent.\n      const agent = platformLogger.getPlatformInfoString();\n      const date = getUTCDateString();\n      if (this._heartbeatsCache?.heartbeats == null) {\n        this._heartbeatsCache = await this._heartbeatsCachePromise;\n        // If we failed to construct a heartbeats cache, then return immediately.\n        if (this._heartbeatsCache?.heartbeats == null) {\n          return;\n        }\n      }\n      // Do not store a heartbeat if one is already stored for this day\n      // or if a header has already been sent today.\n      if (\n        this._heartbeatsCache.lastSentHeartbeatDate === date ||\n        this._heartbeatsCache.heartbeats.some(\n          singleDateHeartbeat => singleDateHeartbeat.date === date\n        )\n      ) {\n        return;\n      } else {\n        // There is no entry for this date. Create one.\n        this._heartbeatsCache.heartbeats.push({ date, agent });\n      }\n      // Remove entries older than 30 days.\n      this._heartbeatsCache.heartbeats =\n        this._heartbeatsCache.heartbeats.filter(singleDateHeartbeat => {\n          const hbTimestamp = new Date(singleDateHeartbeat.date).valueOf();\n          const now = Date.now();\n          return now - hbTimestamp <= STORED_HEARTBEAT_RETENTION_MAX_MILLIS;\n        });\n      return this._storage.overwrite(this._heartbeatsCache);\n    } catch (e) {\n      logger.warn(e);\n    }\n  }\n\n  /**\n   * Returns a base64 encoded string which can be attached to the heartbeat-specific header directly.\n   * It also clears all heartbeats from memory as well as in IndexedDB.\n   *\n   * NOTE: Consuming product SDKs should not send the header if this method\n   * returns an empty string.\n   */\n  async getHeartbeatsHeader(): Promise<string> {\n    try {\n      if (this._heartbeatsCache === null) {\n        await this._heartbeatsCachePromise;\n      }\n      // If it's still null or the array is empty, there is no data to send.\n      if (\n        this._heartbeatsCache?.heartbeats == null ||\n        this._heartbeatsCache.heartbeats.length === 0\n      ) {\n        return '';\n      }\n      const date = getUTCDateString();\n      // Extract as many heartbeats from the cache as will fit under the size limit.\n      const { heartbeatsToSend, unsentEntries } = extractHeartbeatsForHeader(\n        this._heartbeatsCache.heartbeats\n      );\n      const headerString = base64urlEncodeWithoutPadding(\n        JSON.stringify({ version: 2, heartbeats: heartbeatsToSend })\n      );\n      // Store last sent date to prevent another being logged/sent for the same day.\n      this._heartbeatsCache.lastSentHeartbeatDate = date;\n      if (unsentEntries.length > 0) {\n        // Store any unsent entries if they exist.\n        this._heartbeatsCache.heartbeats = unsentEntries;\n        // This seems more likely than emptying the array (below) to lead to some odd state\n        // since the cache isn't empty and this will be called again on the next request,\n        // and is probably safest if we await it.\n        await this._storage.overwrite(this._heartbeatsCache);\n      } else {\n        this._heartbeatsCache.heartbeats = [];\n        // Do not wait for this, to reduce latency.\n        void this._storage.overwrite(this._heartbeatsCache);\n      }\n      return headerString;\n    } catch (e) {\n      logger.warn(e);\n      return '';\n    }\n  }\n}\n\nfunction getUTCDateString(): string {\n  const today = new Date();\n  // Returns date format 'YYYY-MM-DD'\n  return today.toISOString().substring(0, 10);\n}\n\nexport function extractHeartbeatsForHeader(\n  heartbeatsCache: SingleDateHeartbeat[],\n  maxSize = MAX_HEADER_BYTES\n): {\n  heartbeatsToSend: HeartbeatsByUserAgent[];\n  unsentEntries: SingleDateHeartbeat[];\n} {\n  // Heartbeats grouped by user agent in the standard format to be sent in\n  // the header.\n  const heartbeatsToSend: HeartbeatsByUserAgent[] = [];\n  // Single date format heartbeats that are not sent.\n  let unsentEntries = heartbeatsCache.slice();\n  for (const singleDateHeartbeat of heartbeatsCache) {\n    // Look for an existing entry with the same user agent.\n    const heartbeatEntry = heartbeatsToSend.find(\n      hb => hb.agent === singleDateHeartbeat.agent\n    );\n    if (!heartbeatEntry) {\n      // If no entry for this user agent exists, create one.\n      heartbeatsToSend.push({\n        agent: singleDateHeartbeat.agent,\n        dates: [singleDateHeartbeat.date]\n      });\n      if (countBytes(heartbeatsToSend) > maxSize) {\n        // If the header would exceed max size, remove the added heartbeat\n        // entry and stop adding to the header.\n        heartbeatsToSend.pop();\n        break;\n      }\n    } else {\n      heartbeatEntry.dates.push(singleDateHeartbeat.date);\n      // If the header would exceed max size, remove the added date\n      // and stop adding to the header.\n      if (countBytes(heartbeatsToSend) > maxSize) {\n        heartbeatEntry.dates.pop();\n        break;\n      }\n    }\n    // Pop unsent entry from queue. (Skipped if adding the entry exceeded\n    // quota and the loop breaks early.)\n    unsentEntries = unsentEntries.slice(1);\n  }\n  return {\n    heartbeatsToSend,\n    unsentEntries\n  };\n}\n\nexport class HeartbeatStorageImpl implements HeartbeatStorage {\n  private _canUseIndexedDBPromise: Promise<boolean>;\n  constructor(public app: FirebaseApp) {\n    this._canUseIndexedDBPromise = this.runIndexedDBEnvironmentCheck();\n  }\n  async runIndexedDBEnvironmentCheck(): Promise<boolean> {\n    if (!isIndexedDBAvailable()) {\n      return false;\n    } else {\n      return validateIndexedDBOpenable()\n        .then(() => true)\n        .catch(() => false);\n    }\n  }\n  /**\n   * Read all heartbeats.\n   */\n  async read(): Promise<HeartbeatsInIndexedDB> {\n    const canUseIndexedDB = await this._canUseIndexedDBPromise;\n    if (!canUseIndexedDB) {\n      return { heartbeats: [] };\n    } else {\n      const idbHeartbeatObject = await readHeartbeatsFromIndexedDB(this.app);\n      if (idbHeartbeatObject?.heartbeats) {\n        return idbHeartbeatObject;\n      } else {\n        return { heartbeats: [] };\n      }\n    }\n  }\n  // overwrite the storage with the provided heartbeats\n  async overwrite(heartbeatsObject: HeartbeatsInIndexedDB): Promise<void> {\n    const canUseIndexedDB = await this._canUseIndexedDBPromise;\n    if (!canUseIndexedDB) {\n      return;\n    } else {\n      const existingHeartbeatsObject = await this.read();\n      return writeHeartbeatsToIndexedDB(this.app, {\n        lastSentHeartbeatDate:\n          heartbeatsObject.lastSentHeartbeatDate ??\n          existingHeartbeatsObject.lastSentHeartbeatDate,\n        heartbeats: heartbeatsObject.heartbeats\n      });\n    }\n  }\n  // add heartbeats\n  async add(heartbeatsObject: HeartbeatsInIndexedDB): Promise<void> {\n    const canUseIndexedDB = await this._canUseIndexedDBPromise;\n    if (!canUseIndexedDB) {\n      return;\n    } else {\n      const existingHeartbeatsObject = await this.read();\n      return writeHeartbeatsToIndexedDB(this.app, {\n        lastSentHeartbeatDate:\n          heartbeatsObject.lastSentHeartbeatDate ??\n          existingHeartbeatsObject.lastSentHeartbeatDate,\n        heartbeats: [\n          ...existingHeartbeatsObject.heartbeats,\n          ...heartbeatsObject.heartbeats\n        ]\n      });\n    }\n  }\n}\n\n/**\n * Calculate bytes of a HeartbeatsByUserAgent array after being wrapped\n * in a platform logging header JSON object, stringified, and converted\n * to base 64.\n */\nexport function countBytes(heartbeatsCache: HeartbeatsByUserAgent[]): number {\n  // base64 has a restricted set of characters, all of which should be 1 byte.\n  return base64urlEncodeWithoutPadding(\n    // heartbeatsCache wrapper properties\n    JSON.stringify({ version: 2, heartbeats: heartbeatsCache })\n  ).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 { Component, ComponentType } from '@firebase/component';\nimport { PlatformLoggerServiceImpl } from './platformLoggerService';\nimport { name, version } from '../package.json';\nimport { _registerComponent } from './internal';\nimport { registerVersion } from './api';\nimport { HeartbeatServiceImpl } from './heartbeatService';\n\nexport function registerCoreComponents(variant?: string): void {\n  _registerComponent(\n    new Component(\n      'platform-logger',\n      container => new PlatformLoggerServiceImpl(container),\n      ComponentType.PRIVATE\n    )\n  );\n  _registerComponent(\n    new Component(\n      'heartbeat',\n      container => new HeartbeatServiceImpl(container),\n      ComponentType.PRIVATE\n    )\n  );\n\n  // Register `app` package.\n  registerVersion(name, version, variant);\n  // BUILD_TARGET will be replaced by values like esm2017, cjs2017, etc during the compilation\n  registerVersion(name, version, '__BUILD_TARGET__');\n  // Register platform SDK identifier (no version).\n  registerVersion('fire-js', '');\n}\n","/**\n * Firebase App\n *\n * @remarks This package coordinates the communication between the different Firebase components\n * @packageDocumentation\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 { registerCoreComponents } from './registerCoreComponents';\n\nexport * from './api';\nexport * from './internal';\nexport * from './public-types';\n\nregisterCoreComponents('__RUNTIME_ENV__');\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 */\nimport { registerVersion } from '@firebase/app';\nimport { name, version } from '../package.json';\n\nregisterVersion(name, version, 'app');\nexport * from '@firebase/app';\n","/** @license\nCopyright The Closure Library Authors.\nSPDX-License-Identifier: Apache-2.0\n*/\n(function() {'use strict';var h;/** @license\n\n Copyright The Closure Library Authors.\n SPDX-License-Identifier: Apache-2.0\n*/\nfunction k(f,a){function c(){}c.prototype=a.prototype;f.D=a.prototype;f.prototype=new c;f.prototype.constructor=f;f.C=function(d,e,g){for(var b=Array(arguments.length-2),r=2;r<arguments.length;r++)b[r-2]=arguments[r];return a.prototype[e].apply(d,b)}};function l(){this.blockSize=-1};function m(){this.blockSize=-1;this.blockSize=64;this.g=Array(4);this.B=Array(this.blockSize);this.o=this.h=0;this.s()}k(m,l);m.prototype.s=function(){this.g[0]=1732584193;this.g[1]=4023233417;this.g[2]=2562383102;this.g[3]=271733878;this.o=this.h=0};\nfunction n(f,a,c){c||(c=0);var d=Array(16);if(\"string\"===typeof a)for(var e=0;16>e;++e)d[e]=a.charCodeAt(c++)|a.charCodeAt(c++)<<8|a.charCodeAt(c++)<<16|a.charCodeAt(c++)<<24;else for(e=0;16>e;++e)d[e]=a[c++]|a[c++]<<8|a[c++]<<16|a[c++]<<24;a=f.g[0];c=f.g[1];e=f.g[2];var g=f.g[3];var b=a+(g^c&(e^g))+d[0]+3614090360&4294967295;a=c+(b<<7&4294967295|b>>>25);b=g+(e^a&(c^e))+d[1]+3905402710&4294967295;g=a+(b<<12&4294967295|b>>>20);b=e+(c^g&(a^c))+d[2]+606105819&4294967295;e=g+(b<<17&4294967295|b>>>15);\nb=c+(a^e&(g^a))+d[3]+3250441966&4294967295;c=e+(b<<22&4294967295|b>>>10);b=a+(g^c&(e^g))+d[4]+4118548399&4294967295;a=c+(b<<7&4294967295|b>>>25);b=g+(e^a&(c^e))+d[5]+1200080426&4294967295;g=a+(b<<12&4294967295|b>>>20);b=e+(c^g&(a^c))+d[6]+2821735955&4294967295;e=g+(b<<17&4294967295|b>>>15);b=c+(a^e&(g^a))+d[7]+4249261313&4294967295;c=e+(b<<22&4294967295|b>>>10);b=a+(g^c&(e^g))+d[8]+1770035416&4294967295;a=c+(b<<7&4294967295|b>>>25);b=g+(e^a&(c^e))+d[9]+2336552879&4294967295;g=a+(b<<12&4294967295|\nb>>>20);b=e+(c^g&(a^c))+d[10]+4294925233&4294967295;e=g+(b<<17&4294967295|b>>>15);b=c+(a^e&(g^a))+d[11]+2304563134&4294967295;c=e+(b<<22&4294967295|b>>>10);b=a+(g^c&(e^g))+d[12]+1804603682&4294967295;a=c+(b<<7&4294967295|b>>>25);b=g+(e^a&(c^e))+d[13]+4254626195&4294967295;g=a+(b<<12&4294967295|b>>>20);b=e+(c^g&(a^c))+d[14]+2792965006&4294967295;e=g+(b<<17&4294967295|b>>>15);b=c+(a^e&(g^a))+d[15]+1236535329&4294967295;c=e+(b<<22&4294967295|b>>>10);b=a+(e^g&(c^e))+d[1]+4129170786&4294967295;a=c+(b<<\n5&4294967295|b>>>27);b=g+(c^e&(a^c))+d[6]+3225465664&4294967295;g=a+(b<<9&4294967295|b>>>23);b=e+(a^c&(g^a))+d[11]+643717713&4294967295;e=g+(b<<14&4294967295|b>>>18);b=c+(g^a&(e^g))+d[0]+3921069994&4294967295;c=e+(b<<20&4294967295|b>>>12);b=a+(e^g&(c^e))+d[5]+3593408605&4294967295;a=c+(b<<5&4294967295|b>>>27);b=g+(c^e&(a^c))+d[10]+38016083&4294967295;g=a+(b<<9&4294967295|b>>>23);b=e+(a^c&(g^a))+d[15]+3634488961&4294967295;e=g+(b<<14&4294967295|b>>>18);b=c+(g^a&(e^g))+d[4]+3889429448&4294967295;c=\ne+(b<<20&4294967295|b>>>12);b=a+(e^g&(c^e))+d[9]+568446438&4294967295;a=c+(b<<5&4294967295|b>>>27);b=g+(c^e&(a^c))+d[14]+3275163606&4294967295;g=a+(b<<9&4294967295|b>>>23);b=e+(a^c&(g^a))+d[3]+4107603335&4294967295;e=g+(b<<14&4294967295|b>>>18);b=c+(g^a&(e^g))+d[8]+1163531501&4294967295;c=e+(b<<20&4294967295|b>>>12);b=a+(e^g&(c^e))+d[13]+2850285829&4294967295;a=c+(b<<5&4294967295|b>>>27);b=g+(c^e&(a^c))+d[2]+4243563512&4294967295;g=a+(b<<9&4294967295|b>>>23);b=e+(a^c&(g^a))+d[7]+1735328473&4294967295;\ne=g+(b<<14&4294967295|b>>>18);b=c+(g^a&(e^g))+d[12]+2368359562&4294967295;c=e+(b<<20&4294967295|b>>>12);b=a+(c^e^g)+d[5]+4294588738&4294967295;a=c+(b<<4&4294967295|b>>>28);b=g+(a^c^e)+d[8]+2272392833&4294967295;g=a+(b<<11&4294967295|b>>>21);b=e+(g^a^c)+d[11]+1839030562&4294967295;e=g+(b<<16&4294967295|b>>>16);b=c+(e^g^a)+d[14]+4259657740&4294967295;c=e+(b<<23&4294967295|b>>>9);b=a+(c^e^g)+d[1]+2763975236&4294967295;a=c+(b<<4&4294967295|b>>>28);b=g+(a^c^e)+d[4]+1272893353&4294967295;g=a+(b<<11&4294967295|\nb>>>21);b=e+(g^a^c)+d[7]+4139469664&4294967295;e=g+(b<<16&4294967295|b>>>16);b=c+(e^g^a)+d[10]+3200236656&4294967295;c=e+(b<<23&4294967295|b>>>9);b=a+(c^e^g)+d[13]+681279174&4294967295;a=c+(b<<4&4294967295|b>>>28);b=g+(a^c^e)+d[0]+3936430074&4294967295;g=a+(b<<11&4294967295|b>>>21);b=e+(g^a^c)+d[3]+3572445317&4294967295;e=g+(b<<16&4294967295|b>>>16);b=c+(e^g^a)+d[6]+76029189&4294967295;c=e+(b<<23&4294967295|b>>>9);b=a+(c^e^g)+d[9]+3654602809&4294967295;a=c+(b<<4&4294967295|b>>>28);b=g+(a^c^e)+d[12]+\n3873151461&4294967295;g=a+(b<<11&4294967295|b>>>21);b=e+(g^a^c)+d[15]+530742520&4294967295;e=g+(b<<16&4294967295|b>>>16);b=c+(e^g^a)+d[2]+3299628645&4294967295;c=e+(b<<23&4294967295|b>>>9);b=a+(e^(c|~g))+d[0]+4096336452&4294967295;a=c+(b<<6&4294967295|b>>>26);b=g+(c^(a|~e))+d[7]+1126891415&4294967295;g=a+(b<<10&4294967295|b>>>22);b=e+(a^(g|~c))+d[14]+2878612391&4294967295;e=g+(b<<15&4294967295|b>>>17);b=c+(g^(e|~a))+d[5]+4237533241&4294967295;c=e+(b<<21&4294967295|b>>>11);b=a+(e^(c|~g))+d[12]+1700485571&\n4294967295;a=c+(b<<6&4294967295|b>>>26);b=g+(c^(a|~e))+d[3]+2399980690&4294967295;g=a+(b<<10&4294967295|b>>>22);b=e+(a^(g|~c))+d[10]+4293915773&4294967295;e=g+(b<<15&4294967295|b>>>17);b=c+(g^(e|~a))+d[1]+2240044497&4294967295;c=e+(b<<21&4294967295|b>>>11);b=a+(e^(c|~g))+d[8]+1873313359&4294967295;a=c+(b<<6&4294967295|b>>>26);b=g+(c^(a|~e))+d[15]+4264355552&4294967295;g=a+(b<<10&4294967295|b>>>22);b=e+(a^(g|~c))+d[6]+2734768916&4294967295;e=g+(b<<15&4294967295|b>>>17);b=c+(g^(e|~a))+d[13]+1309151649&\n4294967295;c=e+(b<<21&4294967295|b>>>11);b=a+(e^(c|~g))+d[4]+4149444226&4294967295;a=c+(b<<6&4294967295|b>>>26);b=g+(c^(a|~e))+d[11]+3174756917&4294967295;g=a+(b<<10&4294967295|b>>>22);b=e+(a^(g|~c))+d[2]+718787259&4294967295;e=g+(b<<15&4294967295|b>>>17);b=c+(g^(e|~a))+d[9]+3951481745&4294967295;f.g[0]=f.g[0]+a&4294967295;f.g[1]=f.g[1]+(e+(b<<21&4294967295|b>>>11))&4294967295;f.g[2]=f.g[2]+e&4294967295;f.g[3]=f.g[3]+g&4294967295}\nm.prototype.u=function(f,a){void 0===a&&(a=f.length);for(var c=a-this.blockSize,d=this.B,e=this.h,g=0;g<a;){if(0==e)for(;g<=c;)n(this,f,g),g+=this.blockSize;if(\"string\"===typeof f)for(;g<a;){if(d[e++]=f.charCodeAt(g++),e==this.blockSize){n(this,d);e=0;break}}else for(;g<a;)if(d[e++]=f[g++],e==this.blockSize){n(this,d);e=0;break}}this.h=e;this.o+=a};\nm.prototype.v=function(){var f=Array((56>this.h?this.blockSize:2*this.blockSize)-this.h);f[0]=128;for(var a=1;a<f.length-8;++a)f[a]=0;var c=8*this.o;for(a=f.length-8;a<f.length;++a)f[a]=c&255,c/=256;this.u(f);f=Array(16);for(a=c=0;4>a;++a)for(var d=0;32>d;d+=8)f[c++]=this.g[a]>>>d&255;return f};function p(f,a){var c=q;return Object.prototype.hasOwnProperty.call(c,f)?c[f]:c[f]=a(f)};function t(f,a){this.h=a;for(var c=[],d=!0,e=f.length-1;0<=e;e--){var g=f[e]|0;d&&g==a||(c[e]=g,d=!1)}this.g=c}var q={};function u(f){return-128<=f&&128>f?p(f,function(a){return new t([a|0],0>a?-1:0)}):new t([f|0],0>f?-1:0)}function v(f){if(isNaN(f)||!isFinite(f))return w;if(0>f)return x(v(-f));for(var a=[],c=1,d=0;f>=c;d++)a[d]=f/c|0,c*=4294967296;return new t(a,0)}\nfunction y(f,a){if(0==f.length)throw Error(\"number format error: empty string\");a=a||10;if(2>a||36<a)throw Error(\"radix out of range: \"+a);if(\"-\"==f.charAt(0))return x(y(f.substring(1),a));if(0<=f.indexOf(\"-\"))throw Error('number format error: interior \"-\" character');for(var c=v(Math.pow(a,8)),d=w,e=0;e<f.length;e+=8){var g=Math.min(8,f.length-e),b=parseInt(f.substring(e,e+g),a);8>g?(g=v(Math.pow(a,g)),d=d.j(g).add(v(b))):(d=d.j(c),d=d.add(v(b)))}return d}var w=u(0),z=u(1),A=u(16777216);h=t.prototype;\nh.m=function(){if(B(this))return-x(this).m();for(var f=0,a=1,c=0;c<this.g.length;c++){var d=this.i(c);f+=(0<=d?d:4294967296+d)*a;a*=4294967296}return f};h.toString=function(f){f=f||10;if(2>f||36<f)throw Error(\"radix out of range: \"+f);if(C(this))return\"0\";if(B(this))return\"-\"+x(this).toString(f);for(var a=v(Math.pow(f,6)),c=this,d=\"\";;){var e=D(c,a).g;c=F(c,e.j(a));var g=((0<c.g.length?c.g[0]:c.h)>>>0).toString(f);c=e;if(C(c))return g+d;for(;6>g.length;)g=\"0\"+g;d=g+d}};\nh.i=function(f){return 0>f?0:f<this.g.length?this.g[f]:this.h};function C(f){if(0!=f.h)return!1;for(var a=0;a<f.g.length;a++)if(0!=f.g[a])return!1;return!0}function B(f){return-1==f.h}h.l=function(f){f=F(this,f);return B(f)?-1:C(f)?0:1};function x(f){for(var a=f.g.length,c=[],d=0;d<a;d++)c[d]=~f.g[d];return(new t(c,~f.h)).add(z)}h.abs=function(){return B(this)?x(this):this};\nh.add=function(f){for(var a=Math.max(this.g.length,f.g.length),c=[],d=0,e=0;e<=a;e++){var g=d+(this.i(e)&65535)+(f.i(e)&65535),b=(g>>>16)+(this.i(e)>>>16)+(f.i(e)>>>16);d=b>>>16;g&=65535;b&=65535;c[e]=b<<16|g}return new t(c,c[c.length-1]&-2147483648?-1:0)};function F(f,a){return f.add(x(a))}\nh.j=function(f){if(C(this)||C(f))return w;if(B(this))return B(f)?x(this).j(x(f)):x(x(this).j(f));if(B(f))return x(this.j(x(f)));if(0>this.l(A)&&0>f.l(A))return v(this.m()*f.m());for(var a=this.g.length+f.g.length,c=[],d=0;d<2*a;d++)c[d]=0;for(d=0;d<this.g.length;d++)for(var e=0;e<f.g.length;e++){var g=this.i(d)>>>16,b=this.i(d)&65535,r=f.i(e)>>>16,E=f.i(e)&65535;c[2*d+2*e]+=b*E;G(c,2*d+2*e);c[2*d+2*e+1]+=g*E;G(c,2*d+2*e+1);c[2*d+2*e+1]+=b*r;G(c,2*d+2*e+1);c[2*d+2*e+2]+=g*r;G(c,2*d+2*e+2)}for(d=0;d<\na;d++)c[d]=c[2*d+1]<<16|c[2*d];for(d=a;d<2*a;d++)c[d]=0;return new t(c,0)};function G(f,a){for(;(f[a]&65535)!=f[a];)f[a+1]+=f[a]>>>16,f[a]&=65535,a++}function H(f,a){this.g=f;this.h=a}\nfunction D(f,a){if(C(a))throw Error(\"division by zero\");if(C(f))return new H(w,w);if(B(f))return a=D(x(f),a),new H(x(a.g),x(a.h));if(B(a))return a=D(f,x(a)),new H(x(a.g),a.h);if(30<f.g.length){if(B(f)||B(a))throw Error(\"slowDivide_ only works with positive integers.\");for(var c=z,d=a;0>=d.l(f);)c=I(c),d=I(d);var e=J(c,1),g=J(d,1);d=J(d,2);for(c=J(c,2);!C(d);){var b=g.add(d);0>=b.l(f)&&(e=e.add(c),g=b);d=J(d,1);c=J(c,1)}a=F(f,e.j(a));return new H(e,a)}for(e=w;0<=f.l(a);){c=Math.max(1,Math.floor(f.m()/\na.m()));d=Math.ceil(Math.log(c)/Math.LN2);d=48>=d?1:Math.pow(2,d-48);g=v(c);for(b=g.j(a);B(b)||0<b.l(f);)c-=d,g=v(c),b=g.j(a);C(g)&&(g=z);e=e.add(g);f=F(f,b)}return new H(e,f)}h.A=function(f){return D(this,f).h};h.and=function(f){for(var a=Math.max(this.g.length,f.g.length),c=[],d=0;d<a;d++)c[d]=this.i(d)&f.i(d);return new t(c,this.h&f.h)};h.or=function(f){for(var a=Math.max(this.g.length,f.g.length),c=[],d=0;d<a;d++)c[d]=this.i(d)|f.i(d);return new t(c,this.h|f.h)};\nh.xor=function(f){for(var a=Math.max(this.g.length,f.g.length),c=[],d=0;d<a;d++)c[d]=this.i(d)^f.i(d);return new t(c,this.h^f.h)};function I(f){for(var a=f.g.length+1,c=[],d=0;d<a;d++)c[d]=f.i(d)<<1|f.i(d-1)>>>31;return new t(c,f.h)}function J(f,a){var c=a>>5;a%=32;for(var d=f.g.length-c,e=[],g=0;g<d;g++)e[g]=0<a?f.i(g+c)>>>a|f.i(g+c+1)<<32-a:f.i(g+c);return new t(e,f.h)};m.prototype.digest=m.prototype.v;m.prototype.reset=m.prototype.s;m.prototype.update=m.prototype.u;module.exports.Md5=m;t.prototype.add=t.prototype.add;t.prototype.multiply=t.prototype.j;t.prototype.modulo=t.prototype.A;t.prototype.compare=t.prototype.l;t.prototype.toNumber=t.prototype.m;t.prototype.toString=t.prototype.toString;t.prototype.getBits=t.prototype.i;t.fromNumber=v;t.fromString=y;module.exports.Integer=t;}).apply( typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self  : typeof window !== 'undefined' ? window  : {});\n","/** @license\nCopyright The Closure Library Authors.\nSPDX-License-Identifier: Apache-2.0\n*/\n(function() {'use strict';var h,aa=\"function\"==typeof Object.defineProperties?Object.defineProperty:function(a,b,c){if(a==Array.prototype||a==Object.prototype)return a;a[b]=c.value;return a};function ba(a){a=[\"object\"==typeof globalThis&&globalThis,a,\"object\"==typeof window&&window,\"object\"==typeof self&&self,\"object\"==typeof global&&global];for(var b=0;b<a.length;++b){var c=a[b];if(c&&c.Math==Math)return c}throw Error(\"Cannot find global object\");}var ca=ba(this);\nfunction da(a,b){if(b)a:{var c=ca;a=a.split(\".\");for(var d=0;d<a.length-1;d++){var e=a[d];if(!(e in c))break a;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,b){a instanceof String&&(a+=\"\");var c=0,d=!1,e={next:function(){if(!d&&c<a.length){var f=c++;return{value:b(f,a[f]),done:!1}}d=!0;return{done:!0,value:void 0}}};e[Symbol.iterator]=function(){return e};return e}\nda(\"Array.prototype.values\",function(a){return a?a:function(){return ea(this,function(b,c){return c})}});/** @license\n\n Copyright The Closure Library Authors.\n SPDX-License-Identifier: Apache-2.0\n*/\nvar fa=fa||{},k=this||self;function ha(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}function n(a){var b=typeof a;return\"object\"==b&&null!=a||\"function\"==b}function ia(a,b,c){return a.call.apply(a.bind,arguments)}\nfunction ja(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)}}function p(a,b,c){p=Function.prototype.bind&&-1!=Function.prototype.bind.toString().indexOf(\"native code\")?ia:ja;return p.apply(null,arguments)}\nfunction ka(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)}}function r(a,b){function c(){}c.prototype=b.prototype;a.aa=b.prototype;a.prototype=new c;a.prototype.constructor=a;a.Qb=function(d,e,f){for(var g=Array(arguments.length-2),m=2;m<arguments.length;m++)g[m-2]=arguments[m];return b.prototype[e].apply(d,g)}};function la(a){const b=a.length;if(0<b){const c=Array(b);for(let d=0;d<b;d++)c[d]=a[d];return c}return[]}function ma(a,b){for(let c=1;c<arguments.length;c++){const d=arguments[c];if(ha(d)){const e=a.length||0,f=d.length||0;a.length=e+f;for(let g=0;g<f;g++)a[e+g]=d[g]}else a.push(d)}};class na{constructor(a,b){this.i=a;this.j=b;this.h=0;this.g=null}get(){let a;0<this.h?(this.h--,a=this.g,this.g=a.next,a.next=null):a=this.i();return a}};function t(a){return/^[\\s\\xa0]*$/.test(a)};function u(){var a=k.navigator;return a&&(a=a.userAgent)?a:\"\"};function oa(a){oa[\" \"](a);return a}oa[\" \"]=function(){};var pa=-1!=u().indexOf(\"Gecko\")&&!(-1!=u().toLowerCase().indexOf(\"webkit\")&&-1==u().indexOf(\"Edge\"))&&!(-1!=u().indexOf(\"Trident\")||-1!=u().indexOf(\"MSIE\"))&&-1==u().indexOf(\"Edge\");function qa(a,b,c){for(const d in a)b.call(c,a[d],d,a)}function ra(a,b){for(const c in a)b.call(void 0,a[c],c,a)}function sa(a){const b={};for(const c in a)b[c]=a[c];return b}const ta=\"constructor hasOwnProperty isPrototypeOf propertyIsEnumerable toLocaleString toString valueOf\".split(\" \");function ua(a,b){let c,d;for(let e=1;e<arguments.length;e++){d=arguments[e];for(c in d)a[c]=d[c];for(let f=0;f<ta.length;f++)c=ta[f],Object.prototype.hasOwnProperty.call(d,c)&&(a[c]=d[c])}};function va(a){var b=1;a=a.split(\":\");const c=[];for(;0<b&&a.length;)c.push(a.shift()),b--;a.length&&c.push(a.join(\":\"));return c};function wa(a){k.setTimeout(()=>{throw a;},0)};function xa(){var a=za;let b=null;a.g&&(b=a.g,a.g=a.g.next,a.g||(a.h=null),b.next=null);return b}class Aa{constructor(){this.h=this.g=null}add(a,b){const c=Ba.get();c.set(a,b);this.h?this.h.next=c:this.g=c;this.h=c}}var Ba=new na(()=>new Ca,a=>a.reset());class Ca{constructor(){this.next=this.g=this.h=null}set(a,b){this.h=a;this.g=b;this.next=null}reset(){this.next=this.g=this.h=null}};let x,y=!1,za=new Aa,Ea=()=>{const a=k.Promise.resolve(void 0);x=()=>{a.then(Da)}};var Da=()=>{for(var a;a=xa();){try{a.h.call(a.g)}catch(c){wa(c)}var b=Ba;b.j(a);100>b.h&&(b.h++,a.next=b.g,b.g=a)}y=!1};function z(){this.s=this.s;this.C=this.C}z.prototype.s=!1;z.prototype.ma=function(){this.s||(this.s=!0,this.N())};z.prototype.N=function(){if(this.C)for(;this.C.length;)this.C.shift()()};function A(a,b){this.type=a;this.g=this.target=b;this.defaultPrevented=!1}A.prototype.h=function(){this.defaultPrevented=!0};var Fa=function(){if(!k.addEventListener||!Object.defineProperty)return!1;var a=!1,b=Object.defineProperty({},\"passive\",{get:function(){a=!0}});try{const c=()=>{};k.addEventListener(\"test\",c,b);k.removeEventListener(\"test\",c,b)}catch(c){}return a}();function C(a,b){A.call(this,a?a.type:\"\");this.relatedTarget=this.g=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.state=null;this.pointerId=0;this.pointerType=\"\";this.i=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.g=b;if(b=a.relatedTarget){if(pa){a:{try{oa(b.nodeName);var e=!0;break a}catch(f){}e=\n!1}e||(b=null)}}else\"mouseover\"==c?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=\na.shiftKey;this.metaKey=a.metaKey;this.pointerId=a.pointerId||0;this.pointerType=\"string\"===typeof a.pointerType?a.pointerType:Ga[a.pointerType]||\"\";this.state=a.state;this.i=a;a.defaultPrevented&&C.aa.h.call(this)}}r(C,A);var Ga={2:\"touch\",3:\"pen\",4:\"mouse\"};C.prototype.h=function(){C.aa.h.call(this);var a=this.i;a.preventDefault?a.preventDefault():a.returnValue=!1};var D=\"closure_listenable_\"+(1E6*Math.random()|0);var Ha=0;function Ia(a,b,c,d,e){this.listener=a;this.proxy=null;this.src=b;this.type=c;this.capture=!!d;this.ha=e;this.key=++Ha;this.da=this.fa=!1}function Ja(a){a.da=!0;a.listener=null;a.proxy=null;a.src=null;a.ha=null};function Ka(a){this.src=a;this.g={};this.h=0}Ka.prototype.add=function(a,b,c,d,e){var f=a.toString();a=this.g[f];a||(a=this.g[f]=[],this.h++);var g=La(a,b,d,e);-1<g?(b=a[g],c||(b.fa=!1)):(b=new Ia(b,this.src,f,!!d,e),b.fa=c,a.push(b));return b};function Ma(a,b){var c=b.type;if(c in a.g){var d=a.g[c],e=Array.prototype.indexOf.call(d,b,void 0),f;(f=0<=e)&&Array.prototype.splice.call(d,e,1);f&&(Ja(b),0==a.g[c].length&&(delete a.g[c],a.h--))}}\nfunction La(a,b,c,d){for(var e=0;e<a.length;++e){var f=a[e];if(!f.da&&f.listener==b&&f.capture==!!c&&f.ha==d)return e}return-1};var Na=\"closure_lm_\"+(1E6*Math.random()|0),Oa={},Pa=0;function Qa(a,b,c,d,e){if(d&&d.once)return Ra(a,b,c,d,e);if(Array.isArray(b)){for(var f=0;f<b.length;f++)Qa(a,b[f],c,d,e);return null}c=Sa(c);return a&&a[D]?a.K(b,c,n(d)?!!d.capture:!!d,e):Ta(a,b,c,!1,d,e)}\nfunction Ta(a,b,c,d,e,f){if(!b)throw Error(\"Invalid event type\");var g=n(e)?!!e.capture:!!e,m=Ua(a);m||(a[Na]=m=new Ka(a));c=m.add(b,c,d,g,f);if(c.proxy)return c;d=Va();c.proxy=d;d.src=a;d.listener=c;if(a.addEventListener)Fa||(e=g),void 0===e&&(e=!1),a.addEventListener(b.toString(),d,e);else if(a.attachEvent)a.attachEvent(Wa(b.toString()),d);else if(a.addListener&&a.removeListener)a.addListener(d);else throw Error(\"addEventListener and attachEvent are unavailable.\");Pa++;return c}\nfunction Va(){function a(c){return b.call(a.src,a.listener,c)}const b=Xa;return a}function Ra(a,b,c,d,e){if(Array.isArray(b)){for(var f=0;f<b.length;f++)Ra(a,b[f],c,d,e);return null}c=Sa(c);return a&&a[D]?a.L(b,c,n(d)?!!d.capture:!!d,e):Ta(a,b,c,!0,d,e)}\nfunction Ya(a,b,c,d,e){if(Array.isArray(b))for(var f=0;f<b.length;f++)Ya(a,b[f],c,d,e);else(d=n(d)?!!d.capture:!!d,c=Sa(c),a&&a[D])?(a=a.i,b=String(b).toString(),b in a.g&&(f=a.g[b],c=La(f,c,d,e),-1<c&&(Ja(f[c]),Array.prototype.splice.call(f,c,1),0==f.length&&(delete a.g[b],a.h--)))):a&&(a=Ua(a))&&(b=a.g[b.toString()],a=-1,b&&(a=La(b,c,d,e)),(c=-1<a?b[a]:null)&&Za(c))}\nfunction Za(a){if(\"number\"!==typeof a&&a&&!a.da){var b=a.src;if(b&&b[D])Ma(b.i,a);else{var c=a.type,d=a.proxy;b.removeEventListener?b.removeEventListener(c,d,a.capture):b.detachEvent?b.detachEvent(Wa(c),d):b.addListener&&b.removeListener&&b.removeListener(d);Pa--;(c=Ua(b))?(Ma(c,a),0==c.h&&(c.src=null,b[Na]=null)):Ja(a)}}}function Wa(a){return a in Oa?Oa[a]:Oa[a]=\"on\"+a}function Xa(a,b){if(a.da)a=!0;else{b=new C(b,this);var c=a.listener,d=a.ha||a.src;a.fa&&Za(a);a=c.call(d,b)}return a}\nfunction Ua(a){a=a[Na];return a instanceof Ka?a:null}var $a=\"__closure_events_fn_\"+(1E9*Math.random()>>>0);function Sa(a){if(\"function\"===typeof a)return a;a[$a]||(a[$a]=function(b){return a.handleEvent(b)});return a[$a]};function E(){z.call(this);this.i=new Ka(this);this.M=this;this.F=null}r(E,z);E.prototype[D]=!0;E.prototype.removeEventListener=function(a,b,c,d){Ya(this,a,b,c,d)};\nfunction F(a,b){var c,d=a.F;if(d)for(c=[];d;d=d.F)c.push(d);a=a.M;d=b.type||b;if(\"string\"===typeof b)b=new A(b,a);else if(b instanceof A)b.target=b.target||a;else{var e=b;b=new A(d,a);ua(b,e)}e=!0;if(c)for(var f=c.length-1;0<=f;f--){var g=b.g=c[f];e=ab(g,d,!0,b)&&e}g=b.g=a;e=ab(g,d,!0,b)&&e;e=ab(g,d,!1,b)&&e;if(c)for(f=0;f<c.length;f++)g=b.g=c[f],e=ab(g,d,!1,b)&&e}\nE.prototype.N=function(){E.aa.N.call(this);if(this.i){var a=this.i,b=0,c;for(c in a.g){for(var d=a.g[c],e=0;e<d.length;e++)++b,Ja(d[e]);delete a.g[c];a.h--}}this.F=null};E.prototype.K=function(a,b,c,d){return this.i.add(String(a),b,!1,c,d)};E.prototype.L=function(a,b,c,d){return this.i.add(String(a),b,!0,c,d)};\nfunction ab(a,b,c,d){b=a.i.g[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.da&&g.capture==c){var m=g.listener,q=g.ha||g.src;g.fa&&Ma(a.i,g);e=!1!==m.call(q,d)&&e}}return e&&!d.defaultPrevented};function bb(a,b,c){if(\"function\"===typeof a)c&&(a=p(a,c));else if(a&&\"function\"==typeof a.handleEvent)a=p(a.handleEvent,a);else throw Error(\"Invalid listener argument\");return 2147483647<Number(b)?-1:k.setTimeout(a,b||0)};function cb(a){a.g=bb(()=>{a.g=null;a.i&&(a.i=!1,cb(a))},a.l);const b=a.h;a.h=null;a.m.apply(null,b)}class eb extends z{constructor(a,b){super();this.m=a;this.l=b;this.h=null;this.i=!1;this.g=null}j(a){this.h=arguments;this.g?this.i=!0:cb(this)}N(){super.N();this.g&&(k.clearTimeout(this.g),this.g=null,this.i=!1,this.h=null)}};function G(a){z.call(this);this.h=a;this.g={}}r(G,z);var fb=[];function gb(a){qa(a.g,function(b,c){this.g.hasOwnProperty(c)&&Za(b)},a);a.g={}}G.prototype.N=function(){G.aa.N.call(this);gb(this)};G.prototype.handleEvent=function(){throw Error(\"EventHandler.handleEvent not implemented\");};var hb=k.JSON.stringify;var ib=k.JSON.parse;var jb=class{stringify(a){return k.JSON.stringify(a,void 0)}parse(a){return k.JSON.parse(a,void 0)}};function kb(){}kb.prototype.h=null;function lb(a){return a.h||(a.h=a.i())};function mb(){}var H={OPEN:\"a\",kb:\"b\",Ja:\"c\",wb:\"d\"};function nb(){A.call(this,\"d\")}r(nb,A);function ob(){A.call(this,\"c\")}r(ob,A);var I={},pb=null;function qb(){return pb=pb||new E}I.La=\"serverreachability\";function rb(a){A.call(this,I.La,a)}r(rb,A);function J(a){const b=qb();F(b,new rb(b,a))}I.STAT_EVENT=\"statevent\";function sb(a,b){A.call(this,I.STAT_EVENT,a);this.stat=b}r(sb,A);function K(a){const b=qb();F(b,new sb(b,a))}I.Ma=\"timingevent\";function tb(a,b){A.call(this,I.Ma,a);this.size=b}r(tb,A);\nfunction ub(a,b){if(\"function\"!==typeof a)throw Error(\"Fn must not be null and must be a function\");return k.setTimeout(function(){a()},b)};function vb(){this.g=!0}vb.prototype.xa=function(){this.g=!1};function wb(a,b,c,d,e,f){a.info(function(){if(a.g)if(f){var g=\"\";for(var m=f.split(\"&\"),q=0;q<m.length;q++){var l=m[q].split(\"=\");if(1<l.length){var v=l[0];l=l[1];var w=v.split(\"_\");g=2<=w.length&&\"type\"==w[1]?g+(v+\"=\"+l+\"&\"):g+(v+\"=redacted&\")}}}else g=null;else g=f;return\"XMLHTTP REQ (\"+d+\") [attempt \"+e+\"]: \"+b+\"\\n\"+c+\"\\n\"+g})}\nfunction xb(a,b,c,d,e,f,g){a.info(function(){return\"XMLHTTP RESP (\"+d+\") [ attempt \"+e+\"]: \"+b+\"\\n\"+c+\"\\n\"+f+\" \"+g})}function L(a,b,c,d){a.info(function(){return\"XMLHTTP TEXT (\"+b+\"): \"+yb(a,c)+(d?\" \"+d:\"\")})}function zb(a,b){a.info(function(){return\"TIMEOUT: \"+b})}vb.prototype.info=function(){};\nfunction yb(a,b){if(!a.g)return b;if(!b)return null;try{var c=JSON.parse(b);if(c)for(a=0;a<c.length;a++)if(Array.isArray(c[a])){var d=c[a];if(!(2>d.length)){var e=d[1];if(Array.isArray(e)&&!(1>e.length)){var f=e[0];if(\"noop\"!=f&&\"stop\"!=f&&\"close\"!=f)for(var g=1;g<e.length;g++)e[g]=\"\"}}}return hb(c)}catch(m){return b}};var Ab={NO_ERROR:0,gb:1,tb:2,sb:3,nb:4,rb:5,ub:6,Ia:7,TIMEOUT:8,xb:9};var Bb={lb:\"complete\",Hb:\"success\",Ja:\"error\",Ia:\"abort\",zb:\"ready\",Ab:\"readystatechange\",TIMEOUT:\"timeout\",vb:\"incrementaldata\",yb:\"progress\",ob:\"downloadprogress\",Pb:\"uploadprogress\"};var Cb;function Db(){}r(Db,kb);Db.prototype.g=function(){return new XMLHttpRequest};Db.prototype.i=function(){return{}};Cb=new Db;function M(a,b,c,d){this.j=a;this.i=b;this.l=c;this.R=d||1;this.U=new G(this);this.I=45E3;this.H=null;this.o=!1;this.m=this.A=this.v=this.L=this.F=this.S=this.B=null;this.D=[];this.g=null;this.C=0;this.s=this.u=null;this.X=-1;this.J=!1;this.O=0;this.M=null;this.W=this.K=this.T=this.P=!1;this.h=new Eb}function Eb(){this.i=null;this.g=\"\";this.h=!1}var Fb={},Gb={};function Hb(a,b,c){a.L=1;a.v=Ib(N(b));a.m=c;a.P=!0;Jb(a,null)}\nfunction Jb(a,b){a.F=Date.now();Kb(a);a.A=N(a.v);var c=a.A,d=a.R;Array.isArray(d)||(d=[String(d)]);Lb(c.i,\"t\",d);a.C=0;c=a.j.J;a.h=new Eb;a.g=Mb(a.j,c?b:null,!a.m);0<a.O&&(a.M=new eb(p(a.Y,a,a.g),a.O));b=a.U;c=a.g;d=a.ca;var e=\"readystatechange\";Array.isArray(e)||(e&&(fb[0]=e.toString()),e=fb);for(var f=0;f<e.length;f++){var g=Qa(c,e[f],d||b.handleEvent,!1,b.h||b);if(!g)break;b.g[g.key]=g}b=a.H?sa(a.H):{};a.m?(a.u||(a.u=\"POST\"),b[\"Content-Type\"]=\"application/x-www-form-urlencoded\",a.g.ea(a.A,a.u,\na.m,b)):(a.u=\"GET\",a.g.ea(a.A,a.u,null,b));J(1);wb(a.i,a.u,a.A,a.l,a.R,a.m)}M.prototype.ca=function(a){a=a.target;const b=this.M;b&&3==P(a)?b.j():this.Y(a)};\nM.prototype.Y=function(a){try{if(a==this.g)a:{const w=P(this.g);var b=this.g.Ba();const O=this.g.Z();if(!(3>w)&&(3!=w||this.g&&(this.h.h||this.g.oa()||Nb(this.g)))){this.J||4!=w||7==b||(8==b||0>=O?J(3):J(2));Ob(this);var c=this.g.Z();this.X=c;b:if(Pb(this)){var d=Nb(this.g);a=\"\";var e=d.length,f=4==P(this.g);if(!this.h.i){if(\"undefined\"===typeof TextDecoder){Q(this);Qb(this);var g=\"\";break b}this.h.i=new k.TextDecoder}for(b=0;b<e;b++)this.h.h=!0,a+=this.h.i.decode(d[b],{stream:!(f&&b==e-1)});d.length=\n0;this.h.g+=a;this.C=0;g=this.h.g}else g=this.g.oa();this.o=200==c;xb(this.i,this.u,this.A,this.l,this.R,w,c);if(this.o){if(this.T&&!this.K){b:{if(this.g){var m,q=this.g;if((m=q.g?q.g.getResponseHeader(\"X-HTTP-Initial-Response\"):null)&&!t(m)){var l=m;break b}}l=null}if(c=l)L(this.i,this.l,c,\"Initial handshake response via X-HTTP-Initial-Response\"),this.K=!0,Rb(this,c);else{this.o=!1;this.s=3;K(12);Q(this);Qb(this);break a}}if(this.P){c=!0;let B;for(;!this.J&&this.C<g.length;)if(B=Sb(this,g),B==Gb){4==\nw&&(this.s=4,K(14),c=!1);L(this.i,this.l,null,\"[Incomplete Response]\");break}else if(B==Fb){this.s=4;K(15);L(this.i,this.l,g,\"[Invalid Chunk]\");c=!1;break}else L(this.i,this.l,B,null),Rb(this,B);Pb(this)&&0!=this.C&&(this.h.g=this.h.g.slice(this.C),this.C=0);4!=w||0!=g.length||this.h.h||(this.s=1,K(16),c=!1);this.o=this.o&&c;if(!c)L(this.i,this.l,g,\"[Invalid Chunked Response]\"),Q(this),Qb(this);else if(0<g.length&&!this.W){this.W=!0;var v=this.j;v.g==this&&v.ba&&!v.M&&(v.j.info(\"Great, no buffering proxy detected. Bytes received: \"+\ng.length),Tb(v),v.M=!0,K(11))}}else L(this.i,this.l,g,null),Rb(this,g);4==w&&Q(this);this.o&&!this.J&&(4==w?Ub(this.j,this):(this.o=!1,Kb(this)))}else Vb(this.g),400==c&&0<g.indexOf(\"Unknown SID\")?(this.s=3,K(12)):(this.s=0,K(13)),Q(this),Qb(this)}}}catch(w){}finally{}};function Pb(a){return a.g?\"GET\"==a.u&&2!=a.L&&a.j.Ca:!1}\nfunction Sb(a,b){var c=a.C,d=b.indexOf(\"\\n\",c);if(-1==d)return Gb;c=Number(b.substring(c,d));if(isNaN(c))return Fb;d+=1;if(d+c>b.length)return Gb;b=b.slice(d,d+c);a.C=d+c;return b}M.prototype.cancel=function(){this.J=!0;Q(this)};function Kb(a){a.S=Date.now()+a.I;Wb(a,a.I)}function Wb(a,b){if(null!=a.B)throw Error(\"WatchDog timer not null\");a.B=ub(p(a.ba,a),b)}function Ob(a){a.B&&(k.clearTimeout(a.B),a.B=null)}\nM.prototype.ba=function(){this.B=null;const a=Date.now();0<=a-this.S?(zb(this.i,this.A),2!=this.L&&(J(3),K(17)),Q(this),this.s=2,Qb(this)):Wb(this,this.S-a)};function Qb(a){0==a.j.G||a.J||Ub(a.j,a)}function Q(a){Ob(a);var b=a.M;b&&\"function\"==typeof b.ma&&b.ma();a.M=null;gb(a.U);a.g&&(b=a.g,a.g=null,b.abort(),b.ma())}\nfunction Rb(a,b){try{var c=a.j;if(0!=c.G&&(c.g==a||Xb(c.h,a)))if(!a.K&&Xb(c.h,a)&&3==c.G){try{var d=c.Da.g.parse(b)}catch(l){d=null}if(Array.isArray(d)&&3==d.length){var e=d;if(0==e[0])a:{if(!c.u){if(c.g)if(c.g.F+3E3<a.F)Yb(c),Zb(c);else break a;$b(c);K(18)}}else c.za=e[1],0<c.za-c.T&&37500>e[2]&&c.F&&0==c.v&&!c.C&&(c.C=ub(p(c.Za,c),6E3));if(1>=ac(c.h)&&c.ca){try{c.ca()}catch(l){}c.ca=void 0}}else R(c,11)}else if((a.K||c.g==a)&&Yb(c),!t(b))for(e=c.Da.g.parse(b),b=0;b<e.length;b++){let l=e[b];c.T=\nl[0];l=l[1];if(2==c.G)if(\"c\"==l[0]){c.K=l[1];c.ia=l[2];const v=l[3];null!=v&&(c.la=v,c.j.info(\"VER=\"+c.la));const w=l[4];null!=w&&(c.Aa=w,c.j.info(\"SVER=\"+c.Aa));const O=l[5];null!=O&&\"number\"===typeof O&&0<O&&(d=1.5*O,c.L=d,c.j.info(\"backChannelRequestTimeoutMs_=\"+d));d=c;const B=a.g;if(B){const ya=B.g?B.g.getResponseHeader(\"X-Client-Wire-Protocol\"):null;if(ya){var f=d.h;f.g||-1==ya.indexOf(\"spdy\")&&-1==ya.indexOf(\"quic\")&&-1==ya.indexOf(\"h2\")||(f.j=f.l,f.g=new Set,f.h&&(bc(f,f.h),f.h=null))}if(d.D){const db=\nB.g?B.g.getResponseHeader(\"X-HTTP-Session-Id\"):null;db&&(d.ya=db,S(d.I,d.D,db))}}c.G=3;c.l&&c.l.ua();c.ba&&(c.R=Date.now()-a.F,c.j.info(\"Handshake RTT: \"+c.R+\"ms\"));d=c;var g=a;d.qa=cc(d,d.J?d.ia:null,d.W);if(g.K){dc(d.h,g);var m=g,q=d.L;q&&(m.I=q);m.B&&(Ob(m),Kb(m));d.g=g}else ec(d);0<c.i.length&&fc(c)}else\"stop\"!=l[0]&&\"close\"!=l[0]||R(c,7);else 3==c.G&&(\"stop\"==l[0]||\"close\"==l[0]?\"stop\"==l[0]?R(c,7):gc(c):\"noop\"!=l[0]&&c.l&&c.l.ta(l),c.v=0)}J(4)}catch(l){}};var hc=class{constructor(a,b){this.g=a;this.map=b}};function ic(a){this.l=a||10;k.PerformanceNavigationTiming?(a=k.performance.getEntriesByType(\"navigation\"),a=0<a.length&&(\"hq\"==a[0].nextHopProtocol||\"h2\"==a[0].nextHopProtocol)):a=!!(k.chrome&&k.chrome.loadTimes&&k.chrome.loadTimes()&&k.chrome.loadTimes().wasFetchedViaSpdy);this.j=a?this.l:1;this.g=null;1<this.j&&(this.g=new Set);this.h=null;this.i=[]}function jc(a){return a.h?!0:a.g?a.g.size>=a.j:!1}function ac(a){return a.h?1:a.g?a.g.size:0}function Xb(a,b){return a.h?a.h==b:a.g?a.g.has(b):!1}\nfunction bc(a,b){a.g?a.g.add(b):a.h=b}function dc(a,b){a.h&&a.h==b?a.h=null:a.g&&a.g.has(b)&&a.g.delete(b)}ic.prototype.cancel=function(){this.i=kc(this);if(this.h)this.h.cancel(),this.h=null;else if(this.g&&0!==this.g.size){for(const a of this.g.values())a.cancel();this.g.clear()}};function kc(a){if(null!=a.h)return a.i.concat(a.h.D);if(null!=a.g&&0!==a.g.size){let b=a.i;for(const c of a.g.values())b=b.concat(c.D);return b}return la(a.i)};function lc(a){if(a.V&&\"function\"==typeof a.V)return a.V();if(\"undefined\"!==typeof Map&&a instanceof Map||\"undefined\"!==typeof Set&&a instanceof Set)return Array.from(a.values());if(\"string\"===typeof a)return a.split(\"\");if(ha(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}\nfunction mc(a){if(a.na&&\"function\"==typeof a.na)return a.na();if(!a.V||\"function\"!=typeof a.V){if(\"undefined\"!==typeof Map&&a instanceof Map)return Array.from(a.keys());if(!(\"undefined\"!==typeof Set&&a instanceof Set)){if(ha(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(const d in a)b[c++]=d;return b}}}\nfunction nc(a,b){if(a.forEach&&\"function\"==typeof a.forEach)a.forEach(b,void 0);else if(ha(a)||\"string\"===typeof a)Array.prototype.forEach.call(a,b,void 0);else for(var c=mc(a),d=lc(a),e=d.length,f=0;f<e;f++)b.call(void 0,d[f],c&&c[f],a)};var oc=RegExp(\"^(?:([^:/?#.]+):)?(?://(?:([^\\\\\\\\/?#]*)@)?([^\\\\\\\\/?#]*?)(?::([0-9]+))?(?=[\\\\\\\\/?#]|$))?([^?#]+)?(?:\\\\?([^#]*))?(?:#([\\\\s\\\\S]*))?$\");function pc(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 T(a){this.g=this.o=this.j=\"\";this.s=null;this.m=this.l=\"\";this.h=!1;if(a instanceof T){this.h=a.h;qc(this,a.j);this.o=a.o;this.g=a.g;rc(this,a.s);this.l=a.l;var b=a.i;var c=new sc;c.i=b.i;b.g&&(c.g=new Map(b.g),c.h=b.h);tc(this,c);this.m=a.m}else a&&(b=String(a).match(oc))?(this.h=!1,qc(this,b[1]||\"\",!0),this.o=uc(b[2]||\"\"),this.g=uc(b[3]||\"\",!0),rc(this,b[4]),this.l=uc(b[5]||\"\",!0),tc(this,b[6]||\"\",!0),this.m=uc(b[7]||\"\")):(this.h=!1,this.i=new sc(null,this.h))}\nT.prototype.toString=function(){var a=[],b=this.j;b&&a.push(vc(b,wc,!0),\":\");var c=this.g;if(c||\"file\"==b)a.push(\"//\"),(b=this.o)&&a.push(vc(b,wc,!0),\"@\"),a.push(encodeURIComponent(String(c)).replace(/%25([0-9a-fA-F]{2})/g,\"%$1\")),c=this.s,null!=c&&a.push(\":\",String(c));if(c=this.l)this.g&&\"/\"!=c.charAt(0)&&a.push(\"/\"),a.push(vc(c,\"/\"==c.charAt(0)?xc:yc,!0));(c=this.i.toString())&&a.push(\"?\",c);(c=this.m)&&a.push(\"#\",vc(c,zc));return a.join(\"\")};function N(a){return new T(a)}\nfunction qc(a,b,c){a.j=c?uc(b,!0):b;a.j&&(a.j=a.j.replace(/:$/,\"\"))}function rc(a,b){if(b){b=Number(b);if(isNaN(b)||0>b)throw Error(\"Bad port number \"+b);a.s=b}else a.s=null}function tc(a,b,c){b instanceof sc?(a.i=b,Ac(a.i,a.h)):(c||(b=vc(b,Bc)),a.i=new sc(b,a.h))}function S(a,b,c){a.i.set(b,c)}function Ib(a){S(a,\"zx\",Math.floor(2147483648*Math.random()).toString(36)+Math.abs(Math.floor(2147483648*Math.random())^Date.now()).toString(36));return a}\nfunction uc(a,b){return a?b?decodeURI(a.replace(/%25/g,\"%2525\")):decodeURIComponent(a):\"\"}function vc(a,b,c){return\"string\"===typeof a?(a=encodeURI(a).replace(b,Cc),c&&(a=a.replace(/%25([0-9a-fA-F]{2})/g,\"%$1\")),a):null}function Cc(a){a=a.charCodeAt(0);return\"%\"+(a>>4&15).toString(16)+(a&15).toString(16)}var wc=/[#\\/\\?@]/g,yc=/[#\\?:]/g,xc=/[#\\?]/g,Bc=/[#\\?@]/g,zc=/#/g;function sc(a,b){this.h=this.g=null;this.i=a||null;this.j=!!b}\nfunction U(a){a.g||(a.g=new Map,a.h=0,a.i&&pc(a.i,function(b,c){a.add(decodeURIComponent(b.replace(/\\+/g,\" \")),c)}))}h=sc.prototype;h.add=function(a,b){U(this);this.i=null;a=V(this,a);var c=this.g.get(a);c||this.g.set(a,c=[]);c.push(b);this.h+=1;return this};function Dc(a,b){U(a);b=V(a,b);a.g.has(b)&&(a.i=null,a.h-=a.g.get(b).length,a.g.delete(b))}function Ec(a,b){U(a);b=V(a,b);return a.g.has(b)}\nh.forEach=function(a,b){U(this);this.g.forEach(function(c,d){c.forEach(function(e){a.call(b,e,d,this)},this)},this)};h.na=function(){U(this);const a=Array.from(this.g.values()),b=Array.from(this.g.keys()),c=[];for(let d=0;d<b.length;d++){const e=a[d];for(let f=0;f<e.length;f++)c.push(b[d])}return c};h.V=function(a){U(this);let b=[];if(\"string\"===typeof a)Ec(this,a)&&(b=b.concat(this.g.get(V(this,a))));else{a=Array.from(this.g.values());for(let c=0;c<a.length;c++)b=b.concat(a[c])}return b};\nh.set=function(a,b){U(this);this.i=null;a=V(this,a);Ec(this,a)&&(this.h-=this.g.get(a).length);this.g.set(a,[b]);this.h+=1;return this};h.get=function(a,b){if(!a)return b;a=this.V(a);return 0<a.length?String(a[0]):b};function Lb(a,b,c){Dc(a,b);0<c.length&&(a.i=null,a.g.set(V(a,b),la(c)),a.h+=c.length)}\nh.toString=function(){if(this.i)return this.i;if(!this.g)return\"\";const a=[],b=Array.from(this.g.keys());for(var c=0;c<b.length;c++){var d=b[c];const f=encodeURIComponent(String(d)),g=this.V(d);for(d=0;d<g.length;d++){var e=f;\"\"!==g[d]&&(e+=\"=\"+encodeURIComponent(String(g[d])));a.push(e)}}return this.i=a.join(\"&\")};function V(a,b){b=String(b);a.j&&(b=b.toLowerCase());return b}\nfunction Ac(a,b){b&&!a.j&&(U(a),a.i=null,a.g.forEach(function(c,d){var e=d.toLowerCase();d!=e&&(Dc(this,d),Lb(this,e,c))},a));a.j=b};function Fc(a,b){const c=new vb;if(k.Image){const d=new Image;d.onload=ka(W,c,\"TestLoadImage: loaded\",!0,b,d);d.onerror=ka(W,c,\"TestLoadImage: error\",!1,b,d);d.onabort=ka(W,c,\"TestLoadImage: abort\",!1,b,d);d.ontimeout=ka(W,c,\"TestLoadImage: timeout\",!1,b,d);k.setTimeout(function(){if(d.ontimeout)d.ontimeout()},1E4);d.src=a}else b(!1)}\nfunction Gc(a,b){const c=new vb,d=new AbortController,e=setTimeout(()=>{d.abort();W(c,\"TestPingServer: timeout\",!1,b)},1E4);fetch(a,{signal:d.signal}).then(f=>{clearTimeout(e);f.ok?W(c,\"TestPingServer: ok\",!0,b):W(c,\"TestPingServer: server error\",!1,b)}).catch(()=>{clearTimeout(e);W(c,\"TestPingServer: error\",!1,b)})}function W(a,b,c,d,e){try{e&&(e.onload=null,e.onerror=null,e.onabort=null,e.ontimeout=null),d(c)}catch(f){}};function Hc(){this.g=new jb}function Ic(a,b,c){const d=c||\"\";try{nc(a,function(e,f){let g=e;n(e)&&(g=hb(e));b.push(d+f+\"=\"+encodeURIComponent(g))})}catch(e){throw b.push(d+\"type=\"+encodeURIComponent(\"_badmap\")),e;}};function Jc(a){this.l=a.Ub||null;this.j=a.eb||!1}r(Jc,kb);Jc.prototype.g=function(){return new Kc(this.l,this.j)};Jc.prototype.i=function(a){return function(){return a}}({});function Kc(a,b){E.call(this);this.D=a;this.o=b;this.m=void 0;this.status=this.readyState=0;this.responseType=this.responseText=this.response=this.statusText=\"\";this.onreadystatechange=null;this.u=new Headers;this.h=null;this.B=\"GET\";this.A=\"\";this.g=!1;this.v=this.j=this.l=null}r(Kc,E);h=Kc.prototype;\nh.open=function(a,b){if(0!=this.readyState)throw this.abort(),Error(\"Error reopening a connection\");this.B=a;this.A=b;this.readyState=1;Lc(this)};h.send=function(a){if(1!=this.readyState)throw this.abort(),Error(\"need to call open() first. \");this.g=!0;const b={headers:this.u,method:this.B,credentials:this.m,cache:void 0};a&&(b.body=a);(this.D||k).fetch(new Request(this.A,b)).then(this.Sa.bind(this),this.ga.bind(this))};\nh.abort=function(){this.response=this.responseText=\"\";this.u=new Headers;this.status=0;this.j&&this.j.cancel(\"Request was aborted.\").catch(()=>{});1<=this.readyState&&this.g&&4!=this.readyState&&(this.g=!1,Mc(this));this.readyState=0};\nh.Sa=function(a){if(this.g&&(this.l=a,this.h||(this.status=this.l.status,this.statusText=this.l.statusText,this.h=a.headers,this.readyState=2,Lc(this)),this.g&&(this.readyState=3,Lc(this),this.g)))if(\"arraybuffer\"===this.responseType)a.arrayBuffer().then(this.Qa.bind(this),this.ga.bind(this));else if(\"undefined\"!==typeof k.ReadableStream&&\"body\"in a){this.j=a.body.getReader();if(this.o){if(this.responseType)throw Error('responseType must be empty for \"streamBinaryChunks\" mode responses.');this.response=\n[]}else this.response=this.responseText=\"\",this.v=new TextDecoder;Nc(this)}else a.text().then(this.Ra.bind(this),this.ga.bind(this))};function Nc(a){a.j.read().then(a.Pa.bind(a)).catch(a.ga.bind(a))}h.Pa=function(a){if(this.g){if(this.o&&a.value)this.response.push(a.value);else if(!this.o){var b=a.value?a.value:new Uint8Array(0);if(b=this.v.decode(b,{stream:!a.done}))this.response=this.responseText+=b}a.done?Mc(this):Lc(this);3==this.readyState&&Nc(this)}};\nh.Ra=function(a){this.g&&(this.response=this.responseText=a,Mc(this))};h.Qa=function(a){this.g&&(this.response=a,Mc(this))};h.ga=function(){this.g&&Mc(this)};function Mc(a){a.readyState=4;a.l=null;a.j=null;a.v=null;Lc(a)}h.setRequestHeader=function(a,b){this.u.append(a,b)};h.getResponseHeader=function(a){return this.h?this.h.get(a.toLowerCase())||\"\":\"\"};\nh.getAllResponseHeaders=function(){if(!this.h)return\"\";const a=[],b=this.h.entries();for(var c=b.next();!c.done;)c=c.value,a.push(c[0]+\": \"+c[1]),c=b.next();return a.join(\"\\r\\n\")};function Lc(a){a.onreadystatechange&&a.onreadystatechange.call(a)}Object.defineProperty(Kc.prototype,\"withCredentials\",{get:function(){return\"include\"===this.m},set:function(a){this.m=a?\"include\":\"same-origin\"}});function Oc(a){let b=\"\";qa(a,function(c,d){b+=d;b+=\":\";b+=c;b+=\"\\r\\n\"});return b}function Pc(a,b,c){a:{for(d in c){var d=!1;break a}d=!0}d||(c=Oc(c),\"string\"===typeof a?(encodeURIComponent(String(b)),null!=c&&encodeURIComponent(String(c))):S(a,b,c))};function X(a){E.call(this);this.headers=new Map;this.o=a||null;this.h=!1;this.v=this.g=null;this.D=\"\";this.m=0;this.l=\"\";this.j=this.B=this.u=this.A=!1;this.I=null;this.H=\"\";this.J=!1}r(X,E);var Qc=/^https?$/i,Rc=[\"POST\",\"PUT\"];h=X.prototype;h.Ha=function(a){this.J=a};\nh.ea=function(a,b,c,d){if(this.g)throw Error(\"[goog.net.XhrIo] Object is active with another request=\"+this.D+\"; newUri=\"+a);b=b?b.toUpperCase():\"GET\";this.D=a;this.l=\"\";this.m=0;this.A=!1;this.h=!0;this.g=this.o?this.o.g():Cb.g();this.v=this.o?lb(this.o):lb(Cb);this.g.onreadystatechange=p(this.Ea,this);try{this.B=!0,this.g.open(b,String(a),!0),this.B=!1}catch(f){Sc(this,f);return}a=c||\"\";c=new Map(this.headers);if(d)if(Object.getPrototypeOf(d)===Object.prototype)for(var e in d)c.set(e,d[e]);else if(\"function\"===\ntypeof d.keys&&\"function\"===typeof d.get)for(const f of d.keys())c.set(f,d.get(f));else throw Error(\"Unknown input type for opt_headers: \"+String(d));d=Array.from(c.keys()).find(f=>\"content-type\"==f.toLowerCase());e=k.FormData&&a instanceof k.FormData;!(0<=Array.prototype.indexOf.call(Rc,b,void 0))||d||e||c.set(\"Content-Type\",\"application/x-www-form-urlencoded;charset=utf-8\");for(const [f,g]of c)this.g.setRequestHeader(f,g);this.H&&(this.g.responseType=this.H);\"withCredentials\"in this.g&&this.g.withCredentials!==\nthis.J&&(this.g.withCredentials=this.J);try{Tc(this),this.u=!0,this.g.send(a),this.u=!1}catch(f){Sc(this,f)}};function Sc(a,b){a.h=!1;a.g&&(a.j=!0,a.g.abort(),a.j=!1);a.l=b;a.m=5;Uc(a);Vc(a)}function Uc(a){a.A||(a.A=!0,F(a,\"complete\"),F(a,\"error\"))}h.abort=function(a){this.g&&this.h&&(this.h=!1,this.j=!0,this.g.abort(),this.j=!1,this.m=a||7,F(this,\"complete\"),F(this,\"abort\"),Vc(this))};h.N=function(){this.g&&(this.h&&(this.h=!1,this.j=!0,this.g.abort(),this.j=!1),Vc(this,!0));X.aa.N.call(this)};\nh.Ea=function(){this.s||(this.B||this.u||this.j?Wc(this):this.bb())};h.bb=function(){Wc(this)};\nfunction Wc(a){if(a.h&&\"undefined\"!=typeof fa&&(!a.v[1]||4!=P(a)||2!=a.Z()))if(a.u&&4==P(a))bb(a.Ea,0,a);else if(F(a,\"readystatechange\"),4==P(a)){a.h=!1;try{const g=a.Z();a:switch(g){case 200:case 201:case 202:case 204:case 206:case 304:case 1223:var b=!0;break a;default:b=!1}var c;if(!(c=b)){var d;if(d=0===g){var e=String(a.D).match(oc)[1]||null;!e&&k.self&&k.self.location&&(e=k.self.location.protocol.slice(0,-1));d=!Qc.test(e?e.toLowerCase():\"\")}c=d}if(c)F(a,\"complete\"),F(a,\"success\");else{a.m=\n6;try{var f=2<P(a)?a.g.statusText:\"\"}catch(m){f=\"\"}a.l=f+\" [\"+a.Z()+\"]\";Uc(a)}}finally{Vc(a)}}}function Vc(a,b){if(a.g){Tc(a);const c=a.g,d=a.v[0]?()=>{}:null;a.g=null;a.v=null;b||F(a,\"ready\");try{c.onreadystatechange=d}catch(e){}}}function Tc(a){a.I&&(k.clearTimeout(a.I),a.I=null)}h.isActive=function(){return!!this.g};function P(a){return a.g?a.g.readyState:0}h.Z=function(){try{return 2<P(this)?this.g.status:-1}catch(a){return-1}};h.oa=function(){try{return this.g?this.g.responseText:\"\"}catch(a){return\"\"}};\nh.Oa=function(a){if(this.g){var b=this.g.responseText;a&&0==b.indexOf(a)&&(b=b.substring(a.length));return ib(b)}};function Nb(a){try{if(!a.g)return null;if(\"response\"in a.g)return a.g.response;switch(a.H){case \"\":case \"text\":return a.g.responseText;case \"arraybuffer\":if(\"mozResponseArrayBuffer\"in a.g)return a.g.mozResponseArrayBuffer}return null}catch(b){return null}}\nfunction Vb(a){const b={};a=(a.g&&2<=P(a)?a.g.getAllResponseHeaders()||\"\":\"\").split(\"\\r\\n\");for(let d=0;d<a.length;d++){if(t(a[d]))continue;var c=va(a[d]);const e=c[0];c=c[1];if(\"string\"!==typeof c)continue;c=c.trim();const f=b[e]||[];b[e]=f;f.push(c)}ra(b,function(d){return d.join(\", \")})}h.Ba=function(){return this.m};h.Ka=function(){return\"string\"===typeof this.l?this.l:String(this.l)};function Xc(a,b,c){return c&&c.internalChannelParams?c.internalChannelParams[a]||b:b}\nfunction Yc(a){this.Aa=0;this.i=[];this.j=new vb;this.ia=this.qa=this.I=this.W=this.g=this.ya=this.D=this.H=this.m=this.S=this.o=null;this.Ya=this.U=0;this.Va=Xc(\"failFast\",!1,a);this.F=this.C=this.u=this.s=this.l=null;this.X=!0;this.za=this.T=-1;this.Y=this.v=this.B=0;this.Ta=Xc(\"baseRetryDelayMs\",5E3,a);this.cb=Xc(\"retryDelaySeedMs\",1E4,a);this.Wa=Xc(\"forwardChannelMaxRetries\",2,a);this.wa=Xc(\"forwardChannelRequestTimeoutMs\",2E4,a);this.pa=a&&a.xmlHttpFactory||void 0;this.Xa=a&&a.Tb||void 0;this.Ca=\na&&a.useFetchStreams||!1;this.L=void 0;this.J=a&&a.supportsCrossDomainXhr||!1;this.K=\"\";this.h=new ic(a&&a.concurrentRequestLimit);this.Da=new Hc;this.P=a&&a.fastHandshake||!1;this.O=a&&a.encodeInitMessageHeaders||!1;this.P&&this.O&&(this.O=!1);this.Ua=a&&a.Rb||!1;a&&a.xa&&this.j.xa();a&&a.forceLongPolling&&(this.X=!1);this.ba=!this.P&&this.X&&a&&a.detectBufferingProxy||!1;this.ja=void 0;a&&a.longPollingTimeout&&0<a.longPollingTimeout&&(this.ja=a.longPollingTimeout);this.ca=void 0;this.R=0;this.M=\n!1;this.ka=this.A=null}h=Yc.prototype;h.la=8;h.G=1;h.connect=function(a,b,c,d){K(0);this.W=a;this.H=b||{};c&&void 0!==d&&(this.H.OSID=c,this.H.OAID=d);this.F=this.X;this.I=cc(this,null,this.W);fc(this)};\nfunction gc(a){Zc(a);if(3==a.G){var b=a.U++,c=N(a.I);S(c,\"SID\",a.K);S(c,\"RID\",b);S(c,\"TYPE\",\"terminate\");$c(a,c);b=new M(a,a.j,b);b.L=2;b.v=Ib(N(c));c=!1;if(k.navigator&&k.navigator.sendBeacon)try{c=k.navigator.sendBeacon(b.v.toString(),\"\")}catch(d){}!c&&k.Image&&((new Image).src=b.v,c=!0);c||(b.g=Mb(b.j,null),b.g.ea(b.v));b.F=Date.now();Kb(b)}ad(a)}function Zb(a){a.g&&(Tb(a),a.g.cancel(),a.g=null)}\nfunction Zc(a){Zb(a);a.u&&(k.clearTimeout(a.u),a.u=null);Yb(a);a.h.cancel();a.s&&(\"number\"===typeof a.s&&k.clearTimeout(a.s),a.s=null)}function fc(a){if(!jc(a.h)&&!a.s){a.s=!0;var b=a.Ga;x||Ea();y||(x(),y=!0);za.add(b,a);a.B=0}}function bd(a,b){if(ac(a.h)>=a.h.j-(a.s?1:0))return!1;if(a.s)return a.i=b.D.concat(a.i),!0;if(1==a.G||2==a.G||a.B>=(a.Va?0:a.Wa))return!1;a.s=ub(p(a.Ga,a,b),cd(a,a.B));a.B++;return!0}\nh.Ga=function(a){if(this.s)if(this.s=null,1==this.G){if(!a){this.U=Math.floor(1E5*Math.random());a=this.U++;const e=new M(this,this.j,a);let f=this.o;this.S&&(f?(f=sa(f),ua(f,this.S)):f=this.S);null!==this.m||this.O||(e.H=f,f=null);if(this.P)a:{var b=0;for(var c=0;c<this.i.length;c++){b:{var d=this.i[c];if(\"__data__\"in d.map&&(d=d.map.__data__,\"string\"===typeof d)){d=d.length;break b}d=void 0}if(void 0===d)break;b+=d;if(4096<b){b=c;break a}if(4096===b||c===this.i.length-1){b=c+1;break a}}b=1E3}else b=\n1E3;b=dd(this,e,b);c=N(this.I);S(c,\"RID\",a);S(c,\"CVER\",22);this.D&&S(c,\"X-HTTP-Session-Id\",this.D);$c(this,c);f&&(this.O?b=\"headers=\"+encodeURIComponent(String(Oc(f)))+\"&\"+b:this.m&&Pc(c,this.m,f));bc(this.h,e);this.Ua&&S(c,\"TYPE\",\"init\");this.P?(S(c,\"$req\",b),S(c,\"SID\",\"null\"),e.T=!0,Hb(e,c,null)):Hb(e,c,b);this.G=2}}else 3==this.G&&(a?ed(this,a):0==this.i.length||jc(this.h)||ed(this))};\nfunction ed(a,b){var c;b?c=b.l:c=a.U++;const d=N(a.I);S(d,\"SID\",a.K);S(d,\"RID\",c);S(d,\"AID\",a.T);$c(a,d);a.m&&a.o&&Pc(d,a.m,a.o);c=new M(a,a.j,c,a.B+1);null===a.m&&(c.H=a.o);b&&(a.i=b.D.concat(a.i));b=dd(a,c,1E3);c.I=Math.round(.5*a.wa)+Math.round(.5*a.wa*Math.random());bc(a.h,c);Hb(c,d,b)}function $c(a,b){a.H&&qa(a.H,function(c,d){S(b,d,c)});a.l&&nc({},function(c,d){S(b,d,c)})}\nfunction dd(a,b,c){c=Math.min(a.i.length,c);var d=a.l?p(a.l.Na,a.l,a):null;a:{var e=a.i;let f=-1;for(;;){const g=[\"count=\"+c];-1==f?0<c?(f=e[0].g,g.push(\"ofs=\"+f)):f=0:g.push(\"ofs=\"+f);let m=!0;for(let q=0;q<c;q++){let l=e[q].g;const v=e[q].map;l-=f;if(0>l)f=Math.max(0,e[q].g-100),m=!1;else try{Ic(v,g,\"req\"+l+\"_\")}catch(w){d&&d(v)}}if(m){d=g.join(\"&\");break a}}}a=a.i.splice(0,c);b.D=a;return d}function ec(a){if(!a.g&&!a.u){a.Y=1;var b=a.Fa;x||Ea();y||(x(),y=!0);za.add(b,a);a.v=0}}\nfunction $b(a){if(a.g||a.u||3<=a.v)return!1;a.Y++;a.u=ub(p(a.Fa,a),cd(a,a.v));a.v++;return!0}h.Fa=function(){this.u=null;fd(this);if(this.ba&&!(this.M||null==this.g||0>=this.R)){var a=2*this.R;this.j.info(\"BP detection timer enabled: \"+a);this.A=ub(p(this.ab,this),a)}};h.ab=function(){this.A&&(this.A=null,this.j.info(\"BP detection timeout reached.\"),this.j.info(\"Buffering proxy detected and switch to long-polling!\"),this.F=!1,this.M=!0,K(10),Zb(this),fd(this))};\nfunction Tb(a){null!=a.A&&(k.clearTimeout(a.A),a.A=null)}function fd(a){a.g=new M(a,a.j,\"rpc\",a.Y);null===a.m&&(a.g.H=a.o);a.g.O=0;var b=N(a.qa);S(b,\"RID\",\"rpc\");S(b,\"SID\",a.K);S(b,\"AID\",a.T);S(b,\"CI\",a.F?\"0\":\"1\");!a.F&&a.ja&&S(b,\"TO\",a.ja);S(b,\"TYPE\",\"xmlhttp\");$c(a,b);a.m&&a.o&&Pc(b,a.m,a.o);a.L&&(a.g.I=a.L);var c=a.g;a=a.ia;c.L=1;c.v=Ib(N(b));c.m=null;c.P=!0;Jb(c,a)}h.Za=function(){null!=this.C&&(this.C=null,Zb(this),$b(this),K(19))};function Yb(a){null!=a.C&&(k.clearTimeout(a.C),a.C=null)}\nfunction Ub(a,b){var c=null;if(a.g==b){Yb(a);Tb(a);a.g=null;var d=2}else if(Xb(a.h,b))c=b.D,dc(a.h,b),d=1;else return;if(0!=a.G)if(b.o)if(1==d){c=b.m?b.m.length:0;b=Date.now()-b.F;var e=a.B;d=qb();F(d,new tb(d,c,b,e));fc(a)}else ec(a);else if(e=b.s,3==e||0==e&&0<b.X||!(1==d&&bd(a,b)||2==d&&$b(a)))switch(c&&0<c.length&&(b=a.h,b.i=b.i.concat(c)),e){case 1:R(a,5);break;case 4:R(a,10);break;case 3:R(a,6);break;default:R(a,2)}}\nfunction cd(a,b){let c=a.Ta+Math.floor(Math.random()*a.cb);a.isActive()||(c*=2);return c*b}function R(a,b){a.j.info(\"Error code \"+b);if(2==b){var c=p(a.fb,a),d=a.Xa;const e=!d;d=new T(d||\"//www.google.com/images/cleardot.gif\");k.location&&\"http\"==k.location.protocol||qc(d,\"https\");Ib(d);e?Fc(d.toString(),c):Gc(d.toString(),c)}else K(2);a.G=0;a.l&&a.l.sa(b);ad(a);Zc(a)}h.fb=function(a){a?(this.j.info(\"Successfully pinged google.com\"),K(2)):(this.j.info(\"Failed to ping google.com\"),K(1))};\nfunction ad(a){a.G=0;a.ka=[];if(a.l){const b=kc(a.h);if(0!=b.length||0!=a.i.length)ma(a.ka,b),ma(a.ka,a.i),a.h.i.length=0,la(a.i),a.i.length=0;a.l.ra()}}function cc(a,b,c){var d=c instanceof T?N(c):new T(c);if(\"\"!=d.g)b&&(d.g=b+\".\"+d.g),rc(d,d.s);else{var e=k.location;d=e.protocol;b=b?b+\".\"+e.hostname:e.hostname;e=+e.port;var f=new T(null);d&&qc(f,d);b&&(f.g=b);e&&rc(f,e);c&&(f.l=c);d=f}c=a.D;b=a.ya;c&&b&&S(d,c,b);S(d,\"VER\",a.la);$c(a,d);return d}\nfunction Mb(a,b,c){if(b&&!a.J)throw Error(\"Can't create secondary domain capable XhrIo object.\");b=a.Ca&&!a.pa?new X(new Jc({eb:c})):new X(a.pa);b.Ha(a.J);return b}h.isActive=function(){return!!this.l&&this.l.isActive(this)};function gd(){}h=gd.prototype;h.ua=function(){};h.ta=function(){};h.sa=function(){};h.ra=function(){};h.isActive=function(){return!0};h.Na=function(){};function hd(){}hd.prototype.g=function(a,b){return new Y(a,b)};\nfunction Y(a,b){E.call(this);this.g=new Yc(b);this.l=a;this.h=b&&b.messageUrlParams||null;a=b&&b.messageHeaders||null;b&&b.clientProtocolHeaderRequired&&(a?a[\"X-Client-Protocol\"]=\"webchannel\":a={\"X-Client-Protocol\":\"webchannel\"});this.g.o=a;a=b&&b.initMessageHeaders||null;b&&b.messageContentType&&(a?a[\"X-WebChannel-Content-Type\"]=b.messageContentType:a={\"X-WebChannel-Content-Type\":b.messageContentType});b&&b.va&&(a?a[\"X-WebChannel-Client-Profile\"]=b.va:a={\"X-WebChannel-Client-Profile\":b.va});this.g.S=\na;(a=b&&b.Sb)&&!t(a)&&(this.g.m=a);this.v=b&&b.supportsCrossDomainXhr||!1;this.u=b&&b.sendRawJson||!1;(b=b&&b.httpSessionIdParam)&&!t(b)&&(this.g.D=b,a=this.h,null!==a&&b in a&&(a=this.h,b in a&&delete a[b]));this.j=new Z(this)}r(Y,E);Y.prototype.m=function(){this.g.l=this.j;this.v&&(this.g.J=!0);this.g.connect(this.l,this.h||void 0)};Y.prototype.close=function(){gc(this.g)};\nY.prototype.o=function(a){var b=this.g;if(\"string\"===typeof a){var c={};c.__data__=a;a=c}else this.u&&(c={},c.__data__=hb(a),a=c);b.i.push(new hc(b.Ya++,a));3==b.G&&fc(b)};Y.prototype.N=function(){this.g.l=null;delete this.j;gc(this.g);delete this.g;Y.aa.N.call(this)};\nfunction id(a){nb.call(this);a.__headers__&&(this.headers=a.__headers__,this.statusCode=a.__status__,delete a.__headers__,delete a.__status__);var b=a.__sm__;if(b){a:{for(const c in b){a=c;break a}a=void 0}if(this.i=a)a=this.i,b=null!==b&&a in b?b[a]:void 0;this.data=b}else this.data=a}r(id,nb);function jd(){ob.call(this);this.status=1}r(jd,ob);function Z(a){this.g=a}r(Z,gd);Z.prototype.ua=function(){F(this.g,\"a\")};Z.prototype.ta=function(a){F(this.g,new id(a))};\nZ.prototype.sa=function(a){F(this.g,new jd(a))};Z.prototype.ra=function(){F(this.g,\"b\")};hd.prototype.createWebChannel=hd.prototype.g;Y.prototype.send=Y.prototype.o;Y.prototype.open=Y.prototype.m;Y.prototype.close=Y.prototype.close;module.exports.createWebChannelTransport=function(){return new hd};module.exports.getStatEventTarget=function(){return qb()};module.exports.Event=I;module.exports.Stat={mb:0,pb:1,qb:2,Jb:3,Ob:4,Lb:5,Mb:6,Kb:7,Ib:8,Nb:9,PROXY:10,NOPROXY:11,Gb:12,Cb:13,Db:14,Bb:15,Eb:16,Fb:17,ib:18,hb:19,jb:20};Ab.NO_ERROR=0;Ab.TIMEOUT=8;Ab.HTTP_ERROR=6;\nmodule.exports.ErrorCode=Ab;Bb.COMPLETE=\"complete\";module.exports.EventType=Bb;mb.EventType=H;H.OPEN=\"a\";H.CLOSE=\"b\";H.ERROR=\"c\";H.MESSAGE=\"d\";E.prototype.listen=E.prototype.K;module.exports.WebChannel=mb;module.exports.FetchXmlHttpFactory=Jc;X.prototype.listenOnce=X.prototype.L;X.prototype.getLastError=X.prototype.Ka;X.prototype.getLastErrorCode=X.prototype.Ba;X.prototype.getStatus=X.prototype.Z;X.prototype.getResponseJson=X.prototype.Oa;X.prototype.getResponseText=X.prototype.oa;\nX.prototype.send=X.prototype.ea;X.prototype.setWithCredentials=X.prototype.Ha;module.exports.XhrIo=X;}).apply( typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self  : typeof window !== 'undefined' ? window  : {});\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 * Simple wrapper around a nullable UID. Mostly exists to make code more\n * readable.\n */\nexport class User {\n  /** A user with a null UID. */\n  static readonly UNAUTHENTICATED = new User(null);\n\n  // TODO(mikelehen): Look into getting a proper uid-equivalent for\n  // non-FirebaseAuth providers.\n  static readonly GOOGLE_CREDENTIALS = new User('google-credentials-uid');\n  static readonly FIRST_PARTY = new User('first-party-uid');\n  static readonly MOCK_USER = new User('mock-user');\n\n  constructor(readonly uid: string | null) {}\n\n  isAuthenticated(): boolean {\n    return this.uid != null;\n  }\n\n  /**\n   * Returns a key representing this user, suitable for inclusion in a\n   * dictionary.\n   */\n  toKey(): string {\n    if (this.isAuthenticated()) {\n      return 'uid:' + this.uid;\n    } else {\n      return 'anonymous-user';\n    }\n  }\n\n  isEqual(otherUser: User): boolean {\n    return otherUser.uid === this.uid;\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 semver (www.semver.org) version of the SDK. */\nimport { version } from '../../../firebase/package.json';\nexport let SDK_VERSION = version;\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 { Logger, LogLevel, LogLevelString } from '@firebase/logger';\n\nimport { SDK_VERSION } from '../core/version';\nimport { formatJSON } from '../platform/format_json';\n\nexport { LogLevel, LogLevelString };\n\nconst logClient = new Logger('@firebase/firestore');\n\n// Helper methods are needed because variables can't be exported as read/write\nexport function getLogLevel(): LogLevel {\n  return logClient.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 */\nexport function setLogLevel(logLevel: LogLevelString): void {\n  logClient.setLogLevel(logLevel);\n}\n\nexport function logDebug(msg: string, ...obj: unknown[]): void {\n  if (logClient.logLevel <= LogLevel.DEBUG) {\n    const args = obj.map(argToString);\n    logClient.debug(`Firestore (${SDK_VERSION}): ${msg}`, ...args);\n  }\n}\n\nexport function logError(msg: string, ...obj: unknown[]): void {\n  if (logClient.logLevel <= LogLevel.ERROR) {\n    const args = obj.map(argToString);\n    logClient.error(`Firestore (${SDK_VERSION}): ${msg}`, ...args);\n  }\n}\n\n/**\n * @internal\n */\nexport function logWarn(msg: string, ...obj: unknown[]): void {\n  if (logClient.logLevel <= LogLevel.WARN) {\n    const args = obj.map(argToString);\n    logClient.warn(`Firestore (${SDK_VERSION}): ${msg}`, ...args);\n  }\n}\n\n/**\n * Converts an additional log parameter to a string representation.\n */\nfunction argToString(obj: unknown): string | unknown {\n  if (typeof obj === 'string') {\n    return obj;\n  } else {\n    try {\n      return formatJSON(obj);\n    } catch (e) {\n      // Converting to JSON failed, just log the object directly\n      return obj;\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/** Formats an object as a JSON string, suitable for logging. */\nexport function formatJSON(value: unknown): string {\n  return JSON.stringify(value);\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 { SDK_VERSION } from '../core/version';\n\nimport { logError } from './log';\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 */\nexport function fail(failure: string = 'Unexpected state'): never {\n  // Log the failure in addition to throw an exception, just in case the\n  // exception is swallowed.\n  const message =\n    `FIRESTORE (${SDK_VERSION}) INTERNAL ASSERTION FAILED: ` + failure;\n  logError(message);\n\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 new Error(message);\n}\n\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 */\nexport function hardAssert(\n  assertion: boolean,\n  message?: string\n): asserts assertion {\n  if (!assertion) {\n    fail(message);\n  }\n}\n\n/**\n * Fails if the given assertion condition is false, throwing an Error with the\n * given message if it did.\n *\n * The code of callsites invoking this function are stripped out in production\n * builds. Any side-effects of code within the debugAssert() invocation will not\n * happen in this case.\n *\n * @internal\n */\nexport function debugAssert(\n  assertion: boolean,\n  message: string\n): asserts assertion {\n  if (!assertion) {\n    fail(message);\n  }\n}\n\n/**\n * Casts `obj` to `T`. In non-production builds, verifies that `obj` is an\n * instance of `T` before casting.\n */\nexport function debugCast<T>(\n  obj: object,\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  constructor: { new (...args: any[]): T }\n): T | never {\n  debugAssert(\n    obj instanceof constructor,\n    `Expected type '${constructor.name}', but was '${obj.constructor.name}'`\n  );\n  return obj 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 { FirebaseError } from '@firebase/util';\n\n/**\n * The set of Firestore status codes. The codes are the same at the ones\n * exposed by gRPC here:\n * https://github.com/grpc/grpc/blob/master/doc/statuscodes.md\n *\n * Possible values:\n * - 'cancelled': The operation was cancelled (typically by the caller).\n * - 'unknown': Unknown error or an error from a different error domain.\n * - 'invalid-argument': Client specified an invalid argument. Note that this\n *   differs from 'failed-precondition'. 'invalid-argument' indicates\n *   arguments that are problematic regardless of the state of the system\n *   (e.g. an invalid field name).\n * - 'deadline-exceeded': Deadline expired before operation could complete.\n *   For operations that change the state of the system, this error may be\n *   returned even if the operation has completed successfully. For example,\n *   a successful response from a server could have been delayed long enough\n *   for the deadline to expire.\n * - 'not-found': Some requested document was not found.\n * - 'already-exists': Some document that we attempted to create already\n *   exists.\n * - 'permission-denied': The caller does not have permission to execute the\n *   specified operation.\n * - 'resource-exhausted': Some resource has been exhausted, perhaps a\n *   per-user quota, or perhaps the entire file system is out of space.\n * - 'failed-precondition': Operation was rejected because the system is not\n *   in a state required for the operation's execution.\n * - 'aborted': The operation was aborted, typically due to a concurrency\n *   issue like transaction aborts, etc.\n * - 'out-of-range': Operation was attempted past the valid range.\n * - 'unimplemented': Operation is not implemented or not supported/enabled.\n * - 'internal': Internal errors. Means some invariants expected by\n *   underlying system has been broken. If you see one of these errors,\n *   something is very broken.\n * - 'unavailable': The service is currently unavailable. This is most likely\n *   a transient condition and may be corrected by retrying with a backoff.\n * - 'data-loss': Unrecoverable data loss or corruption.\n * - 'unauthenticated': The request does not have valid authentication\n *   credentials for the operation.\n */\nexport type FirestoreErrorCode =\n  | 'cancelled'\n  | 'unknown'\n  | 'invalid-argument'\n  | 'deadline-exceeded'\n  | 'not-found'\n  | 'already-exists'\n  | 'permission-denied'\n  | 'resource-exhausted'\n  | 'failed-precondition'\n  | 'aborted'\n  | 'out-of-range'\n  | 'unimplemented'\n  | 'internal'\n  | 'unavailable'\n  | 'data-loss'\n  | 'unauthenticated';\n\n/**\n * Error Codes describing the different ways Firestore can fail. These come\n * directly from GRPC.\n */\nexport type Code = FirestoreErrorCode;\n\nexport const Code = {\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' as FirestoreErrorCode,\n\n  /** The operation was cancelled (typically by the caller). */\n  CANCELLED: 'cancelled' as FirestoreErrorCode,\n\n  /** Unknown error or an error from a different error domain. */\n  UNKNOWN: 'unknown' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\n  /** Some requested entity (e.g., file or directory) was not found. */\n  NOT_FOUND: 'not-found' as FirestoreErrorCode,\n\n  /**\n   * Some entity that we attempted to create (e.g., file or directory) already\n   * exists.\n   */\n  ALREADY_EXISTS: 'already-exists' as FirestoreErrorCode,\n\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 cannot be identified\n   * (use UNAUTHENTICATED instead for those errors).\n   */\n  PERMISSION_DENIED: 'permission-denied' as FirestoreErrorCode,\n\n  /**\n   * The request does not have valid authentication credentials for the\n   * operation.\n   */\n  UNAUTHENTICATED: 'unauthenticated' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\n  /** Operation is not implemented or not supported/enabled in this service. */\n  UNIMPLEMENTED: 'unimplemented' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\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' as FirestoreErrorCode,\n\n  /** Unrecoverable data loss or corruption. */\n  DATA_LOSS: 'data-loss' as FirestoreErrorCode\n};\n\n/** An error returned by a Firestore operation. */\nexport class FirestoreError extends FirebaseError {\n  /** The stack of the error. */\n  readonly stack?: string;\n\n  /** @hideconstructor */\n  constructor(\n    /**\n     * The backend error code associated with this error.\n     */\n    readonly code: FirestoreErrorCode,\n    /**\n     * A custom error description.\n     */\n    readonly message: string\n  ) {\n    super(code, message);\n\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    this.toString = () => `${this.name}: [code=${this.code}]: ${this.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\nexport interface Resolver<R> {\n  (value: R | Promise<R>): void;\n}\n\nexport interface Rejecter {\n  (reason?: Error): void;\n}\n\nexport class Deferred<R = void> {\n  promise: Promise<R>;\n  // Assigned synchronously in constructor by Promise constructor callback.\n  resolve!: Resolver<R>;\n  reject!: Rejecter;\n\n  constructor() {\n    this.promise = new Promise((resolve: Resolver<R>, reject: Rejecter) => {\n      this.resolve = resolve;\n      this.reject = reject;\n    });\n  }\n}\n\n/**\n * Takes an array of values and a function from a value to a Promise. The function is run on each\n * value sequentially, waiting for the previous promise to resolve before starting the next one.\n * The returned promise resolves once the function has been run on all values.\n */\nexport function sequence<T>(\n  values: T[],\n  fn: (value: T) => Promise<void>\n): Promise<void> {\n  let p = Promise.resolve();\n  for (const value of values) {\n    p = p.then(() => fn(value));\n  }\n  return p;\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  AppCheckInternalComponentName,\n  AppCheckTokenListener,\n  AppCheckTokenResult,\n  FirebaseAppCheckInternal\n} from '@firebase/app-check-interop-types';\nimport {\n  FirebaseAuthInternal,\n  FirebaseAuthInternalName\n} from '@firebase/auth-interop-types';\nimport { Provider } from '@firebase/component';\n\nimport { User } from '../auth/user';\nimport { debugAssert, hardAssert } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug } from '../util/log';\nimport { Deferred } from '../util/promise';\n\n// TODO(mikelehen): This should be split into multiple files and probably\n// moved to an auth/ folder to match other platforms.\n\n/**\n * @internal\n */\nexport type AuthTokenFactory = () => string;\n\n/**\n * @internal\n */\nexport interface FirstPartyCredentialsSettings {\n  // These are external types. Prevent minification.\n  ['type']: 'firstParty';\n  ['sessionIndex']: string;\n  ['iamToken']: string | null;\n  ['authTokenFactory']: AuthTokenFactory | null;\n}\n\nexport interface ProviderCredentialsSettings {\n  // These are external types. Prevent minification.\n  ['type']: 'provider';\n  ['client']: CredentialsProvider<User>;\n}\n\n/** Settings for private credentials */\nexport type CredentialsSettings =\n  | FirstPartyCredentialsSettings\n  | ProviderCredentialsSettings;\n\nexport type TokenType = 'OAuth' | 'FirstParty' | 'AppCheck';\nexport interface Token {\n  /** Type of token. */\n  type: TokenType;\n\n  /**\n   * The user with which the token is associated (used for persisting user\n   * state on disk, etc.).\n   * This will be null for Tokens of the type 'AppCheck'.\n   */\n  user?: User;\n\n  /** Header values to set for this token */\n  headers: Map<string, string>;\n}\n\nexport class OAuthToken implements Token {\n  type = 'OAuth' as TokenType;\n  headers = new Map();\n\n  constructor(value: string, public user: User) {\n    this.headers.set('Authorization', `Bearer ${value}`);\n  }\n}\n\n/**\n * A Listener for credential change events. The listener should fetch a new\n * token and may need to invalidate other state if the current user has also\n * changed.\n */\nexport type CredentialChangeListener<T> = (credential: T) => Promise<void>;\n\n/**\n * Provides methods for getting the uid and token for the current user and\n * listening for changes.\n */\nexport interface CredentialsProvider<T> {\n  /**\n   * Starts the credentials provider and specifies a listener to be notified of\n   * credential changes (sign-in / sign-out, token changes). It is immediately\n   * called once with the initial user.\n   *\n   * The change listener is invoked on the provided AsyncQueue.\n   */\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<T>\n  ): void;\n\n  /** Requests a token for the current user. */\n  getToken(): Promise<Token | null>;\n\n  /**\n   * Marks the last retrieved token as invalid, making the next GetToken request\n   * force-refresh the token.\n   */\n  invalidateToken(): void;\n\n  shutdown(): void;\n}\n\n/**\n * A CredentialsProvider that always yields an empty token.\n * @internal\n */\nexport class EmptyAuthCredentialsProvider implements CredentialsProvider<User> {\n  getToken(): Promise<Token | null> {\n    return Promise.resolve<Token | null>(null);\n  }\n\n  invalidateToken(): void {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<User>\n  ): void {\n    // Fire with initial user.\n    asyncQueue.enqueueRetryable(() => changeListener(User.UNAUTHENTICATED));\n  }\n\n  shutdown(): void {}\n}\n\n/**\n * A CredentialsProvider that always returns a constant token. Used for\n * emulator token mocking.\n */\nexport class EmulatorAuthCredentialsProvider\n  implements CredentialsProvider<User>\n{\n  constructor(private token: Token) {}\n\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  private changeListener: CredentialChangeListener<User> | null = null;\n\n  getToken(): Promise<Token | null> {\n    return Promise.resolve(this.token);\n  }\n\n  invalidateToken(): void {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<User>\n  ): void {\n    debugAssert(\n      !this.changeListener,\n      'Can only call setChangeListener() once.'\n    );\n    this.changeListener = changeListener;\n    // Fire with initial user.\n    asyncQueue.enqueueRetryable(() => changeListener(this.token.user!));\n  }\n\n  shutdown(): void {\n    this.changeListener = null;\n  }\n}\n\n/** Credential provider for the Lite SDK. */\nexport class LiteAuthCredentialsProvider implements CredentialsProvider<User> {\n  private auth: FirebaseAuthInternal | null = null;\n\n  constructor(authProvider: Provider<FirebaseAuthInternalName>) {\n    authProvider.onInit(auth => {\n      this.auth = auth;\n    });\n  }\n\n  getToken(): Promise<Token | null> {\n    if (!this.auth) {\n      return Promise.resolve(null);\n    }\n\n    return this.auth.getToken().then(tokenData => {\n      if (tokenData) {\n        hardAssert(\n          typeof tokenData.accessToken === 'string',\n          'Invalid tokenData returned from getToken():' + tokenData\n        );\n        return new OAuthToken(\n          tokenData.accessToken,\n          new User(this.auth!.getUid())\n        );\n      } else {\n        return null;\n      }\n    });\n  }\n\n  invalidateToken(): void {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<User>\n  ): void {}\n\n  shutdown(): void {}\n}\n\nexport class FirebaseAuthCredentialsProvider\n  implements CredentialsProvider<User>\n{\n  /**\n   * The auth token listener registered with FirebaseApp, retained here so we\n   * can unregister it.\n   */\n  private tokenListener: (() => void) | undefined;\n\n  /** Tracks the current User. */\n  private currentUser: User = User.UNAUTHENTICATED;\n\n  /**\n   * Counter used to detect if the token changed while a getToken request was\n   * outstanding.\n   */\n  private tokenCounter = 0;\n\n  private forceRefresh = false;\n\n  private auth: FirebaseAuthInternal | null = null;\n\n  constructor(private authProvider: Provider<FirebaseAuthInternalName>) {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<User>\n  ): void {\n    hardAssert(\n      this.tokenListener === undefined,\n      'Token listener already added'\n    );\n    let lastTokenId = this.tokenCounter;\n\n    // A change listener that prevents double-firing for the same token change.\n    const guardedChangeListener: (user: User) => Promise<void> = user => {\n      if (this.tokenCounter !== lastTokenId) {\n        lastTokenId = this.tokenCounter;\n        return changeListener(user);\n      } else {\n        return Promise.resolve();\n      }\n    };\n\n    // A promise that can be waited on to block on the next token change.\n    // This promise is re-created after each change.\n    let nextToken = new Deferred<void>();\n\n    this.tokenListener = () => {\n      this.tokenCounter++;\n      this.currentUser = this.getUser();\n      nextToken.resolve();\n      nextToken = new Deferred<void>();\n      asyncQueue.enqueueRetryable(() =>\n        guardedChangeListener(this.currentUser)\n      );\n    };\n\n    const awaitNextToken: () => void = () => {\n      const currentTokenAttempt = nextToken;\n      asyncQueue.enqueueRetryable(async () => {\n        await currentTokenAttempt.promise;\n        await guardedChangeListener(this.currentUser);\n      });\n    };\n\n    const registerAuth = (auth: FirebaseAuthInternal): void => {\n      logDebug('FirebaseAuthCredentialsProvider', 'Auth detected');\n      this.auth = auth;\n      if (this.tokenListener) {\n        this.auth.addAuthTokenListener(this.tokenListener);\n        awaitNextToken();\n      }\n    };\n\n    this.authProvider.onInit(auth => registerAuth(auth));\n\n    // Our users can initialize Auth right after Firestore, so we give it\n    // a chance to register itself with the component framework before we\n    // determine whether to start up in unauthenticated mode.\n    setTimeout(() => {\n      if (!this.auth) {\n        const auth = this.authProvider.getImmediate({ optional: true });\n        if (auth) {\n          registerAuth(auth);\n        } else {\n          // If auth is still not available, proceed with `null` user\n          logDebug('FirebaseAuthCredentialsProvider', 'Auth not yet detected');\n          nextToken.resolve();\n          nextToken = new Deferred<void>();\n        }\n      }\n    }, 0);\n\n    awaitNextToken();\n  }\n\n  getToken(): Promise<Token | null> {\n    debugAssert(\n      this.tokenListener != null,\n      'FirebaseAuthCredentialsProvider not started.'\n    );\n\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    const initialTokenCounter = this.tokenCounter;\n    const forceRefresh = this.forceRefresh;\n    this.forceRefresh = false;\n\n    if (!this.auth) {\n      return Promise.resolve(null);\n    }\n\n    return this.auth.getToken(forceRefresh).then(tokenData => {\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      if (this.tokenCounter !== initialTokenCounter) {\n        logDebug(\n          'FirebaseAuthCredentialsProvider',\n          'getToken aborted due to token change.'\n        );\n        return this.getToken();\n      } else {\n        if (tokenData) {\n          hardAssert(\n            typeof tokenData.accessToken === 'string',\n            'Invalid tokenData returned from getToken():' + tokenData\n          );\n          return new OAuthToken(tokenData.accessToken, this.currentUser);\n        } else {\n          return null;\n        }\n      }\n    });\n  }\n\n  invalidateToken(): void {\n    this.forceRefresh = true;\n  }\n\n  shutdown(): void {\n    if (this.auth && this.tokenListener) {\n      this.auth.removeAuthTokenListener(this.tokenListener);\n    }\n    this.tokenListener = undefined;\n  }\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  private getUser(): User {\n    const currentUid = this.auth && this.auth.getUid();\n    hardAssert(\n      currentUid === null || typeof currentUid === 'string',\n      'Received invalid UID: ' + currentUid\n    );\n    return new User(currentUid);\n  }\n}\n\n/*\n * FirstPartyToken provides a fresh token each time its value\n * is requested, because if the token is too old, requests will be rejected.\n * Technically this may no longer be necessary since the SDK should gracefully\n * recover from unauthenticated errors (see b/33147818 for context), but it's\n * safer to keep the implementation as-is.\n */\nexport class FirstPartyToken implements Token {\n  type = 'FirstParty' as TokenType;\n  user = User.FIRST_PARTY;\n  private _headers = new Map();\n\n  constructor(\n    private readonly sessionIndex: string,\n    private readonly iamToken: string | null,\n    private readonly authTokenFactory: AuthTokenFactory | null\n  ) {}\n\n  /**\n   * Gets an authorization token, using a provided factory function, or return\n   * null.\n   */\n  private getAuthToken(): string | null {\n    if (this.authTokenFactory) {\n      return this.authTokenFactory();\n    } else {\n      return null;\n    }\n  }\n\n  get headers(): Map<string, string> {\n    this._headers.set('X-Goog-AuthUser', this.sessionIndex);\n    // Use array notation to prevent minification\n    const authHeaderTokenValue = this.getAuthToken();\n    if (authHeaderTokenValue) {\n      this._headers.set('Authorization', authHeaderTokenValue);\n    }\n    if (this.iamToken) {\n      this._headers.set('X-Goog-Iam-Authorization-Token', this.iamToken);\n    }\n\n    return this._headers;\n  }\n}\n\n/*\n * Provides user credentials required for the Firestore JavaScript SDK\n * to authenticate the user, using technique that is only available\n * to applications hosted by Google.\n */\nexport class FirstPartyAuthCredentialsProvider\n  implements CredentialsProvider<User>\n{\n  constructor(\n    private sessionIndex: string,\n    private iamToken: string | null,\n    private authTokenFactory: AuthTokenFactory | null\n  ) {}\n\n  getToken(): Promise<Token | null> {\n    return Promise.resolve(\n      new FirstPartyToken(\n        this.sessionIndex,\n        this.iamToken,\n        this.authTokenFactory\n      )\n    );\n  }\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<User>\n  ): void {\n    // Fire with initial uid.\n    asyncQueue.enqueueRetryable(() => changeListener(User.FIRST_PARTY));\n  }\n\n  shutdown(): void {}\n\n  invalidateToken(): void {}\n}\n\nexport class AppCheckToken implements Token {\n  type = 'AppCheck' as TokenType;\n  headers = new Map();\n\n  constructor(private value: string) {\n    if (value && value.length > 0) {\n      this.headers.set('x-firebase-appcheck', this.value);\n    }\n  }\n}\n\nexport class FirebaseAppCheckTokenProvider\n  implements CredentialsProvider<string>\n{\n  /**\n   * The AppCheck token listener registered with FirebaseApp, retained here so\n   * we can unregister it.\n   */\n  private tokenListener: AppCheckTokenListener | undefined;\n  private forceRefresh = false;\n  private appCheck: FirebaseAppCheckInternal | null = null;\n  private latestAppCheckToken: string | null = null;\n\n  constructor(\n    private appCheckProvider: Provider<AppCheckInternalComponentName>\n  ) {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<string>\n  ): void {\n    hardAssert(\n      this.tokenListener === undefined,\n      'Token listener already added'\n    );\n\n    const onTokenChanged: (\n      tokenResult: AppCheckTokenResult\n    ) => Promise<void> = tokenResult => {\n      if (tokenResult.error != null) {\n        logDebug(\n          'FirebaseAppCheckTokenProvider',\n          `Error getting App Check token; using placeholder token instead. Error: ${tokenResult.error.message}`\n        );\n      }\n      const tokenUpdated = tokenResult.token !== this.latestAppCheckToken;\n      this.latestAppCheckToken = tokenResult.token;\n      logDebug(\n        'FirebaseAppCheckTokenProvider',\n        `Received ${tokenUpdated ? 'new' : 'existing'} token.`\n      );\n      return tokenUpdated\n        ? changeListener(tokenResult.token)\n        : Promise.resolve();\n    };\n\n    this.tokenListener = (tokenResult: AppCheckTokenResult) => {\n      asyncQueue.enqueueRetryable(() => onTokenChanged(tokenResult));\n    };\n\n    const registerAppCheck = (appCheck: FirebaseAppCheckInternal): void => {\n      logDebug('FirebaseAppCheckTokenProvider', 'AppCheck detected');\n      this.appCheck = appCheck;\n      if (this.tokenListener) {\n        this.appCheck.addTokenListener(this.tokenListener);\n      }\n    };\n\n    this.appCheckProvider.onInit(appCheck => registerAppCheck(appCheck));\n\n    // Our users can initialize AppCheck after Firestore, so we give it\n    // a chance to register itself with the component framework.\n    setTimeout(() => {\n      if (!this.appCheck) {\n        const appCheck = this.appCheckProvider.getImmediate({ optional: true });\n        if (appCheck) {\n          registerAppCheck(appCheck);\n        } else {\n          // If AppCheck is still not available, proceed without it.\n          logDebug(\n            'FirebaseAppCheckTokenProvider',\n            'AppCheck not yet detected'\n          );\n        }\n      }\n    }, 0);\n  }\n\n  getToken(): Promise<Token | null> {\n    debugAssert(\n      this.tokenListener != null,\n      'FirebaseAppCheckTokenProvider not started.'\n    );\n\n    const forceRefresh = this.forceRefresh;\n    this.forceRefresh = false;\n\n    if (!this.appCheck) {\n      return Promise.resolve(null);\n    }\n\n    return this.appCheck.getToken(forceRefresh).then(tokenResult => {\n      if (tokenResult) {\n        hardAssert(\n          typeof tokenResult.token === 'string',\n          'Invalid tokenResult returned from getToken():' + tokenResult\n        );\n        this.latestAppCheckToken = tokenResult.token;\n        return new AppCheckToken(tokenResult.token);\n      } else {\n        return null;\n      }\n    });\n  }\n\n  invalidateToken(): void {\n    this.forceRefresh = true;\n  }\n\n  shutdown(): void {\n    if (this.appCheck && this.tokenListener) {\n      this.appCheck.removeTokenListener(this.tokenListener);\n    }\n    this.tokenListener = undefined;\n  }\n}\n\n/**\n * An AppCheck token provider that always yields an empty token.\n * @internal\n */\nexport class EmptyAppCheckTokenProvider implements CredentialsProvider<string> {\n  getToken(): Promise<Token | null> {\n    return Promise.resolve<Token | null>(new AppCheckToken(''));\n  }\n\n  invalidateToken(): void {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<string>\n  ): void {}\n\n  shutdown(): void {}\n}\n\n/** AppCheck token provider for the Lite SDK. */\nexport class LiteAppCheckTokenProvider implements CredentialsProvider<string> {\n  private appCheck: FirebaseAppCheckInternal | null = null;\n\n  constructor(\n    private appCheckProvider: Provider<AppCheckInternalComponentName>\n  ) {\n    appCheckProvider.onInit(appCheck => {\n      this.appCheck = appCheck;\n    });\n  }\n\n  getToken(): Promise<Token | null> {\n    if (!this.appCheck) {\n      return Promise.resolve(null);\n    }\n\n    return this.appCheck.getToken().then(tokenResult => {\n      if (tokenResult) {\n        hardAssert(\n          typeof tokenResult.token === 'string',\n          'Invalid tokenResult returned from getToken():' + tokenResult\n        );\n        return new AppCheckToken(tokenResult.token);\n      } else {\n        return null;\n      }\n    });\n  }\n\n  invalidateToken(): void {}\n\n  start(\n    asyncQueue: AsyncQueue,\n    changeListener: CredentialChangeListener<string>\n  ): void {}\n\n  shutdown(): void {}\n}\n\n/**\n * Builds a CredentialsProvider depending on the type of\n * the credentials passed in.\n */\nexport function makeAuthCredentialsProvider(\n  credentials?: CredentialsSettings\n): CredentialsProvider<User> {\n  if (!credentials) {\n    return new EmptyAuthCredentialsProvider();\n  }\n  switch (credentials['type']) {\n    case 'firstParty':\n      return new FirstPartyAuthCredentialsProvider(\n        credentials['sessionIndex'] || '0',\n        credentials['iamToken'] || null,\n        credentials['authTokenFactory'] || null\n      );\n\n    case 'provider':\n      return credentials['client'];\n\n    default:\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'makeAuthCredentialsProvider failed due to invalid credential type'\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 { debugAssert } from '../../util/assert';\n\n/**\n * Generates `nBytes` of random bytes.\n *\n * If `nBytes < 0` , an error will be thrown.\n */\nexport function randomBytes(nBytes: number): Uint8Array {\n  debugAssert(nBytes >= 0, `Expecting non-negative nBytes, got: ${nBytes}`);\n\n  // Polyfills for IE and WebWorker by using `self` and `msCrypto` when `crypto` is not available.\n  const crypto =\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    typeof self !== 'undefined' && (self.crypto || (self as any)['msCrypto']);\n  const bytes = new Uint8Array(nBytes);\n  if (crypto && typeof crypto.getRandomValues === 'function') {\n    crypto.getRandomValues(bytes);\n  } else {\n    // Falls back to Math.random\n    for (let i = 0; i < nBytes; i++) {\n      bytes[i] = Math.floor(Math.random() * 256);\n    }\n  }\n  return bytes;\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 { randomBytes } from '../platform/random_bytes';\n\nimport { debugAssert } from './assert';\n\nexport type EventHandler<E> = (value: E) => void;\nexport interface Indexable {\n  [k: string]: unknown;\n}\n\n/**\n * A utility class for generating unique alphanumeric IDs of a specified length.\n *\n * @internal\n * Exported internally for testing purposes.\n */\nexport class AutoId {\n  static newId(): string {\n    // Alphanumeric characters\n    const chars =\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n    // The largest byte value that is a multiple of `char.length`.\n    const maxMultiple = Math.floor(256 / chars.length) * chars.length;\n    debugAssert(\n      0 < maxMultiple && maxMultiple < 256,\n      `Expect maxMultiple to be (0, 256), but got ${maxMultiple}`\n    );\n\n    let autoId = '';\n    const targetLength = 20;\n    while (autoId.length < targetLength) {\n      const bytes = randomBytes(40);\n      for (let i = 0; i < bytes.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        if (autoId.length < targetLength && bytes[i] < maxMultiple) {\n          autoId += chars.charAt(bytes[i] % chars.length);\n        }\n      }\n    }\n    debugAssert(autoId.length === targetLength, 'Invalid auto ID: ' + autoId);\n\n    return autoId;\n  }\n}\n\nexport function primitiveComparator<T>(left: T, right: T): number {\n  if (left < right) {\n    return -1;\n  }\n  if (left > right) {\n    return 1;\n  }\n  return 0;\n}\n\nexport interface Equatable<T> {\n  isEqual(other: T): boolean;\n}\n\nexport interface Iterable<V> {\n  forEach: (cb: (v: V) => void) => void;\n}\n\n/** Helper to compare arrays using isEqual(). */\nexport function arrayEquals<T>(\n  left: T[],\n  right: T[],\n  comparator: (l: T, r: T) => boolean\n): boolean {\n  if (left.length !== right.length) {\n    return false;\n  }\n  return left.every((value, index) => comparator(value, right[index]));\n}\n/**\n * Returns the immediate lexicographically-following string. This is useful to\n * construct an inclusive range for indexeddb iterators.\n */\nexport function immediateSuccessor(s: string): string {\n  // Return the input string, with an additional NUL byte appended.\n  return s + '\\0';\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 { Code, FirestoreError } from '../util/error';\nimport { primitiveComparator } from '../util/misc';\n\n// The earliest date supported by Firestore timestamps (0001-01-01T00:00:00Z).\nconst MIN_SECONDS = -62135596800;\n\n// Number of nanoseconds in a millisecond.\nconst MS_TO_NANOS = 1e6;\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 */\nexport class Timestamp {\n  /**\n   * Creates a new timestamp with the current date, with millisecond precision.\n   *\n   * @returns a new timestamp representing the current date.\n   */\n  static now(): Timestamp {\n    return Timestamp.fromMillis(Date.now());\n  }\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  static fromDate(date: Date): Timestamp {\n    return Timestamp.fromMillis(date.getTime());\n  }\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  static fromMillis(milliseconds: number): Timestamp {\n    const seconds = Math.floor(milliseconds / 1000);\n    const nanos = Math.floor((milliseconds - seconds * 1000) * MS_TO_NANOS);\n    return new Timestamp(seconds, nanos);\n  }\n\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  constructor(\n    /**\n     * The number of seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z.\n     */\n    readonly seconds: number,\n    /**\n     * The fractions of a second at nanosecond resolution.*\n     */\n    readonly nanoseconds: number\n  ) {\n    if (nanoseconds < 0) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Timestamp nanoseconds out of range: ' + nanoseconds\n      );\n    }\n    if (nanoseconds >= 1e9) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Timestamp nanoseconds out of range: ' + nanoseconds\n      );\n    }\n    if (seconds < MIN_SECONDS) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Timestamp seconds out of range: ' + seconds\n      );\n    }\n    // This will break in the year 10,000.\n    if (seconds >= 253402300800) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Timestamp seconds out of range: ' + seconds\n      );\n    }\n  }\n\n  /**\n   * Converts a `Timestamp` to a JavaScript `Date` object. This conversion\n   * causes a loss of precision since `Date` objects only support millisecond\n   * precision.\n   *\n   * @returns JavaScript `Date` object representing the same point in time as\n   *     this `Timestamp`, with millisecond precision.\n   */\n  toDate(): Date {\n    return new Date(this.toMillis());\n  }\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  toMillis(): number {\n    return this.seconds * 1000 + this.nanoseconds / MS_TO_NANOS;\n  }\n\n  _compareTo(other: Timestamp): number {\n    if (this.seconds === other.seconds) {\n      return primitiveComparator(this.nanoseconds, other.nanoseconds);\n    }\n    return primitiveComparator(this.seconds, other.seconds);\n  }\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  isEqual(other: Timestamp): boolean {\n    return (\n      other.seconds === this.seconds && other.nanoseconds === this.nanoseconds\n    );\n  }\n\n  /** Returns a textual representation of this `Timestamp`. */\n  toString(): string {\n    return (\n      'Timestamp(seconds=' +\n      this.seconds +\n      ', nanoseconds=' +\n      this.nanoseconds +\n      ')'\n    );\n  }\n\n  /** Returns a JSON-serializable representation of this `Timestamp`. */\n  toJSON(): { seconds: number; nanoseconds: number } {\n    return { seconds: this.seconds, nanoseconds: this.nanoseconds };\n  }\n\n  /**\n   * Converts this object to a primitive string, which allows `Timestamp` objects\n   * to be compared using the `>`, `<=`, `>=` and `>` operators.\n   */\n  valueOf(): string {\n    // This method returns a string of the form <seconds>.<nanoseconds> where\n    // <seconds> is translated to have a non-negative value and both <seconds>\n    // and <nanoseconds> are left-padded with zeroes to be a consistent length.\n    // Strings with this format then have a lexicographical ordering that matches\n    // the expected ordering. The <seconds> translation is done to avoid having\n    // a leading negative sign (i.e. a leading '-' character) in its string\n    // representation, which would affect its lexicographical ordering.\n    const adjustedSeconds = this.seconds - MIN_SECONDS;\n    // Note: Up to 12 decimal digits are required to represent all valid\n    // 'seconds' values.\n    const formattedSeconds = String(adjustedSeconds).padStart(12, '0');\n    const formattedNanoseconds = String(this.nanoseconds).padStart(9, '0');\n    return formattedSeconds + '.' + formattedNanoseconds;\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 { Timestamp } from '../lite-api/timestamp';\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 */\nexport class SnapshotVersion {\n  static fromTimestamp(value: Timestamp): SnapshotVersion {\n    return new SnapshotVersion(value);\n  }\n\n  static min(): SnapshotVersion {\n    return new SnapshotVersion(new Timestamp(0, 0));\n  }\n\n  static max(): SnapshotVersion {\n    return new SnapshotVersion(new Timestamp(253402300799, 1e9 - 1));\n  }\n\n  private constructor(private timestamp: Timestamp) {}\n\n  compareTo(other: SnapshotVersion): number {\n    return this.timestamp._compareTo(other.timestamp);\n  }\n\n  isEqual(other: SnapshotVersion): boolean {\n    return this.timestamp.isEqual(other.timestamp);\n  }\n\n  /** Returns a number representation of the version for use in spec tests. */\n  toMicroseconds(): number {\n    // Convert to microseconds.\n    return this.timestamp.seconds * 1e6 + this.timestamp.nanoseconds / 1000;\n  }\n\n  toString(): string {\n    return 'SnapshotVersion(' + this.timestamp.toString() + ')';\n  }\n\n  toTimestamp(): Timestamp {\n    return this.timestamp;\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 { debugAssert, fail } from '../util/assert';\nimport { Code, FirestoreError } from '../util/error';\n\nexport const DOCUMENT_KEY_NAME = '__name__';\n\n/**\n * Path represents an ordered sequence of string segments.\n */\nabstract class BasePath<B extends BasePath<B>> {\n  private segments: string[];\n  private offset: number;\n  private len: number;\n\n  constructor(segments: string[], offset?: number, length?: number) {\n    if (offset === undefined) {\n      offset = 0;\n    } else if (offset > segments.length) {\n      fail('offset ' + offset + ' out of range ' + segments.length);\n    }\n\n    if (length === undefined) {\n      length = segments.length - offset;\n    } else if (length > segments.length - offset) {\n      fail('length ' + length + ' out of range ' + (segments.length - offset));\n    }\n    this.segments = segments;\n    this.offset = offset;\n    this.len = length;\n  }\n\n  /**\n   * Abstract constructor method to construct an instance of B with the given\n   * parameters.\n   */\n  protected abstract construct(\n    segments: string[],\n    offset?: number,\n    length?: number\n  ): B;\n\n  /**\n   * Returns a String representation.\n   *\n   * Implementing classes are required to provide deterministic implementations as\n   * the String representation is used to obtain canonical Query IDs.\n   */\n  abstract toString(): string;\n\n  get length(): number {\n    return this.len;\n  }\n\n  isEqual(other: B): boolean {\n    return BasePath.comparator(this, other) === 0;\n  }\n\n  child(nameOrPath: string | B): B {\n    const segments = this.segments.slice(this.offset, this.limit());\n    if (nameOrPath instanceof BasePath) {\n      nameOrPath.forEach(segment => {\n        segments.push(segment);\n      });\n    } else {\n      segments.push(nameOrPath);\n    }\n    return this.construct(segments);\n  }\n\n  /** The index of one past the last segment of the path. */\n  private limit(): number {\n    return this.offset + this.length;\n  }\n\n  popFirst(size?: number): B {\n    size = size === undefined ? 1 : size;\n    debugAssert(\n      this.length >= size,\n      \"Can't call popFirst() with less segments\"\n    );\n    return this.construct(\n      this.segments,\n      this.offset + size,\n      this.length - size\n    );\n  }\n\n  popLast(): B {\n    debugAssert(!this.isEmpty(), \"Can't call popLast() on empty path\");\n    return this.construct(this.segments, this.offset, this.length - 1);\n  }\n\n  firstSegment(): string {\n    debugAssert(!this.isEmpty(), \"Can't call firstSegment() on empty path\");\n    return this.segments[this.offset];\n  }\n\n  lastSegment(): string {\n    debugAssert(!this.isEmpty(), \"Can't call lastSegment() on empty path\");\n    return this.get(this.length - 1);\n  }\n\n  get(index: number): string {\n    debugAssert(index < this.length, 'Index out of range');\n    return this.segments[this.offset + index];\n  }\n\n  isEmpty(): boolean {\n    return this.length === 0;\n  }\n\n  isPrefixOf(other: this): boolean {\n    if (other.length < this.length) {\n      return false;\n    }\n\n    for (let i = 0; i < this.length; i++) {\n      if (this.get(i) !== other.get(i)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  isImmediateParentOf(potentialChild: this): boolean {\n    if (this.length + 1 !== potentialChild.length) {\n      return false;\n    }\n\n    for (let i = 0; i < this.length; i++) {\n      if (this.get(i) !== potentialChild.get(i)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  forEach(fn: (segment: string) => void): void {\n    for (let i = this.offset, end = this.limit(); i < end; i++) {\n      fn(this.segments[i]);\n    }\n  }\n\n  toArray(): string[] {\n    return this.segments.slice(this.offset, this.limit());\n  }\n\n  static comparator<T extends BasePath<T>>(\n    p1: BasePath<T>,\n    p2: BasePath<T>\n  ): number {\n    const len = Math.min(p1.length, p2.length);\n    for (let i = 0; i < len; i++) {\n      const left = p1.get(i);\n      const right = p2.get(i);\n      if (left < right) {\n        return -1;\n      }\n      if (left > right) {\n        return 1;\n      }\n    }\n    if (p1.length < p2.length) {\n      return -1;\n    }\n    if (p1.length > p2.length) {\n      return 1;\n    }\n    return 0;\n  }\n}\n\n/**\n * A slash-separated path for navigating resources (documents and collections)\n * within Firestore.\n *\n * @internal\n */\nexport class ResourcePath extends BasePath<ResourcePath> {\n  protected construct(\n    segments: string[],\n    offset?: number,\n    length?: number\n  ): ResourcePath {\n    return new ResourcePath(segments, offset, length);\n  }\n\n  canonicalString(): string {\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\n    return this.toArray().join('/');\n  }\n\n  toString(): string {\n    return this.canonicalString();\n  }\n\n  /**\n   * Returns a string representation of this path\n   * where each path segment has been encoded with\n   * `encodeURIComponent`.\n   */\n  toUriEncodedString(): string {\n    return this.toArray().map(encodeURIComponent).join('/');\n  }\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  static fromString(...pathComponents: string[]): ResourcePath {\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\n    const segments: string[] = [];\n    for (const path of pathComponents) {\n      if (path.indexOf('//') >= 0) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid segment (${path}). Paths must not contain // in them.`\n        );\n      }\n      // Strip leading and trailing slashed.\n      segments.push(...path.split('/').filter(segment => segment.length > 0));\n    }\n\n    return new ResourcePath(segments);\n  }\n\n  static emptyPath(): ResourcePath {\n    return new ResourcePath([]);\n  }\n}\n\nconst identifierRegExp = /^[_a-zA-Z][_a-zA-Z0-9]*$/;\n\n/**\n * A dot-separated path for navigating sub-objects within a document.\n * @internal\n */\nexport class FieldPath extends BasePath<FieldPath> {\n  protected construct(\n    segments: string[],\n    offset?: number,\n    length?: number\n  ): FieldPath {\n    return new FieldPath(segments, offset, length);\n  }\n\n  /**\n   * Returns true if the string could be used as a segment in a field path\n   * without escaping.\n   */\n  private static isValidIdentifier(segment: string): boolean {\n    return identifierRegExp.test(segment);\n  }\n\n  canonicalString(): string {\n    return this.toArray()\n      .map(str => {\n        str = str.replace(/\\\\/g, '\\\\\\\\').replace(/`/g, '\\\\`');\n        if (!FieldPath.isValidIdentifier(str)) {\n          str = '`' + str + '`';\n        }\n        return str;\n      })\n      .join('.');\n  }\n\n  toString(): string {\n    return this.canonicalString();\n  }\n\n  /**\n   * Returns true if this field references the key of a document.\n   */\n  isKeyField(): boolean {\n    return this.length === 1 && this.get(0) === DOCUMENT_KEY_NAME;\n  }\n\n  /**\n   * The field designating the key of a document.\n   */\n  static keyField(): FieldPath {\n    return new FieldPath([DOCUMENT_KEY_NAME]);\n  }\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  static fromServerFormat(path: string): FieldPath {\n    const segments: string[] = [];\n    let current = '';\n    let i = 0;\n\n    const addCurrentSegment = (): void => {\n      if (current.length === 0) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid field path (${path}). Paths must not be empty, begin ` +\n            `with '.', end with '.', or contain '..'`\n        );\n      }\n      segments.push(current);\n      current = '';\n    };\n\n    let inBackticks = false;\n\n    while (i < path.length) {\n      const c = path[i];\n      if (c === '\\\\') {\n        if (i + 1 === path.length) {\n          throw new FirestoreError(\n            Code.INVALID_ARGUMENT,\n            'Path has trailing escape character: ' + path\n          );\n        }\n        const next = path[i + 1];\n        if (!(next === '\\\\' || next === '.' || next === '`')) {\n          throw new FirestoreError(\n            Code.INVALID_ARGUMENT,\n            'Path has invalid escape sequence: ' + path\n          );\n        }\n        current += next;\n        i += 2;\n      } else if (c === '`') {\n        inBackticks = !inBackticks;\n        i++;\n      } else if (c === '.' && !inBackticks) {\n        addCurrentSegment();\n        i++;\n      } else {\n        current += c;\n        i++;\n      }\n    }\n    addCurrentSegment();\n\n    if (inBackticks) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Unterminated ` in path: ' + path\n      );\n    }\n\n    return new FieldPath(segments);\n  }\n\n  static emptyPath(): FieldPath {\n    return new FieldPath([]);\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 { debugAssert } from '../util/assert';\n\nimport { ResourcePath } from './path';\n\n/**\n * @internal\n */\nexport class DocumentKey {\n  constructor(readonly path: ResourcePath) {\n    debugAssert(\n      DocumentKey.isDocumentKey(path),\n      'Invalid DocumentKey with an odd number of segments: ' +\n        path.toArray().join('/')\n    );\n  }\n\n  static fromPath(path: string): DocumentKey {\n    return new DocumentKey(ResourcePath.fromString(path));\n  }\n\n  static fromName(name: string): DocumentKey {\n    return new DocumentKey(ResourcePath.fromString(name).popFirst(5));\n  }\n\n  static empty(): DocumentKey {\n    return new DocumentKey(ResourcePath.emptyPath());\n  }\n\n  get collectionGroup(): string {\n    debugAssert(\n      !this.path.isEmpty(),\n      'Cannot get collection group for empty key'\n    );\n    return this.path.popLast().lastSegment();\n  }\n\n  /** Returns true if the document is in the specified collectionId. */\n  hasCollectionId(collectionId: string): boolean {\n    return (\n      this.path.length >= 2 &&\n      this.path.get(this.path.length - 2) === collectionId\n    );\n  }\n\n  /** Returns the collection group (i.e. the name of the parent collection) for this key. */\n  getCollectionGroup(): string {\n    debugAssert(\n      !this.path.isEmpty(),\n      'Cannot get collection group for empty key'\n    );\n    return this.path.get(this.path.length - 2);\n  }\n\n  /** Returns the fully qualified path to the parent collection. */\n  getCollectionPath(): ResourcePath {\n    return this.path.popLast();\n  }\n\n  isEqual(other: DocumentKey | null): boolean {\n    return (\n      other !== null && ResourcePath.comparator(this.path, other.path) === 0\n    );\n  }\n\n  toString(): string {\n    return this.path.toString();\n  }\n\n  static comparator(k1: DocumentKey, k2: DocumentKey): number {\n    return ResourcePath.comparator(k1.path, k2.path);\n  }\n\n  static isDocumentKey(path: ResourcePath): boolean {\n    return path.length % 2 === 0;\n  }\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  static fromSegments(segments: string[]): DocumentKey {\n    return new DocumentKey(new ResourcePath(segments.slice()));\n  }\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { SnapshotVersion } from '../core/snapshot_version';\nimport { Timestamp } from '../lite-api/timestamp';\nimport { primitiveComparator } from '../util/misc';\n\nimport { Document } from './document';\nimport { DocumentKey } from './document_key';\nimport { FieldPath } from './path';\n\n/**\n * The initial mutation batch id for each index. Gets updated during index\n * backfill.\n */\nexport const INITIAL_LARGEST_BATCH_ID = -1;\n\n/**\n * The initial sequence number for each index. Gets updated during index\n * backfill.\n */\nexport const INITIAL_SEQUENCE_NUMBER = 0;\n\n/**\n * An index definition for field indexes in Firestore.\n *\n * Every index is associated with a collection. The definition contains a list\n * of fields and their index kind (which can be `ASCENDING`, `DESCENDING` or\n * `CONTAINS` for ArrayContains/ArrayContainsAny queries).\n *\n * Unlike the backend, the SDK does not differentiate between collection or\n * collection group-scoped indices. Every index can be used for both single\n * collection and collection group queries.\n */\nexport class FieldIndex {\n  /** An ID for an index that has not yet been added to persistence.  */\n  static UNKNOWN_ID = -1;\n\n  constructor(\n    /**\n     * The index ID. Returns -1 if the index ID is not available (e.g. the index\n     * has not yet been persisted).\n     */\n    readonly indexId: number,\n    /** The collection ID this index applies to. */\n    readonly collectionGroup: string,\n    /** The field segments for this index. */\n    readonly fields: IndexSegment[],\n    /** Shows how up-to-date the index is for the current user. */\n    readonly indexState: IndexState\n  ) {}\n}\n\n/** Returns the ArrayContains/ArrayContainsAny segment for this index. */\nexport function fieldIndexGetArraySegment(\n  fieldIndex: FieldIndex\n): IndexSegment | undefined {\n  return fieldIndex.fields.find(s => s.kind === IndexKind.CONTAINS);\n}\n\n/** Returns all directional (ascending/descending) segments for this index. */\nexport function fieldIndexGetDirectionalSegments(\n  fieldIndex: FieldIndex\n): IndexSegment[] {\n  return fieldIndex.fields.filter(s => s.kind !== IndexKind.CONTAINS);\n}\n\n/**\n * Returns the order of the document key component for the given index.\n *\n * PORTING NOTE: This is only used in the Web IndexedDb implementation.\n */\nexport function fieldIndexGetKeyOrder(fieldIndex: FieldIndex): IndexKind {\n  const directionalSegments = fieldIndexGetDirectionalSegments(fieldIndex);\n  return directionalSegments.length === 0\n    ? IndexKind.ASCENDING\n    : directionalSegments[directionalSegments.length - 1].kind;\n}\n\n/**\n * Compares indexes by collection group and segments. Ignores update time and\n * index ID.\n */\nexport function fieldIndexSemanticComparator(\n  left: FieldIndex,\n  right: FieldIndex\n): number {\n  let cmp = primitiveComparator(left.collectionGroup, right.collectionGroup);\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  for (let i = 0; i < Math.min(left.fields.length, right.fields.length); ++i) {\n    cmp = indexSegmentComparator(left.fields[i], right.fields[i]);\n    if (cmp !== 0) {\n      return cmp;\n    }\n  }\n  return primitiveComparator(left.fields.length, right.fields.length);\n}\n\n/** Returns a debug representation of the field index */\nexport function fieldIndexToString(fieldIndex: FieldIndex): string {\n  return `id=${fieldIndex.indexId}|cg=${\n    fieldIndex.collectionGroup\n  }|f=${fieldIndex.fields.map(f => `${f.fieldPath}:${f.kind}`).join(',')}`;\n}\n\n/** The type of the index, e.g. for which type of query it can be used. */\nexport const enum IndexKind {\n  // Note: The order of these values cannot be changed as the enum values are\n  // stored in IndexedDb.\n  /**\n   * Ordered index. Can be used for <, <=, ==, >=, >, !=, IN and NOT IN queries.\n   */\n  ASCENDING,\n  /**\n   * Ordered index. Can be used for <, <=, ==, >=, >, !=, IN and NOT IN queries.\n   */\n  DESCENDING,\n  /** Contains index. Can be used for ArrayContains and ArrayContainsAny. */\n  CONTAINS\n}\n\n/** An index component consisting of field path and index type.  */\nexport class IndexSegment {\n  constructor(\n    /** The field path of the component. */\n    readonly fieldPath: FieldPath,\n    /** The fields sorting order. */\n    readonly kind: IndexKind\n  ) {}\n}\n\nfunction indexSegmentComparator(\n  left: IndexSegment,\n  right: IndexSegment\n): number {\n  const cmp = FieldPath.comparator(left.fieldPath, right.fieldPath);\n  if (cmp !== 0) {\n    return cmp;\n  }\n  return primitiveComparator(left.kind, right.kind);\n}\n\n/**\n * Stores the \"high water mark\" that indicates how updated the Index is for the\n * current user.\n */\nexport class IndexState {\n  constructor(\n    /**\n     * Indicates when the index was last updated (relative to other indexes).\n     */\n    readonly sequenceNumber: number,\n    /** The the latest indexed read time, document and batch id. */\n    readonly offset: IndexOffset\n  ) {}\n\n  /** The state of an index that has not yet been backfilled. */\n  static empty(): IndexState {\n    return new IndexState(INITIAL_SEQUENCE_NUMBER, IndexOffset.min());\n  }\n}\n\n/**\n * Creates an offset that matches all documents with a read time higher than\n * `readTime`.\n */\nexport function newIndexOffsetSuccessorFromReadTime(\n  readTime: SnapshotVersion,\n  largestBatchId: number\n): IndexOffset {\n  // We want to create an offset that matches all documents with a read time\n  // greater than the provided read time. To do so, we technically need to\n  // create an offset for `(readTime, MAX_DOCUMENT_KEY)`. While we could use\n  // Unicode codepoints to generate MAX_DOCUMENT_KEY, it is much easier to use\n  // `(readTime + 1, DocumentKey.empty())` since `> DocumentKey.empty()` matches\n  // all valid document IDs.\n  const successorSeconds = readTime.toTimestamp().seconds;\n  const successorNanos = readTime.toTimestamp().nanoseconds + 1;\n  const successor = SnapshotVersion.fromTimestamp(\n    successorNanos === 1e9\n      ? new Timestamp(successorSeconds + 1, 0)\n      : new Timestamp(successorSeconds, successorNanos)\n  );\n  return new IndexOffset(successor, DocumentKey.empty(), largestBatchId);\n}\n\n/** Creates a new offset based on the provided document. */\nexport function newIndexOffsetFromDocument(document: Document): IndexOffset {\n  return new IndexOffset(\n    document.readTime,\n    document.key,\n    INITIAL_LARGEST_BATCH_ID\n  );\n}\n\n/**\n * Stores the latest read time, document and batch ID that were processed for an\n * index.\n */\nexport class IndexOffset {\n  constructor(\n    /**\n     * The latest read time version that has been indexed by Firestore for this\n     * field index.\n     */\n    readonly readTime: SnapshotVersion,\n\n    /**\n     * The key of the last document that was indexed for this query. Use\n     * `DocumentKey.empty()` if no document has been indexed.\n     */\n    readonly documentKey: DocumentKey,\n\n    /*\n     * The largest mutation batch id that's been processed by Firestore.\n     */\n    readonly largestBatchId: number\n  ) {}\n\n  /** Returns an offset that sorts before all regular offsets. */\n  static min(): IndexOffset {\n    return new IndexOffset(\n      SnapshotVersion.min(),\n      DocumentKey.empty(),\n      INITIAL_LARGEST_BATCH_ID\n    );\n  }\n\n  /** Returns an offset that sorts after all regular offsets. */\n  static max(): IndexOffset {\n    return new IndexOffset(\n      SnapshotVersion.max(),\n      DocumentKey.empty(),\n      INITIAL_LARGEST_BATCH_ID\n    );\n  }\n}\n\nexport function indexOffsetComparator(\n  left: IndexOffset,\n  right: IndexOffset\n): number {\n  let cmp = left.readTime.compareTo(right.readTime);\n  if (cmp !== 0) {\n    return cmp;\n  }\n  cmp = DocumentKey.comparator(left.documentKey, right.documentKey);\n  if (cmp !== 0) {\n    return cmp;\n  }\n  return primitiveComparator(left.largestBatchId, right.largestBatchId);\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 { ListenSequenceNumber } from '../core/types';\nexport const PRIMARY_LEASE_LOST_ERROR_MSG =\n  'The current tab is not in the required state to perform this operation. ' +\n  'It might be necessary to refresh the browser tab.';\n\n/** The different modes supported by `Persistence.runTransaction()`. */\nexport type PersistenceTransactionMode =\n  | 'readonly'\n  | 'readwrite'\n  | 'readwrite-primary';\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 */\nexport abstract class PersistenceTransaction {\n  private readonly onCommittedListeners: Array<() => void> = [];\n\n  abstract readonly currentSequenceNumber: ListenSequenceNumber;\n\n  addOnCommittedListener(listener: () => void): void {\n    this.onCommittedListeners.push(listener);\n  }\n\n  raiseOnCommittedEvent(): void {\n    this.onCommittedListeners.forEach(listener => listener());\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 { Code, FirestoreError } from '../util/error';\nimport { logDebug } from '../util/log';\n\nimport { IndexManager } from './index_manager';\nimport { LocalDocumentsView } from './local_documents_view';\nimport { LruGarbageCollector, LruResults } from './lru_garbage_collector';\nimport { PRIMARY_LEASE_LOST_ERROR_MSG } from './persistence_transaction';\n\nexport interface LocalStore {\n  collectGarbage(garbageCollector: LruGarbageCollector): Promise<LruResults>;\n\n  /** Manages the list of active field and collection indices. */\n  indexManager: IndexManager;\n\n  /**\n   * The \"local\" view of all documents (layering mutationQueue on top of\n   * remoteDocumentCache).\n   */\n  localDocuments: LocalDocumentsView;\n}\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 */\nexport async function ignoreIfPrimaryLeaseLoss(\n  err: FirestoreError\n): Promise<void> {\n  if (\n    err.code === Code.FAILED_PRECONDITION &&\n    err.message === PRIMARY_LEASE_LOST_ERROR_MSG\n  ) {\n    logDebug('LocalStore', 'Unexpectedly lost primary lease');\n  } else {\n    throw err;\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 { fail } from '../util/assert';\n\nexport type FulfilledHandler<T, R> =\n  | ((result: T) => R | PersistencePromise<R>)\n  | null;\nexport type RejectedHandler<R> =\n  | ((reason: Error) => R | PersistencePromise<R>)\n  | null;\nexport type Resolver<T> = (value?: T) => void;\nexport type Rejector = (error: Error) => void;\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 */\nexport class PersistencePromise<T> {\n  // NOTE: next/catchCallback will always point to our own wrapper functions,\n  // not the user's raw next() or catch() callbacks.\n  private nextCallback: FulfilledHandler<T, unknown> = null;\n  private catchCallback: RejectedHandler<unknown> = null;\n\n  // When the operation resolves, we'll set result or error and mark isDone.\n  private result: T | undefined = undefined;\n  private error: Error | undefined = undefined;\n  private isDone = false;\n\n  // Set to true when .then() or .catch() are called and prevents additional\n  // chaining.\n  private callbackAttached = false;\n\n  constructor(callback: (resolve: Resolver<T>, reject: Rejector) => void) {\n    callback(\n      value => {\n        this.isDone = true;\n        this.result = value;\n        if (this.nextCallback) {\n          // value should be defined unless T is Void, but we can't express\n          // that in the type system.\n          this.nextCallback(value!);\n        }\n      },\n      error => {\n        this.isDone = true;\n        this.error = error;\n        if (this.catchCallback) {\n          this.catchCallback(error);\n        }\n      }\n    );\n  }\n\n  catch<R>(\n    fn: (error: Error) => R | PersistencePromise<R>\n  ): PersistencePromise<R> {\n    return this.next(undefined, fn);\n  }\n\n  next<R>(\n    nextFn?: FulfilledHandler<T, R>,\n    catchFn?: RejectedHandler<R>\n  ): PersistencePromise<R> {\n    if (this.callbackAttached) {\n      fail('Called next() or catch() twice for PersistencePromise');\n    }\n    this.callbackAttached = true;\n    if (this.isDone) {\n      if (!this.error) {\n        return this.wrapSuccess(nextFn, this.result!);\n      } else {\n        return this.wrapFailure(catchFn, this.error);\n      }\n    } else {\n      return new PersistencePromise<R>((resolve, reject) => {\n        this.nextCallback = (value: T) => {\n          this.wrapSuccess(nextFn, value).next(resolve, reject);\n        };\n        this.catchCallback = (error: Error) => {\n          this.wrapFailure(catchFn, error).next(resolve, reject);\n        };\n      });\n    }\n  }\n\n  toPromise(): Promise<T> {\n    return new Promise((resolve, reject) => {\n      this.next(resolve, reject);\n    });\n  }\n\n  private wrapUserFunction<R>(\n    fn: () => R | PersistencePromise<R>\n  ): PersistencePromise<R> {\n    try {\n      const result = fn();\n      if (result instanceof PersistencePromise) {\n        return result;\n      } else {\n        return PersistencePromise.resolve(result);\n      }\n    } catch (e) {\n      return PersistencePromise.reject<R>(e as Error);\n    }\n  }\n\n  private wrapSuccess<R>(\n    nextFn: FulfilledHandler<T, R> | undefined,\n    value: T\n  ): PersistencePromise<R> {\n    if (nextFn) {\n      return this.wrapUserFunction(() => nextFn(value));\n    } else {\n      // If there's no nextFn, then R must be the same as T\n      return PersistencePromise.resolve<R>(value as unknown as R);\n    }\n  }\n\n  private wrapFailure<R>(\n    catchFn: RejectedHandler<R> | undefined,\n    error: Error\n  ): PersistencePromise<R> {\n    if (catchFn) {\n      return this.wrapUserFunction(() => catchFn(error));\n    } else {\n      return PersistencePromise.reject<R>(error);\n    }\n  }\n\n  static resolve(): PersistencePromise<void>;\n  static resolve<R>(result: R): PersistencePromise<R>;\n  static resolve<R>(result?: R): PersistencePromise<R | void> {\n    return new PersistencePromise<R | void>((resolve, reject) => {\n      resolve(result);\n    });\n  }\n\n  static reject<R>(error: Error): PersistencePromise<R> {\n    return new PersistencePromise<R>((resolve, reject) => {\n      reject(error);\n    });\n  }\n\n  static waitFor(\n    // Accept all Promise types in waitFor().\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    all: { forEach: (cb: (el: PersistencePromise<any>) => void) => void }\n  ): PersistencePromise<void> {\n    return new PersistencePromise<void>((resolve, reject) => {\n      let expectedCount = 0;\n      let resolvedCount = 0;\n      let done = false;\n\n      all.forEach(element => {\n        ++expectedCount;\n        element.next(\n          () => {\n            ++resolvedCount;\n            if (done && resolvedCount === expectedCount) {\n              resolve();\n            }\n          },\n          err => reject(err)\n        );\n      });\n\n      done = true;\n      if (resolvedCount === expectedCount) {\n        resolve();\n      }\n    });\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  static or(\n    predicates: Array<() => PersistencePromise<boolean>>\n  ): PersistencePromise<boolean> {\n    let p: PersistencePromise<boolean> =\n      PersistencePromise.resolve<boolean>(false);\n    for (const predicate of predicates) {\n      p = p.next(isTrue => {\n        if (isTrue) {\n          return PersistencePromise.resolve<boolean>(isTrue);\n        } else {\n          return predicate();\n        }\n      });\n    }\n    return p;\n  }\n\n  /**\n   * Given an iterable, call the given function on each element in the\n   * collection and wait for all of the resulting concurrent PersistencePromises\n   * to resolve.\n   */\n  static forEach<R, S>(\n    collection: { forEach: (cb: (r: R, s: S) => void) => void },\n    f:\n      | ((r: R, s: S) => PersistencePromise<void>)\n      | ((r: R) => PersistencePromise<void>)\n  ): PersistencePromise<void>;\n  static forEach<R>(\n    collection: { forEach: (cb: (r: R) => void) => void },\n    f: (r: R) => PersistencePromise<void>\n  ): PersistencePromise<void>;\n  static forEach<R, S>(\n    collection: { forEach: (cb: (r: R, s?: S) => void) => void },\n    f: (r: R, s?: S) => PersistencePromise<void>\n  ): PersistencePromise<void> {\n    const promises: Array<PersistencePromise<void>> = [];\n    collection.forEach((r, s) => {\n      promises.push(f.call(this, r, s));\n    });\n    return this.waitFor(promises);\n  }\n\n  /**\n   * Concurrently map all array elements through asynchronous function.\n   */\n  static mapArray<T, U>(\n    array: T[],\n    f: (t: T) => PersistencePromise<U>\n  ): PersistencePromise<U[]> {\n    return new PersistencePromise<U[]>((resolve, reject) => {\n      const expectedCount = array.length;\n      const results: U[] = new Array(expectedCount);\n      let resolvedCount = 0;\n      for (let i = 0; i < expectedCount; i++) {\n        const current = i;\n        f(array[current]).next(\n          result => {\n            results[current] = result;\n            ++resolvedCount;\n            if (resolvedCount === expectedCount) {\n              resolve(results);\n            }\n          },\n          err => reject(err)\n        );\n      }\n    });\n  }\n\n  /**\n   * An alternative to recursive PersistencePromise calls, that avoids\n   * potential memory problems from unbounded chains of promises.\n   *\n   * The `action` will be called repeatedly while `condition` is true.\n   */\n  static doWhile(\n    condition: () => boolean,\n    action: () => PersistencePromise<void>\n  ): PersistencePromise<void> {\n    return new PersistencePromise<void>((resolve, reject) => {\n      const process = (): void => {\n        if (condition() === true) {\n          action().next(() => {\n            process();\n          }, reject);\n        } else {\n          resolve();\n        }\n      };\n      process();\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 { getUA, isIndexedDBAvailable } from '@firebase/util';\n\nimport { debugAssert } from '../util/assert';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug, logError } from '../util/log';\nimport { Deferred } from '../util/promise';\n\nimport { PersistencePromise } from './persistence_promise';\n\n// References to `window` are guarded by SimpleDb.isAvailable()\n/* eslint-disable no-restricted-globals */\n\nconst LOG_TAG = 'SimpleDb';\n\n/**\n * The maximum number of retry attempts for an IndexedDb transaction that fails\n * with a DOMException.\n */\nconst TRANSACTION_RETRY_COUNT = 3;\n\n// The different modes supported by `SimpleDb.runTransaction()`\ntype SimpleDbTransactionMode = 'readonly' | 'readwrite';\n\nexport interface SimpleDbSchemaConverter {\n  createOrUpgrade(\n    db: IDBDatabase,\n    txn: IDBTransaction,\n    fromVersion: number,\n    toVersion: number\n  ): PersistencePromise<void>;\n}\n\n/**\n * Wraps an IDBTransaction and exposes a store() method to get a handle to a\n * specific object store.\n */\nexport class SimpleDbTransaction {\n  private aborted = false;\n\n  /**\n   * A `Promise` that resolves with the result of the IndexedDb transaction.\n   */\n  private readonly completionDeferred = new Deferred<void>();\n\n  static open(\n    db: IDBDatabase,\n    action: string,\n    mode: IDBTransactionMode,\n    objectStoreNames: string[]\n  ): SimpleDbTransaction {\n    try {\n      return new SimpleDbTransaction(\n        action,\n        db.transaction(objectStoreNames, mode)\n      );\n    } catch (e) {\n      throw new IndexedDbTransactionError(action, e as Error);\n    }\n  }\n\n  constructor(\n    private readonly action: string,\n    private readonly transaction: IDBTransaction\n  ) {\n    this.transaction.oncomplete = () => {\n      this.completionDeferred.resolve();\n    };\n    this.transaction.onabort = () => {\n      if (transaction.error) {\n        this.completionDeferred.reject(\n          new IndexedDbTransactionError(action, transaction.error)\n        );\n      } else {\n        this.completionDeferred.resolve();\n      }\n    };\n    this.transaction.onerror = (event: Event) => {\n      const error = checkForAndReportiOSError(\n        (event.target as IDBRequest).error!\n      );\n      this.completionDeferred.reject(\n        new IndexedDbTransactionError(action, error)\n      );\n    };\n  }\n\n  get completionPromise(): Promise<void> {\n    return this.completionDeferred.promise;\n  }\n\n  abort(error?: Error): void {\n    if (error) {\n      this.completionDeferred.reject(error);\n    }\n\n    if (!this.aborted) {\n      logDebug(\n        LOG_TAG,\n        'Aborting transaction:',\n        error ? error.message : 'Client-initiated abort'\n      );\n      this.aborted = true;\n      this.transaction.abort();\n    }\n  }\n\n  maybeCommit(): void {\n    // If the browser supports V3 IndexedDB, we invoke commit() explicitly to\n    // speed up index DB processing if the event loop remains blocks.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const maybeV3IndexedDb = this.transaction as any;\n    if (!this.aborted && typeof maybeV3IndexedDb.commit === 'function') {\n      maybeV3IndexedDb.commit();\n    }\n  }\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  store<KeyType extends IDBValidKey, ValueType extends unknown>(\n    storeName: string\n  ): SimpleDbStore<KeyType, ValueType> {\n    const store = this.transaction.objectStore(storeName);\n    debugAssert(!!store, 'Object store not part of transaction: ' + storeName);\n    return new SimpleDbStore<KeyType, ValueType>(store);\n  }\n}\n\n/**\n * Provides a wrapper around IndexedDb with a simplified interface that uses\n * Promise-like return values to chain operations. Real promises cannot be used\n * since .then() continuations are executed asynchronously (e.g. via\n * .setImmediate), which would cause IndexedDB to end the transaction.\n * See PersistencePromise for more details.\n */\nexport class SimpleDb {\n  private db?: IDBDatabase;\n  private versionchangelistener?: (event: IDBVersionChangeEvent) => void;\n\n  /** Deletes the specified database. */\n  static delete(name: string): Promise<void> {\n    logDebug(LOG_TAG, 'Removing database:', name);\n    return wrapRequest<void>(window.indexedDB.deleteDatabase(name)).toPromise();\n  }\n\n  /** Returns true if IndexedDB is available in the current environment. */\n  static isAvailable(): boolean {\n    if (!isIndexedDBAvailable()) {\n      return false;\n    }\n\n    if (SimpleDb.isMockPersistence()) {\n      return true;\n    }\n\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\n    // Check the UA string to find out the browser.\n    const ua = getUA();\n\n    // IE 10\n    // ua = 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)';\n\n    // IE 11\n    // ua = 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko';\n\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\n    // iOS Safari: Disable for users running iOS version < 10.\n    const iOSVersion = SimpleDb.getIOSVersion(ua);\n    const isUnsupportedIOS = 0 < iOSVersion && iOSVersion < 10;\n\n    // Android browser: Disable for users running version < 4.5.\n    const androidVersion = getAndroidVersion(ua);\n    const isUnsupportedAndroid = 0 < androidVersion && androidVersion < 4.5;\n\n    if (\n      ua.indexOf('MSIE ') > 0 ||\n      ua.indexOf('Trident/') > 0 ||\n      ua.indexOf('Edge/') > 0 ||\n      isUnsupportedIOS ||\n      isUnsupportedAndroid\n    ) {\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  /**\n   * Returns true if the backing IndexedDB store is the Node IndexedDBShim\n   * (see https://github.com/axemclion/IndexedDBShim).\n   */\n  static isMockPersistence(): boolean {\n    return (\n      typeof process !== 'undefined' &&\n      process.env?.USE_MOCK_PERSISTENCE === 'YES'\n    );\n  }\n\n  /** Helper to get a typed SimpleDbStore from a transaction. */\n  static getStore<KeyType extends IDBValidKey, ValueType extends unknown>(\n    txn: SimpleDbTransaction,\n    store: string\n  ): SimpleDbStore<KeyType, ValueType> {\n    return txn.store<KeyType, ValueType>(store);\n  }\n\n  // visible for testing\n  /** Parse User Agent to determine iOS version. Returns -1 if not found. */\n  static getIOSVersion(ua: string): number {\n    const iOSVersionRegex = ua.match(/i(?:phone|pad|pod) os ([\\d_]+)/i);\n    const version = iOSVersionRegex\n      ? iOSVersionRegex[1].split('_').slice(0, 2).join('.')\n      : '-1';\n    return Number(version);\n  }\n\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  constructor(\n    private readonly name: string,\n    private readonly version: number,\n    private readonly schemaConverter: SimpleDbSchemaConverter\n  ) {\n    debugAssert(\n      SimpleDb.isAvailable(),\n      'IndexedDB not supported in current environment.'\n    );\n\n    const iOSVersion = SimpleDb.getIOSVersion(getUA());\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    if (iOSVersion === 12.2) {\n      logError(\n        'Firestore persistence suffers from a bug in iOS 12.2 ' +\n          'Safari that may cause your app to stop working. See ' +\n          'https://stackoverflow.com/q/56496296/110915 for details ' +\n          'and a potential workaround.'\n      );\n    }\n  }\n\n  /**\n   * Opens the specified database, creating or upgrading it if necessary.\n   */\n  async ensureDb(action: string): Promise<IDBDatabase> {\n    if (!this.db) {\n      logDebug(LOG_TAG, 'Opening database:', this.name);\n      this.db = await new Promise<IDBDatabase>((resolve, reject) => {\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        const request = indexedDB.open(this.name, this.version);\n\n        request.onsuccess = (event: Event) => {\n          const db = (event.target as IDBOpenDBRequest).result;\n          resolve(db);\n        };\n\n        request.onblocked = () => {\n          reject(\n            new IndexedDbTransactionError(\n              action,\n              'Cannot upgrade IndexedDB schema while another tab is open. ' +\n                'Close all tabs that access Firestore and reload this page to proceed.'\n            )\n          );\n        };\n\n        request.onerror = (event: Event) => {\n          const error: DOMException = (event.target as IDBOpenDBRequest).error!;\n          if (error.name === 'VersionError') {\n            reject(\n              new FirestoreError(\n                Code.FAILED_PRECONDITION,\n                'A newer version of the Firestore SDK was previously used and so the persisted ' +\n                  'data is not compatible with the version of the SDK you are now using. The SDK ' +\n                  'will operate with persistence disabled. If you need persistence, please ' +\n                  're-upgrade to a newer version of the SDK or else clear the persisted IndexedDB ' +\n                  'data for your app to start fresh.'\n              )\n            );\n          } else if (error.name === 'InvalidStateError') {\n            reject(\n              new FirestoreError(\n                Code.FAILED_PRECONDITION,\n                'Unable to open an IndexedDB connection. This could be due to running in a ' +\n                  'private browsing session on a browser whose private browsing sessions do not ' +\n                  'support IndexedDB: ' +\n                  error\n              )\n            );\n          } else {\n            reject(new IndexedDbTransactionError(action, error));\n          }\n        };\n\n        request.onupgradeneeded = (event: IDBVersionChangeEvent) => {\n          logDebug(\n            LOG_TAG,\n            'Database \"' + this.name + '\" requires upgrade from version:',\n            event.oldVersion\n          );\n          const db = (event.target as IDBOpenDBRequest).result;\n          this.schemaConverter\n            .createOrUpgrade(\n              db,\n              request.transaction!,\n              event.oldVersion,\n              this.version\n            )\n            .next(() => {\n              logDebug(\n                LOG_TAG,\n                'Database upgrade to version ' + this.version + ' complete'\n              );\n            });\n        };\n      });\n    }\n\n    if (this.versionchangelistener) {\n      this.db.onversionchange = event => this.versionchangelistener!(event);\n    }\n    return this.db;\n  }\n\n  setVersionChangeListener(\n    versionChangeListener: (event: IDBVersionChangeEvent) => void\n  ): void {\n    this.versionchangelistener = versionChangeListener;\n    if (this.db) {\n      this.db.onversionchange = (event: IDBVersionChangeEvent) => {\n        return versionChangeListener(event);\n      };\n    }\n  }\n\n  async runTransaction<T>(\n    action: string,\n    mode: SimpleDbTransactionMode,\n    objectStores: string[],\n    transactionFn: (transaction: SimpleDbTransaction) => PersistencePromise<T>\n  ): Promise<T> {\n    const readonly = mode === 'readonly';\n    let attemptNumber = 0;\n\n    while (true) {\n      ++attemptNumber;\n\n      try {\n        this.db = await this.ensureDb(action);\n\n        const transaction = SimpleDbTransaction.open(\n          this.db,\n          action,\n          readonly ? 'readonly' : 'readwrite',\n          objectStores\n        );\n        const transactionFnResult = transactionFn(transaction)\n          .next(result => {\n            transaction.maybeCommit();\n            return result;\n          })\n          .catch(error => {\n            // Abort the transaction if there was an error.\n            transaction.abort(error);\n            // We cannot actually recover, and calling `abort()` will cause the transaction's\n            // completion promise to be rejected. This in turn means that we won't use\n            // `transactionFnResult` below. We return a rejection here so that we don't add the\n            // possibility of returning `void` to the type of `transactionFnResult`.\n            return PersistencePromise.reject<T>(error);\n          })\n          .toPromise();\n\n        // As noted above, errors are propagated by aborting the transaction. So\n        // we swallow any error here to avoid the browser logging it as unhandled.\n        transactionFnResult.catch(() => {});\n\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        await transaction.completionPromise;\n        return transactionFnResult;\n      } catch (e) {\n        const error = e as Error;\n        // TODO(schmidt-sebastian): We could probably be smarter about this and\n        // not retry exceptions that are likely unrecoverable (such as quota\n        // exceeded errors).\n\n        // Note: We cannot use an instanceof check for FirestoreException, since the\n        // exception is wrapped in a generic error by our async/await handling.\n        const retryable =\n          error.name !== 'FirebaseError' &&\n          attemptNumber < TRANSACTION_RETRY_COUNT;\n        logDebug(\n          LOG_TAG,\n          'Transaction failed with error:',\n          error.message,\n          'Retrying:',\n          retryable\n        );\n\n        this.close();\n\n        if (!retryable) {\n          return Promise.reject(error);\n        }\n      }\n    }\n  }\n\n  close(): void {\n    if (this.db) {\n      this.db.close();\n    }\n    this.db = undefined;\n  }\n}\n\n/** Parse User Agent to determine Android version. Returns -1 if not found. */\nexport function getAndroidVersion(ua: string): number {\n  const androidVersionRegex = ua.match(/Android ([\\d.]+)/i);\n  const version = androidVersionRegex\n    ? androidVersionRegex[1].split('.').slice(0, 2).join('.')\n    : '-1';\n  return Number(version);\n}\n\n/**\n * A controller for iterating over a key range or index. It allows an iterate\n * callback to delete the currently-referenced object, or jump to a new key\n * within the key range or index.\n */\nexport class IterationController {\n  private shouldStop = false;\n  private nextKey: IDBValidKey | null = null;\n\n  constructor(private dbCursor: IDBCursorWithValue) {}\n\n  get isDone(): boolean {\n    return this.shouldStop;\n  }\n\n  get skipToKey(): IDBValidKey | null {\n    return this.nextKey;\n  }\n\n  set cursor(value: IDBCursorWithValue) {\n    this.dbCursor = value;\n  }\n\n  /**\n   * This function can be called to stop iteration at any point.\n   */\n  done(): void {\n    this.shouldStop = true;\n  }\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  skip(key: IDBValidKey): void {\n    this.nextKey = key;\n  }\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  delete(): PersistencePromise<void> {\n    return wrapRequest<void>(this.dbCursor.delete());\n  }\n}\n\n/**\n * Callback used with iterate() method.\n */\nexport type IterateCallback<KeyType, ValueType> = (\n  key: KeyType,\n  value: ValueType,\n  control: IterationController\n) => void | PersistencePromise<void>;\n\n/** Options available to the iterate() method. */\nexport interface IterateOptions {\n  /** Index to iterate over (else primary keys will be iterated) */\n  index?: string;\n\n  /** IndexedDB Range to iterate over (else entire store will be iterated) */\n  range?: IDBKeyRange;\n\n  /** If true, values aren't read while iterating. */\n  keysOnly?: boolean;\n\n  /** If true, iterate over the store in reverse. */\n  reverse?: boolean;\n}\n\n/** An error that wraps exceptions that thrown during IndexedDB execution. */\nexport class IndexedDbTransactionError extends FirestoreError {\n  name = 'IndexedDbTransactionError';\n\n  constructor(actionName: string, cause: Error | string) {\n    super(\n      Code.UNAVAILABLE,\n      `IndexedDB transaction '${actionName}' failed: ${cause}`\n    );\n  }\n}\n\n/** Verifies whether `e` is an IndexedDbTransactionError. */\nexport function isIndexedDbTransactionError(e: Error): boolean {\n  // Use name equality, as instanceof checks on errors don't work with errors\n  // that wrap other errors.\n  return e.name === 'IndexedDbTransactionError';\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 */\nexport class SimpleDbStore<\n  KeyType extends IDBValidKey,\n  ValueType extends unknown\n> {\n  constructor(private store: IDBObjectStore) {}\n\n  /**\n   * Writes a value into the Object Store.\n   *\n   * @param key - Optional explicit key to use when writing the object, else the\n   * key will be auto-assigned (e.g. via the defined keyPath for the store).\n   * @param value - The object to write.\n   */\n  put(value: ValueType): PersistencePromise<void>;\n  put(key: KeyType, value: ValueType): PersistencePromise<void>;\n  put(\n    keyOrValue: KeyType | ValueType,\n    value?: ValueType\n  ): PersistencePromise<void> {\n    let request;\n    if (value !== undefined) {\n      logDebug(LOG_TAG, 'PUT', this.store.name, keyOrValue, value);\n      request = this.store.put(value, keyOrValue as KeyType);\n    } else {\n      logDebug(LOG_TAG, 'PUT', this.store.name, '<auto-key>', keyOrValue);\n      request = this.store.put(keyOrValue as ValueType);\n    }\n    return wrapRequest<void>(request);\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  add(value: ValueType): PersistencePromise<KeyType> {\n    logDebug(LOG_TAG, 'ADD', this.store.name, value, value);\n    const request = this.store.add(value as ValueType);\n    return wrapRequest<KeyType>(request);\n  }\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  get(key: KeyType): PersistencePromise<ValueType | null> {\n    const request = this.store.get(key);\n    // We're doing an unsafe cast to ValueType.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return wrapRequest<any>(request).next(result => {\n      // Normalize nonexistence to null.\n      if (result === undefined) {\n        result = null;\n      }\n      logDebug(LOG_TAG, 'GET', this.store.name, key, result);\n      return result;\n    });\n  }\n\n  delete(key: KeyType | IDBKeyRange): PersistencePromise<void> {\n    logDebug(LOG_TAG, 'DELETE', this.store.name, key);\n    const request = this.store.delete(key);\n    return wrapRequest<void>(request);\n  }\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  count(): PersistencePromise<number> {\n    logDebug(LOG_TAG, 'COUNT', this.store.name);\n    const request = this.store.count();\n    return wrapRequest<number>(request);\n  }\n\n  /** Loads all elements from the object store. */\n  loadAll(): PersistencePromise<ValueType[]>;\n  /** Loads all elements for the index range from the object store. */\n  loadAll(range: IDBKeyRange): PersistencePromise<ValueType[]>;\n  /** Loads all elements ordered by the given index. */\n  loadAll(index: string): PersistencePromise<ValueType[]>;\n  /**\n   * Loads all elements from the object store that fall into the provided in the\n   * index range for the given index.\n   */\n  loadAll(index: string, range: IDBKeyRange): PersistencePromise<ValueType[]>;\n  loadAll(\n    indexOrRange?: string | IDBKeyRange,\n    range?: IDBKeyRange\n  ): PersistencePromise<ValueType[]> {\n    const iterateOptions = this.options(indexOrRange, range);\n    // Use `getAll()` if the browser supports IndexedDB v3, as it is roughly\n    // 20% faster.\n    const store = iterateOptions.index\n      ? this.store.index(iterateOptions.index)\n      : this.store;\n    if (typeof store.getAll === 'function') {\n      const request = store.getAll(iterateOptions.range);\n      return new PersistencePromise((resolve, reject) => {\n        request.onerror = (event: Event) => {\n          reject((event.target as IDBRequest).error!);\n        };\n        request.onsuccess = (event: Event) => {\n          resolve((event.target as IDBRequest).result);\n        };\n      });\n    } else {\n      const cursor = this.cursor(iterateOptions);\n      const results: ValueType[] = [];\n      return this.iterateCursor(cursor, (key, value) => {\n        results.push(value);\n      }).next(() => {\n        return results;\n      });\n    }\n  }\n\n  /**\n   * Loads the first `count` elements from the provided index range. Loads all\n   * elements if no limit is provided.\n   */\n  loadFirst(\n    range: IDBKeyRange,\n    count: number | null\n  ): PersistencePromise<ValueType[]> {\n    const request = this.store.getAll(\n      range,\n      count === null ? undefined : count\n    );\n    return new PersistencePromise((resolve, reject) => {\n      request.onerror = (event: Event) => {\n        reject((event.target as IDBRequest).error!);\n      };\n      request.onsuccess = (event: Event) => {\n        resolve((event.target as IDBRequest).result);\n      };\n    });\n  }\n\n  deleteAll(): PersistencePromise<void>;\n  deleteAll(range: IDBKeyRange): PersistencePromise<void>;\n  deleteAll(index: string, range: IDBKeyRange): PersistencePromise<void>;\n  deleteAll(\n    indexOrRange?: string | IDBKeyRange,\n    range?: IDBKeyRange\n  ): PersistencePromise<void> {\n    logDebug(LOG_TAG, 'DELETE ALL', this.store.name);\n    const options = this.options(indexOrRange, range);\n    options.keysOnly = false;\n    const cursor = this.cursor(options);\n    return this.iterateCursor(cursor, (key, value, control) => {\n      // NOTE: Calling delete() on a cursor is documented as more efficient than\n      // calling delete() on an object store with a single key\n      // (https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/delete),\n      // however, this requires us *not* to use a keysOnly cursor\n      // (https://developer.mozilla.org/en-US/docs/Web/API/IDBCursor/delete). We\n      // may want to compare the performance of each method.\n      return control.delete();\n    });\n  }\n\n  /**\n   * Iterates over keys and values in an object store.\n   *\n   * @param options - Options specifying how to iterate the objects in the\n   * store.\n   * @param callback - will be called for each iterated object. Iteration can be\n   * canceled at any point by calling the doneFn passed to the callback.\n   * The callback can return a PersistencePromise if it performs async\n   * operations but note that iteration will continue without waiting for them\n   * to complete.\n   * @returns A PersistencePromise that resolves once all PersistencePromises\n   * returned by callbacks resolve.\n   */\n  iterate(\n    callback: IterateCallback<KeyType, ValueType>\n  ): PersistencePromise<void>;\n  iterate(\n    options: IterateOptions,\n    callback: IterateCallback<KeyType, ValueType>\n  ): PersistencePromise<void>;\n  iterate(\n    optionsOrCallback: IterateOptions | IterateCallback<KeyType, ValueType>,\n    callback?: IterateCallback<KeyType, ValueType>\n  ): PersistencePromise<void> {\n    let options;\n    if (!callback) {\n      options = {};\n      callback = optionsOrCallback as IterateCallback<KeyType, ValueType>;\n    } else {\n      options = optionsOrCallback as IterateOptions;\n    }\n    const cursor = this.cursor(options);\n    return this.iterateCursor(cursor, callback);\n  }\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  iterateSerial(\n    callback: (k: KeyType, v: ValueType) => PersistencePromise<boolean>\n  ): PersistencePromise<void> {\n    const cursorRequest = this.cursor({});\n    return new PersistencePromise((resolve, reject) => {\n      cursorRequest.onerror = (event: Event) => {\n        const error = checkForAndReportiOSError(\n          (event.target as IDBRequest).error!\n        );\n        reject(error);\n      };\n      cursorRequest.onsuccess = (event: Event) => {\n        const cursor: IDBCursorWithValue = (event.target as IDBRequest).result;\n        if (!cursor) {\n          resolve();\n          return;\n        }\n\n        callback(cursor.primaryKey as KeyType, cursor.value).next(\n          shouldContinue => {\n            if (shouldContinue) {\n              cursor.continue();\n            } else {\n              resolve();\n            }\n          }\n        );\n      };\n    });\n  }\n\n  private iterateCursor(\n    cursorRequest: IDBRequest,\n    fn: IterateCallback<KeyType, ValueType>\n  ): PersistencePromise<void> {\n    const results: Array<PersistencePromise<void>> = [];\n    return new PersistencePromise((resolve, reject) => {\n      cursorRequest.onerror = (event: Event) => {\n        reject((event.target as IDBRequest).error!);\n      };\n      cursorRequest.onsuccess = (event: Event) => {\n        const cursor: IDBCursorWithValue = (event.target as IDBRequest).result;\n        if (!cursor) {\n          resolve();\n          return;\n        }\n        const controller = new IterationController(cursor);\n        const userResult = fn(\n          cursor.primaryKey as KeyType,\n          cursor.value,\n          controller\n        );\n        if (userResult instanceof PersistencePromise) {\n          const userPromise: PersistencePromise<void> = userResult.catch(\n            err => {\n              controller.done();\n              return PersistencePromise.reject(err);\n            }\n          );\n          results.push(userPromise);\n        }\n        if (controller.isDone) {\n          resolve();\n        } else if (controller.skipToKey === null) {\n          cursor.continue();\n        } else {\n          cursor.continue(controller.skipToKey);\n        }\n      };\n    }).next(() => PersistencePromise.waitFor(results));\n  }\n\n  private options(\n    indexOrRange?: string | IDBKeyRange,\n    range?: IDBKeyRange\n  ): IterateOptions {\n    let indexName: string | undefined = undefined;\n    if (indexOrRange !== undefined) {\n      if (typeof indexOrRange === 'string') {\n        indexName = indexOrRange;\n      } else {\n        debugAssert(\n          range === undefined,\n          '3rd argument must not be defined if 2nd is a range.'\n        );\n        range = indexOrRange;\n      }\n    }\n    return { index: indexName, range };\n  }\n\n  private cursor(options: IterateOptions): IDBRequest {\n    let direction: IDBCursorDirection = 'next';\n    if (options.reverse) {\n      direction = 'prev';\n    }\n    if (options.index) {\n      const index = this.store.index(options.index);\n      if (options.keysOnly) {\n        return index.openKeyCursor(options.range, direction);\n      } else {\n        return index.openCursor(options.range, direction);\n      }\n    } else {\n      return this.store.openCursor(options.range, direction);\n    }\n  }\n}\n\n/**\n * Wraps an IDBRequest in a PersistencePromise, using the onsuccess / onerror\n * handlers to resolve / reject the PersistencePromise as appropriate.\n */\nfunction wrapRequest<R>(request: IDBRequest): PersistencePromise<R> {\n  return new PersistencePromise<R>((resolve, reject) => {\n    request.onsuccess = (event: Event) => {\n      const result = (event.target as IDBRequest).result;\n      resolve(result);\n    };\n\n    request.onerror = (event: Event) => {\n      const error = checkForAndReportiOSError(\n        (event.target as IDBRequest).error!\n      );\n      reject(error);\n    };\n  });\n}\n\n// Guard so we only report the error once.\nlet reportedIOSError = false;\nfunction checkForAndReportiOSError(error: DOMException): Error {\n  const iOSVersion = SimpleDb.getIOSVersion(getUA());\n  if (iOSVersion >= 12.2 && iOSVersion < 13) {\n    const IOS_ERROR =\n      'An internal error was encountered in the Indexed Database server';\n    if (error.message.indexOf(IOS_ERROR) >= 0) {\n      // Wrap error in a more descriptive one.\n      const newError = new FirestoreError(\n        'internal',\n        `IOS_INDEXEDDB_BUG1: IndexedDb has thrown '${IOS_ERROR}'. This is likely ` +\n          `due to an unavoidable bug in iOS. See https://stackoverflow.com/q/56496296/110915 ` +\n          `for details and a potential workaround.`\n      );\n      if (!reportedIOSError) {\n        reportedIOSError = true;\n        // Throw a global exception outside of this promise chain, for the user to\n        // potentially catch.\n        setTimeout(() => {\n          throw newError;\n        }, 0);\n      }\n      return newError;\n    }\n  }\n  return error;\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 { ListenSequenceNumber } from './types';\n\n/**\n * `SequenceNumberSyncer` defines the methods required to keep multiple instances of a\n * `ListenSequence` in sync.\n */\nexport interface SequenceNumberSyncer {\n  // Notify the syncer that a new sequence number has been used.\n  writeSequenceNumber(sequenceNumber: ListenSequenceNumber): void;\n  // Setting this property allows the syncer to notify when a sequence number has been used, and\n  // and lets the ListenSequence adjust its internal previous value accordingly.\n  sequenceNumberHandler:\n    | ((sequenceNumber: ListenSequenceNumber) => void)\n    | null;\n}\n\n/**\n * `ListenSequence` is a monotonic sequence. It is initialized with a minimum value to\n * exceed. All subsequent calls to next will return increasing values. If provided with a\n * `SequenceNumberSyncer`, it will additionally bump its next value when told of a new value, as\n * well as write out sequence numbers that it produces via `next()`.\n */\nexport class ListenSequence {\n  static readonly INVALID: ListenSequenceNumber = -1;\n\n  private writeNewSequenceNumber?: (\n    newSequenceNumber: ListenSequenceNumber\n  ) => void;\n\n  constructor(\n    private previousValue: ListenSequenceNumber,\n    sequenceNumberSyncer?: SequenceNumberSyncer\n  ) {\n    if (sequenceNumberSyncer) {\n      sequenceNumberSyncer.sequenceNumberHandler = sequenceNumber =>\n        this.setPreviousValue(sequenceNumber);\n      this.writeNewSequenceNumber = sequenceNumber =>\n        sequenceNumberSyncer.writeSequenceNumber(sequenceNumber);\n    }\n  }\n\n  private setPreviousValue(\n    externalPreviousValue: ListenSequenceNumber\n  ): ListenSequenceNumber {\n    this.previousValue = Math.max(externalPreviousValue, this.previousValue);\n    return this.previousValue;\n  }\n\n  next(): ListenSequenceNumber {\n    const nextValue = ++this.previousValue;\n    if (this.writeNewSequenceNumber) {\n      this.writeNewSequenceNumber(nextValue);\n    }\n    return nextValue;\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/** Sentinel value that sorts before any Mutation Batch ID. */\nexport const BATCHID_UNKNOWN = -1;\n\n// An Object whose keys and values are strings.\nexport interface StringMap {\n  [key: string]: string;\n}\n\n/**\n * Returns whether a variable is either undefined or null.\n */\nexport function isNullOrUndefined(value: unknown): value is null | undefined {\n  return value === null || value === undefined;\n}\n\n/** Returns whether the value represents -0. */\nexport function isNegativeZero(value: number): boolean {\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 value === 0 && 1 / value === 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 */\nexport function isSafeInteger(value: unknown): boolean {\n  return (\n    typeof value === 'number' &&\n    Number.isInteger(value) &&\n    !isNegativeZero(value) &&\n    value <= Number.MAX_SAFE_INTEGER &&\n    value >= Number.MIN_SAFE_INTEGER\n  );\n}\n\n/** The subset of the browser's Window interface used by the SDK. */\nexport interface WindowLike {\n  readonly localStorage: Storage;\n  readonly indexedDB: IDBFactory | null;\n  addEventListener(type: string, listener: EventListener): void;\n  removeEventListener(type: string, listener: EventListener): void;\n}\n\n/** The subset of the browser's Document interface used by the SDK. */\nexport interface DocumentLike {\n  readonly visibilityState: DocumentVisibilityState;\n  addEventListener(type: string, listener: EventListener): void;\n  removeEventListener(type: string, listener: EventListener): 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 { ResourcePath } from '../model/path';\nimport { fail, hardAssert } from '../util/assert';\n\n/**\n * Helpers for dealing with resource paths stored in IndexedDB.\n *\n * Resource paths in their canonical string form do not sort as the server\n * sorts them. Specifically the server splits paths into segments first and then\n * sorts, putting end-of-segment before any character. In a UTF-8 string\n * encoding the slash ('/') that denotes the end-of-segment naturally comes\n * after other characters so the intent here is to encode the path delimiters in\n * such a way that the resulting strings sort naturally.\n *\n * Resource paths are also used for prefix scans so it's important to\n * distinguish whole segments from any longer segments of which they might be a\n * prefix. For example, it's important to make it possible to scan documents in\n * a collection \"foo\" without encountering documents in a collection \"foobar\".\n *\n * Separate from the concerns about resource path ordering and separation,\n * On Android, SQLite imposes additional restrictions since it does not handle\n * keys with embedded NUL bytes particularly well. Rather than change the\n * implementation we keep the encoding identical to keep the ports similar.\n *\n * Taken together this means resource paths when encoded for storage in\n * IndexedDB have the following characteristics:\n *\n *   * Segment separators (\"/\") sort before everything else.\n *   * All paths have a trailing separator.\n *   * NUL bytes do not exist in the output, since IndexedDB doesn't treat them\n * well.\n *\n * Therefore resource paths are encoded into string form using the following\n * rules:\n *\n *   * '\\x01' is used as an escape character.\n *   * Path separators are encoded as \"\\x01\\x01\"\n *   * NUL bytes are encoded as \"\\x01\\x10\"\n *   * '\\x01' is encoded as \"\\x01\\x11\"\n *\n * This encoding leaves some room between path separators and the NUL byte\n * just in case we decide to support integer document ids after all.\n *\n * Note that characters treated specially by the backend ('.', '/', and '~')\n * are not treated specially here. This class assumes that any unescaping of\n * resource path strings into actual ResourcePath objects will handle these\n * characters there.\n */\nexport type EncodedResourcePath = string;\n\nconst escapeChar = '\\u0001';\nconst encodedSeparatorChar = '\\u0001';\nconst encodedNul = '\\u0010';\nconst encodedEscape = '\\u0011';\n\n/**\n * Encodes a resource path into a IndexedDb-compatible string form.\n */\nexport function encodeResourcePath(path: ResourcePath): EncodedResourcePath {\n  let result = '';\n  for (let i = 0; i < path.length; i++) {\n    if (result.length > 0) {\n      result = encodeSeparator(result);\n    }\n    result = encodeSegment(path.get(i), result);\n  }\n  return encodeSeparator(result);\n}\n\n/** Encodes a single segment of a resource path into the given result */\nfunction encodeSegment(segment: string, resultBuf: string): string {\n  let result = resultBuf;\n  const length = segment.length;\n  for (let i = 0; i < length; i++) {\n    const c = segment.charAt(i);\n    switch (c) {\n      case '\\0':\n        result += escapeChar + encodedNul;\n        break;\n      case escapeChar:\n        result += escapeChar + encodedEscape;\n        break;\n      default:\n        result += c;\n    }\n  }\n  return result;\n}\n\n/** Encodes a path separator into the given result */\nfunction encodeSeparator(result: string): string {\n  return result + escapeChar + encodedSeparatorChar;\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 */\nexport function decodeResourcePath(path: EncodedResourcePath): ResourcePath {\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  const length = path.length;\n  hardAssert(length >= 2, 'Invalid path ' + path);\n  if (length === 2) {\n    hardAssert(\n      path.charAt(0) === escapeChar && path.charAt(1) === encodedSeparatorChar,\n      'Non-empty path ' + path + ' had length 2'\n    );\n    return ResourcePath.emptyPath();\n  }\n\n  // Escape characters cannot exist past the second-to-last position in the\n  // source value.\n  const lastReasonableEscapeIndex = length - 2;\n\n  const segments: string[] = [];\n  let segmentBuilder = '';\n\n  for (let start = 0; start < length; ) {\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    const end = path.indexOf(escapeChar, start);\n    if (end < 0 || end > lastReasonableEscapeIndex) {\n      fail('Invalid encoded resource path: \"' + path + '\"');\n    }\n\n    const next = path.charAt(end + 1);\n    switch (next) {\n      case encodedSeparatorChar:\n        const currentPiece = path.substring(start, end);\n        let segment;\n        if (segmentBuilder.length === 0) {\n          // Avoid copying for the common case of a segment that excludes \\0\n          // and \\001\n          segment = currentPiece;\n        } else {\n          segmentBuilder += currentPiece;\n          segment = segmentBuilder;\n          segmentBuilder = '';\n        }\n        segments.push(segment);\n        break;\n      case encodedNul:\n        segmentBuilder += path.substring(start, end);\n        segmentBuilder += '\\0';\n        break;\n      case encodedEscape:\n        // The escape character can be used in the output to encode itself.\n        segmentBuilder += path.substring(start, end + 1);\n        break;\n      default:\n        fail('Invalid encoded resource path: \"' + path + '\"');\n    }\n\n    start = end + 2;\n  }\n\n  return new ResourcePath(segments);\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { BatchId, TargetId } from '../core/types';\nimport { ResourcePath } from '../model/path';\nimport { fail } from '../util/assert';\n\nimport {\n  EncodedResourcePath,\n  encodeResourcePath\n} from './encoded_resource_path';\nimport { DbDocumentMutation } from './indexeddb_schema';\nimport { DbRemoteDocumentStore as DbRemoteDocumentStoreLegacy } from './indexeddb_schema_legacy';\n\n// This file contains static constants and helper functions for IndexedDB.\n// It is split from indexeddb_schema to allow for minification.\n\n/** A timestamp type that can be used in IndexedDb keys. */\nexport type DbTimestampKey = [/* seconds */ number, /* nanos */ number];\n\n// The key for the singleton object in the DbPrimaryClient is a single string.\nexport type DbPrimaryClientKey = typeof DbPrimaryClientKey;\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 */\nexport const DbPrimaryClientStore = 'owner';\n\n/**\n * The key string used for the single object that exists in the\n * DbPrimaryClient store.\n */\n\nexport const DbPrimaryClientKey = 'owner';\n\n/** Object keys in the 'mutationQueues' store are userId strings. */\nexport type DbMutationQueueKey = string;\n\n/** Name of the IndexedDb object store.  */\nexport const DbMutationQueueStore = 'mutationQueues';\n\n/** Keys are automatically assigned via the userId property. */\nexport const DbMutationQueueKeyPath = 'userId';\n\n/** The 'mutations' store  is keyed by batch ID. */\nexport type DbMutationBatchKey = BatchId;\n\n/** Name of the IndexedDb object store.  */\nexport const DbMutationBatchStore = 'mutations';\n\n/** Keys are automatically assigned via the userId, batchId properties. */\nexport const DbMutationBatchKeyPath = 'batchId';\n\n/** The index name for lookup of mutations by user. */\n\nexport const DbMutationBatchUserMutationsIndex = 'userMutationsIndex';\n\n/** The user mutations index is keyed by [userId, batchId] pairs. */\nexport const DbMutationBatchUserMutationsKeyPath = ['userId', 'batchId'];\n\n/**\n * The key for a db document mutation, which is made up of a userID, path, and\n * batchId. Note that the path must be serialized into a form that indexedDB can\n * sort.\n */\nexport type DbDocumentMutationKey = [string, EncodedResourcePath, BatchId];\n\n/**\n * Creates a [userId] key for use in the DbDocumentMutations index to iterate\n * over all of a user's document mutations.\n */\nexport function newDbDocumentMutationPrefixForUser(userId: string): [string] {\n  return [userId];\n}\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 */\nexport function newDbDocumentMutationPrefixForPath(\n  userId: string,\n  path: ResourcePath\n): [string, EncodedResourcePath] {\n  return [userId, encodeResourcePath(path)];\n}\n\n/**\n * Creates a full index key of [userId, encodedPath, batchId] for inserting\n * and deleting into the DbDocumentMutations index.\n */\nexport function newDbDocumentMutationKey(\n  userId: string,\n  path: ResourcePath,\n  batchId: BatchId\n): DbDocumentMutationKey {\n  return [userId, encodeResourcePath(path), batchId];\n}\n\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 */\nexport const DbDocumentMutationPlaceholder: DbDocumentMutation = {};\n\nexport const DbDocumentMutationStore = 'documentMutations';\n\nexport const DbRemoteDocumentStore = 'remoteDocumentsV14';\n\n/**\n * A key in the 'remoteDocumentsV14' object store is an array containing the\n * collection path, the collection group, the read time and the document id.\n */\nexport type DbRemoteDocumentKey = [\n  /** path to collection */ string[],\n  /** collection group */ string,\n  /** read time */ DbTimestampKey,\n  /** document ID */ string\n];\n\n/**\n * The primary key of the remote documents store, which allows for efficient\n * access by collection path and read time.\n */\nexport const DbRemoteDocumentKeyPath = [\n  'prefixPath',\n  'collectionGroup',\n  'readTime',\n  'documentId'\n];\n\n/** An index that provides access to documents by key. */\nexport const DbRemoteDocumentDocumentKeyIndex = 'documentKeyIndex';\n\nexport const DbRemoteDocumentDocumentKeyIndexPath = [\n  'prefixPath',\n  'collectionGroup',\n  'documentId'\n];\n\n/**\n * An index that provides access to documents by collection group and read\n * time.\n *\n * This index is used by the index backfiller.\n */\nexport const DbRemoteDocumentCollectionGroupIndex = 'collectionGroupIndex';\n\nexport const DbRemoteDocumentCollectionGroupIndexPath = [\n  'collectionGroup',\n  'readTime',\n  'prefixPath',\n  'documentId'\n];\n\nexport const DbRemoteDocumentGlobalStore = 'remoteDocumentGlobal';\n\nexport const DbRemoteDocumentGlobalKey = 'remoteDocumentGlobalKey';\n\nexport type DbRemoteDocumentGlobalKey = typeof DbRemoteDocumentGlobalKey;\n\n/**\n * A key in the 'targets' object store is a targetId of the query.\n */\nexport type DbTargetKey = TargetId;\n\nexport const DbTargetStore = 'targets';\n\n/** Keys are automatically assigned via the targetId property. */\nexport const DbTargetKeyPath = 'targetId';\n\n/** The name of the queryTargets index. */\nexport const DbTargetQueryTargetsIndexName = 'queryTargetsIndex';\n\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 */\nexport const DbTargetQueryTargetsKeyPath = ['canonicalId', 'targetId'];\n\n/**\n * The key for a DbTargetDocument, containing a targetId and an encoded resource\n * path.\n */\nexport type DbTargetDocumentKey = [TargetId, EncodedResourcePath];\n\n/** Name of the IndexedDb object store.  */\nexport const DbTargetDocumentStore = 'targetDocuments';\n\n/** Keys are automatically assigned via the targetId, path properties. */\nexport const DbTargetDocumentKeyPath = ['targetId', 'path'];\n\n/** The index name for the reverse index. */\nexport const DbTargetDocumentDocumentTargetsIndex = 'documentTargetsIndex';\n\n/** We also need to create the reverse index for these properties. */\nexport const DbTargetDocumentDocumentTargetsKeyPath = ['path', 'targetId'];\n\n/**\n * The type to represent the single allowed key for the DbTargetGlobal store.\n */\nexport type DbTargetGlobalKey = typeof DbTargetGlobalKey;\n\n/**\n * The key string used for the single object that exists in the\n * DbTargetGlobal store.\n */\nexport const DbTargetGlobalKey = 'targetGlobalKey';\n\nexport const DbTargetGlobalStore = 'targetGlobal';\n\n/**\n * The key for a DbCollectionParent entry, containing the collection ID\n * and the parent path that contains it. Note that the parent path will be an\n * empty path in the case of root-level collections.\n */\nexport type DbCollectionParentKey = [string, EncodedResourcePath];\n\n/** Name of the IndexedDb object store. */\nexport const DbCollectionParentStore = 'collectionParents';\n\n/** Keys are automatically assigned via the collectionId, parent properties. */\nexport const DbCollectionParentKeyPath = ['collectionId', 'parent'];\n\n/** Name of the IndexedDb object store. */\nexport const DbClientMetadataStore = 'clientMetadata';\n\n/** Keys are automatically assigned via the clientId properties. */\nexport const DbClientMetadataKeyPath = 'clientId';\n\n/** Object keys in the 'clientMetadata' store are clientId strings. */\nexport type DbClientMetadataKey = string;\n\nexport type DbBundlesKey = string;\n\n/** Name of the IndexedDb object store. */\nexport const DbBundleStore = 'bundles';\n\nexport const DbBundleKeyPath = 'bundleId';\n\nexport type DbNamedQueriesKey = string;\n\n/** Name of the IndexedDb object store. */\nexport const DbNamedQueryStore = 'namedQueries';\n\nexport const DbNamedQueryKeyPath = 'name';\n\n/** The key for each index consisting of just the index id. */\nexport type DbIndexConfigurationKey = number;\n\n/** Name of the IndexedDb object store. */\nexport const DbIndexConfigurationStore = 'indexConfiguration';\n\nexport const DbIndexConfigurationKeyPath = 'indexId';\n\n/**\n * An index that provides access to the index configurations by collection\n * group.\n *\n * PORTING NOTE: iOS and Android maintain this index in-memory, but this is\n * not possible here as the Web client supports concurrent access to\n * persistence via multi-tab.\n */\nexport const DbIndexConfigurationCollectionGroupIndex = 'collectionGroupIndex';\n\nexport const DbIndexConfigurationCollectionGroupIndexPath = 'collectionGroup';\n\n/** The key for each index state consisting of the index id and its user id. */\nexport type DbIndexStateKey = [number, string];\n\n/** Name of the IndexedDb object store. */\nexport const DbIndexStateStore = 'indexState';\n\nexport const DbIndexStateKeyPath = ['indexId', 'uid'];\n\n/**\n * An index that provides access to documents in a collection sorted by last\n * update time. Used by the backfiller.\n *\n * PORTING NOTE: iOS and Android maintain this index in-memory, but this is\n * not possible here as the Web client supports concurrent access to\n * persistence via multi-tab.\n */\nexport const DbIndexStateSequenceNumberIndex = 'sequenceNumberIndex';\n\nexport const DbIndexStateSequenceNumberIndexPath = ['uid', 'sequenceNumber'];\n\n/**\n * The key for each index entry consists of the index id and its user id,\n * the encoded array and directional value for the indexed fields as well as\n * an ordered and an encoded document path for the indexed document.\n */\nexport type DbIndexEntryKey = [\n  number,\n  string,\n  Uint8Array,\n  Uint8Array,\n  Uint8Array,\n  string[]\n];\n\n/** Name of the IndexedDb object store. */\nexport const DbIndexEntryStore = 'indexEntries';\n\nexport const DbIndexEntryKeyPath = [\n  'indexId',\n  'uid',\n  'arrayValue',\n  'directionalValue',\n  'orderedDocumentKey',\n  'documentKey'\n];\n\nexport const DbIndexEntryDocumentKeyIndex = 'documentKeyIndex';\n\nexport const DbIndexEntryDocumentKeyIndexPath = [\n  'indexId',\n  'uid',\n  'orderedDocumentKey'\n];\n\nexport type DbDocumentOverlayKey = [\n  /* userId */ string,\n  /* collectionPath */ string,\n  /* documentId */ string\n];\n\n/** Name of the IndexedDb object store. */\nexport const DbDocumentOverlayStore = 'documentOverlays';\n\nexport const DbDocumentOverlayKeyPath = [\n  'userId',\n  'collectionPath',\n  'documentId'\n];\n\nexport const DbDocumentOverlayCollectionPathOverlayIndex =\n  'collectionPathOverlayIndex';\n\nexport const DbDocumentOverlayCollectionPathOverlayIndexPath = [\n  'userId',\n  'collectionPath',\n  'largestBatchId'\n];\n\nexport const DbDocumentOverlayCollectionGroupOverlayIndex =\n  'collectionGroupOverlayIndex';\n\nexport const DbDocumentOverlayCollectionGroupOverlayIndexPath = [\n  'userId',\n  'collectionGroup',\n  'largestBatchId'\n];\n\n/** Name of the IndexedDb object store. */\nexport const DbGlobalsStore = 'globals';\n\nexport const DbGlobalsKeyPath = 'name';\n\n/** Names of global values */\nexport type DbGlobalsKey = 'sessionToken';\n\n// Visible for testing\nexport const V1_STORES = [\n  DbMutationQueueStore,\n  DbMutationBatchStore,\n  DbDocumentMutationStore,\n  DbRemoteDocumentStoreLegacy,\n  DbTargetStore,\n  DbPrimaryClientStore,\n  DbTargetGlobalStore,\n  DbTargetDocumentStore\n];\n\n// Visible for testing\nexport const V3_STORES = V1_STORES;\n// Note: DbRemoteDocumentChanges is no longer used and dropped with v9.\nexport const V4_STORES = [...V3_STORES, DbClientMetadataStore];\nexport const V6_STORES = [...V4_STORES, DbRemoteDocumentGlobalStore];\nexport const V8_STORES = [...V6_STORES, DbCollectionParentStore];\nexport const V11_STORES = [...V8_STORES, DbBundleStore, DbNamedQueryStore];\nexport const V12_STORES = [...V11_STORES, DbDocumentOverlayStore];\nexport const V13_STORES = [\n  DbMutationQueueStore,\n  DbMutationBatchStore,\n  DbDocumentMutationStore,\n  DbRemoteDocumentStore,\n  DbTargetStore,\n  DbPrimaryClientStore,\n  DbTargetGlobalStore,\n  DbTargetDocumentStore,\n  DbClientMetadataStore,\n  DbRemoteDocumentGlobalStore,\n  DbCollectionParentStore,\n  DbBundleStore,\n  DbNamedQueryStore,\n  DbDocumentOverlayStore\n];\nexport const V14_STORES = V13_STORES;\nexport const V15_STORES = [\n  ...V14_STORES,\n  DbIndexConfigurationStore,\n  DbIndexStateStore,\n  DbIndexEntryStore\n];\nexport const V16_STORES = V15_STORES;\nexport const V17_STORES = [...V15_STORES, DbGlobalsStore];\n\n/**\n * The list of all default IndexedDB stores used throughout the SDK. This is\n * used when creating transactions so that access across all stores is done\n * atomically.\n */\nexport const ALL_STORES = V12_STORES;\n\n/** Returns the object stores for the provided schema. */\nexport function getObjectStores(schemaVersion: number): string[] {\n  if (schemaVersion === 17) {\n    return V17_STORES;\n  } else if (schemaVersion === 16) {\n    return V16_STORES;\n  } else if (schemaVersion === 15) {\n    return V15_STORES;\n  } else if (schemaVersion === 14) {\n    return V14_STORES;\n  } else if (schemaVersion === 13) {\n    return V13_STORES;\n  } else if (schemaVersion === 12) {\n    return V12_STORES;\n  } else if (schemaVersion === 11) {\n    return V11_STORES;\n  } else {\n    fail('Only schema version 11 and 12 and 13 are supported');\n  }\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { Document as ProtoDocument } from '../protos/firestore_proto_api';\n\nimport { DbNoDocument, DbUnknownDocument } from './indexeddb_schema';\nimport { DbTimestampKey } from './indexeddb_sentinels';\n\n// This file contains older schema definitions for object stores that were\n// migrated to newer schema versions. These object stores should only be used\n// during schema migrations.\n\nexport interface DbRemoteDocument {\n  unknownDocument?: DbUnknownDocument;\n  noDocument?: DbNoDocument;\n  document?: ProtoDocument;\n  hasCommittedMutations?: boolean;\n  readTime?: DbTimestampKey;\n  parentPath?: string[];\n}\n\nexport type DbRemoteDocumentKey = string[];\nexport const DbRemoteDocumentStore = 'remoteDocuments';\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 { debugAssert } from './assert';\n\nexport interface Dict<V> {\n  [stringKey: string]: V;\n}\n\nexport function objectSize(obj: object): number {\n  let count = 0;\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      count++;\n    }\n  }\n  return count;\n}\n\nexport function forEach<V>(\n  obj: Dict<V> | undefined,\n  fn: (key: string, val: V) => void\n): void {\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      fn(key, obj[key]);\n    }\n  }\n}\n\nexport function mapToArray<V, R>(\n  obj: Dict<V>,\n  fn: (element: V, key: string, obj: Dict<V>) => R\n): R[] {\n  const result: R[] = [];\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      result.push(fn(obj[key], key, obj));\n    }\n  }\n  return result;\n}\n\nexport function isEmpty<V>(obj: Dict<V>): boolean {\n  debugAssert(\n    obj != null && typeof obj === 'object',\n    'isEmpty() expects object parameter.'\n  );\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      return false;\n    }\n  }\n  return 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 { debugAssert, fail } from './assert';\n\n/*\n * 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\nexport type Comparator<K> = (key1: K, key2: K) => number;\n\nexport interface Entry<K, V> {\n  key: K;\n  value: V;\n}\n\n// An immutable sorted map implementation, based on a Left-leaning Red-Black\n// tree.\nexport class SortedMap<K, V> {\n  // visible for testing\n  root: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n\n  constructor(\n    public comparator: Comparator<K>,\n    root?: LLRBNode<K, V> | LLRBEmptyNode<K, V>\n  ) {\n    this.root = root ? root : LLRBNode.EMPTY;\n  }\n\n  // Returns a copy of the map, with the specified key/value added or replaced.\n  insert(key: K, value: V): SortedMap<K, V> {\n    return new SortedMap<K, V>(\n      this.comparator,\n      this.root\n        .insert(key, value, this.comparator)\n        .copy(null, null, LLRBNode.BLACK, null, null)\n    );\n  }\n\n  // Returns a copy of the map, with the specified key removed.\n  remove(key: K): SortedMap<K, V> {\n    return new SortedMap<K, V>(\n      this.comparator,\n      this.root\n        .remove(key, this.comparator)\n        .copy(null, null, LLRBNode.BLACK, null, null)\n    );\n  }\n\n  // Returns the value of the node with the given key, or null.\n  get(key: K): V | null {\n    let node = this.root;\n    while (!node.isEmpty()) {\n      const 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  // Returns the index of the element in this sorted map, or -1 if it doesn't\n  // exist.\n  indexOf(key: K): number {\n    // Number of nodes that were pruned when descending right\n    let prunedNodes = 0;\n    let node = this.root;\n    while (!node.isEmpty()) {\n      const cmp = this.comparator(key, node.key);\n      if (cmp === 0) {\n        return prunedNodes + node.left.size;\n      } else if (cmp < 0) {\n        node = node.left;\n      } else {\n        // Count all nodes left of the node plus the node itself\n        prunedNodes += node.left.size + 1;\n        node = node.right;\n      }\n    }\n    // Node not found\n    return -1;\n  }\n\n  isEmpty(): boolean {\n    return this.root.isEmpty();\n  }\n\n  // Returns the total number of nodes in the map.\n  get size(): number {\n    return this.root.size;\n  }\n\n  // Returns the minimum key in the map.\n  minKey(): K | null {\n    return this.root.minKey();\n  }\n\n  // Returns the maximum key in the map.\n  maxKey(): K | null {\n    return this.root.maxKey();\n  }\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  inorderTraversal<T>(action: (k: K, v: V) => T): T {\n    return (this.root as LLRBNode<K, V>).inorderTraversal(action);\n  }\n\n  forEach(fn: (k: K, v: V) => void): void {\n    this.inorderTraversal((k, v) => {\n      fn(k, v);\n      return false;\n    });\n  }\n\n  toString(): string {\n    const descriptions: string[] = [];\n    this.inorderTraversal((k, v) => {\n      descriptions.push(`${k}:${v}`);\n      return false;\n    });\n    return `{${descriptions.join(', ')}}`;\n  }\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  reverseTraversal<T>(action: (k: K, v: V) => T): T {\n    return (this.root as LLRBNode<K, V>).reverseTraversal(action);\n  }\n\n  // Returns an iterator over the SortedMap.\n  getIterator(): SortedMapIterator<K, V> {\n    return new SortedMapIterator<K, V>(this.root, null, this.comparator, false);\n  }\n\n  getIteratorFrom(key: K): SortedMapIterator<K, V> {\n    return new SortedMapIterator<K, V>(this.root, key, this.comparator, false);\n  }\n\n  getReverseIterator(): SortedMapIterator<K, V> {\n    return new SortedMapIterator<K, V>(this.root, null, this.comparator, true);\n  }\n\n  getReverseIteratorFrom(key: K): SortedMapIterator<K, V> {\n    return new SortedMapIterator<K, V>(this.root, key, this.comparator, true);\n  }\n} // end SortedMap\n\n// An iterator over an LLRBNode.\nexport class SortedMapIterator<K, V> {\n  private isReverse: boolean;\n  private nodeStack: Array<LLRBNode<K, V> | LLRBEmptyNode<K, V>>;\n\n  constructor(\n    node: LLRBNode<K, V> | LLRBEmptyNode<K, V>,\n    startKey: K | null,\n    comparator: Comparator<K>,\n    isReverse: boolean\n  ) {\n    this.isReverse = isReverse;\n    this.nodeStack = [];\n\n    let cmp = 1;\n    while (!node.isEmpty()) {\n      cmp = startKey ? comparator(node.key, startKey) : 1;\n      // flip the comparison if we're going in reverse\n      if (startKey && 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,\n        // 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\n        // 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(): Entry<K, V> {\n    debugAssert(\n      this.nodeStack.length > 0,\n      'getNext() called on iterator when hasNext() is false.'\n    );\n\n    let node = this.nodeStack.pop()!;\n    const result = { key: node.key, value: node.value };\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(): Entry<K, V> | null {\n    if (this.nodeStack.length === 0) {\n      return null;\n    }\n\n    const node = this.nodeStack[this.nodeStack.length - 1];\n    return { key: node.key, value: node.value };\n  }\n} // end SortedMapIterator\n\n// Represents a node in a Left-leaning Red-Black tree.\nexport class LLRBNode<K, V> {\n  readonly color: boolean;\n  readonly left: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n  readonly right: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n  readonly size: number;\n\n  // Empty node is shared between all LLRB trees.\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  static EMPTY: LLRBEmptyNode<any, any> = null as any;\n\n  static RED = true;\n  static BLACK = false;\n\n  constructor(\n    public key: K,\n    public value: V,\n    color?: boolean,\n    left?: LLRBNode<K, V> | LLRBEmptyNode<K, V>,\n    right?: LLRBNode<K, V> | LLRBEmptyNode<K, V>\n  ) {\n    this.color = color != null ? color : LLRBNode.RED;\n    this.left = left != null ? left : LLRBNode.EMPTY;\n    this.right = right != null ? right : LLRBNode.EMPTY;\n    this.size = this.left.size + 1 + this.right.size;\n  }\n\n  // Returns a copy of the current node, optionally replacing pieces of it.\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<K, V>(\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  isEmpty(): boolean {\n    return false;\n  }\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  inorderTraversal<T>(action: (k: K, v: V) => T): T {\n    return (\n      (this.left as LLRBNode<K, V>).inorderTraversal(action) ||\n      action(this.key, this.value) ||\n      (this.right as LLRBNode<K, V>).inorderTraversal(action)\n    );\n  }\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  reverseTraversal<T>(action: (k: K, v: V) => T): T {\n    return (\n      (this.right as LLRBNode<K, V>).reverseTraversal(action) ||\n      action(this.key, this.value) ||\n      (this.left as LLRBNode<K, V>).reverseTraversal(action)\n    );\n  }\n\n  // Returns the minimum node in the tree.\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  // Returns the maximum key in the tree.\n  minKey(): K | null {\n    return this.min().key;\n  }\n\n  // Returns the maximum key in the tree.\n  maxKey(): K | null {\n    if (this.right.isEmpty()) {\n      return this.key;\n    } else {\n      return this.right.maxKey();\n    }\n  }\n\n  // Returns new tree, with the key/value added.\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  private removeMin(): LLRBNode<K, V> | LLRBEmptyNode<K, V> {\n    if (this.left.isEmpty()) {\n      return LLRBNode.EMPTY;\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  // Returns new tree, with the specified item removed.\n  remove(\n    key: K,\n    comparator: Comparator<K>\n  ): LLRBNode<K, V> | LLRBEmptyNode<K, V> {\n    let smallest: LLRBNode<K, V>;\n    let n: LLRBNode<K, V> = 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 LLRBNode.EMPTY;\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  isRed(): boolean {\n    return this.color;\n  }\n\n  // Returns new tree after performing any needed rotations.\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  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  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  private rotateLeft(): LLRBNode<K, V> {\n    const nl = this.copy(null, null, LLRBNode.RED, null, this.right.left);\n    return (this.right as LLRBNode<K, V>).copy(\n      null,\n      null,\n      this.color,\n      nl,\n      null\n    );\n  }\n\n  private rotateRight(): LLRBNode<K, V> {\n    const nr = this.copy(null, null, LLRBNode.RED, this.left.right, null);\n    return (this.left as LLRBNode<K, V>).copy(null, null, this.color, null, nr);\n  }\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  // For testing.\n  checkMaxDepth(): boolean {\n    const blackDepth = this.check();\n    if (Math.pow(2.0, blackDepth) <= this.size + 1) {\n      return true;\n    } else {\n      return false;\n    }\n  }\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  protected check(): number {\n    if (this.isRed() && this.left.isRed()) {\n      throw fail('Red node has red child(' + this.key + ',' + this.value + ')');\n    }\n    if (this.right.isRed()) {\n      throw fail('Right child of (' + this.key + ',' + this.value + ') is red');\n    }\n    const blackDepth = (this.left as LLRBNode<K, V>).check();\n    if (blackDepth !== (this.right as LLRBNode<K, V>).check()) {\n      throw fail('Black depths differ');\n    } else {\n      return blackDepth + (this.isRed() ? 0 : 1);\n    }\n  }\n} // end LLRBNode\n\n// Represents an empty node (a leaf node in the Red-Black Tree).\nexport class LLRBEmptyNode<K, V> {\n  get key(): never {\n    throw fail('LLRBEmptyNode has no key.');\n  }\n  get value(): never {\n    throw fail('LLRBEmptyNode has no value.');\n  }\n  get color(): never {\n    throw fail('LLRBEmptyNode has no color.');\n  }\n  get left(): never {\n    throw fail('LLRBEmptyNode has no left child.');\n  }\n  get right(): never {\n    throw fail('LLRBEmptyNode has no right child.');\n  }\n  size = 0;\n\n  // Returns a copy of the current node.\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  // Returns a copy of the tree, with the specified key/value added.\n  insert(key: K, value: V, comparator: Comparator<K>): LLRBNode<K, V> {\n    return new LLRBNode<K, V>(key, value);\n  }\n\n  // Returns a copy of the tree, with the specified key removed.\n  remove(key: K, comparator: Comparator<K>): LLRBEmptyNode<K, V> {\n    return this;\n  }\n\n  isEmpty(): boolean {\n    return true;\n  }\n\n  inorderTraversal(action: (k: K, v: V) => boolean): boolean {\n    return false;\n  }\n\n  reverseTraversal(action: (k: K, v: V) => boolean): boolean {\n    return false;\n  }\n\n  minKey(): K | null {\n    return null;\n  }\n\n  maxKey(): K | null {\n    return null;\n  }\n\n  isRed(): boolean {\n    return false;\n  }\n\n  // For testing.\n  checkMaxDepth(): boolean {\n    return true;\n  }\n\n  protected check(): 0 {\n    return 0;\n  }\n} // end LLRBEmptyNode\n\nLLRBNode.EMPTY = new LLRBEmptyNode<unknown, unknown>();\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, SortedMapIterator } from './sorted_map';\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 */\nexport class SortedSet<T> {\n  private data: SortedMap<T, boolean>;\n\n  constructor(private comparator: (left: T, right: T) => number) {\n    this.data = new SortedMap<T, boolean>(this.comparator);\n  }\n\n  has(elem: T): boolean {\n    return this.data.get(elem) !== null;\n  }\n\n  first(): T | null {\n    return this.data.minKey();\n  }\n\n  last(): T | null {\n    return this.data.maxKey();\n  }\n\n  get size(): number {\n    return this.data.size;\n  }\n\n  indexOf(elem: T): number {\n    return this.data.indexOf(elem);\n  }\n\n  /** Iterates elements in order defined by \"comparator\" */\n  forEach(cb: (elem: T) => void): void {\n    this.data.inorderTraversal((k: T, v: boolean) => {\n      cb(k);\n      return false;\n    });\n  }\n\n  /** Iterates over `elem`s such that: range[0] &lt;= elem &lt; range[1]. */\n  forEachInRange(range: [T, T], cb: (elem: T) => void): void {\n    const iter = this.data.getIteratorFrom(range[0]);\n    while (iter.hasNext()) {\n      const elem = iter.getNext();\n      if (this.comparator(elem.key, range[1]) >= 0) {\n        return;\n      }\n      cb(elem.key);\n    }\n  }\n\n  /**\n   * Iterates over `elem`s such that: start &lt;= elem until false is returned.\n   */\n  forEachWhile(cb: (elem: T) => boolean, start?: T): void {\n    let iter: SortedMapIterator<T, boolean>;\n    if (start !== undefined) {\n      iter = this.data.getIteratorFrom(start);\n    } else {\n      iter = this.data.getIterator();\n    }\n    while (iter.hasNext()) {\n      const elem = iter.getNext();\n      const result = cb(elem.key);\n      if (!result) {\n        return;\n      }\n    }\n  }\n\n  /** Finds the least element greater than or equal to `elem`. */\n  firstAfterOrEqual(elem: T): T | null {\n    const iter = this.data.getIteratorFrom(elem);\n    return iter.hasNext() ? iter.getNext().key : null;\n  }\n\n  getIterator(): SortedSetIterator<T> {\n    return new SortedSetIterator<T>(this.data.getIterator());\n  }\n\n  getIteratorFrom(key: T): SortedSetIterator<T> {\n    return new SortedSetIterator<T>(this.data.getIteratorFrom(key));\n  }\n\n  /** Inserts or updates an element */\n  add(elem: T): SortedSet<T> {\n    return this.copy(this.data.remove(elem).insert(elem, true));\n  }\n\n  /** Deletes an element */\n  delete(elem: T): SortedSet<T> {\n    if (!this.has(elem)) {\n      return this;\n    }\n    return this.copy(this.data.remove(elem));\n  }\n\n  isEmpty(): boolean {\n    return this.data.isEmpty();\n  }\n\n  unionWith(other: SortedSet<T>): SortedSet<T> {\n    let result: SortedSet<T> = this;\n\n    // Make sure `result` always refers to the larger one of the two sets.\n    if (result.size < other.size) {\n      result = other;\n      other = this;\n    }\n\n    other.forEach(elem => {\n      result = result.add(elem);\n    });\n    return result;\n  }\n\n  isEqual(other: SortedSet<T>): boolean {\n    if (!(other instanceof SortedSet)) {\n      return false;\n    }\n    if (this.size !== other.size) {\n      return false;\n    }\n\n    const thisIt = this.data.getIterator();\n    const otherIt = other.data.getIterator();\n    while (thisIt.hasNext()) {\n      const thisElem = thisIt.getNext().key;\n      const otherElem = otherIt.getNext().key;\n      if (this.comparator(thisElem, otherElem) !== 0) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  toArray(): T[] {\n    const res: T[] = [];\n    this.forEach(targetId => {\n      res.push(targetId);\n    });\n    return res;\n  }\n\n  toString(): string {\n    const result: T[] = [];\n    this.forEach(elem => result.push(elem));\n    return 'SortedSet(' + result.toString() + ')';\n  }\n\n  private copy(data: SortedMap<T, boolean>): SortedSet<T> {\n    const result = new SortedSet(this.comparator);\n    result.data = data;\n    return result;\n  }\n}\n\nexport class SortedSetIterator<T> {\n  constructor(private iter: SortedMapIterator<T, boolean>) {}\n\n  getNext(): T {\n    return this.iter.getNext().key;\n  }\n\n  hasNext(): boolean {\n    return this.iter.hasNext();\n  }\n}\n\n/**\n * Compares two sorted sets for equality using their natural ordering. The\n * method computes the intersection and invokes `onAdd` for every element that\n * is in `after` but not `before`. `onRemove` is invoked for every element in\n * `before` but missing from `after`.\n *\n * The method creates a copy of both `before` and `after` and runs in O(n log\n * n), where n is the size of the two lists.\n *\n * @param before - The elements that exist in the original set.\n * @param after - The elements to diff against the original set.\n * @param comparator - The comparator for the elements in before and after.\n * @param onAdd - A function to invoke for every element that is part of `\n * after` but not `before`.\n * @param onRemove - A function to invoke for every element that is part of\n * `before` but not `after`.\n */\nexport function diffSortedSets<T>(\n  before: SortedSet<T>,\n  after: SortedSet<T>,\n  comparator: (l: T, r: T) => number,\n  onAdd: (entry: T) => void,\n  onRemove: (entry: T) => void\n): void {\n  const beforeIt = before.getIterator();\n  const afterIt = after.getIterator();\n\n  let beforeValue = advanceIterator(beforeIt);\n  let afterValue = advanceIterator(afterIt);\n\n  // Walk through the two sets at the same time, using the ordering defined by\n  // `comparator`.\n  while (beforeValue || afterValue) {\n    let added = false;\n    let removed = false;\n\n    if (beforeValue && afterValue) {\n      const cmp = comparator(beforeValue, afterValue);\n      if (cmp < 0) {\n        // The element was removed if the next element in our ordered\n        // walkthrough is only in `before`.\n        removed = true;\n      } else if (cmp > 0) {\n        // The element was added if the next element in our ordered walkthrough\n        // is only in `after`.\n        added = true;\n      }\n    } else if (beforeValue != null) {\n      removed = true;\n    } else {\n      added = true;\n    }\n\n    if (added) {\n      onAdd(afterValue!);\n      afterValue = advanceIterator(afterIt);\n    } else if (removed) {\n      onRemove(beforeValue!);\n      beforeValue = advanceIterator(beforeIt);\n    } else {\n      beforeValue = advanceIterator(beforeIt);\n      afterValue = advanceIterator(afterIt);\n    }\n  }\n}\n\n/**\n * Returns the next element from the iterator or `undefined` if none available.\n */\nfunction advanceIterator<T>(it: SortedSetIterator<T>): T | undefined {\n  return it.hasNext() ? it.getNext() : undefined;\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 { debugAssert } from '../util/assert';\nimport { arrayEquals } from '../util/misc';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { FieldPath } from './path';\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 */\nexport class FieldMask {\n  constructor(readonly fields: FieldPath[]) {\n    // TODO(dimond): validation of FieldMask\n    // Sort the field mask to support `FieldMask.isEqual()` and assert below.\n    fields.sort(FieldPath.comparator);\n    debugAssert(\n      !fields.some((v, i) => i !== 0 && v.isEqual(fields[i - 1])),\n      'FieldMask contains field that is not unique: ' +\n        fields.find((v, i) => i !== 0 && v.isEqual(fields[i - 1]))!\n    );\n  }\n\n  static empty(): FieldMask {\n    return new FieldMask([]);\n  }\n\n  /**\n   * Returns a new FieldMask object that is the result of adding all the given\n   * fields paths to this field mask.\n   */\n  unionWith(extraFields: FieldPath[]): FieldMask {\n    let mergedMaskSet = new SortedSet<FieldPath>(FieldPath.comparator);\n    for (const fieldPath of this.fields) {\n      mergedMaskSet = mergedMaskSet.add(fieldPath);\n    }\n    for (const fieldPath of extraFields) {\n      mergedMaskSet = mergedMaskSet.add(fieldPath);\n    }\n    return new FieldMask(mergedMaskSet.toArray());\n  }\n\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  covers(fieldPath: FieldPath): boolean {\n    for (const fieldMaskPath of this.fields) {\n      if (fieldMaskPath.isPrefixOf(fieldPath)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  isEqual(other: FieldMask): boolean {\n    return arrayEquals(this.fields, other.fields, (l, r) => l.isEqual(r));\n  }\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * An error encountered while decoding base64 string.\n */\nexport class Base64DecodeError extends Error {\n  readonly name = 'Base64DecodeError';\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 { decodeBase64, encodeBase64 } from '../platform/base64';\n\nimport { primitiveComparator } from './misc';\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 * @internal\n */\nexport class ByteString {\n  static readonly EMPTY_BYTE_STRING = new ByteString('');\n\n  private constructor(private readonly binaryString: string) {}\n\n  static fromBase64String(base64: string): ByteString {\n    const binaryString = decodeBase64(base64);\n    return new ByteString(binaryString);\n  }\n\n  static fromUint8Array(array: Uint8Array): ByteString {\n    // TODO(indexing); Remove the copy of the byte string here as this method\n    // is frequently called during indexing.\n    const binaryString = binaryStringFromUint8Array(array);\n    return new ByteString(binaryString);\n  }\n\n  [Symbol.iterator](): Iterator<number> {\n    let i = 0;\n    return {\n      next: () => {\n        if (i < this.binaryString.length) {\n          return { value: this.binaryString.charCodeAt(i++), done: false };\n        } else {\n          return { value: undefined, done: true };\n        }\n      }\n    };\n  }\n\n  toBase64(): string {\n    return encodeBase64(this.binaryString);\n  }\n\n  toUint8Array(): Uint8Array {\n    return uint8ArrayFromBinaryString(this.binaryString);\n  }\n\n  approximateByteSize(): number {\n    return this.binaryString.length * 2;\n  }\n\n  compareTo(other: ByteString): number {\n    return primitiveComparator(this.binaryString, other.binaryString);\n  }\n\n  isEqual(other: ByteString): boolean {\n    return this.binaryString === other.binaryString;\n  }\n}\n\n/**\n * Helper function to convert an Uint8array to a binary string.\n */\nexport function binaryStringFromUint8Array(array: Uint8Array): string {\n  let binaryString = '';\n  for (let i = 0; i < array.length; ++i) {\n    binaryString += String.fromCharCode(array[i]);\n  }\n  return binaryString;\n}\n\n/**\n * Helper function to convert a binary string to an Uint8Array.\n */\nexport function uint8ArrayFromBinaryString(binaryString: string): Uint8Array {\n  const buffer = new Uint8Array(binaryString.length);\n  for (let i = 0; i < binaryString.length; i++) {\n    buffer[i] = binaryString.charCodeAt(i);\n  }\n  return buffer;\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 { Base64DecodeError } from '../../util/base64_decode_error';\n\n/** Converts a Base64 encoded string to a binary string. */\nexport function decodeBase64(encoded: string): string {\n  try {\n    return atob(encoded);\n  } catch (e) {\n    // Check that `DOMException` is defined before using it to avoid\n    // \"ReferenceError: Property 'DOMException' doesn't exist\" in react-native.\n    // (https://github.com/firebase/firebase-js-sdk/issues/7115)\n    if (typeof DOMException !== 'undefined' && e instanceof DOMException) {\n      throw new Base64DecodeError('Invalid base64 string: ' + e);\n    } else {\n      throw e;\n    }\n  }\n}\n\n/** Converts a binary string to a Base64 encoded string. */\nexport function encodeBase64(raw: string): string {\n  return btoa(raw);\n}\n\n/** True if and only if the Base64 conversion functions are available. */\nexport function isBase64Available(): boolean {\n  return typeof atob !== 'undefined';\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 { Timestamp } from '../protos/firestore_proto_api';\nimport { hardAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\n\n// A RegExp matching ISO 8601 UTC timestamps with optional fraction.\nconst ISO_TIMESTAMP_REG_EXP = new RegExp(\n  /^\\d{4}-\\d\\d-\\d\\dT\\d\\d:\\d\\d:\\d\\d(?:\\.(\\d+))?Z$/\n);\n\n/**\n * Converts the possible Proto values for a timestamp value into a \"seconds and\n * nanos\" representation.\n */\nexport function normalizeTimestamp(date: Timestamp): {\n  seconds: number;\n  nanos: number;\n} {\n  hardAssert(!!date, 'Cannot normalize null or undefined timestamp.');\n\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 (typeof date === 'string') {\n    // The date string can have higher precision (nanos) than the Date class\n    // (millis), so we do some custom parsing here.\n\n    // Parse the nanos right out of the string.\n    let nanos = 0;\n    const fraction = ISO_TIMESTAMP_REG_EXP.exec(date);\n    hardAssert(!!fraction, 'invalid timestamp: ' + date);\n    if (fraction[1]) {\n      // Pad the fraction out to 9 digits (nanos).\n      let nanoStr = fraction[1];\n      nanoStr = (nanoStr + '000000000').substr(0, 9);\n      nanos = Number(nanoStr);\n    }\n\n    // Parse the date to get the seconds.\n    const parsedDate = new Date(date);\n    const seconds = Math.floor(parsedDate.getTime() / 1000);\n\n    return { seconds, nanos };\n  } else {\n    // TODO(b/37282237): Use strings for Proto3 timestamps\n    // assert(!this.options.useProto3Json,\n    //   'The timestamp instance format requires Proto JS.');\n    const seconds = normalizeNumber(date.seconds);\n    const nanos = normalizeNumber(date.nanos);\n    return { seconds, 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 */\nexport function normalizeNumber(value: number | string | undefined): number {\n  // TODO(bjornick): Handle int64 greater than 53 bits.\n  if (typeof value === 'number') {\n    return value;\n  } else if (typeof value === 'string') {\n    return Number(value);\n  } else {\n    return 0;\n  }\n}\n\n/** Converts the possible Proto types for Blobs into a ByteString. */\nexport function normalizeByteString(blob: string | Uint8Array): ByteString {\n  if (typeof blob === 'string') {\n    return ByteString.fromBase64String(blob);\n  } else {\n    return ByteString.fromUint8Array(blob);\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 { Timestamp } from '../lite-api/timestamp';\nimport {\n  Value as ProtoValue,\n  MapValue as ProtoMapValue\n} from '../protos/firestore_proto_api';\n\nimport { normalizeTimestamp } from './normalize';\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 */\n\nconst SERVER_TIMESTAMP_SENTINEL = 'server_timestamp';\nconst TYPE_KEY = '__type__';\nconst PREVIOUS_VALUE_KEY = '__previous_value__';\nconst LOCAL_WRITE_TIME_KEY = '__local_write_time__';\n\nexport function isServerTimestamp(value: ProtoValue | null): boolean {\n  const type = (value?.mapValue?.fields || {})[TYPE_KEY]?.stringValue;\n  return type === SERVER_TIMESTAMP_SENTINEL;\n}\n\n/**\n * Creates a new ServerTimestamp proto value (using the internal format).\n */\nexport function serverTimestamp(\n  localWriteTime: Timestamp,\n  previousValue: ProtoValue | null\n): ProtoValue {\n  const mapValue: ProtoMapValue = {\n    fields: {\n      [TYPE_KEY]: {\n        stringValue: SERVER_TIMESTAMP_SENTINEL\n      },\n      [LOCAL_WRITE_TIME_KEY]: {\n        timestampValue: {\n          seconds: localWriteTime.seconds,\n          nanos: localWriteTime.nanoseconds\n        }\n      }\n    }\n  };\n\n  // We should avoid storing deeply nested server timestamp map values\n  // because we never use the intermediate \"previous values\".\n  // For example:\n  // previous: 42L, add: t1, result: t1 -> 42L\n  // previous: t1,  add: t2, result: t2 -> 42L (NOT t2 -> t1 -> 42L)\n  // previous: t2,  add: t3, result: t3 -> 42L (NOT t3 -> t2 -> t1 -> 42L)\n  // `getPreviousValue` recursively traverses server timestamps to find the\n  // least recent Value.\n  if (previousValue && isServerTimestamp(previousValue)) {\n    previousValue = getPreviousValue(previousValue);\n  }\n  if (previousValue) {\n    mapValue.fields![PREVIOUS_VALUE_KEY] = previousValue;\n  }\n\n  return { mapValue };\n}\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 */\nexport function getPreviousValue(value: ProtoValue): ProtoValue | null {\n  const previousValue = value.mapValue!.fields![PREVIOUS_VALUE_KEY];\n\n  if (isServerTimestamp(previousValue)) {\n    return getPreviousValue(previousValue);\n  }\n  return previousValue;\n}\n\n/**\n * Returns the local time at which this timestamp was first set.\n */\nexport function getLocalWriteTime(value: ProtoValue): Timestamp {\n  const localWriteTime = normalizeTimestamp(\n    value.mapValue!.fields![LOCAL_WRITE_TIME_KEY].timestampValue!\n  );\n  return new Timestamp(localWriteTime.seconds, localWriteTime.nanos);\n}\n","import { FirebaseApp } from '@firebase/app';\n\nimport { ExperimentalLongPollingOptions } from '../api/long_polling_options';\nimport { Code, FirestoreError } from '../util/error';\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 DatabaseInfo {\n  /**\n   * Constructs a DatabaseInfo using the provided host, databaseId and\n   * persistenceKey.\n   *\n   * @param databaseId - The database to use.\n   * @param appId - The Firebase App Id.\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   * @param longPollingOptions Options that configure long-polling.\n   * @param useFetchStreams Whether to use the Fetch API instead of\n   * XMLHTTPRequest\n   */\n  constructor(\n    readonly databaseId: DatabaseId,\n    readonly appId: string,\n    readonly persistenceKey: string,\n    readonly host: string,\n    readonly ssl: boolean,\n    readonly forceLongPolling: boolean,\n    readonly autoDetectLongPolling: boolean,\n    readonly longPollingOptions: ExperimentalLongPollingOptions,\n    readonly useFetchStreams: boolean\n  ) {}\n}\n\n/** The default database name for a project. */\nexport const DEFAULT_DATABASE_NAME = '(default)';\n\n/**\n * Represents the database ID a Firestore client is associated with.\n * @internal\n */\nexport class DatabaseId {\n  readonly database: string;\n  constructor(readonly projectId: string, database?: string) {\n    this.database = database ? database : DEFAULT_DATABASE_NAME;\n  }\n\n  static empty(): DatabaseId {\n    return new DatabaseId('', '');\n  }\n\n  get isDefaultDatabase(): boolean {\n    return this.database === DEFAULT_DATABASE_NAME;\n  }\n\n  isEqual(other: {}): boolean {\n    return (\n      other instanceof DatabaseId &&\n      other.projectId === this.projectId &&\n      other.database === this.database\n    );\n  }\n}\n\nexport function databaseIdFromApp(\n  app: FirebaseApp,\n  database?: string\n): DatabaseId {\n  if (!Object.prototype.hasOwnProperty.apply(app.options, ['projectId'])) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      '\"projectId\" not provided in firebase.initializeApp.'\n    );\n  }\n\n  return new DatabaseId(app.options.projectId!, database);\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 { DatabaseId } from '../core/database_info';\nimport {\n  ArrayValue,\n  LatLng,\n  MapValue,\n  Timestamp,\n  Value as ProtoValue,\n  Value\n} from '../protos/firestore_proto_api';\nimport { fail } from '../util/assert';\nimport { arrayEquals, primitiveComparator } from '../util/misc';\nimport { forEach, objectSize } from '../util/obj';\nimport { isNegativeZero } from '../util/types';\n\nimport { DocumentKey } from './document_key';\nimport {\n  normalizeByteString,\n  normalizeNumber,\n  normalizeTimestamp\n} from './normalize';\nimport {\n  getLocalWriteTime,\n  getPreviousValue,\n  isServerTimestamp\n} from './server_timestamps';\nimport { TypeOrder } from './type_order';\n\nexport const TYPE_KEY = '__type__';\nconst MAX_VALUE_TYPE = '__max__';\nexport const MAX_VALUE: Value = {\n  mapValue: {\n    fields: {\n      '__type__': { stringValue: MAX_VALUE_TYPE }\n    }\n  }\n};\n\nexport const VECTOR_VALUE_SENTINEL = '__vector__';\nexport const VECTOR_MAP_VECTORS_KEY = 'value';\n\nexport const MIN_VALUE: Value = {\n  nullValue: 'NULL_VALUE'\n};\n\n/** Extracts the backend's type order for the provided value. */\nexport function typeOrder(value: Value): TypeOrder {\n  if ('nullValue' in value) {\n    return TypeOrder.NullValue;\n  } else if ('booleanValue' in value) {\n    return TypeOrder.BooleanValue;\n  } else if ('integerValue' in value || 'doubleValue' in value) {\n    return TypeOrder.NumberValue;\n  } else if ('timestampValue' in value) {\n    return TypeOrder.TimestampValue;\n  } else if ('stringValue' in value) {\n    return TypeOrder.StringValue;\n  } else if ('bytesValue' in value) {\n    return TypeOrder.BlobValue;\n  } else if ('referenceValue' in value) {\n    return TypeOrder.RefValue;\n  } else if ('geoPointValue' in value) {\n    return TypeOrder.GeoPointValue;\n  } else if ('arrayValue' in value) {\n    return TypeOrder.ArrayValue;\n  } else if ('mapValue' in value) {\n    if (isServerTimestamp(value)) {\n      return TypeOrder.ServerTimestampValue;\n    } else if (isMaxValue(value)) {\n      return TypeOrder.MaxValue;\n    } else if (isVectorValue(value)) {\n      return TypeOrder.VectorValue;\n    }\n    return TypeOrder.ObjectValue;\n  } else {\n    return fail('Invalid value type: ' + JSON.stringify(value));\n  }\n}\n\n/** Tests `left` and `right` for equality based on the backend semantics. */\nexport function valueEquals(left: Value, right: Value): boolean {\n  if (left === right) {\n    return true;\n  }\n\n  const leftType = typeOrder(left);\n  const rightType = typeOrder(right);\n  if (leftType !== rightType) {\n    return false;\n  }\n\n  switch (leftType) {\n    case TypeOrder.NullValue:\n      return true;\n    case TypeOrder.BooleanValue:\n      return left.booleanValue === right.booleanValue;\n    case TypeOrder.ServerTimestampValue:\n      return getLocalWriteTime(left).isEqual(getLocalWriteTime(right));\n    case TypeOrder.TimestampValue:\n      return timestampEquals(left, right);\n    case TypeOrder.StringValue:\n      return left.stringValue === right.stringValue;\n    case TypeOrder.BlobValue:\n      return blobEquals(left, right);\n    case TypeOrder.RefValue:\n      return left.referenceValue === right.referenceValue;\n    case TypeOrder.GeoPointValue:\n      return geoPointEquals(left, right);\n    case TypeOrder.NumberValue:\n      return numberEquals(left, right);\n    case TypeOrder.ArrayValue:\n      return arrayEquals(\n        left.arrayValue!.values || [],\n        right.arrayValue!.values || [],\n        valueEquals\n      );\n    case TypeOrder.VectorValue:\n    case TypeOrder.ObjectValue:\n      return objectEquals(left, right);\n    case TypeOrder.MaxValue:\n      return true;\n    default:\n      return fail('Unexpected value type: ' + JSON.stringify(left));\n  }\n}\n\nfunction timestampEquals(left: Value, right: Value): boolean {\n  if (\n    typeof left.timestampValue === 'string' &&\n    typeof right.timestampValue === 'string' &&\n    left.timestampValue.length === right.timestampValue.length\n  ) {\n    // Use string equality for ISO 8601 timestamps\n    return left.timestampValue === right.timestampValue;\n  }\n\n  const leftTimestamp = normalizeTimestamp(left.timestampValue!);\n  const rightTimestamp = normalizeTimestamp(right.timestampValue!);\n  return (\n    leftTimestamp.seconds === rightTimestamp.seconds &&\n    leftTimestamp.nanos === rightTimestamp.nanos\n  );\n}\n\nfunction geoPointEquals(left: Value, right: Value): boolean {\n  return (\n    normalizeNumber(left.geoPointValue!.latitude) ===\n      normalizeNumber(right.geoPointValue!.latitude) &&\n    normalizeNumber(left.geoPointValue!.longitude) ===\n      normalizeNumber(right.geoPointValue!.longitude)\n  );\n}\n\nfunction blobEquals(left: Value, right: Value): boolean {\n  return normalizeByteString(left.bytesValue!).isEqual(\n    normalizeByteString(right.bytesValue!)\n  );\n}\n\nexport function numberEquals(left: Value, right: Value): boolean {\n  if ('integerValue' in left && 'integerValue' in right) {\n    return (\n      normalizeNumber(left.integerValue) === normalizeNumber(right.integerValue)\n    );\n  } else if ('doubleValue' in left && 'doubleValue' in right) {\n    const n1 = normalizeNumber(left.doubleValue!);\n    const n2 = normalizeNumber(right.doubleValue!);\n\n    if (n1 === n2) {\n      return isNegativeZero(n1) === isNegativeZero(n2);\n    } else {\n      return isNaN(n1) && isNaN(n2);\n    }\n  }\n\n  return false;\n}\n\nfunction objectEquals(left: Value, right: Value): boolean {\n  const leftMap = left.mapValue!.fields || {};\n  const rightMap = right.mapValue!.fields || {};\n\n  if (objectSize(leftMap) !== objectSize(rightMap)) {\n    return false;\n  }\n\n  for (const key in leftMap) {\n    if (leftMap.hasOwnProperty(key)) {\n      if (\n        rightMap[key] === undefined ||\n        !valueEquals(leftMap[key], rightMap[key])\n      ) {\n        return false;\n      }\n    }\n  }\n  return true;\n}\n\n/** Returns true if the ArrayValue contains the specified element. */\nexport function arrayValueContains(\n  haystack: ArrayValue,\n  needle: Value\n): boolean {\n  return (\n    (haystack.values || []).find(v => valueEquals(v, needle)) !== undefined\n  );\n}\n\nexport function valueCompare(left: Value, right: Value): number {\n  if (left === right) {\n    return 0;\n  }\n\n  const leftType = typeOrder(left);\n  const rightType = typeOrder(right);\n\n  if (leftType !== rightType) {\n    return primitiveComparator(leftType, rightType);\n  }\n\n  switch (leftType) {\n    case TypeOrder.NullValue:\n    case TypeOrder.MaxValue:\n      return 0;\n    case TypeOrder.BooleanValue:\n      return primitiveComparator(left.booleanValue!, right.booleanValue!);\n    case TypeOrder.NumberValue:\n      return compareNumbers(left, right);\n    case TypeOrder.TimestampValue:\n      return compareTimestamps(left.timestampValue!, right.timestampValue!);\n    case TypeOrder.ServerTimestampValue:\n      return compareTimestamps(\n        getLocalWriteTime(left),\n        getLocalWriteTime(right)\n      );\n    case TypeOrder.StringValue:\n      return primitiveComparator(left.stringValue!, right.stringValue!);\n    case TypeOrder.BlobValue:\n      return compareBlobs(left.bytesValue!, right.bytesValue!);\n    case TypeOrder.RefValue:\n      return compareReferences(left.referenceValue!, right.referenceValue!);\n    case TypeOrder.GeoPointValue:\n      return compareGeoPoints(left.geoPointValue!, right.geoPointValue!);\n    case TypeOrder.ArrayValue:\n      return compareArrays(left.arrayValue!, right.arrayValue!);\n    case TypeOrder.VectorValue:\n      return compareVectors(left.mapValue!, right.mapValue!);\n    case TypeOrder.ObjectValue:\n      return compareMaps(left.mapValue!, right.mapValue!);\n    default:\n      throw fail('Invalid value type: ' + leftType);\n  }\n}\n\nfunction compareNumbers(left: Value, right: Value): number {\n  const leftNumber = normalizeNumber(left.integerValue || left.doubleValue);\n  const rightNumber = normalizeNumber(right.integerValue || right.doubleValue);\n\n  if (leftNumber < rightNumber) {\n    return -1;\n  } else if (leftNumber > rightNumber) {\n    return 1;\n  } else if (leftNumber === rightNumber) {\n    return 0;\n  } else {\n    // one or both are NaN.\n    if (isNaN(leftNumber)) {\n      return isNaN(rightNumber) ? 0 : -1;\n    } else {\n      return 1;\n    }\n  }\n}\n\nfunction compareTimestamps(left: Timestamp, right: Timestamp): number {\n  if (\n    typeof left === 'string' &&\n    typeof right === 'string' &&\n    left.length === right.length\n  ) {\n    return primitiveComparator(left, right);\n  }\n\n  const leftTimestamp = normalizeTimestamp(left);\n  const rightTimestamp = normalizeTimestamp(right);\n\n  const comparison = primitiveComparator(\n    leftTimestamp.seconds,\n    rightTimestamp.seconds\n  );\n  if (comparison !== 0) {\n    return comparison;\n  }\n  return primitiveComparator(leftTimestamp.nanos, rightTimestamp.nanos);\n}\n\nfunction compareReferences(leftPath: string, rightPath: string): number {\n  const leftSegments = leftPath.split('/');\n  const rightSegments = rightPath.split('/');\n  for (let i = 0; i < leftSegments.length && i < rightSegments.length; i++) {\n    const comparison = primitiveComparator(leftSegments[i], rightSegments[i]);\n    if (comparison !== 0) {\n      return comparison;\n    }\n  }\n  return primitiveComparator(leftSegments.length, rightSegments.length);\n}\n\nfunction compareGeoPoints(left: LatLng, right: LatLng): number {\n  const comparison = primitiveComparator(\n    normalizeNumber(left.latitude),\n    normalizeNumber(right.latitude)\n  );\n  if (comparison !== 0) {\n    return comparison;\n  }\n  return primitiveComparator(\n    normalizeNumber(left.longitude),\n    normalizeNumber(right.longitude)\n  );\n}\n\nfunction compareBlobs(\n  left: string | Uint8Array,\n  right: string | Uint8Array\n): number {\n  const leftBytes = normalizeByteString(left);\n  const rightBytes = normalizeByteString(right);\n  return leftBytes.compareTo(rightBytes);\n}\n\nfunction compareArrays(left: ArrayValue, right: ArrayValue): number {\n  const leftArray = left.values || [];\n  const rightArray = right.values || [];\n\n  for (let i = 0; i < leftArray.length && i < rightArray.length; ++i) {\n    const compare = valueCompare(leftArray[i], rightArray[i]);\n    if (compare) {\n      return compare;\n    }\n  }\n  return primitiveComparator(leftArray.length, rightArray.length);\n}\n\nfunction compareVectors(left: MapValue, right: MapValue): number {\n  const leftMap = left.fields || {};\n  const rightMap = right.fields || {};\n\n  // The vector is a map, but only vector value is compared.\n  const leftArrayValue = leftMap[VECTOR_MAP_VECTORS_KEY]?.arrayValue;\n  const rightArrayValue = rightMap[VECTOR_MAP_VECTORS_KEY]?.arrayValue;\n\n  const lengthCompare = primitiveComparator(\n    leftArrayValue?.values?.length || 0,\n    rightArrayValue?.values?.length || 0\n  );\n  if (lengthCompare !== 0) {\n    return lengthCompare;\n  }\n\n  return compareArrays(leftArrayValue!, rightArrayValue!);\n}\n\nfunction compareMaps(left: MapValue, right: MapValue): number {\n  if (left === MAX_VALUE.mapValue && right === MAX_VALUE.mapValue) {\n    return 0;\n  } else if (left === MAX_VALUE.mapValue) {\n    return 1;\n  } else if (right === MAX_VALUE.mapValue) {\n    return -1;\n  }\n\n  const leftMap = left.fields || {};\n  const leftKeys = Object.keys(leftMap);\n  const rightMap = right.fields || {};\n  const rightKeys = Object.keys(rightMap);\n\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  leftKeys.sort();\n  rightKeys.sort();\n\n  for (let i = 0; i < leftKeys.length && i < rightKeys.length; ++i) {\n    const keyCompare = primitiveComparator(leftKeys[i], rightKeys[i]);\n    if (keyCompare !== 0) {\n      return keyCompare;\n    }\n    const compare = valueCompare(leftMap[leftKeys[i]], rightMap[rightKeys[i]]);\n    if (compare !== 0) {\n      return compare;\n    }\n  }\n\n  return primitiveComparator(leftKeys.length, rightKeys.length);\n}\n\n/**\n * Generates the canonical ID for the provided field value (as used in Target\n * serialization).\n */\nexport function canonicalId(value: Value): string {\n  return canonifyValue(value);\n}\n\nfunction canonifyValue(value: Value): string {\n  if ('nullValue' in value) {\n    return 'null';\n  } else if ('booleanValue' in value) {\n    return '' + value.booleanValue!;\n  } else if ('integerValue' in value) {\n    return '' + value.integerValue!;\n  } else if ('doubleValue' in value) {\n    return '' + value.doubleValue!;\n  } else if ('timestampValue' in value) {\n    return canonifyTimestamp(value.timestampValue!);\n  } else if ('stringValue' in value) {\n    return value.stringValue!;\n  } else if ('bytesValue' in value) {\n    return canonifyByteString(value.bytesValue!);\n  } else if ('referenceValue' in value) {\n    return canonifyReference(value.referenceValue!);\n  } else if ('geoPointValue' in value) {\n    return canonifyGeoPoint(value.geoPointValue!);\n  } else if ('arrayValue' in value) {\n    return canonifyArray(value.arrayValue!);\n  } else if ('mapValue' in value) {\n    return canonifyMap(value.mapValue!);\n  } else {\n    return fail('Invalid value type: ' + JSON.stringify(value));\n  }\n}\n\nfunction canonifyByteString(byteString: string | Uint8Array): string {\n  return normalizeByteString(byteString).toBase64();\n}\n\nfunction canonifyTimestamp(timestamp: Timestamp): string {\n  const normalizedTimestamp = normalizeTimestamp(timestamp);\n  return `time(${normalizedTimestamp.seconds},${normalizedTimestamp.nanos})`;\n}\n\nfunction canonifyGeoPoint(geoPoint: LatLng): string {\n  return `geo(${geoPoint.latitude},${geoPoint.longitude})`;\n}\n\nfunction canonifyReference(referenceValue: string): string {\n  return DocumentKey.fromName(referenceValue).toString();\n}\n\nfunction canonifyMap(mapValue: MapValue): string {\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  const sortedKeys = Object.keys(mapValue.fields || {}).sort();\n\n  let result = '{';\n  let first = true;\n  for (const key of sortedKeys) {\n    if (!first) {\n      result += ',';\n    } else {\n      first = false;\n    }\n    result += `${key}:${canonifyValue(mapValue.fields![key])}`;\n  }\n  return result + '}';\n}\n\nfunction canonifyArray(arrayValue: ArrayValue): string {\n  let result = '[';\n  let first = true;\n  for (const value of arrayValue.values || []) {\n    if (!first) {\n      result += ',';\n    } else {\n      first = false;\n    }\n    result += canonifyValue(value);\n  }\n  return result + ']';\n}\n\n/**\n * Returns an approximate (and wildly inaccurate) in-memory size for the field\n * value.\n *\n * The memory size takes into account only the actual user data as it resides\n * in memory and ignores object overhead.\n */\nexport function estimateByteSize(value: Value): number {\n  switch (typeOrder(value)) {\n    case TypeOrder.NullValue:\n      return 4;\n    case TypeOrder.BooleanValue:\n      return 4;\n    case TypeOrder.NumberValue:\n      return 8;\n    case TypeOrder.TimestampValue:\n      // Timestamps are made up of two distinct numbers (seconds + nanoseconds)\n      return 16;\n    case TypeOrder.ServerTimestampValue:\n      const previousValue = getPreviousValue(value);\n      return previousValue ? 16 + estimateByteSize(previousValue) : 16;\n    case TypeOrder.StringValue:\n      // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures:\n      // \"JavaScript's String type is [...] a set of elements of 16-bit unsigned\n      // integer values\"\n      return value.stringValue!.length * 2;\n    case TypeOrder.BlobValue:\n      return normalizeByteString(value.bytesValue!).approximateByteSize();\n    case TypeOrder.RefValue:\n      return value.referenceValue!.length;\n    case TypeOrder.GeoPointValue:\n      // GeoPoints are made up of two distinct numbers (latitude + longitude)\n      return 16;\n    case TypeOrder.ArrayValue:\n      return estimateArrayByteSize(value.arrayValue!);\n    case TypeOrder.VectorValue:\n    case TypeOrder.ObjectValue:\n      return estimateMapByteSize(value.mapValue!);\n    default:\n      throw fail('Invalid value type: ' + JSON.stringify(value));\n  }\n}\n\nfunction estimateMapByteSize(mapValue: MapValue): number {\n  let size = 0;\n  forEach(mapValue.fields, (key, val) => {\n    size += key.length + estimateByteSize(val);\n  });\n  return size;\n}\n\nfunction estimateArrayByteSize(arrayValue: ArrayValue): number {\n  return (arrayValue.values || []).reduce(\n    (previousSize, value) => previousSize + estimateByteSize(value),\n    0\n  );\n}\n\n/** Returns a reference value for the provided database and key. */\nexport function refValue(databaseId: DatabaseId, key: DocumentKey): Value {\n  return {\n    referenceValue: `projects/${databaseId.projectId}/databases/${\n      databaseId.database\n    }/documents/${key.path.canonicalString()}`\n  };\n}\n\n/** Returns true if `value` is an IntegerValue . */\nexport function isInteger(\n  value?: Value | null\n): value is { integerValue: string | number } {\n  return !!value && 'integerValue' in value;\n}\n\n/** Returns true if `value` is a DoubleValue. */\nexport function isDouble(\n  value?: Value | null\n): value is { doubleValue: string | number } {\n  return !!value && 'doubleValue' in value;\n}\n\n/** Returns true if `value` is either an IntegerValue or a DoubleValue. */\nexport function isNumber(value?: Value | null): boolean {\n  return isInteger(value) || isDouble(value);\n}\n\n/** Returns true if `value` is an ArrayValue. */\nexport function isArray(\n  value?: Value | null\n): value is { arrayValue: ArrayValue } {\n  return !!value && 'arrayValue' in value;\n}\n\n/** Returns true if `value` is a ReferenceValue. */\nexport function isReferenceValue(\n  value?: Value | null\n): value is { referenceValue: string } {\n  return !!value && 'referenceValue' in value;\n}\n\n/** Returns true if `value` is a NullValue. */\nexport function isNullValue(\n  value?: Value | null\n): value is { nullValue: 'NULL_VALUE' } {\n  return !!value && 'nullValue' in value;\n}\n\n/** Returns true if `value` is NaN. */\nexport function isNanValue(\n  value?: Value | null\n): value is { doubleValue: 'NaN' | number } {\n  return !!value && 'doubleValue' in value && isNaN(Number(value.doubleValue));\n}\n\n/** Returns true if `value` is a MapValue. */\nexport function isMapValue(\n  value?: Value | null\n): value is { mapValue: MapValue } {\n  return !!value && 'mapValue' in value;\n}\n\n/** Returns true if `value` is a VetorValue. */\nexport function isVectorValue(value: ProtoValue | null): boolean {\n  const type = (value?.mapValue?.fields || {})[TYPE_KEY]?.stringValue;\n  return type === VECTOR_VALUE_SENTINEL;\n}\n\n/** Creates a deep copy of `source`. */\nexport function deepClone(source: Value): Value {\n  if (source.geoPointValue) {\n    return { geoPointValue: { ...source.geoPointValue } };\n  } else if (\n    source.timestampValue &&\n    typeof source.timestampValue === 'object'\n  ) {\n    return { timestampValue: { ...source.timestampValue } };\n  } else if (source.mapValue) {\n    const target: Value = { mapValue: { fields: {} } };\n    forEach(\n      source.mapValue.fields,\n      (key, val) => (target.mapValue!.fields![key] = deepClone(val))\n    );\n    return target;\n  } else if (source.arrayValue) {\n    const target: Value = { arrayValue: { values: [] } };\n    for (let i = 0; i < (source.arrayValue.values || []).length; ++i) {\n      target.arrayValue!.values![i] = deepClone(source.arrayValue.values![i]);\n    }\n    return target;\n  } else {\n    return { ...source };\n  }\n}\n\n/** Returns true if the Value represents the canonical {@link #MAX_VALUE} . */\nexport function isMaxValue(value: Value): boolean {\n  return (\n    (((value.mapValue || {}).fields || {})['__type__'] || {}).stringValue ===\n    MAX_VALUE_TYPE\n  );\n}\n\nexport const MIN_VECTOR_VALUE = {\n  mapValue: {\n    fields: {\n      [TYPE_KEY]: { stringValue: VECTOR_VALUE_SENTINEL },\n      [VECTOR_MAP_VECTORS_KEY]: {\n        arrayValue: {}\n      }\n    }\n  }\n};\n\n/** Returns the lowest value for the given value type (inclusive). */\nexport function valuesGetLowerBound(value: Value): Value {\n  if ('nullValue' in value) {\n    return MIN_VALUE;\n  } else if ('booleanValue' in value) {\n    return { booleanValue: false };\n  } else if ('integerValue' in value || 'doubleValue' in value) {\n    return { doubleValue: NaN };\n  } else if ('timestampValue' in value) {\n    return { timestampValue: { seconds: Number.MIN_SAFE_INTEGER } };\n  } else if ('stringValue' in value) {\n    return { stringValue: '' };\n  } else if ('bytesValue' in value) {\n    return { bytesValue: '' };\n  } else if ('referenceValue' in value) {\n    return refValue(DatabaseId.empty(), DocumentKey.empty());\n  } else if ('geoPointValue' in value) {\n    return { geoPointValue: { latitude: -90, longitude: -180 } };\n  } else if ('arrayValue' in value) {\n    return { arrayValue: {} };\n  } else if ('mapValue' in value) {\n    if (isVectorValue(value)) {\n      return MIN_VECTOR_VALUE;\n    }\n    return { mapValue: {} };\n  } else {\n    return fail('Invalid value type: ' + JSON.stringify(value));\n  }\n}\n\n/** Returns the largest value for the given value type (exclusive). */\nexport function valuesGetUpperBound(value: Value): Value {\n  if ('nullValue' in value) {\n    return { booleanValue: false };\n  } else if ('booleanValue' in value) {\n    return { doubleValue: NaN };\n  } else if ('integerValue' in value || 'doubleValue' in value) {\n    return { timestampValue: { seconds: Number.MIN_SAFE_INTEGER } };\n  } else if ('timestampValue' in value) {\n    return { stringValue: '' };\n  } else if ('stringValue' in value) {\n    return { bytesValue: '' };\n  } else if ('bytesValue' in value) {\n    return refValue(DatabaseId.empty(), DocumentKey.empty());\n  } else if ('referenceValue' in value) {\n    return { geoPointValue: { latitude: -90, longitude: -180 } };\n  } else if ('geoPointValue' in value) {\n    return { arrayValue: {} };\n  } else if ('arrayValue' in value) {\n    return MIN_VECTOR_VALUE;\n  } else if ('mapValue' in value) {\n    if (isVectorValue(value)) {\n      return { mapValue: {} };\n    }\n    return MAX_VALUE;\n  } else {\n    return fail('Invalid value type: ' + JSON.stringify(value));\n  }\n}\n\nexport function lowerBoundCompare(\n  left: { value: Value; inclusive: boolean },\n  right: { value: Value; inclusive: boolean }\n): number {\n  const cmp = valueCompare(left.value, right.value);\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  if (left.inclusive && !right.inclusive) {\n    return -1;\n  } else if (!left.inclusive && right.inclusive) {\n    return 1;\n  }\n\n  return 0;\n}\n\nexport function upperBoundCompare(\n  left: { value: Value; inclusive: boolean },\n  right: { value: Value; inclusive: boolean }\n): number {\n  const cmp = valueCompare(left.value, right.value);\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  if (left.inclusive && !right.inclusive) {\n    return 1;\n  } else if (!left.inclusive && right.inclusive) {\n    return -1;\n  }\n\n  return 0;\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  MapValue as ProtoMapValue,\n  Value as ProtoValue\n} from '../protos/firestore_proto_api';\nimport { debugAssert } from '../util/assert';\nimport { forEach } from '../util/obj';\n\nimport { FieldMask } from './field_mask';\nimport { FieldPath } from './path';\nimport { isServerTimestamp } from './server_timestamps';\nimport { deepClone, isMapValue, valueEquals } from './values';\n\nexport interface JsonObject<T> {\n  [name: string]: T;\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 */\nexport class ObjectValue {\n  constructor(readonly value: { mapValue: ProtoMapValue }) {\n    debugAssert(\n      !isServerTimestamp(value),\n      'ServerTimestamps should be converted to ServerTimestampValue'\n    );\n  }\n\n  static empty(): ObjectValue {\n    return new ObjectValue({ 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 null if the path is not set.\n   */\n  field(path: FieldPath): ProtoValue | null {\n    if (path.isEmpty()) {\n      return this.value;\n    } else {\n      let currentLevel: ProtoValue = this.value;\n      for (let i = 0; i < path.length - 1; ++i) {\n        currentLevel = (currentLevel.mapValue!.fields || {})[path.get(i)];\n        if (!isMapValue(currentLevel)) {\n          return null;\n        }\n      }\n      currentLevel = (currentLevel.mapValue!.fields! || {})[path.lastSegment()];\n      return currentLevel || null;\n    }\n  }\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   */\n  set(path: FieldPath, value: ProtoValue): void {\n    debugAssert(\n      !path.isEmpty(),\n      'Cannot set field for empty path on ObjectValue'\n    );\n    const fieldsMap = this.getFieldsMap(path.popLast());\n    fieldsMap[path.lastSegment()] = deepClone(value);\n  }\n\n  /**\n   * Sets the provided fields to the provided values.\n   *\n   * @param data - A map of fields to values (or null for deletes).\n   */\n  setAll(data: Map<FieldPath, ProtoValue | null>): void {\n    let parent = FieldPath.emptyPath();\n\n    let upserts: { [key: string]: ProtoValue } = {};\n    let deletes: string[] = [];\n\n    data.forEach((value, path) => {\n      if (!parent.isImmediateParentOf(path)) {\n        // Insert the accumulated changes at this parent location\n        const fieldsMap = this.getFieldsMap(parent);\n        this.applyChanges(fieldsMap, upserts, deletes);\n        upserts = {};\n        deletes = [];\n        parent = path.popLast();\n      }\n\n      if (value) {\n        upserts[path.lastSegment()] = deepClone(value);\n      } else {\n        deletes.push(path.lastSegment());\n      }\n    });\n\n    const fieldsMap = this.getFieldsMap(parent);\n    this.applyChanges(fieldsMap, upserts, deletes);\n  }\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   */\n  delete(path: FieldPath): void {\n    debugAssert(\n      !path.isEmpty(),\n      'Cannot delete field for empty path on ObjectValue'\n    );\n    const nestedValue = this.field(path.popLast());\n    if (isMapValue(nestedValue) && nestedValue.mapValue.fields) {\n      delete nestedValue.mapValue.fields[path.lastSegment()];\n    }\n  }\n\n  isEqual(other: ObjectValue): boolean {\n    return valueEquals(this.value, other.value);\n  }\n\n  /**\n   * Returns the map that contains the leaf element of `path`. If the parent\n   * entry does not yet exist, or if it is not a map, a new map will be created.\n   */\n  private getFieldsMap(path: FieldPath): Record<string, ProtoValue> {\n    let current = this.value;\n\n    if (!current.mapValue!.fields) {\n      current.mapValue = { fields: {} };\n    }\n\n    for (let i = 0; i < path.length; ++i) {\n      let next = current.mapValue!.fields![path.get(i)];\n      if (!isMapValue(next) || !next.mapValue.fields) {\n        next = { mapValue: { fields: {} } };\n        current.mapValue!.fields![path.get(i)] = next;\n      }\n      current = next as { mapValue: ProtoMapValue };\n    }\n\n    return current.mapValue!.fields!;\n  }\n\n  /**\n   * Modifies `fieldsMap` by adding, replacing or deleting the specified\n   * entries.\n   */\n  private applyChanges(\n    fieldsMap: Record<string, ProtoValue>,\n    inserts: { [key: string]: ProtoValue },\n    deletes: string[]\n  ): void {\n    forEach(inserts, (key, val) => (fieldsMap[key] = val));\n    for (const field of deletes) {\n      delete fieldsMap[field];\n    }\n  }\n\n  clone(): ObjectValue {\n    return new ObjectValue(\n      deepClone(this.value) as { mapValue: ProtoMapValue }\n    );\n  }\n}\n\n/**\n * Returns a FieldMask built from all fields in a MapValue.\n */\nexport function extractFieldMask(value: ProtoMapValue): FieldMask {\n  const fields: FieldPath[] = [];\n  forEach(value!.fields, (key, value) => {\n    const currentPath = new FieldPath([key]);\n    if (isMapValue(value)) {\n      const nestedMask = extractFieldMask(value.mapValue!);\n      const nestedFields = nestedMask.fields;\n      if (nestedFields.length === 0) {\n        // Preserve the empty map by adding it to the FieldMask.\n        fields.push(currentPath);\n      } else {\n        // For nested and non-empty ObjectValues, add the FieldPath of the\n        // leaf nodes.\n        for (const nestedPath of nestedFields) {\n          fields.push(currentPath.child(nestedPath));\n        }\n      }\n    } else {\n      // For nested and non-empty ObjectValues, add the FieldPath of the leaf\n      // nodes.\n      fields.push(currentPath);\n    }\n  });\n  return new FieldMask(fields);\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { debugAssert, fail } from '../util/assert';\n\nimport { DocumentKey } from './document_key';\nimport { ObjectValue } from './object_value';\nimport { FieldPath } from './path';\nimport { valueCompare } from './values';\n\n/**\n * Whether the document represents an existing document, a document that is\n * known to exist or a document whose state or existence is unknown.\n */\nconst enum DocumentType {\n  /**\n   * Represents the initial state of a MutableDocument when only the document\n   * key is known. Invalid documents transition to other states as mutations are\n   * applied. If a document remains invalid after applying mutations, it should\n   * be discarded.\n   *\n   * Invalid documents can have neither local nor committed mutations.\n   */\n  INVALID,\n  /**\n   * Represents a document in Firestore with a key, version, data and whether\n   * the data has local mutations applied to it.\n   *\n   * Found documents can be synced or have or committed mutations applied.\n   */\n  FOUND_DOCUMENT,\n  /**\n   * Represents that no documents exists for the key at the given version.\n   *\n   * Documents that are deleted based on a local mutation do not raise snapshots\n   * with `hasPendingWrites`. As such, deleted documents never have\n   * `HAS_LOCAL_MUTATIONS` set. Once a delete is committed, we store them with\n   * `HAS_COMMITTED_MUTATIONS` until we received the delete from the Watch\n   * stream.\n   */\n  NO_DOCUMENT,\n  /**\n   * Represents an existing document whose data is unknown (e.g. a document that\n   * was updated without a known base document).\n   *\n   * An unknown document always has `HAS_COMMITTED_MUTATIONS` set, since unknown\n   * documents can only be generated by applying a patch mutation from a write\n   * acknowledgement.\n   */\n  UNKNOWN_DOCUMENT\n}\n\n/** Describes whether a document has latency-compensated edits applied. */\nconst enum DocumentState {\n  /** No mutations applied. Document was sent to us by Watch. */\n  SYNCED,\n  /**\n   * Local mutations applied via the mutation queue. Document is potentially\n   * inconsistent.\n   */\n  HAS_LOCAL_MUTATIONS,\n  /**\n   * Mutations applied based on a write acknowledgment. Document is potentially\n   * inconsistent.\n   */\n  HAS_COMMITTED_MUTATIONS\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 */\nexport interface Document {\n  /** The key for this document */\n  readonly key: DocumentKey;\n\n  /**\n   * The version of this document if it exists or a version at which this\n   * document was guaranteed to not exist.\n   */\n  readonly version: SnapshotVersion;\n\n  /**\n   * The timestamp at which this document was read from the remote server. Uses\n   * `SnapshotVersion.min()` for documents created by the user.\n   */\n  readonly readTime: SnapshotVersion;\n\n  /**\n   * The timestamp at which the document was created. This value increases\n   * monotonically when a document is deleted then recreated. It can also be\n   * compared to `createTime` of other documents and the `readTime` of a query.\n   */\n  readonly createTime: SnapshotVersion;\n\n  /** The underlying data of this document or an empty value if no data exists. */\n  readonly data: ObjectValue;\n\n  /** Returns whether local mutations were applied via the mutation queue. */\n  readonly hasLocalMutations: boolean;\n\n  /** Returns whether mutations were applied based on a write acknowledgment. */\n  readonly hasCommittedMutations: boolean;\n\n  /**\n   * Whether this document had a local mutation applied that has not yet been\n   * acknowledged by Watch.\n   */\n  readonly hasPendingWrites: boolean;\n\n  /**\n   * Returns whether this document is valid (i.e. it is an entry in the\n   * RemoteDocumentCache, was created by a mutation or read from the backend).\n   */\n  isValidDocument(): boolean;\n\n  /**\n   * Returns whether the document exists and its data is known at the current\n   * version.\n   */\n  isFoundDocument(): boolean;\n\n  /**\n   * Returns whether the document is known to not exist at the current version.\n   */\n  isNoDocument(): boolean;\n\n  /**\n   * Returns whether the document exists and its data is unknown at the current\n   * version.\n   */\n  isUnknownDocument(): boolean;\n\n  isEqual(other: Document | null | undefined): boolean;\n\n  /** Creates a mutable copy of this document. */\n  mutableCopy(): MutableDocument;\n\n  toString(): string;\n}\n\n/**\n * Represents a document in Firestore with a key, version, data and whether it\n * has local mutations applied to it.\n *\n * Documents can transition between states via `convertToFoundDocument()`,\n * `convertToNoDocument()` and `convertToUnknownDocument()`. If a document does\n * not transition to one of these states even after all mutations have been\n * applied, `isValidDocument()` returns false and the document should be removed\n * from all views.\n */\nexport class MutableDocument implements Document {\n  private constructor(\n    readonly key: DocumentKey,\n    private documentType: DocumentType,\n    public version: SnapshotVersion,\n    public readTime: SnapshotVersion,\n    public createTime: SnapshotVersion,\n    public data: ObjectValue,\n    private documentState: DocumentState\n  ) {}\n\n  /**\n   * Creates a document with no known version or data, but which can serve as\n   * base document for mutations.\n   */\n  static newInvalidDocument(documentKey: DocumentKey): MutableDocument {\n    return new MutableDocument(\n      documentKey,\n      DocumentType.INVALID,\n      /* version */ SnapshotVersion.min(),\n      /* readTime */ SnapshotVersion.min(),\n      /* createTime */ SnapshotVersion.min(),\n      ObjectValue.empty(),\n      DocumentState.SYNCED\n    );\n  }\n\n  /**\n   * Creates a new document that is known to exist with the given data at the\n   * given version.\n   */\n  static newFoundDocument(\n    documentKey: DocumentKey,\n    version: SnapshotVersion,\n    createTime: SnapshotVersion,\n    value: ObjectValue\n  ): MutableDocument {\n    return new MutableDocument(\n      documentKey,\n      DocumentType.FOUND_DOCUMENT,\n      /* version */ version,\n      /* readTime */ SnapshotVersion.min(),\n      /* createTime */ createTime,\n      value,\n      DocumentState.SYNCED\n    );\n  }\n\n  /** Creates a new document that is known to not exist at the given version. */\n  static newNoDocument(\n    documentKey: DocumentKey,\n    version: SnapshotVersion\n  ): MutableDocument {\n    return new MutableDocument(\n      documentKey,\n      DocumentType.NO_DOCUMENT,\n      /* version */ version,\n      /* readTime */ SnapshotVersion.min(),\n      /* createTime */ SnapshotVersion.min(),\n      ObjectValue.empty(),\n      DocumentState.SYNCED\n    );\n  }\n\n  /**\n   * Creates a new document that is known to exist at the given version but\n   * whose data is not known (e.g. a document that was updated without a known\n   * base document).\n   */\n  static newUnknownDocument(\n    documentKey: DocumentKey,\n    version: SnapshotVersion\n  ): MutableDocument {\n    return new MutableDocument(\n      documentKey,\n      DocumentType.UNKNOWN_DOCUMENT,\n      /* version */ version,\n      /* readTime */ SnapshotVersion.min(),\n      /* createTime */ SnapshotVersion.min(),\n      ObjectValue.empty(),\n      DocumentState.HAS_COMMITTED_MUTATIONS\n    );\n  }\n\n  /**\n   * Changes the document type to indicate that it exists and that its version\n   * and data are known.\n   */\n  convertToFoundDocument(\n    version: SnapshotVersion,\n    value: ObjectValue\n  ): MutableDocument {\n    // If a document is switching state from being an invalid or deleted\n    // document to a valid (FOUND_DOCUMENT) document, either due to receiving an\n    // update from Watch or due to applying a local set mutation on top\n    // of a deleted document, our best guess about its createTime would be the\n    // version at which the document transitioned to a FOUND_DOCUMENT.\n    if (\n      this.createTime.isEqual(SnapshotVersion.min()) &&\n      (this.documentType === DocumentType.NO_DOCUMENT ||\n        this.documentType === DocumentType.INVALID)\n    ) {\n      this.createTime = version;\n    }\n    this.version = version;\n    this.documentType = DocumentType.FOUND_DOCUMENT;\n    this.data = value;\n    this.documentState = DocumentState.SYNCED;\n    return this;\n  }\n\n  /**\n   * Changes the document type to indicate that it doesn't exist at the given\n   * version.\n   */\n  convertToNoDocument(version: SnapshotVersion): MutableDocument {\n    this.version = version;\n    this.documentType = DocumentType.NO_DOCUMENT;\n    this.data = ObjectValue.empty();\n    this.documentState = DocumentState.SYNCED;\n    return this;\n  }\n\n  /**\n   * Changes the document type to indicate that it exists at a given version but\n   * that its data is not known (e.g. a document that was updated without a known\n   * base document).\n   */\n  convertToUnknownDocument(version: SnapshotVersion): MutableDocument {\n    this.version = version;\n    this.documentType = DocumentType.UNKNOWN_DOCUMENT;\n    this.data = ObjectValue.empty();\n    this.documentState = DocumentState.HAS_COMMITTED_MUTATIONS;\n    return this;\n  }\n\n  setHasCommittedMutations(): MutableDocument {\n    debugAssert(\n      this.isValidDocument(),\n      'Invalid documents cannot have committed mutations'\n    );\n    this.documentState = DocumentState.HAS_COMMITTED_MUTATIONS;\n    return this;\n  }\n\n  setHasLocalMutations(): MutableDocument {\n    this.documentState = DocumentState.HAS_LOCAL_MUTATIONS;\n    this.version = SnapshotVersion.min();\n    return this;\n  }\n\n  setReadTime(readTime: SnapshotVersion): MutableDocument {\n    this.readTime = readTime;\n    return this;\n  }\n\n  get hasLocalMutations(): boolean {\n    return this.documentState === DocumentState.HAS_LOCAL_MUTATIONS;\n  }\n\n  get hasCommittedMutations(): boolean {\n    return this.documentState === DocumentState.HAS_COMMITTED_MUTATIONS;\n  }\n\n  get hasPendingWrites(): boolean {\n    return this.hasLocalMutations || this.hasCommittedMutations;\n  }\n\n  isValidDocument(): boolean {\n    return this.documentType !== DocumentType.INVALID;\n  }\n\n  isFoundDocument(): boolean {\n    return this.documentType === DocumentType.FOUND_DOCUMENT;\n  }\n\n  isNoDocument(): boolean {\n    return this.documentType === DocumentType.NO_DOCUMENT;\n  }\n\n  isUnknownDocument(): boolean {\n    return this.documentType === DocumentType.UNKNOWN_DOCUMENT;\n  }\n\n  isEqual(other: Document | null | undefined): boolean {\n    return (\n      other instanceof MutableDocument &&\n      this.key.isEqual(other.key) &&\n      this.version.isEqual(other.version) &&\n      this.documentType === other.documentType &&\n      this.documentState === other.documentState &&\n      this.data.isEqual(other.data)\n    );\n  }\n\n  mutableCopy(): MutableDocument {\n    return new MutableDocument(\n      this.key,\n      this.documentType,\n      this.version,\n      this.readTime,\n      this.createTime,\n      this.data.clone(),\n      this.documentState\n    );\n  }\n\n  toString(): string {\n    return (\n      `Document(${this.key}, ${this.version}, ${JSON.stringify(\n        this.data.value\n      )}, ` +\n      `{createTime: ${this.createTime}}), ` +\n      `{documentType: ${this.documentType}}), ` +\n      `{documentState: ${this.documentState}})`\n    );\n  }\n}\n\n/**\n * Compares the value for field `field` in the provided documents. Throws if\n * the field does not exist in both documents.\n */\nexport function compareDocumentsByField(\n  field: FieldPath,\n  d1: Document,\n  d2: Document\n): number {\n  const v1 = d1.data.field(field);\n  const v2 = d2.data.field(field);\n  if (v1 !== null && v2 !== null) {\n    return valueCompare(v1, v2);\n  } else {\n    return fail(\"Trying to compare documents on fields that don't exist\");\n  }\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { isReferenceValue, valueCompare, valueEquals } from '../model/values';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { debugAssert } from '../util/assert';\n\nimport { Direction, OrderBy } from './order_by';\n\n/**\n * Represents a bound of a query.\n *\n * The bound is specified with the given components representing a position and\n * whether it's just before or just after the position (relative to whatever the\n * query order is).\n *\n * The position represents a logical index position for a query. It's a prefix\n * of values for the (potentially implicit) order by clauses of a query.\n *\n * Bound provides a function to determine whether a document comes before or\n * after a bound. This is influenced by whether the position is just before or\n * just after the provided values.\n */\nexport class Bound {\n  constructor(readonly position: ProtoValue[], readonly inclusive: boolean) {}\n}\n\nfunction boundCompareToDocument(\n  bound: Bound,\n  orderBy: OrderBy[],\n  doc: Document\n): number {\n  debugAssert(\n    bound.position.length <= orderBy.length,\n    \"Bound has more components than query's orderBy\"\n  );\n  let comparison = 0;\n  for (let i = 0; i < bound.position.length; i++) {\n    const orderByComponent = orderBy[i];\n    const component = bound.position[i];\n    if (orderByComponent.field.isKeyField()) {\n      debugAssert(\n        isReferenceValue(component),\n        'Bound has a non-key value where the key path is being used.'\n      );\n      comparison = DocumentKey.comparator(\n        DocumentKey.fromName(component.referenceValue),\n        doc.key\n      );\n    } else {\n      const docValue = doc.data.field(orderByComponent.field);\n      debugAssert(\n        docValue !== null,\n        'Field should exist since document matched the orderBy already.'\n      );\n      comparison = valueCompare(component, docValue);\n    }\n    if (orderByComponent.dir === Direction.DESCENDING) {\n      comparison = comparison * -1;\n    }\n    if (comparison !== 0) {\n      break;\n    }\n  }\n  return comparison;\n}\n\n/**\n * Returns true if a document sorts after a bound using the provided sort\n * order.\n */\nexport function boundSortsAfterDocument(\n  bound: Bound,\n  orderBy: OrderBy[],\n  doc: Document\n): boolean {\n  const comparison = boundCompareToDocument(bound, orderBy, doc);\n  return bound.inclusive ? comparison >= 0 : comparison > 0;\n}\n\n/**\n * Returns true if a document sorts before a bound using the provided sort\n * order.\n */\nexport function boundSortsBeforeDocument(\n  bound: Bound,\n  orderBy: OrderBy[],\n  doc: Document\n): boolean {\n  const comparison = boundCompareToDocument(bound, orderBy, doc);\n  return bound.inclusive ? comparison <= 0 : comparison < 0;\n}\n\nexport function boundEquals(left: Bound | null, right: Bound | null): boolean {\n  if (left === null) {\n    return right === null;\n  } else if (right === null) {\n    return false;\n  }\n\n  if (\n    left.inclusive !== right.inclusive ||\n    left.position.length !== right.position.length\n  ) {\n    return false;\n  }\n  for (let i = 0; i < left.position.length; i++) {\n    const leftPosition = left.position[i];\n    const rightPosition = right.position[i];\n    if (!valueEquals(leftPosition, rightPosition)) {\n      return false;\n    }\n  }\n  return true;\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { FieldPath } from '../model/path';\n\n/**\n * The direction of sorting in an order by.\n */\nexport const enum Direction {\n  ASCENDING = 'asc',\n  DESCENDING = 'desc'\n}\n\n/**\n * An ordering on a field, in some Direction. Direction defaults to ASCENDING.\n */\nexport class OrderBy {\n  constructor(\n    readonly field: FieldPath,\n    readonly dir: Direction = Direction.ASCENDING\n  ) {}\n}\n\nexport function canonifyOrderBy(orderBy: OrderBy): string {\n  // TODO(b/29183165): Make this collision robust.\n  return orderBy.field.canonicalString() + orderBy.dir;\n}\n\nexport function stringifyOrderBy(orderBy: OrderBy): string {\n  return `${orderBy.field.canonicalString()} (${orderBy.dir})`;\n}\n\nexport function orderByEquals(left: OrderBy, right: OrderBy): boolean {\n  return left.dir === right.dir && left.field.isEqual(right.field);\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldPath } from '../model/path';\nimport {\n  arrayValueContains,\n  canonicalId,\n  isArray,\n  isReferenceValue,\n  typeOrder,\n  valueCompare,\n  valueEquals\n} from '../model/values';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { debugAssert, fail } from '../util/assert';\n\n// The operator of a FieldFilter\nexport const enum Operator {\n  LESS_THAN = '<',\n  LESS_THAN_OR_EQUAL = '<=',\n  EQUAL = '==',\n  NOT_EQUAL = '!=',\n  GREATER_THAN = '>',\n  GREATER_THAN_OR_EQUAL = '>=',\n  ARRAY_CONTAINS = 'array-contains',\n  IN = 'in',\n  NOT_IN = 'not-in',\n  ARRAY_CONTAINS_ANY = 'array-contains-any'\n}\n\n// The operator of a CompositeFilter\nexport const enum CompositeOperator {\n  OR = 'or',\n  AND = 'and'\n}\n\nexport abstract class Filter {\n  abstract matches(doc: Document): boolean;\n\n  abstract getFlattenedFilters(): readonly FieldFilter[];\n\n  abstract getFilters(): Filter[];\n}\n\nexport class FieldFilter extends Filter {\n  protected constructor(\n    public readonly field: FieldPath,\n    public readonly op: Operator,\n    public readonly value: ProtoValue\n  ) {\n    super();\n  }\n\n  /**\n   * Creates a filter based on the provided arguments.\n   */\n  static create(\n    field: FieldPath,\n    op: Operator,\n    value: ProtoValue\n  ): FieldFilter {\n    if (field.isKeyField()) {\n      if (op === Operator.IN || op === Operator.NOT_IN) {\n        return this.createKeyFieldInFilter(field, op, value);\n      } else {\n        debugAssert(\n          isReferenceValue(value),\n          'Comparing on key, but filter value not a RefValue'\n        );\n        debugAssert(\n          op !== Operator.ARRAY_CONTAINS && op !== Operator.ARRAY_CONTAINS_ANY,\n          `'${op.toString()}' queries don't make sense on document keys.`\n        );\n        return new KeyFieldFilter(field, op, value);\n      }\n    } else if (op === Operator.ARRAY_CONTAINS) {\n      return new ArrayContainsFilter(field, value);\n    } else if (op === Operator.IN) {\n      debugAssert(\n        isArray(value),\n        'IN filter has invalid value: ' + value.toString()\n      );\n      return new InFilter(field, value);\n    } else if (op === Operator.NOT_IN) {\n      debugAssert(\n        isArray(value),\n        'NOT_IN filter has invalid value: ' + value.toString()\n      );\n      return new NotInFilter(field, value);\n    } else if (op === Operator.ARRAY_CONTAINS_ANY) {\n      debugAssert(\n        isArray(value),\n        'ARRAY_CONTAINS_ANY filter has invalid value: ' + value.toString()\n      );\n      return new ArrayContainsAnyFilter(field, value);\n    } else {\n      return new FieldFilter(field, op, value);\n    }\n  }\n\n  private static createKeyFieldInFilter(\n    field: FieldPath,\n    op: Operator.IN | Operator.NOT_IN,\n    value: ProtoValue\n  ): FieldFilter {\n    debugAssert(\n      isArray(value),\n      `Comparing on key with ${op.toString()}` +\n        ', but filter value not an ArrayValue'\n    );\n    debugAssert(\n      (value.arrayValue.values || []).every(elem => isReferenceValue(elem)),\n      `Comparing on key with ${op.toString()}` +\n        ', but an array value was not a RefValue'\n    );\n\n    return op === Operator.IN\n      ? new KeyFieldInFilter(field, value)\n      : new KeyFieldNotInFilter(field, value);\n  }\n\n  matches(doc: Document): boolean {\n    const other = doc.data.field(this.field);\n    // Types do not have to match in NOT_EQUAL filters.\n    if (this.op === Operator.NOT_EQUAL) {\n      return (\n        other !== null &&\n        this.matchesComparison(valueCompare(other!, this.value))\n      );\n    }\n\n    // Only compare types with matching backend order (such as double and int).\n    return (\n      other !== null &&\n      typeOrder(this.value) === typeOrder(other) &&\n      this.matchesComparison(valueCompare(other, this.value))\n    );\n  }\n\n  protected matchesComparison(comparison: number): boolean {\n    switch (this.op) {\n      case Operator.LESS_THAN:\n        return comparison < 0;\n      case Operator.LESS_THAN_OR_EQUAL:\n        return comparison <= 0;\n      case Operator.EQUAL:\n        return comparison === 0;\n      case Operator.NOT_EQUAL:\n        return comparison !== 0;\n      case Operator.GREATER_THAN:\n        return comparison > 0;\n      case Operator.GREATER_THAN_OR_EQUAL:\n        return comparison >= 0;\n      default:\n        return fail('Unknown FieldFilter operator: ' + this.op);\n    }\n  }\n\n  isInequality(): boolean {\n    return (\n      [\n        Operator.LESS_THAN,\n        Operator.LESS_THAN_OR_EQUAL,\n        Operator.GREATER_THAN,\n        Operator.GREATER_THAN_OR_EQUAL,\n        Operator.NOT_EQUAL,\n        Operator.NOT_IN\n      ].indexOf(this.op) >= 0\n    );\n  }\n\n  getFlattenedFilters(): readonly FieldFilter[] {\n    return [this];\n  }\n\n  getFilters(): Filter[] {\n    return [this];\n  }\n}\n\nexport class CompositeFilter extends Filter {\n  private memoizedFlattenedFilters: FieldFilter[] | null = null;\n\n  protected constructor(\n    public readonly filters: readonly Filter[],\n    public readonly op: CompositeOperator\n  ) {\n    super();\n  }\n\n  /**\n   * Creates a filter based on the provided arguments.\n   */\n  static create(filters: Filter[], op: CompositeOperator): CompositeFilter {\n    return new CompositeFilter(filters, op);\n  }\n\n  matches(doc: Document): boolean {\n    if (compositeFilterIsConjunction(this)) {\n      // For conjunctions, all filters must match, so return false if any filter doesn't match.\n      return this.filters.find(filter => !filter.matches(doc)) === undefined;\n    } else {\n      // For disjunctions, at least one filter should match.\n      return this.filters.find(filter => filter.matches(doc)) !== undefined;\n    }\n  }\n\n  getFlattenedFilters(): readonly FieldFilter[] {\n    if (this.memoizedFlattenedFilters !== null) {\n      return this.memoizedFlattenedFilters;\n    }\n\n    this.memoizedFlattenedFilters = this.filters.reduce((result, subfilter) => {\n      return result.concat(subfilter.getFlattenedFilters());\n    }, [] as FieldFilter[]);\n\n    return this.memoizedFlattenedFilters;\n  }\n\n  // Returns a mutable copy of `this.filters`\n  getFilters(): Filter[] {\n    return Object.assign([], this.filters);\n  }\n}\n\nexport function compositeFilterIsConjunction(\n  compositeFilter: CompositeFilter\n): boolean {\n  return compositeFilter.op === CompositeOperator.AND;\n}\n\nexport function compositeFilterIsDisjunction(\n  compositeFilter: CompositeFilter\n): boolean {\n  return compositeFilter.op === CompositeOperator.OR;\n}\n\n/**\n * Returns true if this filter is a conjunction of field filters only. Returns false otherwise.\n */\nexport function compositeFilterIsFlatConjunction(\n  compositeFilter: CompositeFilter\n): boolean {\n  return (\n    compositeFilterIsFlat(compositeFilter) &&\n    compositeFilterIsConjunction(compositeFilter)\n  );\n}\n\n/**\n * Returns true if this filter does not contain any composite filters. Returns false otherwise.\n */\nexport function compositeFilterIsFlat(\n  compositeFilter: CompositeFilter\n): boolean {\n  for (const filter of compositeFilter.filters) {\n    if (filter instanceof CompositeFilter) {\n      return false;\n    }\n  }\n  return true;\n}\n\nexport function canonifyFilter(filter: Filter): string {\n  debugAssert(\n    filter instanceof FieldFilter || filter instanceof CompositeFilter,\n    'canonifyFilter() only supports FieldFilters and CompositeFilters'\n  );\n\n  if (filter instanceof FieldFilter) {\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 (\n      filter.field.canonicalString() +\n      filter.op.toString() +\n      canonicalId(filter.value)\n    );\n  } else if (compositeFilterIsFlatConjunction(filter)) {\n    // Older SDK versions use an implicit AND operation between their filters.\n    // In the new SDK versions, the developer may use an explicit AND filter.\n    // To stay consistent with the old usages, we add a special case to ensure\n    // the canonical ID for these two are the same. For example:\n    // `col.whereEquals(\"a\", 1).whereEquals(\"b\", 2)` should have the same\n    // canonical ID as `col.where(and(equals(\"a\",1), equals(\"b\",2)))`.\n    return filter.filters.map(filter => canonifyFilter(filter)).join(',');\n  } else {\n    // filter instanceof CompositeFilter\n    const canonicalIdsString = filter.filters\n      .map(filter => canonifyFilter(filter))\n      .join(',');\n    return `${filter.op}(${canonicalIdsString})`;\n  }\n}\n\nexport function filterEquals(f1: Filter, f2: Filter): boolean {\n  if (f1 instanceof FieldFilter) {\n    return fieldFilterEquals(f1, f2);\n  } else if (f1 instanceof CompositeFilter) {\n    return compositeFilterEquals(f1, f2);\n  } else {\n    fail('Only FieldFilters and CompositeFilters can be compared');\n  }\n}\n\nexport function fieldFilterEquals(f1: FieldFilter, f2: Filter): boolean {\n  return (\n    f2 instanceof FieldFilter &&\n    f1.op === f2.op &&\n    f1.field.isEqual(f2.field) &&\n    valueEquals(f1.value, f2.value)\n  );\n}\n\nexport function compositeFilterEquals(\n  f1: CompositeFilter,\n  f2: Filter\n): boolean {\n  if (\n    f2 instanceof CompositeFilter &&\n    f1.op === f2.op &&\n    f1.filters.length === f2.filters.length\n  ) {\n    const subFiltersMatch: boolean = f1.filters.reduce(\n      (result: boolean, f1Filter: Filter, index: number): boolean =>\n        result && filterEquals(f1Filter, f2.filters[index]),\n      true\n    );\n\n    return subFiltersMatch;\n  }\n\n  return false;\n}\n\n/**\n * Returns a new composite filter that contains all filter from\n * `compositeFilter` plus all the given filters in `otherFilters`.\n */\nexport function compositeFilterWithAddedFilters(\n  compositeFilter: CompositeFilter,\n  otherFilters: Filter[]\n): CompositeFilter {\n  const mergedFilters = compositeFilter.filters.concat(otherFilters);\n  return CompositeFilter.create(mergedFilters, compositeFilter.op);\n}\n\n/** Returns a debug description for `filter`. */\nexport function stringifyFilter(filter: Filter): string {\n  debugAssert(\n    filter instanceof FieldFilter || filter instanceof CompositeFilter,\n    'stringifyFilter() only supports FieldFilters and CompositeFilters'\n  );\n  if (filter instanceof FieldFilter) {\n    return stringifyFieldFilter(filter);\n  } else if (filter instanceof CompositeFilter) {\n    return stringifyCompositeFilter(filter);\n  } else {\n    return 'Filter';\n  }\n}\n\nexport function stringifyCompositeFilter(filter: CompositeFilter): string {\n  return (\n    filter.op.toString() +\n    ` {` +\n    filter.getFilters().map(stringifyFilter).join(' ,') +\n    '}'\n  );\n}\n\nexport function stringifyFieldFilter(filter: FieldFilter): string {\n  return `${filter.field.canonicalString()} ${filter.op} ${canonicalId(\n    filter.value\n  )}`;\n}\n\n/** Filter that matches on key fields (i.e. '__name__'). */\nexport class KeyFieldFilter extends FieldFilter {\n  private readonly key: DocumentKey;\n\n  constructor(field: FieldPath, op: Operator, value: ProtoValue) {\n    super(field, op, value);\n    debugAssert(\n      isReferenceValue(value),\n      'KeyFieldFilter expects a ReferenceValue'\n    );\n    this.key = DocumentKey.fromName(value.referenceValue);\n  }\n\n  matches(doc: Document): boolean {\n    const comparison = DocumentKey.comparator(doc.key, this.key);\n    return this.matchesComparison(comparison);\n  }\n}\n\n/** Filter that matches on key fields within an array. */\nexport class KeyFieldInFilter extends FieldFilter {\n  private readonly keys: DocumentKey[];\n\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.IN, value);\n    this.keys = extractDocumentKeysFromArrayValue(Operator.IN, value);\n  }\n\n  matches(doc: Document): boolean {\n    return this.keys.some(key => key.isEqual(doc.key));\n  }\n}\n\n/** Filter that matches on key fields not present within an array. */\nexport class KeyFieldNotInFilter extends FieldFilter {\n  private readonly keys: DocumentKey[];\n\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.NOT_IN, value);\n    this.keys = extractDocumentKeysFromArrayValue(Operator.NOT_IN, value);\n  }\n\n  matches(doc: Document): boolean {\n    return !this.keys.some(key => key.isEqual(doc.key));\n  }\n}\n\nfunction extractDocumentKeysFromArrayValue(\n  op: Operator.IN | Operator.NOT_IN,\n  value: ProtoValue\n): DocumentKey[] {\n  debugAssert(\n    isArray(value),\n    'KeyFieldInFilter/KeyFieldNotInFilter expects an ArrayValue'\n  );\n  return (value.arrayValue?.values || []).map(v => {\n    debugAssert(\n      isReferenceValue(v),\n      `Comparing on key with ${op.toString()}, but an array value was not ` +\n        `a ReferenceValue`\n    );\n    return DocumentKey.fromName(v.referenceValue);\n  });\n}\n\n/** A Filter that implements the array-contains operator. */\nexport class ArrayContainsFilter extends FieldFilter {\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.ARRAY_CONTAINS, value);\n  }\n\n  matches(doc: Document): boolean {\n    const other = doc.data.field(this.field);\n    return isArray(other) && arrayValueContains(other.arrayValue, this.value);\n  }\n}\n\n/** A Filter that implements the IN operator. */\nexport class InFilter extends FieldFilter {\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.IN, value);\n    debugAssert(isArray(value), 'InFilter expects an ArrayValue');\n  }\n\n  matches(doc: Document): boolean {\n    const other = doc.data.field(this.field);\n    return other !== null && arrayValueContains(this.value.arrayValue!, other);\n  }\n}\n\n/** A Filter that implements the not-in operator. */\nexport class NotInFilter extends FieldFilter {\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.NOT_IN, value);\n    debugAssert(isArray(value), 'NotInFilter expects an ArrayValue');\n  }\n\n  matches(doc: Document): boolean {\n    if (\n      arrayValueContains(this.value.arrayValue!, { nullValue: 'NULL_VALUE' })\n    ) {\n      return false;\n    }\n    const other = doc.data.field(this.field);\n    return other !== null && !arrayValueContains(this.value.arrayValue!, other);\n  }\n}\n\n/** A Filter that implements the array-contains-any operator. */\nexport class ArrayContainsAnyFilter extends FieldFilter {\n  constructor(field: FieldPath, value: ProtoValue) {\n    super(field, Operator.ARRAY_CONTAINS_ANY, value);\n    debugAssert(isArray(value), 'ArrayContainsAnyFilter expects an ArrayValue');\n  }\n\n  matches(doc: Document): boolean {\n    const other = doc.data.field(this.field);\n    if (!isArray(other) || !other.arrayValue.values) {\n      return false;\n    }\n    return other.arrayValue.values.some(val =>\n      arrayValueContains(this.value.arrayValue!, val)\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 { DocumentKey } from '../model/document_key';\nimport {\n  FieldIndex,\n  fieldIndexGetArraySegment,\n  fieldIndexGetDirectionalSegments,\n  IndexKind\n} from '../model/field_index';\nimport { FieldPath, ResourcePath } from '../model/path';\nimport {\n  canonicalId,\n  MAX_VALUE,\n  MIN_VALUE,\n  lowerBoundCompare,\n  upperBoundCompare,\n  valuesGetLowerBound,\n  valuesGetUpperBound\n} from '../model/values';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { debugCast } from '../util/assert';\nimport { SortedSet } from '../util/sorted_set';\nimport { isNullOrUndefined } from '../util/types';\n\nimport { Bound, boundEquals } from './bound';\nimport {\n  Filter,\n  FieldFilter,\n  canonifyFilter,\n  stringifyFilter,\n  filterEquals,\n  Operator\n} from './filter';\nimport {\n  canonifyOrderBy,\n  OrderBy,\n  orderByEquals,\n  stringifyOrderBy\n} from './order_by';\n\n/**\n * A Target represents the WatchTarget representation of a Query, which is used\n * by the LocalStore and the RemoteStore to keep track of and to execute\n * backend queries. While a Query can represent multiple Targets, each Targets\n * maps to a single WatchTarget in RemoteStore and a single TargetData entry\n * in persistence.\n */\nexport interface Target {\n  readonly path: ResourcePath;\n  readonly collectionGroup: string | null;\n  readonly orderBy: OrderBy[];\n  readonly filters: Filter[];\n  readonly limit: number | null;\n  readonly startAt: Bound | null;\n  readonly endAt: Bound | null;\n}\n\n// Visible for testing\nexport class TargetImpl implements Target {\n  memoizedCanonicalId: string | null = null;\n  constructor(\n    readonly path: ResourcePath,\n    readonly collectionGroup: string | null = null,\n    readonly orderBy: OrderBy[] = [],\n    readonly filters: Filter[] = [],\n    readonly limit: number | null = null,\n    readonly startAt: Bound | null = null,\n    readonly endAt: Bound | null = null\n  ) {}\n}\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 */\nexport function newTarget(\n  path: ResourcePath,\n  collectionGroup: string | null = null,\n  orderBy: OrderBy[] = [],\n  filters: Filter[] = [],\n  limit: number | null = null,\n  startAt: Bound | null = null,\n  endAt: Bound | null = null\n): Target {\n  return new TargetImpl(\n    path,\n    collectionGroup,\n    orderBy,\n    filters,\n    limit,\n    startAt,\n    endAt\n  );\n}\n\nexport function canonifyTarget(target: Target): string {\n  const targetImpl = debugCast(target, TargetImpl);\n\n  if (targetImpl.memoizedCanonicalId === null) {\n    let str = targetImpl.path.canonicalString();\n    if (targetImpl.collectionGroup !== null) {\n      str += '|cg:' + targetImpl.collectionGroup;\n    }\n    str += '|f:';\n    str += targetImpl.filters.map(f => canonifyFilter(f)).join(',');\n    str += '|ob:';\n    str += targetImpl.orderBy.map(o => canonifyOrderBy(o)).join(',');\n\n    if (!isNullOrUndefined(targetImpl.limit)) {\n      str += '|l:';\n      str += targetImpl.limit!;\n    }\n    if (targetImpl.startAt) {\n      str += '|lb:';\n      str += targetImpl.startAt.inclusive ? 'b:' : 'a:';\n      str += targetImpl.startAt.position.map(p => canonicalId(p)).join(',');\n    }\n    if (targetImpl.endAt) {\n      str += '|ub:';\n      str += targetImpl.endAt.inclusive ? 'a:' : 'b:';\n      str += targetImpl.endAt.position.map(p => canonicalId(p)).join(',');\n    }\n    targetImpl.memoizedCanonicalId = str;\n  }\n  return targetImpl.memoizedCanonicalId;\n}\n\nexport function stringifyTarget(target: Target): string {\n  let str = target.path.canonicalString();\n  if (target.collectionGroup !== null) {\n    str += ' collectionGroup=' + target.collectionGroup;\n  }\n  if (target.filters.length > 0) {\n    str += `, filters: [${target.filters\n      .map(f => stringifyFilter(f))\n      .join(', ')}]`;\n  }\n  if (!isNullOrUndefined(target.limit)) {\n    str += ', limit: ' + target.limit;\n  }\n  if (target.orderBy.length > 0) {\n    str += `, orderBy: [${target.orderBy\n      .map(o => stringifyOrderBy(o))\n      .join(', ')}]`;\n  }\n  if (target.startAt) {\n    str += ', startAt: ';\n    str += target.startAt.inclusive ? 'b:' : 'a:';\n    str += target.startAt.position.map(p => canonicalId(p)).join(',');\n  }\n  if (target.endAt) {\n    str += ', endAt: ';\n    str += target.endAt.inclusive ? 'a:' : 'b:';\n    str += target.endAt.position.map(p => canonicalId(p)).join(',');\n  }\n  return `Target(${str})`;\n}\n\nexport function targetEquals(left: Target, right: Target): boolean {\n  if (left.limit !== right.limit) {\n    return false;\n  }\n\n  if (left.orderBy.length !== right.orderBy.length) {\n    return false;\n  }\n\n  for (let i = 0; i < left.orderBy.length; i++) {\n    if (!orderByEquals(left.orderBy[i], right.orderBy[i])) {\n      return false;\n    }\n  }\n\n  if (left.filters.length !== right.filters.length) {\n    return false;\n  }\n\n  for (let i = 0; i < left.filters.length; i++) {\n    if (!filterEquals(left.filters[i], right.filters[i])) {\n      return false;\n    }\n  }\n\n  if (left.collectionGroup !== right.collectionGroup) {\n    return false;\n  }\n\n  if (!left.path.isEqual(right.path)) {\n    return false;\n  }\n\n  if (!boundEquals(left.startAt, right.startAt)) {\n    return false;\n  }\n\n  return boundEquals(left.endAt, right.endAt);\n}\n\nexport function targetIsDocumentTarget(target: Target): boolean {\n  return (\n    DocumentKey.isDocumentKey(target.path) &&\n    target.collectionGroup === null &&\n    target.filters.length === 0\n  );\n}\n\n/** Returns the field filters that target the given field path. */\nexport function targetGetFieldFiltersForPath(\n  target: Target,\n  path: FieldPath\n): FieldFilter[] {\n  return target.filters.filter(\n    f => f instanceof FieldFilter && f.field.isEqual(path)\n  ) as FieldFilter[];\n}\n\n/**\n * Returns the values that are used in ARRAY_CONTAINS or ARRAY_CONTAINS_ANY\n * filters. Returns `null` if there are no such filters.\n */\nexport function targetGetArrayValues(\n  target: Target,\n  fieldIndex: FieldIndex\n): ProtoValue[] | null {\n  const segment = fieldIndexGetArraySegment(fieldIndex);\n  if (segment === undefined) {\n    return null;\n  }\n\n  for (const fieldFilter of targetGetFieldFiltersForPath(\n    target,\n    segment.fieldPath\n  )) {\n    switch (fieldFilter.op) {\n      case Operator.ARRAY_CONTAINS_ANY:\n        return fieldFilter.value.arrayValue!.values || [];\n      case Operator.ARRAY_CONTAINS:\n        return [fieldFilter.value];\n      default:\n      // Remaining filters are not array filters.\n    }\n  }\n  return null;\n}\n\n/**\n * Returns the list of values that are used in != or NOT_IN filters. Returns\n * `null` if there are no such filters.\n */\nexport function targetGetNotInValues(\n  target: Target,\n  fieldIndex: FieldIndex\n): ProtoValue[] | null {\n  const values = new Map</* fieldPath = */ string, ProtoValue>();\n\n  for (const segment of fieldIndexGetDirectionalSegments(fieldIndex)) {\n    for (const fieldFilter of targetGetFieldFiltersForPath(\n      target,\n      segment.fieldPath\n    )) {\n      switch (fieldFilter.op) {\n        case Operator.EQUAL:\n        case Operator.IN:\n          // Encode equality prefix, which is encoded in the index value before\n          // the inequality (e.g. `a == 'a' && b != 'b'` is encoded to\n          // `value != 'ab'`).\n          values.set(segment.fieldPath.canonicalString(), fieldFilter.value);\n          break;\n        case Operator.NOT_IN:\n        case Operator.NOT_EQUAL:\n          // NotIn/NotEqual is always a suffix. There cannot be any remaining\n          // segments and hence we can return early here.\n          values.set(segment.fieldPath.canonicalString(), fieldFilter.value);\n          return Array.from(values.values());\n        default:\n        // Remaining filters cannot be used as notIn bounds.\n      }\n    }\n  }\n\n  return null;\n}\n\n/**\n * Returns a lower bound of field values that can be used as a starting point to\n * scan the index defined by `fieldIndex`. Returns `MIN_VALUE` if no lower bound\n * exists.\n */\nexport function targetGetLowerBound(\n  target: Target,\n  fieldIndex: FieldIndex\n): Bound {\n  const values: ProtoValue[] = [];\n  let inclusive = true;\n\n  // For each segment, retrieve a lower bound if there is a suitable filter or\n  // startAt.\n  for (const segment of fieldIndexGetDirectionalSegments(fieldIndex)) {\n    const segmentBound =\n      segment.kind === IndexKind.ASCENDING\n        ? targetGetAscendingBound(target, segment.fieldPath, target.startAt)\n        : targetGetDescendingBound(target, segment.fieldPath, target.startAt);\n\n    values.push(segmentBound.value);\n    inclusive &&= segmentBound.inclusive;\n  }\n  return new Bound(values, inclusive);\n}\n\n/**\n * Returns an upper bound of field values that can be used as an ending point\n * when scanning the index defined by `fieldIndex`. Returns `MAX_VALUE` if no\n * upper bound exists.\n */\nexport function targetGetUpperBound(\n  target: Target,\n  fieldIndex: FieldIndex\n): Bound {\n  const values: ProtoValue[] = [];\n  let inclusive = true;\n\n  // For each segment, retrieve an upper bound if there is a suitable filter or\n  // endAt.\n  for (const segment of fieldIndexGetDirectionalSegments(fieldIndex)) {\n    const segmentBound =\n      segment.kind === IndexKind.ASCENDING\n        ? targetGetDescendingBound(target, segment.fieldPath, target.endAt)\n        : targetGetAscendingBound(target, segment.fieldPath, target.endAt);\n\n    values.push(segmentBound.value);\n    inclusive &&= segmentBound.inclusive;\n  }\n\n  return new Bound(values, inclusive);\n}\n\n/**\n * Returns the value to use as the lower bound for ascending index segment at\n * the provided `fieldPath` (or the upper bound for an descending segment).\n */\nfunction targetGetAscendingBound(\n  target: Target,\n  fieldPath: FieldPath,\n  bound: Bound | null\n): { value: ProtoValue; inclusive: boolean } {\n  let value: ProtoValue = MIN_VALUE;\n\n  let inclusive = true;\n\n  // Process all filters to find a value for the current field segment\n  for (const fieldFilter of targetGetFieldFiltersForPath(target, fieldPath)) {\n    let filterValue: ProtoValue = MIN_VALUE;\n    let filterInclusive = true;\n\n    switch (fieldFilter.op) {\n      case Operator.LESS_THAN:\n      case Operator.LESS_THAN_OR_EQUAL:\n        filterValue = valuesGetLowerBound(fieldFilter.value);\n        break;\n      case Operator.EQUAL:\n      case Operator.IN:\n      case Operator.GREATER_THAN_OR_EQUAL:\n        filterValue = fieldFilter.value;\n        break;\n      case Operator.GREATER_THAN:\n        filterValue = fieldFilter.value;\n        filterInclusive = false;\n        break;\n      case Operator.NOT_EQUAL:\n      case Operator.NOT_IN:\n        filterValue = MIN_VALUE;\n        break;\n      default:\n      // Remaining filters cannot be used as lower bounds.\n    }\n\n    if (\n      lowerBoundCompare(\n        { value, inclusive },\n        { value: filterValue, inclusive: filterInclusive }\n      ) < 0\n    ) {\n      value = filterValue;\n      inclusive = filterInclusive;\n    }\n  }\n\n  // If there is an additional bound, compare the values against the existing\n  // range to see if we can narrow the scope.\n  if (bound !== null) {\n    for (let i = 0; i < target.orderBy.length; ++i) {\n      const orderBy = target.orderBy[i];\n      if (orderBy.field.isEqual(fieldPath)) {\n        const cursorValue = bound.position[i];\n        if (\n          lowerBoundCompare(\n            { value, inclusive },\n            { value: cursorValue, inclusive: bound.inclusive }\n          ) < 0\n        ) {\n          value = cursorValue;\n          inclusive = bound.inclusive;\n        }\n        break;\n      }\n    }\n  }\n\n  return { value, inclusive };\n}\n\n/**\n * Returns the value to use as the upper bound for ascending index segment at\n * the provided `fieldPath` (or the lower bound for a descending segment).\n */\nfunction targetGetDescendingBound(\n  target: Target,\n  fieldPath: FieldPath,\n  bound: Bound | null\n): { value: ProtoValue; inclusive: boolean } {\n  let value: ProtoValue = MAX_VALUE;\n  let inclusive = true;\n\n  // Process all filters to find a value for the current field segment\n  for (const fieldFilter of targetGetFieldFiltersForPath(target, fieldPath)) {\n    let filterValue: ProtoValue = MAX_VALUE;\n    let filterInclusive = true;\n\n    switch (fieldFilter.op) {\n      case Operator.GREATER_THAN_OR_EQUAL:\n      case Operator.GREATER_THAN:\n        filterValue = valuesGetUpperBound(fieldFilter.value);\n        filterInclusive = false;\n        break;\n      case Operator.EQUAL:\n      case Operator.IN:\n      case Operator.LESS_THAN_OR_EQUAL:\n        filterValue = fieldFilter.value;\n        break;\n      case Operator.LESS_THAN:\n        filterValue = fieldFilter.value;\n        filterInclusive = false;\n        break;\n      case Operator.NOT_EQUAL:\n      case Operator.NOT_IN:\n        filterValue = MAX_VALUE;\n        break;\n      default:\n      // Remaining filters cannot be used as upper bounds.\n    }\n\n    if (\n      upperBoundCompare(\n        { value, inclusive },\n        { value: filterValue, inclusive: filterInclusive }\n      ) > 0\n    ) {\n      value = filterValue;\n      inclusive = filterInclusive;\n    }\n  }\n\n  // If there is an additional bound, compare the values against the existing\n  // range to see if we can narrow the scope.\n  if (bound !== null) {\n    for (let i = 0; i < target.orderBy.length; ++i) {\n      const orderBy = target.orderBy[i];\n      if (orderBy.field.isEqual(fieldPath)) {\n        const cursorValue = bound.position[i];\n        if (\n          upperBoundCompare(\n            { value, inclusive },\n            { value: cursorValue, inclusive: bound.inclusive }\n          ) > 0\n        ) {\n          value = cursorValue;\n          inclusive = bound.inclusive;\n        }\n        break;\n      }\n    }\n  }\n\n  return { value, inclusive };\n}\n\n/** Returns the number of segments of a perfect index for this target. */\nexport function targetGetSegmentCount(target: Target): number {\n  let fields = new SortedSet<FieldPath>(FieldPath.comparator);\n  let hasArraySegment = false;\n\n  for (const filter of target.filters) {\n    for (const subFilter of filter.getFlattenedFilters()) {\n      // __name__ is not an explicit segment of any index, so we don't need to\n      // count it.\n      if (subFilter.field.isKeyField()) {\n        continue;\n      }\n\n      // ARRAY_CONTAINS or ARRAY_CONTAINS_ANY filters must be counted separately.\n      // For instance, it is possible to have an index for \"a ARRAY a ASC\". Even\n      // though these are on the same field, they should be counted as two\n      // separate segments in an index.\n      if (\n        subFilter.op === Operator.ARRAY_CONTAINS ||\n        subFilter.op === Operator.ARRAY_CONTAINS_ANY\n      ) {\n        hasArraySegment = true;\n      } else {\n        fields = fields.add(subFilter.field);\n      }\n    }\n  }\n\n  for (const orderBy of target.orderBy) {\n    // __name__ is not an explicit segment of any index, so we don't need to\n    // count it.\n    if (!orderBy.field.isKeyField()) {\n      fields = fields.add(orderBy.field);\n    }\n  }\n\n  return fields.size + (hasArraySegment ? 1 : 0);\n}\n\nexport function targetHasLimit(target: Target): boolean {\n  return target.limit !== 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 { compareDocumentsByField, Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldPath, ResourcePath } from '../model/path';\nimport { debugAssert, debugCast, fail } from '../util/assert';\nimport { SortedSet } from '../util/sorted_set';\n\nimport {\n  Bound,\n  boundSortsAfterDocument,\n  boundSortsBeforeDocument\n} from './bound';\nimport { FieldFilter, Filter } from './filter';\nimport { Direction, OrderBy } from './order_by';\nimport {\n  canonifyTarget,\n  newTarget,\n  stringifyTarget,\n  Target,\n  targetEquals\n} from './target';\n\nexport const enum LimitType {\n  First = 'F',\n  Last = 'L'\n}\n\n/**\n * The Query interface defines all external properties of a query.\n *\n * QueryImpl implements this interface to provide memoization for `queryNormalizedOrderBy`\n * and `queryToTarget`.\n */\nexport interface Query {\n  readonly path: ResourcePath;\n  readonly collectionGroup: string | null;\n  readonly explicitOrderBy: OrderBy[];\n  readonly filters: Filter[];\n  readonly limit: number | null;\n  readonly limitType: LimitType;\n  readonly startAt: Bound | null;\n  readonly endAt: Bound | null;\n}\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 */\nexport class QueryImpl implements Query {\n  memoizedNormalizedOrderBy: OrderBy[] | null = null;\n\n  // The corresponding `Target` of this `Query` instance, for use with\n  // non-aggregate queries.\n  memoizedTarget: Target | null = null;\n\n  // The corresponding `Target` of this `Query` instance, for use with\n  // aggregate queries. Unlike targets for non-aggregate queries,\n  // aggregate query targets do not contain normalized order-bys, they only\n  // contain explicit order-bys.\n  memoizedAggregateTarget: Target | null = null;\n\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   */\n  constructor(\n    readonly path: ResourcePath,\n    readonly collectionGroup: string | null = null,\n    readonly explicitOrderBy: OrderBy[] = [],\n    readonly filters: Filter[] = [],\n    readonly limit: number | null = null,\n    readonly limitType: LimitType = LimitType.First,\n    readonly startAt: Bound | null = null,\n    readonly endAt: Bound | null = null\n  ) {\n    if (this.startAt) {\n      debugAssert(\n        this.startAt.position.length <= queryNormalizedOrderBy(this).length,\n        'Bound is longer than orderBy'\n      );\n    }\n    if (this.endAt) {\n      debugAssert(\n        this.endAt.position.length <= queryNormalizedOrderBy(this).length,\n        'Bound is longer than orderBy'\n      );\n    }\n  }\n}\n\n/** Creates a new Query instance with the options provided. */\nexport function newQuery(\n  path: ResourcePath,\n  collectionGroup: string | null,\n  explicitOrderBy: OrderBy[],\n  filters: Filter[],\n  limit: number | null,\n  limitType: LimitType,\n  startAt: Bound | null,\n  endAt: Bound | null\n): Query {\n  return new QueryImpl(\n    path,\n    collectionGroup,\n    explicitOrderBy,\n    filters,\n    limit,\n    limitType,\n    startAt,\n    endAt\n  );\n}\n\n/** Creates a new Query for a query that matches all documents at `path` */\nexport function newQueryForPath(path: ResourcePath): Query {\n  return new QueryImpl(path);\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 */\nexport function asCollectionQueryAtPath(\n  query: Query,\n  path: ResourcePath\n): Query {\n  return new QueryImpl(\n    path,\n    /*collectionGroup=*/ null,\n    query.explicitOrderBy.slice(),\n    query.filters.slice(),\n    query.limit,\n    query.limitType,\n    query.startAt,\n    query.endAt\n  );\n}\n\n/**\n * Returns true if this query does not specify any query constraints that\n * could remove results.\n */\nexport function queryMatchesAllDocuments(query: Query): boolean {\n  return (\n    query.filters.length === 0 &&\n    query.limit === null &&\n    query.startAt == null &&\n    query.endAt == null &&\n    (query.explicitOrderBy.length === 0 ||\n      (query.explicitOrderBy.length === 1 &&\n        query.explicitOrderBy[0].field.isKeyField()))\n  );\n}\n\n// Returns the sorted set of inequality filter fields used in this query.\nexport function getInequalityFilterFields(query: Query): SortedSet<FieldPath> {\n  let result = new SortedSet<FieldPath>(FieldPath.comparator);\n  query.filters.forEach((filter: Filter) => {\n    const subFilters = filter.getFlattenedFilters();\n    subFilters.forEach((filter: FieldFilter) => {\n      if (filter.isInequality()) {\n        result = result.add(filter.field);\n      }\n    });\n  });\n  return result;\n}\n\n/**\n * Creates a new Query for a collection group query that matches all documents\n * within the provided collection group.\n */\nexport function newQueryForCollectionGroup(collectionId: string): Query {\n  return new QueryImpl(ResourcePath.emptyPath(), collectionId);\n}\n\n/**\n * Returns whether the query matches a single document by path (rather than a\n * collection).\n */\nexport function isDocumentQuery(query: Query): boolean {\n  return (\n    DocumentKey.isDocumentKey(query.path) &&\n    query.collectionGroup === null &&\n    query.filters.length === 0\n  );\n}\n\n/**\n * Returns whether the query matches a collection group rather than a specific\n * collection.\n */\nexport function isCollectionGroupQuery(query: Query): boolean {\n  return query.collectionGroup !== null;\n}\n\n/**\n * Returns the normalized 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__`). The normalized order-by\n * includes implicit order-bys in addition to the explicit user provided\n * order-bys.\n */\nexport function queryNormalizedOrderBy(query: Query): OrderBy[] {\n  const queryImpl = debugCast(query, QueryImpl);\n  if (queryImpl.memoizedNormalizedOrderBy === null) {\n    queryImpl.memoizedNormalizedOrderBy = [];\n    const fieldsNormalized = new Set<string>();\n\n    // Any explicit order by fields should be added as is.\n    for (const orderBy of queryImpl.explicitOrderBy) {\n      queryImpl.memoizedNormalizedOrderBy.push(orderBy);\n      fieldsNormalized.add(orderBy.field.canonicalString());\n    }\n\n    // The order of the implicit ordering always matches the last explicit order by.\n    const lastDirection =\n      queryImpl.explicitOrderBy.length > 0\n        ? queryImpl.explicitOrderBy[queryImpl.explicitOrderBy.length - 1].dir\n        : Direction.ASCENDING;\n\n    // Any inequality fields not explicitly ordered should be implicitly ordered in a lexicographical\n    // order. When there are multiple inequality filters on the same field, the field should be added\n    // only once.\n    // Note: `SortedSet<FieldPath>` sorts the key field before other fields. However, we want the key\n    // field to be sorted last.\n    const inequalityFields: SortedSet<FieldPath> =\n      getInequalityFilterFields(queryImpl);\n    inequalityFields.forEach(field => {\n      if (\n        !fieldsNormalized.has(field.canonicalString()) &&\n        !field.isKeyField()\n      ) {\n        queryImpl.memoizedNormalizedOrderBy!.push(\n          new OrderBy(field, lastDirection)\n        );\n      }\n    });\n\n    // Add the document key field to the last if it is not explicitly ordered.\n    if (!fieldsNormalized.has(FieldPath.keyField().canonicalString())) {\n      queryImpl.memoizedNormalizedOrderBy.push(\n        new OrderBy(FieldPath.keyField(), lastDirection)\n      );\n    }\n  }\n  return queryImpl.memoizedNormalizedOrderBy;\n}\n\n/**\n * Converts this `Query` instance to its corresponding `Target` representation.\n */\nexport function queryToTarget(query: Query): Target {\n  const queryImpl = debugCast(query, QueryImpl);\n  if (!queryImpl.memoizedTarget) {\n    queryImpl.memoizedTarget = _queryToTarget(\n      queryImpl,\n      queryNormalizedOrderBy(query)\n    );\n  }\n\n  return queryImpl.memoizedTarget;\n}\n\n/**\n * Converts this `Query` instance to its corresponding `Target` representation,\n * for use within an aggregate query. Unlike targets for non-aggregate queries,\n * aggregate query targets do not contain normalized order-bys, they only\n * contain explicit order-bys.\n */\nexport function queryToAggregateTarget(query: Query): Target {\n  const queryImpl = debugCast(query, QueryImpl);\n\n  if (!queryImpl.memoizedAggregateTarget) {\n    // Do not include implicit order-bys for aggregate queries.\n    queryImpl.memoizedAggregateTarget = _queryToTarget(\n      queryImpl,\n      query.explicitOrderBy\n    );\n  }\n\n  return queryImpl.memoizedAggregateTarget;\n}\n\nfunction _queryToTarget(queryImpl: QueryImpl, orderBys: OrderBy[]): Target {\n  if (queryImpl.limitType === LimitType.First) {\n    return newTarget(\n      queryImpl.path,\n      queryImpl.collectionGroup,\n      orderBys,\n      queryImpl.filters,\n      queryImpl.limit,\n      queryImpl.startAt,\n      queryImpl.endAt\n    );\n  } else {\n    // Flip the orderBy directions since we want the last results\n    orderBys = orderBys.map(orderBy => {\n      const dir =\n        orderBy.dir === Direction.DESCENDING\n          ? Direction.ASCENDING\n          : Direction.DESCENDING;\n      return new OrderBy(orderBy.field, dir);\n    });\n\n    // We need to swap the cursors to match the now-flipped query ordering.\n    const startAt = queryImpl.endAt\n      ? new Bound(queryImpl.endAt.position, queryImpl.endAt.inclusive)\n      : null;\n    const endAt = queryImpl.startAt\n      ? new Bound(queryImpl.startAt.position, queryImpl.startAt.inclusive)\n      : null;\n\n    // Now return as a LimitType.First query.\n    return newTarget(\n      queryImpl.path,\n      queryImpl.collectionGroup,\n      orderBys,\n      queryImpl.filters,\n      queryImpl.limit,\n      startAt,\n      endAt\n    );\n  }\n}\n\nexport function queryWithAddedFilter(query: Query, filter: Filter): Query {\n  debugAssert(\n    !isDocumentQuery(query),\n    'No filtering allowed for document query'\n  );\n\n  const newFilters = query.filters.concat([filter]);\n  return new QueryImpl(\n    query.path,\n    query.collectionGroup,\n    query.explicitOrderBy.slice(),\n    newFilters,\n    query.limit,\n    query.limitType,\n    query.startAt,\n    query.endAt\n  );\n}\n\nexport function queryWithAddedOrderBy(query: Query, orderBy: OrderBy): Query {\n  debugAssert(\n    !query.startAt && !query.endAt,\n    'Bounds must be set after orderBy'\n  );\n  // TODO(dimond): validate that orderBy does not list the same key twice.\n  const newOrderBy = query.explicitOrderBy.concat([orderBy]);\n  return new QueryImpl(\n    query.path,\n    query.collectionGroup,\n    newOrderBy,\n    query.filters.slice(),\n    query.limit,\n    query.limitType,\n    query.startAt,\n    query.endAt\n  );\n}\n\nexport function queryWithLimit(\n  query: Query,\n  limit: number | null,\n  limitType: LimitType\n): Query {\n  return new QueryImpl(\n    query.path,\n    query.collectionGroup,\n    query.explicitOrderBy.slice(),\n    query.filters.slice(),\n    limit,\n    limitType,\n    query.startAt,\n    query.endAt\n  );\n}\n\nexport function queryWithStartAt(query: Query, bound: Bound): Query {\n  return new QueryImpl(\n    query.path,\n    query.collectionGroup,\n    query.explicitOrderBy.slice(),\n    query.filters.slice(),\n    query.limit,\n    query.limitType,\n    bound,\n    query.endAt\n  );\n}\n\nexport function queryWithEndAt(query: Query, bound: Bound): Query {\n  return new QueryImpl(\n    query.path,\n    query.collectionGroup,\n    query.explicitOrderBy.slice(),\n    query.filters.slice(),\n    query.limit,\n    query.limitType,\n    query.startAt,\n    bound\n  );\n}\n\nexport function queryEquals(left: Query, right: Query): boolean {\n  return (\n    targetEquals(queryToTarget(left), queryToTarget(right)) &&\n    left.limitType === right.limitType\n  );\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.\nexport function canonifyQuery(query: Query): string {\n  return `${canonifyTarget(queryToTarget(query))}|lt:${query.limitType}`;\n}\n\nexport function stringifyQuery(query: Query): string {\n  return `Query(target=${stringifyTarget(queryToTarget(query))}; limitType=${\n    query.limitType\n  })`;\n}\n\n/** Returns whether `doc` matches the constraints of `query`. */\nexport function queryMatches(query: Query, doc: Document): boolean {\n  return (\n    doc.isFoundDocument() &&\n    queryMatchesPathAndCollectionGroup(query, doc) &&\n    queryMatchesOrderBy(query, doc) &&\n    queryMatchesFilters(query, doc) &&\n    queryMatchesBounds(query, doc)\n  );\n}\n\nfunction queryMatchesPathAndCollectionGroup(\n  query: Query,\n  doc: Document\n): boolean {\n  const docPath = doc.key.path;\n  if (query.collectionGroup !== null) {\n    // NOTE: this.path is currently always empty since we don't expose Collection\n    // Group queries rooted at a document path yet.\n    return (\n      doc.key.hasCollectionId(query.collectionGroup) &&\n      query.path.isPrefixOf(docPath)\n    );\n  } else if (DocumentKey.isDocumentKey(query.path)) {\n    // exact match for document queries\n    return query.path.isEqual(docPath);\n  } else {\n    // shallow ancestor queries by default\n    return query.path.isImmediateParentOf(docPath);\n  }\n}\n\n/**\n * A document must have a value for every ordering clause in order to show up\n * in the results.\n */\nfunction queryMatchesOrderBy(query: Query, doc: Document): boolean {\n  // We must use `queryNormalizedOrderBy()` to get the list of all orderBys (both implicit and explicit).\n  // Note that for OR queries, orderBy applies to all disjunction terms and implicit orderBys must\n  // be taken into account. For example, the query \"a > 1 || b==1\" has an implicit \"orderBy a\" due\n  // to the inequality, and is evaluated as \"a > 1 orderBy a || b==1 orderBy a\".\n  // A document with content of {b:1} matches the filters, but does not match the orderBy because\n  // it's missing the field 'a'.\n  for (const orderBy of queryNormalizedOrderBy(query)) {\n    // order-by key always matches\n    if (!orderBy.field.isKeyField() && doc.data.field(orderBy.field) === null) {\n      return false;\n    }\n  }\n  return true;\n}\n\nfunction queryMatchesFilters(query: Query, doc: Document): boolean {\n  for (const filter of query.filters) {\n    if (!filter.matches(doc)) {\n      return false;\n    }\n  }\n  return true;\n}\n\n/** Makes sure a document is within the bounds, if provided. */\nfunction queryMatchesBounds(query: Query, doc: Document): boolean {\n  if (\n    query.startAt &&\n    !boundSortsBeforeDocument(query.startAt, queryNormalizedOrderBy(query), doc)\n  ) {\n    return false;\n  }\n  if (\n    query.endAt &&\n    !boundSortsAfterDocument(query.endAt, queryNormalizedOrderBy(query), doc)\n  ) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Returns the collection group that this query targets.\n *\n * PORTING NOTE: This is only used in the Web SDK to facilitate multi-tab\n * synchronization for query results.\n */\nexport function queryCollectionGroup(query: Query): string {\n  return (\n    query.collectionGroup ||\n    (query.path.length % 2 === 1\n      ? query.path.lastSegment()\n      : query.path.get(query.path.length - 2))\n  );\n}\n\n/**\n * Returns a new comparator function that can be used to compare two documents\n * based on the Query's ordering constraint.\n */\nexport function newQueryComparator(\n  query: Query\n): (d1: Document, d2: Document) => number {\n  return (d1: Document, d2: Document): number => {\n    let comparedOnKeyField = false;\n    for (const orderBy of queryNormalizedOrderBy(query)) {\n      const comp = compareDocs(orderBy, d1, d2);\n      if (comp !== 0) {\n        return comp;\n      }\n      comparedOnKeyField = comparedOnKeyField || orderBy.field.isKeyField();\n    }\n    // Assert that we actually compared by key\n    debugAssert(\n      comparedOnKeyField,\n      \"orderBy used that doesn't compare on key field\"\n    );\n    return 0;\n  };\n}\n\nexport function compareDocs(\n  orderBy: OrderBy,\n  d1: Document,\n  d2: Document\n): number {\n  const comparison = orderBy.field.isKeyField()\n    ? DocumentKey.comparator(d1.key, d2.key)\n    : compareDocumentsByField(orderBy.field, d1, d2);\n  switch (orderBy.dir) {\n    case Direction.ASCENDING:\n      return comparison;\n    case Direction.DESCENDING:\n      return -1 * comparison;\n    default:\n      return fail('Unknown direction: ' + orderBy.dir);\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 { forEach, isEmpty } from './obj';\n\ntype Entry<K, V> = [K, V];\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 */\nexport class ObjectMap<KeyType, ValueType> {\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  private inner: {\n    [canonicalId: string]: Array<Entry<KeyType, ValueType>>;\n  } = {};\n\n  /** The number of entries stored in the map */\n  private innerSize = 0;\n\n  constructor(\n    private mapKeyFn: (key: KeyType) => string,\n    private equalsFn: (l: KeyType, r: KeyType) => boolean\n  ) {}\n\n  /** Get a value for this key, or undefined if it does not exist. */\n  get(key: KeyType): ValueType | undefined {\n    const id = this.mapKeyFn(key);\n    const matches = this.inner[id];\n    if (matches === undefined) {\n      return undefined;\n    }\n    for (const [otherKey, value] of matches) {\n      if (this.equalsFn(otherKey, key)) {\n        return value;\n      }\n    }\n    return undefined;\n  }\n\n  has(key: KeyType): boolean {\n    return this.get(key) !== undefined;\n  }\n\n  /** Put this key and value in the map. */\n  set(key: KeyType, value: ValueType): void {\n    const id = this.mapKeyFn(key);\n    const matches = this.inner[id];\n    if (matches === undefined) {\n      this.inner[id] = [[key, value]];\n      this.innerSize++;\n      return;\n    }\n    for (let i = 0; i < matches.length; i++) {\n      if (this.equalsFn(matches[i][0], key)) {\n        // This is updating an existing entry and does not increase `innerSize`.\n        matches[i] = [key, value];\n        return;\n      }\n    }\n    matches.push([key, value]);\n    this.innerSize++;\n  }\n\n  /**\n   * Remove this key from the map. Returns a boolean if anything was deleted.\n   */\n  delete(key: KeyType): boolean {\n    const id = this.mapKeyFn(key);\n    const matches = this.inner[id];\n    if (matches === undefined) {\n      return false;\n    }\n    for (let i = 0; i < matches.length; i++) {\n      if (this.equalsFn(matches[i][0], key)) {\n        if (matches.length === 1) {\n          delete this.inner[id];\n        } else {\n          matches.splice(i, 1);\n        }\n        this.innerSize--;\n        return true;\n      }\n    }\n    return false;\n  }\n\n  forEach(fn: (key: KeyType, val: ValueType) => void): void {\n    forEach(this.inner, (_, entries) => {\n      for (const [k, v] of entries) {\n        fn(k, v);\n      }\n    });\n  }\n\n  isEmpty(): boolean {\n    return isEmpty(this.inner);\n  }\n\n  size(): number {\n    return this.innerSize;\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { TargetId } from '../core/types';\nimport { OverlayedDocument } from '../local/overlayed_document';\nimport { primitiveComparator } from '../util/misc';\nimport { ObjectMap } from '../util/obj_map';\nimport { SortedMap } from '../util/sorted_map';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { Document, MutableDocument } from './document';\nimport { DocumentKey } from './document_key';\nimport { Mutation } from './mutation';\nimport { Overlay } from './overlay';\n\n/** Miscellaneous collection types / constants. */\n\nexport type MutableDocumentMap = SortedMap<DocumentKey, MutableDocument>;\nconst EMPTY_MUTABLE_DOCUMENT_MAP = new SortedMap<DocumentKey, MutableDocument>(\n  DocumentKey.comparator\n);\nexport function mutableDocumentMap(): MutableDocumentMap {\n  return EMPTY_MUTABLE_DOCUMENT_MAP;\n}\n\nexport interface DocumentSizeEntries {\n  documents: MutableDocumentMap;\n  sizeMap: SortedMap<DocumentKey, number>;\n}\n\nexport type DocumentMap = SortedMap<DocumentKey, Document>;\nconst EMPTY_DOCUMENT_MAP = new SortedMap<DocumentKey, Document>(\n  DocumentKey.comparator\n);\nexport function documentMap(...docs: Document[]): DocumentMap {\n  let map = EMPTY_DOCUMENT_MAP;\n  for (const doc of docs) {\n    map = map.insert(doc.key, doc);\n  }\n  return map;\n}\n\nexport type OverlayedDocumentMap = DocumentKeyMap<OverlayedDocument>;\nexport function newOverlayedDocumentMap(): OverlayedDocumentMap {\n  return newDocumentKeyMap<OverlayedDocument>();\n}\n\nexport function convertOverlayedDocumentMapToDocumentMap(\n  collection: OverlayedDocumentMap\n): DocumentMap {\n  let documents = EMPTY_DOCUMENT_MAP;\n  collection.forEach(\n    (k, v) => (documents = documents.insert(k, v.overlayedDocument))\n  );\n  return documents;\n}\n\nexport type OverlayMap = DocumentKeyMap<Overlay>;\nexport function newOverlayMap(): OverlayMap {\n  return newDocumentKeyMap<Overlay>();\n}\n\nexport type MutationMap = DocumentKeyMap<Mutation>;\nexport function newMutationMap(): MutationMap {\n  return newDocumentKeyMap<Mutation>();\n}\n\nexport type DocumentKeyMap<T> = ObjectMap<DocumentKey, T>;\nexport function newDocumentKeyMap<T>(): DocumentKeyMap<T> {\n  return new ObjectMap<DocumentKey, T>(\n    key => key.toString(),\n    (l, r) => l.isEqual(r)\n  );\n}\n\nexport type DocumentVersionMap = SortedMap<DocumentKey, SnapshotVersion>;\nconst EMPTY_DOCUMENT_VERSION_MAP = new SortedMap<DocumentKey, SnapshotVersion>(\n  DocumentKey.comparator\n);\nexport function documentVersionMap(): DocumentVersionMap {\n  return EMPTY_DOCUMENT_VERSION_MAP;\n}\n\nexport type DocumentKeySet = SortedSet<DocumentKey>;\nconst EMPTY_DOCUMENT_KEY_SET = new SortedSet(DocumentKey.comparator);\nexport function documentKeySet(...keys: DocumentKey[]): DocumentKeySet {\n  let set = EMPTY_DOCUMENT_KEY_SET;\n  for (const key of keys) {\n    set = set.add(key);\n  }\n  return set;\n}\n\nexport type TargetIdSet = SortedSet<TargetId>;\nconst EMPTY_TARGET_ID_SET = new SortedSet<TargetId>(primitiveComparator);\nexport function targetIdSet(): SortedSet<TargetId> {\n  return EMPTY_TARGET_ID_SET;\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 { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { isNegativeZero, isSafeInteger } from '../util/types';\n\n/** Base interface for the Serializer implementation. */\nexport interface Serializer {\n  readonly useProto3Json: boolean;\n}\n\n/**\n * Returns an DoubleValue for `value` that is encoded based the serializer's\n * `useProto3Json` setting.\n */\nexport function toDouble(serializer: Serializer, value: number): ProtoValue {\n  if (serializer.useProto3Json) {\n    if (isNaN(value)) {\n      return { doubleValue: 'NaN' };\n    } else if (value === Infinity) {\n      return { doubleValue: 'Infinity' };\n    } else if (value === -Infinity) {\n      return { doubleValue: '-Infinity' };\n    }\n  }\n  return { doubleValue: isNegativeZero(value) ? '-0' : value };\n}\n\n/**\n * Returns an IntegerValue for `value`.\n */\nexport function toInteger(value: number): ProtoValue {\n  return { integerValue: '' + value };\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 */\nexport function toNumber(serializer: Serializer, value: number): ProtoValue {\n  return isSafeInteger(value) ? toInteger(value) : toDouble(serializer, value);\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 { Timestamp } from '../lite-api/timestamp';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { Serializer, toDouble, toInteger } from '../remote/number_serializer';\nimport { debugAssert } from '../util/assert';\nimport { arrayEquals } from '../util/misc';\n\nimport { normalizeNumber } from './normalize';\nimport { serverTimestamp } from './server_timestamps';\nimport { isArray, isInteger, isNumber, valueEquals } from './values';\n\n/** Used to represent a field transform on a mutation. */\nexport class TransformOperation {\n  // Make sure that the structural type of `TransformOperation` is unique.\n  // See https://github.com/microsoft/TypeScript/issues/5451\n  private _ = undefined;\n}\n\n/**\n * Computes the local transform result against the provided `previousValue`,\n * optionally using the provided localWriteTime.\n */\nexport function applyTransformOperationToLocalView(\n  transform: TransformOperation,\n  previousValue: ProtoValue | null,\n  localWriteTime: Timestamp\n): ProtoValue {\n  if (transform instanceof ServerTimestampTransform) {\n    return serverTimestamp(localWriteTime, previousValue);\n  } else if (transform instanceof ArrayUnionTransformOperation) {\n    return applyArrayUnionTransformOperation(transform, previousValue);\n  } else if (transform instanceof ArrayRemoveTransformOperation) {\n    return applyArrayRemoveTransformOperation(transform, previousValue);\n  } else {\n    debugAssert(\n      transform instanceof NumericIncrementTransformOperation,\n      'Expected NumericIncrementTransformOperation but was: ' + transform\n    );\n    return applyNumericIncrementTransformOperationToLocalView(\n      transform,\n      previousValue\n    );\n  }\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 */\nexport function applyTransformOperationToRemoteDocument(\n  transform: TransformOperation,\n  previousValue: ProtoValue | null,\n  transformResult: ProtoValue | null\n): ProtoValue {\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  if (transform instanceof ArrayUnionTransformOperation) {\n    return applyArrayUnionTransformOperation(transform, previousValue);\n  } else if (transform instanceof ArrayRemoveTransformOperation) {\n    return applyArrayRemoveTransformOperation(transform, previousValue);\n  }\n\n  debugAssert(\n    transformResult !== null,\n    \"Didn't receive transformResult for non-array transform\"\n  );\n  return transformResult;\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 */\nexport function computeTransformOperationBaseValue(\n  transform: TransformOperation,\n  previousValue: ProtoValue | null\n): ProtoValue | null {\n  if (transform instanceof NumericIncrementTransformOperation) {\n    return isNumber(previousValue) ? previousValue! : { integerValue: 0 };\n  }\n  return null;\n}\n\nexport function transformOperationEquals(\n  left: TransformOperation,\n  right: TransformOperation\n): boolean {\n  if (\n    left instanceof ArrayUnionTransformOperation &&\n    right instanceof ArrayUnionTransformOperation\n  ) {\n    return arrayEquals(left.elements, right.elements, valueEquals);\n  } else if (\n    left instanceof ArrayRemoveTransformOperation &&\n    right instanceof ArrayRemoveTransformOperation\n  ) {\n    return arrayEquals(left.elements, right.elements, valueEquals);\n  } else if (\n    left instanceof NumericIncrementTransformOperation &&\n    right instanceof NumericIncrementTransformOperation\n  ) {\n    return valueEquals(left.operand, right.operand);\n  }\n\n  return (\n    left instanceof ServerTimestampTransform &&\n    right instanceof ServerTimestampTransform\n  );\n}\n\n/** Transforms a value into a server-generated timestamp. */\nexport class ServerTimestampTransform extends TransformOperation {}\n\n/** Transforms an array value via a union operation. */\nexport class ArrayUnionTransformOperation extends TransformOperation {\n  constructor(readonly elements: ProtoValue[]) {\n    super();\n  }\n}\n\nfunction applyArrayUnionTransformOperation(\n  transform: ArrayUnionTransformOperation,\n  previousValue: ProtoValue | null\n): ProtoValue {\n  const values = coercedFieldValuesArray(previousValue);\n  for (const toUnion of transform.elements) {\n    if (!values.some(element => valueEquals(element, toUnion))) {\n      values.push(toUnion);\n    }\n  }\n  return { arrayValue: { values } };\n}\n\n/** Transforms an array value via a remove operation. */\nexport class ArrayRemoveTransformOperation extends TransformOperation {\n  constructor(readonly elements: ProtoValue[]) {\n    super();\n  }\n}\n\nfunction applyArrayRemoveTransformOperation(\n  transform: ArrayRemoveTransformOperation,\n  previousValue: ProtoValue | null\n): ProtoValue {\n  let values = coercedFieldValuesArray(previousValue);\n  for (const toRemove of transform.elements) {\n    values = values.filter(element => !valueEquals(element, toRemove));\n  }\n  return { arrayValue: { values } };\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 */\nexport class NumericIncrementTransformOperation extends TransformOperation {\n  constructor(readonly serializer: Serializer, readonly operand: ProtoValue) {\n    super();\n    debugAssert(\n      isNumber(operand),\n      'NumericIncrementTransform transform requires a NumberValue'\n    );\n  }\n}\n\nexport function applyNumericIncrementTransformOperationToLocalView(\n  transform: NumericIncrementTransformOperation,\n  previousValue: ProtoValue | null\n): ProtoValue {\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  const baseValue = computeTransformOperationBaseValue(\n    transform,\n    previousValue\n  )!;\n  const sum = asNumber(baseValue) + asNumber(transform.operand);\n  if (isInteger(baseValue) && isInteger(transform.operand)) {\n    return toInteger(sum);\n  } else {\n    return toDouble(transform.serializer, sum);\n  }\n}\n\nfunction asNumber(value: ProtoValue): number {\n  return normalizeNumber(value.integerValue || value.doubleValue);\n}\n\nfunction coercedFieldValuesArray(value: ProtoValue | null): ProtoValue[] {\n  return isArray(value) && value.arrayValue.values\n    ? value.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\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { Timestamp } from '../lite-api/timestamp';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { debugAssert, hardAssert } from '../util/assert';\nimport { arrayEquals } from '../util/misc';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { Document, MutableDocument } from './document';\nimport { DocumentKey } from './document_key';\nimport { FieldMask } from './field_mask';\nimport { ObjectValue } from './object_value';\nimport { FieldPath } from './path';\nimport {\n  applyTransformOperationToLocalView,\n  applyTransformOperationToRemoteDocument,\n  computeTransformOperationBaseValue,\n  TransformOperation,\n  transformOperationEquals\n} from './transform_operation';\n\n/** A field path and the TransformOperation to perform upon it. */\nexport class FieldTransform {\n  constructor(\n    readonly field: FieldPath,\n    readonly transform: TransformOperation\n  ) {}\n}\n\nexport function fieldTransformEquals(\n  left: FieldTransform,\n  right: FieldTransform\n): boolean {\n  return (\n    left.field.isEqual(right.field) &&\n    transformOperationEquals(left.transform, right.transform)\n  );\n}\n\nexport function fieldTransformsAreEqual(\n  left?: FieldTransform[],\n  right?: FieldTransform[]\n): boolean {\n  if (left === undefined && right === undefined) {\n    return true;\n  }\n\n  if (left && right) {\n    return arrayEquals(left, right, (l, r) => fieldTransformEquals(l, r));\n  }\n\n  return false;\n}\n\n/** The result of successfully applying a mutation to the backend. */\nexport class MutationResult {\n  constructor(\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     */\n    readonly version: SnapshotVersion,\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     */\n    readonly transformResults: Array<ProtoValue | null>\n  ) {}\n}\n\nexport const enum MutationType {\n  Set,\n  Patch,\n  Delete,\n  Verify\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 */\nexport class Precondition {\n  private constructor(\n    readonly updateTime?: SnapshotVersion,\n    readonly exists?: boolean\n  ) {\n    debugAssert(\n      updateTime === undefined || exists === undefined,\n      'Precondition can specify \"exists\" or \"updateTime\" but not both'\n    );\n  }\n\n  /** Creates a new empty Precondition. */\n  static none(): Precondition {\n    return new Precondition();\n  }\n\n  /** Creates a new Precondition with an exists flag. */\n  static exists(exists: boolean): Precondition {\n    return new Precondition(undefined, exists);\n  }\n\n  /** Creates a new Precondition based on a version a document exists at. */\n  static updateTime(version: SnapshotVersion): Precondition {\n    return new Precondition(version);\n  }\n\n  /** Returns whether this Precondition is empty. */\n  get isNone(): boolean {\n    return this.updateTime === undefined && this.exists === undefined;\n  }\n\n  isEqual(other: Precondition): boolean {\n    return (\n      this.exists === other.exists &&\n      (this.updateTime\n        ? !!other.updateTime && this.updateTime.isEqual(other.updateTime)\n        : !other.updateTime)\n    );\n  }\n}\n\n/** Returns true if the preconditions is valid for the given document. */\nexport function preconditionIsValidForDocument(\n  precondition: Precondition,\n  document: MutableDocument\n): boolean {\n  if (precondition.updateTime !== undefined) {\n    return (\n      document.isFoundDocument() &&\n      document.version.isEqual(precondition.updateTime)\n    );\n  } else if (precondition.exists !== undefined) {\n    return precondition.exists === document.isFoundDocument();\n  } else {\n    debugAssert(precondition.isNone, 'Precondition should be empty');\n    return true;\n  }\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        InvalidDocument(v0)   Document(v0)\n * PatchMutation      Document(v3)          Document(v3)\n * PatchMutation      NoDocument(v3)        NoDocument(v3)\n * PatchMutation      InvalidDocument(v0)   UnknownDocument(v3)\n * DeleteMutation     Document(v3)          NoDocument(v0)\n * DeleteMutation     NoDocument(v3)        NoDocument(v0)\n * DeleteMutation     InvalidDocument(v0)   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 transition to an `UnknownDocument` and rely on Watch to send us\n * the 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 * Every type of mutation needs to implement its own applyToRemoteDocument() and\n * applyToLocalView() to implement the actual behavior of applying the mutation\n * to some source document (see `setMutationApplyToRemoteDocument()` for an\n * example).\n */\nexport abstract class Mutation {\n  abstract readonly type: MutationType;\n  abstract readonly key: DocumentKey;\n  abstract readonly precondition: Precondition;\n  abstract readonly fieldTransforms: FieldTransform[];\n  /**\n   * Returns a `FieldMask` representing the fields that will be changed by\n   * applying this mutation. Returns `null` if the mutation will overwrite the\n   * entire document.\n   */\n  abstract getFieldMask(): FieldMask | null;\n}\n\n/**\n * A utility method to calculate a `Mutation` representing the overlay from the\n * final state of the document, and a `FieldMask` representing the fields that\n * are mutated by the local mutations.\n */\nexport function calculateOverlayMutation(\n  doc: MutableDocument,\n  mask: FieldMask | null\n): Mutation | null {\n  if (!doc.hasLocalMutations || (mask && mask!.fields.length === 0)) {\n    return null;\n  }\n\n  // mask is null when sets or deletes are applied to the current document.\n  if (mask === null) {\n    if (doc.isNoDocument()) {\n      return new DeleteMutation(doc.key, Precondition.none());\n    } else {\n      return new SetMutation(doc.key, doc.data, Precondition.none());\n    }\n  } else {\n    const docValue = doc.data;\n    const patchValue = ObjectValue.empty();\n    let maskSet = new SortedSet<FieldPath>(FieldPath.comparator);\n    for (let path of mask.fields) {\n      if (!maskSet.has(path)) {\n        let value = docValue.field(path);\n        // If we are deleting a nested field, we take the immediate parent as\n        // the mask used to construct the resulting mutation.\n        // Justification: Nested fields can create parent fields implicitly. If\n        // only a leaf entry is deleted in later mutations, the parent field\n        // should still remain, but we may have lost this information.\n        // Consider mutation (foo.bar 1), then mutation (foo.bar delete()).\n        // This leaves the final result (foo, {}). Despite the fact that `doc`\n        // has the correct result, `foo` is not in `mask`, and the resulting\n        // mutation would miss `foo`.\n        if (value === null && path.length > 1) {\n          path = path.popLast();\n          value = docValue.field(path);\n        }\n        if (value === null) {\n          patchValue.delete(path);\n        } else {\n          patchValue.set(path, value);\n        }\n        maskSet = maskSet.add(path);\n      }\n    }\n    return new PatchMutation(\n      doc.key,\n      patchValue,\n      new FieldMask(maskSet.toArray()),\n      Precondition.none()\n    );\n  }\n}\n\n/**\n * Applies this mutation to the given document for the purposes of computing a\n * new remote document. If the input document doesn't match the expected state\n * (e.g. it is invalid or outdated), the document type may transition to\n * unknown.\n *\n * @param mutation - The mutation to apply.\n * @param document - The document to mutate. The input document can be an\n *     invalid document if the client has no knowledge of the pre-mutation state\n *     of the document.\n * @param mutationResult - The result of applying the mutation from the backend.\n */\nexport function mutationApplyToRemoteDocument(\n  mutation: Mutation,\n  document: MutableDocument,\n  mutationResult: MutationResult\n): void {\n  mutationVerifyKeyMatches(mutation, document);\n  if (mutation instanceof SetMutation) {\n    setMutationApplyToRemoteDocument(mutation, document, mutationResult);\n  } else if (mutation instanceof PatchMutation) {\n    patchMutationApplyToRemoteDocument(mutation, document, mutationResult);\n  } else {\n    debugAssert(\n      mutation instanceof DeleteMutation,\n      'Unexpected mutation type: ' + mutation\n    );\n    deleteMutationApplyToRemoteDocument(mutation, document, mutationResult);\n  }\n}\n\n/**\n * Applies this mutation to the given document for the purposes of computing\n * the new local view of a document. If the input document doesn't match the\n * expected state, the document is not modified.\n *\n * @param mutation - The mutation to apply.\n * @param document - The document to mutate. The input document can be an\n *     invalid document if the client has no knowledge of the pre-mutation state\n *     of the document.\n * @param previousMask - The fields that have been updated before applying this mutation.\n * @param localWriteTime - A timestamp indicating the local write time of the\n *     batch this mutation is a part of.\n * @returns A `FieldMask` representing the fields that are changed by applying this mutation.\n */\nexport function mutationApplyToLocalView(\n  mutation: Mutation,\n  document: MutableDocument,\n  previousMask: FieldMask | null,\n  localWriteTime: Timestamp\n): FieldMask | null {\n  mutationVerifyKeyMatches(mutation, document);\n\n  if (mutation instanceof SetMutation) {\n    return setMutationApplyToLocalView(\n      mutation,\n      document,\n      previousMask,\n      localWriteTime\n    );\n  } else if (mutation instanceof PatchMutation) {\n    return patchMutationApplyToLocalView(\n      mutation,\n      document,\n      previousMask,\n      localWriteTime\n    );\n  } else {\n    debugAssert(\n      mutation instanceof DeleteMutation,\n      'Unexpected mutation type: ' + mutation\n    );\n    return deleteMutationApplyToLocalView(mutation, document, previousMask);\n  }\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 */\nexport function mutationExtractBaseValue(\n  mutation: Mutation,\n  document: Document\n): ObjectValue | null {\n  let baseObject: ObjectValue | null = null;\n  for (const fieldTransform of mutation.fieldTransforms) {\n    const existingValue = document.data.field(fieldTransform.field);\n    const coercedValue = computeTransformOperationBaseValue(\n      fieldTransform.transform,\n      existingValue || null\n    );\n\n    if (coercedValue != null) {\n      if (baseObject === null) {\n        baseObject = ObjectValue.empty();\n      }\n      baseObject.set(fieldTransform.field, coercedValue);\n    }\n  }\n  return baseObject ? baseObject : null;\n}\n\nexport function mutationEquals(left: Mutation, right: Mutation): boolean {\n  if (left.type !== right.type) {\n    return false;\n  }\n\n  if (!left.key.isEqual(right.key)) {\n    return false;\n  }\n\n  if (!left.precondition.isEqual(right.precondition)) {\n    return false;\n  }\n\n  if (!fieldTransformsAreEqual(left.fieldTransforms, right.fieldTransforms)) {\n    return false;\n  }\n\n  if (left.type === MutationType.Set) {\n    return (left as SetMutation).value.isEqual((right as SetMutation).value);\n  }\n\n  if (left.type === MutationType.Patch) {\n    return (\n      (left as PatchMutation).data.isEqual((right as PatchMutation).data) &&\n      (left as PatchMutation).fieldMask.isEqual(\n        (right as PatchMutation).fieldMask\n      )\n    );\n  }\n\n  return true;\n}\n\nfunction mutationVerifyKeyMatches(\n  mutation: Mutation,\n  document: MutableDocument\n): void {\n  debugAssert(\n    document.key.isEqual(mutation.key),\n    'Can only apply a mutation to a document with the same key'\n  );\n}\n\n/**\n * A mutation that creates or replaces the document at the given key with the\n * object value contents.\n */\nexport class SetMutation extends Mutation {\n  constructor(\n    readonly key: DocumentKey,\n    readonly value: ObjectValue,\n    readonly precondition: Precondition,\n    readonly fieldTransforms: FieldTransform[] = []\n  ) {\n    super();\n  }\n\n  readonly type: MutationType = MutationType.Set;\n\n  getFieldMask(): FieldMask | null {\n    return null;\n  }\n}\n\nfunction setMutationApplyToRemoteDocument(\n  mutation: SetMutation,\n  document: MutableDocument,\n  mutationResult: MutationResult\n): void {\n  // Unlike setMutationApplyToLocalView, 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  const newData = mutation.value.clone();\n  const transformResults = serverTransformResults(\n    mutation.fieldTransforms,\n    document,\n    mutationResult.transformResults\n  );\n  newData.setAll(transformResults);\n  document\n    .convertToFoundDocument(mutationResult.version, newData)\n    .setHasCommittedMutations();\n}\n\nfunction setMutationApplyToLocalView(\n  mutation: SetMutation,\n  document: MutableDocument,\n  previousMask: FieldMask | null,\n  localWriteTime: Timestamp\n): FieldMask | null {\n  if (!preconditionIsValidForDocument(mutation.precondition, document)) {\n    // The mutation failed to apply (e.g. a document ID created with add()\n    // caused a name collision).\n    return previousMask;\n  }\n\n  const newData = mutation.value.clone();\n  const transformResults = localTransformResults(\n    mutation.fieldTransforms,\n    localWriteTime,\n    document\n  );\n  newData.setAll(transformResults);\n  document\n    .convertToFoundDocument(document.version, newData)\n    .setHasLocalMutations();\n  return null; // SetMutation overwrites all fields.\n}\n\n/**\n * A mutation that modifies fields of the document at the given key with the\n * given values. The values are applied through a field mask:\n *\n *  * When a field is in both the mask and the values, the corresponding field\n *    is updated.\n *  * When a field is in neither the mask nor the values, the corresponding\n *    field is unmodified.\n *  * When a field is in the mask but not in the values, the corresponding field\n *    is deleted.\n *  * When a field is not in the mask but is in the values, the values map is\n *    ignored.\n */\nexport class PatchMutation extends Mutation {\n  constructor(\n    readonly key: DocumentKey,\n    readonly data: ObjectValue,\n    readonly fieldMask: FieldMask,\n    readonly precondition: Precondition,\n    readonly fieldTransforms: FieldTransform[] = []\n  ) {\n    super();\n  }\n\n  readonly type: MutationType = MutationType.Patch;\n\n  getFieldMask(): FieldMask | null {\n    return this.fieldMask;\n  }\n}\n\nfunction patchMutationApplyToRemoteDocument(\n  mutation: PatchMutation,\n  document: MutableDocument,\n  mutationResult: MutationResult\n): void {\n  if (!preconditionIsValidForDocument(mutation.precondition, document)) {\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 convert to an UnknownDocument with a\n    // known updateTime.\n    document.convertToUnknownDocument(mutationResult.version);\n    return;\n  }\n\n  const transformResults = serverTransformResults(\n    mutation.fieldTransforms,\n    document,\n    mutationResult.transformResults\n  );\n  const newData = document.data;\n  newData.setAll(getPatch(mutation));\n  newData.setAll(transformResults);\n  document\n    .convertToFoundDocument(mutationResult.version, newData)\n    .setHasCommittedMutations();\n}\n\nfunction patchMutationApplyToLocalView(\n  mutation: PatchMutation,\n  document: MutableDocument,\n  previousMask: FieldMask | null,\n  localWriteTime: Timestamp\n): FieldMask | null {\n  if (!preconditionIsValidForDocument(mutation.precondition, document)) {\n    return previousMask;\n  }\n\n  const transformResults = localTransformResults(\n    mutation.fieldTransforms,\n    localWriteTime,\n    document\n  );\n  const newData = document.data;\n  newData.setAll(getPatch(mutation));\n  newData.setAll(transformResults);\n  document\n    .convertToFoundDocument(document.version, newData)\n    .setHasLocalMutations();\n\n  if (previousMask === null) {\n    return null;\n  }\n\n  return previousMask\n    .unionWith(mutation.fieldMask.fields)\n    .unionWith(mutation.fieldTransforms.map(transform => transform.field));\n}\n\n/**\n * Returns a FieldPath/Value map with the content of the PatchMutation.\n */\nfunction getPatch(mutation: PatchMutation): Map<FieldPath, ProtoValue | null> {\n  const result = new Map<FieldPath, ProtoValue | null>();\n  mutation.fieldMask.fields.forEach(fieldPath => {\n    if (!fieldPath.isEmpty()) {\n      const newValue = mutation.data.field(fieldPath);\n      result.set(fieldPath, newValue);\n    }\n  });\n  return result;\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 after a mutation\n * containing transforms has been acknowledged by the server.\n *\n * @param fieldTransforms - The field transforms to apply the result to.\n * @param mutableDocument - The current state of the document after applying all\n * previous mutations.\n * @param serverTransformResults - The transform results received by the server.\n * @returns The transform results list.\n */\nfunction serverTransformResults(\n  fieldTransforms: FieldTransform[],\n  mutableDocument: MutableDocument,\n  serverTransformResults: Array<ProtoValue | null>\n): Map<FieldPath, ProtoValue> {\n  const transformResults = new Map<FieldPath, ProtoValue>();\n  hardAssert(\n    fieldTransforms.length === serverTransformResults.length,\n    `server transform result count (${serverTransformResults.length}) ` +\n      `should match field transform count (${fieldTransforms.length})`\n  );\n\n  for (let i = 0; i < serverTransformResults.length; i++) {\n    const fieldTransform = fieldTransforms[i];\n    const transform = fieldTransform.transform;\n    const previousValue = mutableDocument.data.field(fieldTransform.field);\n    transformResults.set(\n      fieldTransform.field,\n      applyTransformOperationToRemoteDocument(\n        transform,\n        previousValue,\n        serverTransformResults[i]\n      )\n    );\n  }\n  return transformResults;\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 mutableDocument - The document to apply transforms on.\n * @returns The transform results list.\n */\nfunction localTransformResults(\n  fieldTransforms: FieldTransform[],\n  localWriteTime: Timestamp,\n  mutableDocument: MutableDocument\n): Map<FieldPath, ProtoValue> {\n  const transformResults = new Map<FieldPath, ProtoValue>();\n  for (const fieldTransform of fieldTransforms) {\n    const transform = fieldTransform.transform;\n\n    const previousValue = mutableDocument.data.field(fieldTransform.field);\n    transformResults.set(\n      fieldTransform.field,\n      applyTransformOperationToLocalView(\n        transform,\n        previousValue,\n        localWriteTime\n      )\n    );\n  }\n  return transformResults;\n}\n\n/** A mutation that deletes the document at the given key. */\nexport class DeleteMutation extends Mutation {\n  constructor(readonly key: DocumentKey, readonly precondition: Precondition) {\n    super();\n  }\n\n  readonly type: MutationType = MutationType.Delete;\n  readonly fieldTransforms: FieldTransform[] = [];\n\n  getFieldMask(): FieldMask | null {\n    return null;\n  }\n}\n\nfunction deleteMutationApplyToRemoteDocument(\n  mutation: DeleteMutation,\n  document: MutableDocument,\n  mutationResult: MutationResult\n): void {\n  debugAssert(\n    mutationResult.transformResults.length === 0,\n    'Transform results received by DeleteMutation.'\n  );\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  document\n    .convertToNoDocument(mutationResult.version)\n    .setHasCommittedMutations();\n}\n\nfunction deleteMutationApplyToLocalView(\n  mutation: DeleteMutation,\n  document: MutableDocument,\n  previousMask: FieldMask | null\n): FieldMask | null {\n  debugAssert(\n    document.key.isEqual(mutation.key),\n    'Can only apply mutation to document with same key'\n  );\n  if (preconditionIsValidForDocument(mutation.precondition, document)) {\n    document.convertToNoDocument(document.version).setHasLocalMutations();\n    return null;\n  }\n  return previousMask;\n}\n\n/**\n * A mutation that verifies the existence of the document at the given key with\n * the provided precondition.\n *\n * The `verify` operation is only used in Transactions, and this class serves\n * primarily to facilitate serialization into protos.\n */\nexport class VerifyMutation extends Mutation {\n  constructor(readonly key: DocumentKey, readonly precondition: Precondition) {\n    super();\n  }\n\n  readonly type: MutationType = MutationType.Verify;\n  readonly fieldTransforms: FieldTransform[] = [];\n\n  getFieldMask(): FieldMask | null {\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\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { BatchId } from '../core/types';\nimport { Timestamp } from '../lite-api/timestamp';\nimport { debugAssert, hardAssert } from '../util/assert';\nimport { arrayEquals } from '../util/misc';\n\nimport {\n  documentKeySet,\n  DocumentKeySet,\n  MutationMap,\n  DocumentVersionMap,\n  documentVersionMap,\n  newMutationMap,\n  OverlayedDocumentMap\n} from './collections';\nimport { MutableDocument } from './document';\nimport { FieldMask } from './field_mask';\nimport {\n  calculateOverlayMutation,\n  Mutation,\n  mutationApplyToLocalView,\n  mutationApplyToRemoteDocument,\n  mutationEquals,\n  MutationResult\n} from './mutation';\n\n/**\n * A batch of mutations that will be sent as one unit to the backend.\n */\nexport class MutationBatch {\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  constructor(\n    public batchId: BatchId,\n    public localWriteTime: Timestamp,\n    public baseMutations: Mutation[],\n    public mutations: Mutation[]\n  ) {\n    debugAssert(mutations.length > 0, 'Cannot create an empty mutation batch');\n  }\n\n  /**\n   * Applies all the mutations in this MutationBatch to the specified document\n   * to compute the state of the remote document\n   *\n   * @param document - The document to apply mutations to.\n   * @param batchResult - The result of applying the MutationBatch to the\n   * backend.\n   */\n  applyToRemoteDocument(\n    document: MutableDocument,\n    batchResult: MutationBatchResult\n  ): void {\n    const mutationResults = batchResult.mutationResults;\n    debugAssert(\n      mutationResults.length === this.mutations.length,\n      `Mismatch between mutations length\n      (${this.mutations.length}) and mutation results length\n      (${mutationResults.length}).`\n    );\n\n    for (let i = 0; i < this.mutations.length; i++) {\n      const mutation = this.mutations[i];\n      if (mutation.key.isEqual(document.key)) {\n        const mutationResult = mutationResults[i];\n        mutationApplyToRemoteDocument(mutation, document, mutationResult);\n      }\n    }\n  }\n\n  /**\n   * Computes the local view of a document given all the mutations in this\n   * batch.\n   *\n   * @param document - The document to apply mutations to.\n   * @param mutatedFields - Fields that have been updated before applying this mutation batch.\n   * @returns A `FieldMask` representing all the fields that are mutated.\n   */\n  applyToLocalView(\n    document: MutableDocument,\n    mutatedFields: FieldMask | null\n  ): FieldMask | null {\n    // First, apply the base state. This allows us to apply non-idempotent\n    // transform against a consistent set of values.\n    for (const mutation of this.baseMutations) {\n      if (mutation.key.isEqual(document.key)) {\n        mutatedFields = mutationApplyToLocalView(\n          mutation,\n          document,\n          mutatedFields,\n          this.localWriteTime\n        );\n      }\n    }\n\n    // Second, apply all user-provided mutations.\n    for (const mutation of this.mutations) {\n      if (mutation.key.isEqual(document.key)) {\n        mutatedFields = mutationApplyToLocalView(\n          mutation,\n          document,\n          mutatedFields,\n          this.localWriteTime\n        );\n      }\n    }\n    return mutatedFields;\n  }\n\n  /**\n   * Computes the local view for all provided documents given the mutations in\n   * this batch. Returns a `DocumentKey` to `Mutation` map which can be used to\n   * replace all the mutation applications.\n   */\n  applyToLocalDocumentSet(\n    documentMap: OverlayedDocumentMap,\n    documentsWithoutRemoteVersion: DocumentKeySet\n  ): MutationMap {\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    const overlays = newMutationMap();\n    this.mutations.forEach(m => {\n      const overlayedDocument = documentMap.get(m.key)!;\n      // TODO(mutabledocuments): This method should take a MutableDocumentMap\n      // and we should remove this cast.\n      const mutableDocument =\n        overlayedDocument.overlayedDocument as MutableDocument;\n      let mutatedFields = this.applyToLocalView(\n        mutableDocument,\n        overlayedDocument.mutatedFields\n      );\n      // Set mutatedFields to null if the document is only from local mutations.\n      // This creates a Set or Delete mutation, instead of trying to create a\n      // patch mutation as the overlay.\n      mutatedFields = documentsWithoutRemoteVersion.has(m.key)\n        ? null\n        : mutatedFields;\n      const overlay = calculateOverlayMutation(mutableDocument, mutatedFields);\n      if (overlay !== null) {\n        overlays.set(m.key, overlay);\n      }\n\n      if (!mutableDocument.isValidDocument()) {\n        mutableDocument.convertToNoDocument(SnapshotVersion.min());\n      }\n    });\n    return overlays;\n  }\n\n  keys(): DocumentKeySet {\n    return this.mutations.reduce(\n      (keys, m) => keys.add(m.key),\n      documentKeySet()\n    );\n  }\n\n  isEqual(other: MutationBatch): boolean {\n    return (\n      this.batchId === other.batchId &&\n      arrayEquals(this.mutations, other.mutations, (l, r) =>\n        mutationEquals(l, r)\n      ) &&\n      arrayEquals(this.baseMutations, other.baseMutations, (l, r) =>\n        mutationEquals(l, r)\n      )\n    );\n  }\n}\n\n/** The result of applying a mutation batch to the backend. */\nexport class MutationBatchResult {\n  private constructor(\n    readonly batch: MutationBatch,\n    readonly commitVersion: SnapshotVersion,\n    readonly mutationResults: MutationResult[],\n    /**\n     * A pre-computed mapping from each mutated document to the resulting\n     * version.\n     */\n    readonly docVersions: DocumentVersionMap\n  ) {}\n\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  static from(\n    batch: MutationBatch,\n    commitVersion: SnapshotVersion,\n    results: MutationResult[]\n  ): MutationBatchResult {\n    hardAssert(\n      batch.mutations.length === results.length,\n      'Mutations sent ' +\n        batch.mutations.length +\n        ' must equal results received ' +\n        results.length\n    );\n\n    let versionMap = documentVersionMap();\n    const mutations = batch.mutations;\n    for (let i = 0; i < mutations.length; i++) {\n      versionMap = versionMap.insert(mutations[i].key, results[i].version);\n    }\n\n    return new MutationBatchResult(batch, commitVersion, results, versionMap);\n  }\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { DocumentKey } from './document_key';\nimport { Mutation } from './mutation';\n\n/**\n * Representation of an overlay computed by Firestore.\n *\n * Holds information about a mutation and the largest batch id in Firestore when\n * the mutation was created.\n */\nexport class Overlay {\n  constructor(readonly largestBatchId: number, readonly mutation: Mutation) {}\n\n  getKey(): DocumentKey {\n    return this.mutation.key;\n  }\n\n  isEqual(other: Overlay | null): boolean {\n    return other !== null && this.mutation === other.mutation;\n  }\n\n  toString(): string {\n    return `Overlay{\n      largestBatchId: ${this.largestBatchId},\n      mutation: ${this.mutation.toString()}\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 { BloomFilter as ProtoBloomFilter } from '../protos/firestore_proto_api';\n\nexport class ExistenceFilter {\n  constructor(public count: number, public unchangedNames?: ProtoBloomFilter) {}\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 { fail } from '../util/assert';\nimport { Code } from '../util/error';\nimport { logError } from '../util/log';\n\n/**\n * Error Codes describing the different ways GRPC can fail. These are copied\n * directly from GRPC's sources here:\n *\n * https://github.com/grpc/grpc/blob/bceec94ea4fc5f0085d81235d8e1c06798dc341a/include/grpc%2B%2B/impl/codegen/status_code_enum.h\n *\n * Important! The names of these identifiers matter because the string forms\n * are used for reverse lookups from the webchannel stream. Do NOT change the\n * names of these identifiers or change this into a const enum.\n */\nenum RpcCode {\n  OK = 0,\n  CANCELLED = 1,\n  UNKNOWN = 2,\n  INVALID_ARGUMENT = 3,\n  DEADLINE_EXCEEDED = 4,\n  NOT_FOUND = 5,\n  ALREADY_EXISTS = 6,\n  PERMISSION_DENIED = 7,\n  UNAUTHENTICATED = 16,\n  RESOURCE_EXHAUSTED = 8,\n  FAILED_PRECONDITION = 9,\n  ABORTED = 10,\n  OUT_OF_RANGE = 11,\n  UNIMPLEMENTED = 12,\n  INTERNAL = 13,\n  UNAVAILABLE = 14,\n  DATA_LOSS = 15\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 */\nexport function isPermanentError(code: Code): boolean {\n  switch (code) {\n    case Code.OK:\n      return fail('Treated status OK as error');\n    case Code.CANCELLED:\n    case Code.UNKNOWN:\n    case Code.DEADLINE_EXCEEDED:\n    case Code.RESOURCE_EXHAUSTED:\n    case Code.INTERNAL:\n    case Code.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 Code.UNAUTHENTICATED:\n      return false;\n    case Code.INVALID_ARGUMENT:\n    case Code.NOT_FOUND:\n    case Code.ALREADY_EXISTS:\n    case Code.PERMISSION_DENIED:\n    case Code.FAILED_PRECONDITION:\n    // Aborted might be retried in some scenarios, but that is dependent on\n    // the context and should handled individually by the calling code.\n    // See https://cloud.google.com/apis/design/errors.\n    case Code.ABORTED:\n    case Code.OUT_OF_RANGE:\n    case Code.UNIMPLEMENTED:\n    case Code.DATA_LOSS:\n      return true;\n    default:\n      return fail('Unknown status code: ' + code);\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 */\nexport function isPermanentWriteError(code: Code): boolean {\n  return isPermanentError(code) && code !== Code.ABORTED;\n}\n\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 */\nexport function mapCodeFromRpcStatus(status: string): Code | undefined {\n  // lookup by string\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const code: RpcCode = RpcCode[status as any] as any;\n  if (code === undefined) {\n    return undefined;\n  }\n\n  return mapCodeFromRpcCode(code);\n}\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 */\nexport function mapCodeFromRpcCode(code: number | undefined): Code {\n  if (code === undefined) {\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    logError('GRPC error has no .code');\n    return Code.UNKNOWN;\n  }\n\n  switch (code) {\n    case RpcCode.OK:\n      return Code.OK;\n    case RpcCode.CANCELLED:\n      return Code.CANCELLED;\n    case RpcCode.UNKNOWN:\n      return Code.UNKNOWN;\n    case RpcCode.DEADLINE_EXCEEDED:\n      return Code.DEADLINE_EXCEEDED;\n    case RpcCode.RESOURCE_EXHAUSTED:\n      return Code.RESOURCE_EXHAUSTED;\n    case RpcCode.INTERNAL:\n      return Code.INTERNAL;\n    case RpcCode.UNAVAILABLE:\n      return Code.UNAVAILABLE;\n    case RpcCode.UNAUTHENTICATED:\n      return Code.UNAUTHENTICATED;\n    case RpcCode.INVALID_ARGUMENT:\n      return Code.INVALID_ARGUMENT;\n    case RpcCode.NOT_FOUND:\n      return Code.NOT_FOUND;\n    case RpcCode.ALREADY_EXISTS:\n      return Code.ALREADY_EXISTS;\n    case RpcCode.PERMISSION_DENIED:\n      return Code.PERMISSION_DENIED;\n    case RpcCode.FAILED_PRECONDITION:\n      return Code.FAILED_PRECONDITION;\n    case RpcCode.ABORTED:\n      return Code.ABORTED;\n    case RpcCode.OUT_OF_RANGE:\n      return Code.OUT_OF_RANGE;\n    case RpcCode.UNIMPLEMENTED:\n      return Code.UNIMPLEMENTED;\n    case RpcCode.DATA_LOSS:\n      return Code.DATA_LOSS;\n    default:\n      return fail('Unknown status code: ' + code);\n  }\n}\n\n/**\n * Maps an RPC code from a Code. This is the reverse operation from\n * mapCodeFromRpcCode and should really only be used in tests.\n */\nexport function mapRpcCodeFromCode(code: Code | undefined): number {\n  if (code === undefined) {\n    return RpcCode.OK;\n  }\n\n  switch (code) {\n    case Code.OK:\n      return RpcCode.OK;\n    case Code.CANCELLED:\n      return RpcCode.CANCELLED;\n    case Code.UNKNOWN:\n      return RpcCode.UNKNOWN;\n    case Code.DEADLINE_EXCEEDED:\n      return RpcCode.DEADLINE_EXCEEDED;\n    case Code.RESOURCE_EXHAUSTED:\n      return RpcCode.RESOURCE_EXHAUSTED;\n    case Code.INTERNAL:\n      return RpcCode.INTERNAL;\n    case Code.UNAVAILABLE:\n      return RpcCode.UNAVAILABLE;\n    case Code.UNAUTHENTICATED:\n      return RpcCode.UNAUTHENTICATED;\n    case Code.INVALID_ARGUMENT:\n      return RpcCode.INVALID_ARGUMENT;\n    case Code.NOT_FOUND:\n      return RpcCode.NOT_FOUND;\n    case Code.ALREADY_EXISTS:\n      return RpcCode.ALREADY_EXISTS;\n    case Code.PERMISSION_DENIED:\n      return RpcCode.PERMISSION_DENIED;\n    case Code.FAILED_PRECONDITION:\n      return RpcCode.FAILED_PRECONDITION;\n    case Code.ABORTED:\n      return RpcCode.ABORTED;\n    case Code.OUT_OF_RANGE:\n      return RpcCode.OUT_OF_RANGE;\n    case Code.UNIMPLEMENTED:\n      return RpcCode.UNIMPLEMENTED;\n    case Code.DATA_LOSS:\n      return RpcCode.DATA_LOSS;\n    default:\n      return fail('Unknown status code: ' + code);\n  }\n}\n\n/**\n * Converts an HTTP Status Code to the equivalent error code.\n *\n * @param status - An HTTP Status Code, like 200, 404, 503, etc.\n * @returns The equivalent Code. Unknown status codes are mapped to\n *     Code.UNKNOWN.\n */\nexport function mapCodeFromHttpStatus(status?: number): Code {\n  if (status === undefined) {\n    logError('RPC_ERROR', 'HTTP error has no status');\n    return Code.UNKNOWN;\n  }\n\n  // The canonical error codes for Google APIs [1] specify mapping onto HTTP\n  // status codes but the mapping is not bijective. In each case of ambiguity\n  // this function chooses a primary error.\n  //\n  // [1]\n  // https://github.com/googleapis/googleapis/blob/master/google/rpc/code.proto\n  switch (status) {\n    case 200: // OK\n      return Code.OK;\n\n    case 400: // Bad Request\n      return Code.FAILED_PRECONDITION;\n    // Other possibilities based on the forward mapping\n    // return Code.INVALID_ARGUMENT;\n    // return Code.OUT_OF_RANGE;\n\n    case 401: // Unauthorized\n      return Code.UNAUTHENTICATED;\n\n    case 403: // Forbidden\n      return Code.PERMISSION_DENIED;\n\n    case 404: // Not Found\n      return Code.NOT_FOUND;\n\n    case 409: // Conflict\n      return Code.ABORTED;\n    // Other possibilities:\n    // return Code.ALREADY_EXISTS;\n\n    case 416: // Range Not Satisfiable\n      return Code.OUT_OF_RANGE;\n\n    case 429: // Too Many Requests\n      return Code.RESOURCE_EXHAUSTED;\n\n    case 499: // Client Closed Request\n      return Code.CANCELLED;\n\n    case 500: // Internal Server Error\n      return Code.UNKNOWN;\n    // Other possibilities:\n    // return Code.INTERNAL;\n    // return Code.DATA_LOSS;\n\n    case 501: // Unimplemented\n      return Code.UNIMPLEMENTED;\n\n    case 503: // Service Unavailable\n      return Code.UNAVAILABLE;\n\n    case 504: // Gateway Timeout\n      return Code.DEADLINE_EXCEEDED;\n\n    default:\n      if (status >= 200 && status < 300) {\n        return Code.OK;\n      }\n      if (status >= 400 && status < 500) {\n        return Code.FAILED_PRECONDITION;\n      }\n      if (status >= 500 && status < 600) {\n        return Code.INTERNAL;\n      }\n      return Code.UNKNOWN;\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 */\nexport function mapCodeFromHttpResponseErrorStatus(status: string): Code {\n  const serverError = status.toLowerCase().replace(/_/g, '-');\n  return Object.values(Code).indexOf(serverError as Code) >= 0\n    ? (serverError as Code)\n    : Code.UNKNOWN;\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 global, singleton instance of TestingHooksSpi.\n *\n * This variable will be `null` in all cases _except_ when running from\n * integration tests that have registered callbacks to be notified of events\n * that happen during the test execution.\n */\nexport let testingHooksSpi: TestingHooksSpi | null = null;\n\n/**\n * Sets the value of the `testingHooksSpi` object.\n * @param instance the instance to set.\n */\nexport function setTestingHooksSpi(instance: TestingHooksSpi): void {\n  if (testingHooksSpi) {\n    throw new Error('a TestingHooksSpi instance is already set');\n  }\n  testingHooksSpi = instance;\n}\n\n/**\n * The \"service provider interface\" for the testing hooks.\n *\n * The implementation of this object will handle the callbacks made by the SDK\n * to be handled by the integration tests.\n *\n * This \"SPI\" is separated from the implementation to avoid import cycles and\n * to enable production builds to fully tree-shake away the testing hooks logic.\n */\nexport interface TestingHooksSpi {\n  /**\n   * Invokes all callbacks registered with\n   * `TestingHooks.onExistenceFilterMismatch()` with the given info.\n   */\n  notifyOnExistenceFilterMismatch(info: ExistenceFilterMismatchInfo): void;\n}\n\n/**\n * Information about an existence filter mismatch.\n * @internal\n */\nexport interface ExistenceFilterMismatchInfo {\n  /** The number of documents that matched the query in the local cache. */\n  localCacheCount: number;\n\n  /**\n   * The number of documents that matched the query on the server, as specified\n   * in the ExistenceFilter message's `count` field.\n   */\n  existenceFilterCount: number;\n\n  /**\n   * The projectId used when checking documents for membership in the bloom\n   * filter.\n   */\n  projectId: string;\n\n  /**\n   * The databaseId used when checking documents for membership in the bloom\n   * filter.\n   */\n  databaseId: string;\n\n  /**\n   * Information about the bloom filter provided by Watch in the ExistenceFilter\n   * message's `unchangedNames` field. If this property is omitted or undefined\n   * then that means that Watch did _not_ provide a bloom filter.\n   */\n  bloomFilter?: {\n    /**\n     * Whether a full requery was averted by using the bloom filter. If false,\n     * then something happened, such as a false positive, to prevent using the\n     * bloom filter to avoid a full requery.\n     */\n    applied: boolean;\n\n    /** The number of hash functions used in the bloom filter. */\n    hashCount: number;\n\n    /** The number of bytes in the bloom filter's bitmask. */\n    bitmapLength: number;\n\n    /** The number of bits of padding in the last byte of the bloom filter. */\n    padding: number;\n\n    /**\n     * Tests the given string for membership in the bloom filter created from\n     * the existence filter; will be undefined if creating the bloom filter\n     * failed.\n     */\n    mightContain?: (value: string) => boolean;\n  };\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * An instance of the Platform's 'TextEncoder' implementation.\n */\nexport function newTextEncoder(): TextEncoder {\n  return new TextEncoder();\n}\n\n/**\n * An instance of the Platform's 'TextDecoder' implementation.\n */\nexport function newTextDecoder(): TextDecoder {\n  return new TextDecoder('utf-8');\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { Md5, Integer } from '@firebase/webchannel-wrapper/bloom-blob';\n\nimport { newTextEncoder } from '../platform/text_serializer';\n\nconst MAX_64_BIT_UNSIGNED_INTEGER = new Integer([0xffffffff, 0xffffffff], 0);\n\n// Hash a string using md5 hashing algorithm.\nfunction getMd5HashValue(value: string): Uint8Array {\n  const encodedValue = newTextEncoder().encode(value);\n  const md5 = new Md5();\n  md5.update(encodedValue);\n  return new Uint8Array(md5.digest());\n}\n\n// Interpret the 16 bytes array as two 64-bit unsigned integers, encoded using\n// 2’s complement using little endian.\nfunction get64BitUints(Bytes: Uint8Array): [Integer, Integer] {\n  const dataView = new DataView(Bytes.buffer);\n  const chunk1 = dataView.getUint32(0, /* littleEndian= */ true);\n  const chunk2 = dataView.getUint32(4, /* littleEndian= */ true);\n  const chunk3 = dataView.getUint32(8, /* littleEndian= */ true);\n  const chunk4 = dataView.getUint32(12, /* littleEndian= */ true);\n  const integer1 = new Integer([chunk1, chunk2], 0);\n  const integer2 = new Integer([chunk3, chunk4], 0);\n  return [integer1, integer2];\n}\n\nexport class BloomFilter {\n  readonly bitCount: number;\n  private readonly bitCountInInteger: Integer;\n\n  constructor(\n    readonly bitmap: Uint8Array,\n    readonly padding: number,\n    readonly hashCount: number\n  ) {\n    if (padding < 0 || padding >= 8) {\n      throw new BloomFilterError(`Invalid padding: ${padding}`);\n    }\n\n    if (hashCount < 0) {\n      throw new BloomFilterError(`Invalid hash count: ${hashCount}`);\n    }\n\n    if (bitmap.length > 0 && this.hashCount === 0) {\n      // Only empty bloom filter can have 0 hash count.\n      throw new BloomFilterError(`Invalid hash count: ${hashCount}`);\n    }\n\n    if (bitmap.length === 0 && padding !== 0) {\n      // Empty bloom filter should have 0 padding.\n      throw new BloomFilterError(\n        `Invalid padding when bitmap length is 0: ${padding}`\n      );\n    }\n\n    this.bitCount = bitmap.length * 8 - padding;\n    // Set the bit count in Integer to avoid repetition in mightContain().\n    this.bitCountInInteger = Integer.fromNumber(this.bitCount);\n  }\n\n  // Calculate the ith hash value based on the hashed 64bit integers,\n  // and calculate its corresponding bit index in the bitmap to be checked.\n  private getBitIndex(num1: Integer, num2: Integer, hashIndex: number): number {\n    // Calculate hashed value h(i) = h1 + (i * h2).\n    let hashValue = num1.add(num2.multiply(Integer.fromNumber(hashIndex)));\n    // Wrap if hash value overflow 64bit.\n    if (hashValue.compare(MAX_64_BIT_UNSIGNED_INTEGER) === 1) {\n      hashValue = new Integer([hashValue.getBits(0), hashValue.getBits(1)], 0);\n    }\n    return hashValue.modulo(this.bitCountInInteger).toNumber();\n  }\n\n  // Return whether the bit on the given index in the bitmap is set to 1.\n  private isBitSet(index: number): boolean {\n    // To retrieve bit n, calculate: (bitmap[n / 8] & (0x01 << (n % 8))).\n    const byte = this.bitmap[Math.floor(index / 8)];\n    const offset = index % 8;\n    return (byte & (0x01 << offset)) !== 0;\n  }\n\n  mightContain(value: string): boolean {\n    // Empty bitmap should always return false on membership check.\n    if (this.bitCount === 0) {\n      return false;\n    }\n    const md5HashedValue = getMd5HashValue(value);\n    const [hash1, hash2] = get64BitUints(md5HashedValue);\n    for (let i = 0; i < this.hashCount; i++) {\n      const index = this.getBitIndex(hash1, hash2, i);\n      if (!this.isBitSet(index)) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /** Create bloom filter for testing purposes only. */\n  static create(\n    bitCount: number,\n    hashCount: number,\n    contains: string[]\n  ): BloomFilter {\n    const padding = bitCount % 8 === 0 ? 0 : 8 - (bitCount % 8);\n    const bitmap = new Uint8Array(Math.ceil(bitCount / 8));\n    const bloomFilter = new BloomFilter(bitmap, padding, hashCount);\n    contains.forEach(item => bloomFilter.insert(item));\n    return bloomFilter;\n  }\n\n  private insert(value: string): void {\n    if (this.bitCount === 0) {\n      return;\n    }\n\n    const md5HashedValue = getMd5HashValue(value);\n    const [hash1, hash2] = get64BitUints(md5HashedValue);\n    for (let i = 0; i < this.hashCount; i++) {\n      const index = this.getBitIndex(hash1, hash2, i);\n      this.setBit(index);\n    }\n  }\n\n  private setBit(index: number): void {\n    const indexOfByte = Math.floor(index / 8);\n    const offset = index % 8;\n    this.bitmap[indexOfByte] |= 0x01 << offset;\n  }\n}\n\nexport class BloomFilterError extends Error {\n  readonly name = 'BloomFilterError';\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { TargetId } from '../core/types';\nimport { TargetPurpose } from '../local/target_data';\nimport {\n  documentKeySet,\n  DocumentKeySet,\n  mutableDocumentMap,\n  MutableDocumentMap\n} from '../model/collections';\nimport { ByteString } from '../util/byte_string';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedMap } from '../util/sorted_map';\n\n/**\n * An event from the RemoteStore. It is split into targetChanges (changes to the\n * state or the set of documents in our watched targets) and documentUpdates\n * (changes to the actual documents).\n */\nexport class RemoteEvent {\n  constructor(\n    /**\n     * The snapshot version this event brings us up to, or MIN if not set.\n     */\n    readonly snapshotVersion: SnapshotVersion,\n    /**\n     * A map from target to changes to the target. See TargetChange.\n     */\n    readonly targetChanges: Map<TargetId, TargetChange>,\n    /**\n     * A map of targets that is known to be inconsistent, and the purpose for\n     * re-listening. Listens for these targets should be re-established without\n     * resume tokens.\n     */\n    readonly targetMismatches: SortedMap<TargetId, TargetPurpose>,\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    readonly documentUpdates: MutableDocumentMap,\n    /**\n     * A set of which document updates are due only to limbo resolution targets.\n     */\n    readonly resolvedLimboDocuments: DocumentKeySet\n  ) {}\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  static createSynthesizedRemoteEventForCurrentChange(\n    targetId: TargetId,\n    current: boolean,\n    resumeToken: ByteString\n  ): RemoteEvent {\n    const targetChanges = new Map<TargetId, TargetChange>();\n    targetChanges.set(\n      targetId,\n      TargetChange.createSynthesizedTargetChangeForCurrentChange(\n        targetId,\n        current,\n        resumeToken\n      )\n    );\n    return new RemoteEvent(\n      SnapshotVersion.min(),\n      targetChanges,\n      new SortedMap<TargetId, TargetPurpose>(primitiveComparator),\n      mutableDocumentMap(),\n      documentKeySet()\n    );\n  }\n}\n\n/**\n * A TargetChange specifies the set of changes for a specific target as part of\n * a RemoteEvent. These changes track which documents are added, modified or\n * removed, as well as the target's resume token and whether the target is\n * marked CURRENT.\n * The actual changes *to* documents are not part of the TargetChange since\n * documents may be part of multiple targets.\n */\nexport class TargetChange {\n  constructor(\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    readonly resumeToken: ByteString,\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    readonly current: boolean,\n    /**\n     * The set of documents that were newly assigned to this target as part of\n     * this remote event.\n     */\n    readonly addedDocuments: DocumentKeySet,\n    /**\n     * The set of documents that were already assigned to this target but received\n     * an update during this remote event.\n     */\n    readonly modifiedDocuments: DocumentKeySet,\n    /**\n     * The set of documents that were removed from this target as part of this\n     * remote event.\n     */\n    readonly removedDocuments: DocumentKeySet\n  ) {}\n\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  static createSynthesizedTargetChangeForCurrentChange(\n    targetId: TargetId,\n    current: boolean,\n    resumeToken: ByteString\n  ): TargetChange {\n    return new TargetChange(\n      resumeToken,\n      current,\n      documentKeySet(),\n      documentKeySet(),\n      documentKeySet()\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 { DatabaseId } from '../core/database_info';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { targetIsDocumentTarget } from '../core/target';\nimport { TargetId } from '../core/types';\nimport { ChangeType } from '../core/view_snapshot';\nimport { TargetData, TargetPurpose } from '../local/target_data';\nimport {\n  documentKeySet,\n  DocumentKeySet,\n  mutableDocumentMap\n} from '../model/collections';\nimport { MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { normalizeByteString } from '../model/normalize';\nimport { debugAssert, fail, hardAssert } from '../util/assert';\nimport { Base64DecodeError } from '../util/base64_decode_error';\nimport { ByteString } from '../util/byte_string';\nimport { FirestoreError } from '../util/error';\nimport { logDebug, logWarn } from '../util/log';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedMap } from '../util/sorted_map';\nimport { SortedSet } from '../util/sorted_set';\nimport {\n  testingHooksSpi,\n  ExistenceFilterMismatchInfo as TestingHooksExistenceFilterMismatchInfo\n} from '../util/testing_hooks_spi';\n\nimport { BloomFilter, BloomFilterError } from './bloom_filter';\nimport { ExistenceFilter } from './existence_filter';\nimport { RemoteEvent, TargetChange } from './remote_event';\n\n/**\n * Internal representation of the watcher API protocol buffers.\n */\nexport type WatchChange =\n  | DocumentWatchChange\n  | WatchTargetChange\n  | ExistenceFilterChange;\n\n/**\n * Represents a changed document and a list of target ids to which this change\n * applies.\n *\n * If document has been deleted NoDocument will be provided.\n */\nexport class DocumentWatchChange {\n  constructor(\n    /** The new document applies to all of these targets. */\n    public updatedTargetIds: TargetId[],\n    /** The new document is removed from all of these targets. */\n    public removedTargetIds: TargetId[],\n    /** The key of the document for this change. */\n    public key: DocumentKey,\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     */\n    public newDoc: MutableDocument | null\n  ) {}\n}\n\nexport class ExistenceFilterChange {\n  constructor(\n    public targetId: TargetId,\n    public existenceFilter: ExistenceFilter\n  ) {}\n}\n\nexport const enum WatchTargetChangeState {\n  NoChange,\n  Added,\n  Removed,\n  Current,\n  Reset\n}\n\nconst enum BloomFilterApplicationStatus {\n  Success,\n  Skipped,\n  FalsePositive\n}\nexport class WatchTargetChange {\n  constructor(\n    /** What kind of change occurred to the watch target. */\n    public state: WatchTargetChangeState,\n    /** The target IDs that were added/removed/set. */\n    public targetIds: TargetId[],\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     */\n    public resumeToken: ByteString = ByteString.EMPTY_BYTE_STRING,\n    /** An RPC error indicating why the watch failed. */\n    public cause: FirestoreError | null = null\n  ) {}\n}\n\n/** Tracks the internal state of a Watch target. */\nclass TargetState {\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  private pendingResponses = 0;\n\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  private documentChanges: SortedMap<DocumentKey, ChangeType> =\n    snapshotChangesMap();\n\n  /** See public getters for explanations of these fields. */\n  private _resumeToken: ByteString = ByteString.EMPTY_BYTE_STRING;\n  private _current = false;\n\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  private _hasPendingChanges = true;\n\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 current(): boolean {\n    return this._current;\n  }\n\n  /** The last resume token sent to us for this target. */\n  get resumeToken(): ByteString {\n    return this._resumeToken;\n  }\n\n  /** Whether this target has pending target adds or target removes. */\n  get isPending(): boolean {\n    return this.pendingResponses !== 0;\n  }\n\n  /** Whether we have modified any state that should trigger a snapshot. */\n  get hasPendingChanges(): boolean {\n    return this._hasPendingChanges;\n  }\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  updateResumeToken(resumeToken: ByteString): void {\n    if (resumeToken.approximateByteSize() > 0) {\n      this._hasPendingChanges = true;\n      this._resumeToken = resumeToken;\n    }\n  }\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  toTargetChange(): TargetChange {\n    let addedDocuments = documentKeySet();\n    let modifiedDocuments = documentKeySet();\n    let removedDocuments = documentKeySet();\n\n    this.documentChanges.forEach((key, changeType) => {\n      switch (changeType) {\n        case ChangeType.Added:\n          addedDocuments = addedDocuments.add(key);\n          break;\n        case ChangeType.Modified:\n          modifiedDocuments = modifiedDocuments.add(key);\n          break;\n        case ChangeType.Removed:\n          removedDocuments = removedDocuments.add(key);\n          break;\n        default:\n          fail('Encountered invalid change type: ' + changeType);\n      }\n    });\n\n    return new TargetChange(\n      this._resumeToken,\n      this._current,\n      addedDocuments,\n      modifiedDocuments,\n      removedDocuments\n    );\n  }\n\n  /**\n   * Resets the document changes and sets `hasPendingChanges` to false.\n   */\n  clearPendingChanges(): void {\n    this._hasPendingChanges = false;\n    this.documentChanges = snapshotChangesMap();\n  }\n\n  addDocumentChange(key: DocumentKey, changeType: ChangeType): void {\n    this._hasPendingChanges = true;\n    this.documentChanges = this.documentChanges.insert(key, changeType);\n  }\n\n  removeDocumentChange(key: DocumentKey): void {\n    this._hasPendingChanges = true;\n    this.documentChanges = this.documentChanges.remove(key);\n  }\n\n  recordPendingTargetRequest(): void {\n    this.pendingResponses += 1;\n  }\n\n  recordTargetResponse(): void {\n    this.pendingResponses -= 1;\n    hardAssert(\n      this.pendingResponses >= 0,\n      '`pendingResponses` is less than 0. Actual value: ' +\n        this.pendingResponses +\n        '. This indicates that the SDK received more target acks from the ' +\n        'server than expected. The SDK should not continue to operate.'\n    );\n  }\n\n  markCurrent(): void {\n    this._hasPendingChanges = true;\n    this._current = true;\n  }\n}\n\n/**\n * Interface implemented by RemoteStore to expose target metadata to the\n * WatchChangeAggregator.\n */\nexport interface TargetMetadataProvider {\n  /**\n   * Returns the set of remote document keys for the given target ID as of the\n   * last raised snapshot.\n   */\n  getRemoteKeysForTarget(targetId: TargetId): DocumentKeySet;\n\n  /**\n   * Returns the TargetData for an active target ID or 'null' if this target\n   * has become inactive\n   */\n  getTargetDataForTarget(targetId: TargetId): TargetData | null;\n\n  /**\n   * Returns the database ID of the Firestore instance.\n   */\n  getDatabaseId(): DatabaseId;\n}\n\nconst LOG_TAG = 'WatchChangeAggregator';\n\n/**\n * A helper class to accumulate watch changes into a RemoteEvent.\n */\nexport class WatchChangeAggregator {\n  constructor(private metadataProvider: TargetMetadataProvider) {}\n\n  /** The internal state of all tracked targets. */\n  private targetStates = new Map<TargetId, TargetState>();\n\n  /** Keeps track of the documents to update since the last raised snapshot. */\n  private pendingDocumentUpdates = mutableDocumentMap();\n  private pendingDocumentUpdatesByTarget = documentTargetMap();\n\n  /** A mapping of document keys to their set of target IDs. */\n  private pendingDocumentTargetMapping = documentTargetMap();\n\n  /**\n   * A map 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  private pendingTargetResets = new SortedMap<TargetId, TargetPurpose>(\n    primitiveComparator\n  );\n\n  /**\n   * Processes and adds the DocumentWatchChange to the current set of changes.\n   */\n  handleDocumentChange(docChange: DocumentWatchChange): void {\n    for (const targetId of docChange.updatedTargetIds) {\n      if (docChange.newDoc && docChange.newDoc.isFoundDocument()) {\n        this.addDocumentToTarget(targetId, docChange.newDoc);\n      } else {\n        this.removeDocumentFromTarget(\n          targetId,\n          docChange.key,\n          docChange.newDoc\n        );\n      }\n    }\n\n    for (const targetId of docChange.removedTargetIds) {\n      this.removeDocumentFromTarget(targetId, docChange.key, docChange.newDoc);\n    }\n  }\n\n  /** Processes and adds the WatchTargetChange to the current set of changes. */\n  handleTargetChange(targetChange: WatchTargetChange): void {\n    this.forEachTarget(targetChange, targetId => {\n      const targetState = this.ensureTargetState(targetId);\n      switch (targetChange.state) {\n        case WatchTargetChangeState.NoChange:\n          if (this.isActiveTarget(targetId)) {\n            targetState.updateResumeToken(targetChange.resumeToken);\n          }\n          break;\n        case WatchTargetChangeState.Added:\n          // We need to decrement the number of pending acks needed from watch\n          // for this targetId.\n          targetState.recordTargetResponse();\n          if (!targetState.isPending) {\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            targetState.clearPendingChanges();\n          }\n          targetState.updateResumeToken(targetChange.resumeToken);\n          break;\n        case WatchTargetChangeState.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          targetState.recordTargetResponse();\n          if (!targetState.isPending) {\n            this.removeTarget(targetId);\n          }\n          debugAssert(\n            !targetChange.cause,\n            'WatchChangeAggregator does not handle errored targets'\n          );\n          break;\n        case WatchTargetChangeState.Current:\n          if (this.isActiveTarget(targetId)) {\n            targetState.markCurrent();\n            targetState.updateResumeToken(targetChange.resumeToken);\n          }\n          break;\n        case WatchTargetChangeState.Reset:\n          if (this.isActiveTarget(targetId)) {\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            this.resetTarget(targetId);\n            targetState.updateResumeToken(targetChange.resumeToken);\n          }\n          break;\n        default:\n          fail('Unknown target watch change state: ' + targetChange.state);\n      }\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  forEachTarget(\n    targetChange: WatchTargetChange,\n    fn: (targetId: TargetId) => void\n  ): void {\n    if (targetChange.targetIds.length > 0) {\n      targetChange.targetIds.forEach(fn);\n    } else {\n      this.targetStates.forEach((_, targetId) => {\n        if (this.isActiveTarget(targetId)) {\n          fn(targetId);\n        }\n      });\n    }\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  handleExistenceFilter(watchChange: ExistenceFilterChange): void {\n    const targetId = watchChange.targetId;\n    const expectedCount = watchChange.existenceFilter.count;\n\n    const targetData = this.targetDataForActiveTarget(targetId);\n    if (targetData) {\n      const target = targetData.target;\n      if (targetIsDocumentTarget(target)) {\n        if (expectedCount === 0) {\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          const key = new DocumentKey(target.path);\n          this.removeDocumentFromTarget(\n            targetId,\n            key,\n            MutableDocument.newNoDocument(key, SnapshotVersion.min())\n          );\n        } else {\n          hardAssert(\n            expectedCount === 1,\n            'Single document existence filter with count: ' + expectedCount\n          );\n        }\n      } else {\n        const currentSize = this.getCurrentDocumentCountForTarget(targetId);\n        // Existence filter mismatch. Mark the documents as being in limbo, and\n        // raise a snapshot with `isFromCache:true`.\n        if (currentSize !== expectedCount) {\n          // Apply bloom filter to identify and mark removed documents.\n          const bloomFilter = this.parseBloomFilter(watchChange);\n          const status = bloomFilter\n            ? this.applyBloomFilter(bloomFilter, watchChange, currentSize)\n            : BloomFilterApplicationStatus.Skipped;\n\n          if (status !== BloomFilterApplicationStatus.Success) {\n            // If bloom filter application fails, we reset the mapping and\n            // trigger re-run of the query.\n            this.resetTarget(targetId);\n\n            const purpose: TargetPurpose =\n              status === BloomFilterApplicationStatus.FalsePositive\n                ? TargetPurpose.ExistenceFilterMismatchBloom\n                : TargetPurpose.ExistenceFilterMismatch;\n            this.pendingTargetResets = this.pendingTargetResets.insert(\n              targetId,\n              purpose\n            );\n          }\n          testingHooksSpi?.notifyOnExistenceFilterMismatch(\n            createExistenceFilterMismatchInfoForTestingHooks(\n              currentSize,\n              watchChange.existenceFilter,\n              this.metadataProvider.getDatabaseId(),\n              bloomFilter,\n              status\n            )\n          );\n        }\n      }\n    }\n  }\n\n  /**\n   * Parse the bloom filter from the \"unchanged_names\" field of an existence\n   * filter.\n   */\n  private parseBloomFilter(\n    watchChange: ExistenceFilterChange\n  ): BloomFilter | null {\n    const unchangedNames = watchChange.existenceFilter.unchangedNames;\n    if (!unchangedNames || !unchangedNames.bits) {\n      return null;\n    }\n\n    const {\n      bits: { bitmap = '', padding = 0 },\n      hashCount = 0\n    } = unchangedNames;\n\n    let normalizedBitmap: Uint8Array;\n    try {\n      normalizedBitmap = normalizeByteString(bitmap).toUint8Array();\n    } catch (err) {\n      if (err instanceof Base64DecodeError) {\n        logWarn(\n          'Decoding the base64 bloom filter in existence filter failed (' +\n            err.message +\n            '); ignoring the bloom filter and falling back to full re-query.'\n        );\n        return null;\n      } else {\n        throw err;\n      }\n    }\n\n    let bloomFilter: BloomFilter;\n    try {\n      // BloomFilter throws error if the inputs are invalid.\n      bloomFilter = new BloomFilter(normalizedBitmap, padding, hashCount);\n    } catch (err) {\n      if (err instanceof BloomFilterError) {\n        logWarn('BloomFilter error: ', err);\n      } else {\n        logWarn('Applying bloom filter failed: ', err);\n      }\n      return null;\n    }\n\n    if (bloomFilter.bitCount === 0) {\n      return null;\n    }\n\n    return bloomFilter;\n  }\n\n  /**\n   * Apply bloom filter to remove the deleted documents, and return the\n   * application status.\n   */\n  private applyBloomFilter(\n    bloomFilter: BloomFilter,\n    watchChange: ExistenceFilterChange,\n    currentCount: number\n  ): BloomFilterApplicationStatus {\n    const expectedCount = watchChange.existenceFilter.count;\n\n    const removedDocumentCount = this.filterRemovedDocuments(\n      bloomFilter,\n      watchChange.targetId\n    );\n\n    return expectedCount === currentCount - removedDocumentCount\n      ? BloomFilterApplicationStatus.Success\n      : BloomFilterApplicationStatus.FalsePositive;\n  }\n\n  /**\n   * Filter out removed documents based on bloom filter membership result and\n   * return number of documents removed.\n   */\n  private filterRemovedDocuments(\n    bloomFilter: BloomFilter,\n    targetId: number\n  ): number {\n    const existingKeys = this.metadataProvider.getRemoteKeysForTarget(targetId);\n    let removalCount = 0;\n\n    existingKeys.forEach(key => {\n      const databaseId = this.metadataProvider.getDatabaseId();\n      const documentPath =\n        `projects/${databaseId.projectId}` +\n        `/databases/${databaseId.database}` +\n        `/documents/${key.path.canonicalString()}`;\n\n      if (!bloomFilter.mightContain(documentPath)) {\n        this.removeDocumentFromTarget(targetId, key, /*updatedDocument=*/ null);\n        removalCount++;\n      }\n    });\n\n    return removalCount;\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  createRemoteEvent(snapshotVersion: SnapshotVersion): RemoteEvent {\n    const targetChanges = new Map<TargetId, TargetChange>();\n\n    this.targetStates.forEach((targetState, targetId) => {\n      const targetData = this.targetDataForActiveTarget(targetId);\n      if (targetData) {\n        if (targetState.current && targetIsDocumentTarget(targetData.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 for this\n          // target. This resolves the limbo state of the document, removing it\n          // from limboDocumentRefs.\n          //\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          const key = new DocumentKey(targetData.target.path);\n          if (\n            !this.ensureDocumentUpdateByTarget(key).has(targetId) &&\n            !this.targetContainsDocument(targetId, key)\n          ) {\n            this.removeDocumentFromTarget(\n              targetId,\n              key,\n              MutableDocument.newNoDocument(key, snapshotVersion)\n            );\n          }\n        }\n\n        if (targetState.hasPendingChanges) {\n          targetChanges.set(targetId, targetState.toTargetChange());\n          targetState.clearPendingChanges();\n        }\n      }\n    });\n\n    let resolvedLimboDocuments = documentKeySet();\n\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    //\n    // TODO(gsoltis): Expand on this comment once GC is available in the JS\n    // client.\n    this.pendingDocumentTargetMapping.forEach((key, targets) => {\n      let isOnlyLimboTarget = true;\n\n      targets.forEachWhile(targetId => {\n        const targetData = this.targetDataForActiveTarget(targetId);\n        if (\n          targetData &&\n          targetData.purpose !== TargetPurpose.LimboResolution\n        ) {\n          isOnlyLimboTarget = false;\n          return false;\n        }\n\n        return true;\n      });\n\n      if (isOnlyLimboTarget) {\n        resolvedLimboDocuments = resolvedLimboDocuments.add(key);\n      }\n    });\n\n    this.pendingDocumentUpdates.forEach((_, doc) =>\n      doc.setReadTime(snapshotVersion)\n    );\n\n    const remoteEvent = new RemoteEvent(\n      snapshotVersion,\n      targetChanges,\n      this.pendingTargetResets,\n      this.pendingDocumentUpdates,\n      resolvedLimboDocuments\n    );\n\n    this.pendingDocumentUpdates = mutableDocumentMap();\n    this.pendingDocumentUpdatesByTarget = documentTargetMap();\n    this.pendingDocumentTargetMapping = documentTargetMap();\n    this.pendingTargetResets = new SortedMap<TargetId, TargetPurpose>(\n      primitiveComparator\n    );\n\n    return remoteEvent;\n  }\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  addDocumentToTarget(targetId: TargetId, document: MutableDocument): void {\n    if (!this.isActiveTarget(targetId)) {\n      return;\n    }\n\n    const changeType = this.targetContainsDocument(targetId, document.key)\n      ? ChangeType.Modified\n      : ChangeType.Added;\n\n    const targetState = this.ensureTargetState(targetId);\n    targetState.addDocumentChange(document.key, changeType);\n\n    this.pendingDocumentUpdates = this.pendingDocumentUpdates.insert(\n      document.key,\n      document\n    );\n\n    this.pendingDocumentUpdatesByTarget =\n      this.pendingDocumentUpdatesByTarget.insert(\n        document.key,\n        this.ensureDocumentUpdateByTarget(document.key).add(targetId)\n      );\n\n    this.pendingDocumentTargetMapping =\n      this.pendingDocumentTargetMapping.insert(\n        document.key,\n        this.ensureDocumentTargetMapping(document.key).add(targetId)\n      );\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  removeDocumentFromTarget(\n    targetId: TargetId,\n    key: DocumentKey,\n    updatedDocument: MutableDocument | null\n  ): void {\n    if (!this.isActiveTarget(targetId)) {\n      return;\n    }\n\n    const targetState = this.ensureTargetState(targetId);\n    if (this.targetContainsDocument(targetId, key)) {\n      targetState.addDocumentChange(key, ChangeType.Removed);\n    } else {\n      // The document may have entered and left the target before we raised a\n      // snapshot, so we can just ignore the change.\n      targetState.removeDocumentChange(key);\n    }\n\n    this.pendingDocumentTargetMapping =\n      this.pendingDocumentTargetMapping.insert(\n        key,\n        this.ensureDocumentTargetMapping(key).delete(targetId)\n      );\n\n    this.pendingDocumentTargetMapping =\n      this.pendingDocumentTargetMapping.insert(\n        key,\n        this.ensureDocumentTargetMapping(key).add(targetId)\n      );\n\n    if (updatedDocument) {\n      this.pendingDocumentUpdates = this.pendingDocumentUpdates.insert(\n        key,\n        updatedDocument\n      );\n    }\n  }\n\n  removeTarget(targetId: TargetId): void {\n    this.targetStates.delete(targetId);\n  }\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  private getCurrentDocumentCountForTarget(targetId: TargetId): number {\n    const targetState = this.ensureTargetState(targetId);\n    const targetChange = targetState.toTargetChange();\n    return (\n      this.metadataProvider.getRemoteKeysForTarget(targetId).size +\n      targetChange.addedDocuments.size -\n      targetChange.removedDocuments.size\n    );\n  }\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  recordPendingTargetRequest(targetId: TargetId): void {\n    // For each request we get we need to record we need a response for it.\n    const targetState = this.ensureTargetState(targetId);\n    targetState.recordPendingTargetRequest();\n  }\n\n  private ensureTargetState(targetId: TargetId): TargetState {\n    let result = this.targetStates.get(targetId);\n    if (!result) {\n      result = new TargetState();\n      this.targetStates.set(targetId, result);\n    }\n    return result;\n  }\n\n  private ensureDocumentTargetMapping(key: DocumentKey): SortedSet<TargetId> {\n    let targetMapping = this.pendingDocumentTargetMapping.get(key);\n\n    if (!targetMapping) {\n      targetMapping = new SortedSet<TargetId>(primitiveComparator);\n      this.pendingDocumentTargetMapping =\n        this.pendingDocumentTargetMapping.insert(key, targetMapping);\n    }\n\n    return targetMapping;\n  }\n\n  private ensureDocumentUpdateByTarget(key: DocumentKey): SortedSet<TargetId> {\n    let targetMapping = this.pendingDocumentUpdatesByTarget.get(key);\n\n    if (!targetMapping) {\n      targetMapping = new SortedSet<TargetId>(primitiveComparator);\n      this.pendingDocumentUpdatesByTarget =\n        this.pendingDocumentUpdatesByTarget.insert(key, targetMapping);\n    }\n\n    return targetMapping;\n  }\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  protected isActiveTarget(targetId: TargetId): boolean {\n    const targetActive = this.targetDataForActiveTarget(targetId) !== null;\n    if (!targetActive) {\n      logDebug(LOG_TAG, 'Detected inactive target', targetId);\n    }\n    return targetActive;\n  }\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  protected targetDataForActiveTarget(targetId: TargetId): TargetData | null {\n    const targetState = this.targetStates.get(targetId);\n    return targetState && targetState.isPending\n      ? null\n      : this.metadataProvider.getTargetDataForTarget(targetId);\n  }\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  private resetTarget(targetId: TargetId): void {\n    debugAssert(\n      !this.targetStates.get(targetId)!.isPending,\n      'Should only reset active targets'\n    );\n    this.targetStates.set(targetId, new TargetState());\n\n    // Trigger removal for any documents currently mapped to this target.\n    // These removals will be part of the initial snapshot if Watch does not\n    // resend these documents.\n    const existingKeys = this.metadataProvider.getRemoteKeysForTarget(targetId);\n    existingKeys.forEach(key => {\n      this.removeDocumentFromTarget(targetId, key, /*updatedDocument=*/ null);\n    });\n  }\n  /**\n   * Returns whether the LocalStore considers the document to be part of the\n   * specified target.\n   */\n  private targetContainsDocument(\n    targetId: TargetId,\n    key: DocumentKey\n  ): boolean {\n    const existingKeys = this.metadataProvider.getRemoteKeysForTarget(targetId);\n    return existingKeys.has(key);\n  }\n}\n\nfunction documentTargetMap(): SortedMap<DocumentKey, SortedSet<TargetId>> {\n  return new SortedMap<DocumentKey, SortedSet<TargetId>>(\n    DocumentKey.comparator\n  );\n}\n\nfunction snapshotChangesMap(): SortedMap<DocumentKey, ChangeType> {\n  return new SortedMap<DocumentKey, ChangeType>(DocumentKey.comparator);\n}\n\nfunction createExistenceFilterMismatchInfoForTestingHooks(\n  localCacheCount: number,\n  existenceFilter: ExistenceFilter,\n  databaseId: DatabaseId,\n  bloomFilter: BloomFilter | null,\n  bloomFilterStatus: BloomFilterApplicationStatus\n): TestingHooksExistenceFilterMismatchInfo {\n  const result: TestingHooksExistenceFilterMismatchInfo = {\n    localCacheCount,\n    existenceFilterCount: existenceFilter.count,\n    databaseId: databaseId.database,\n    projectId: databaseId.projectId\n  };\n\n  const unchangedNames = existenceFilter.unchangedNames;\n  if (unchangedNames) {\n    result.bloomFilter = {\n      applied: bloomFilterStatus === BloomFilterApplicationStatus.Success,\n      hashCount: unchangedNames?.hashCount ?? 0,\n      bitmapLength: unchangedNames?.bits?.bitmap?.length ?? 0,\n      padding: unchangedNames?.bits?.padding ?? 0,\n      mightContain: (value: string): boolean =>\n        bloomFilter?.mightContain(value) ?? false\n    };\n  }\n\n  return result;\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 { Aggregate } from '../core/aggregate';\nimport { Bound } from '../core/bound';\nimport { DatabaseId } from '../core/database_info';\nimport {\n  CompositeFilter,\n  compositeFilterIsFlatConjunction,\n  CompositeOperator,\n  FieldFilter,\n  Filter,\n  Operator\n} from '../core/filter';\nimport { Direction, OrderBy } from '../core/order_by';\nimport {\n  LimitType,\n  newQuery,\n  newQueryForPath,\n  Query,\n  queryToTarget\n} from '../core/query';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { targetIsDocumentTarget, Target } from '../core/target';\nimport { TargetId } from '../core/types';\nimport { Timestamp } from '../lite-api/timestamp';\nimport { TargetData, TargetPurpose } from '../local/target_data';\nimport { MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldMask } from '../model/field_mask';\nimport {\n  DeleteMutation,\n  FieldTransform,\n  Mutation,\n  MutationResult,\n  PatchMutation,\n  Precondition,\n  SetMutation,\n  VerifyMutation\n} from '../model/mutation';\nimport { normalizeTimestamp } from '../model/normalize';\nimport { ObjectValue } from '../model/object_value';\nimport { FieldPath, ResourcePath } from '../model/path';\nimport {\n  ArrayRemoveTransformOperation,\n  ArrayUnionTransformOperation,\n  NumericIncrementTransformOperation,\n  ServerTimestampTransform,\n  TransformOperation\n} from '../model/transform_operation';\nimport { isNanValue, isNullValue } from '../model/values';\nimport {\n  ApiClientObjectMap as ProtoApiClientObjectMap,\n  BatchGetDocumentsResponse as ProtoBatchGetDocumentsResponse,\n  CompositeFilterOp as ProtoCompositeFilterOp,\n  Cursor as ProtoCursor,\n  Document as ProtoDocument,\n  DocumentMask as ProtoDocumentMask,\n  DocumentsTarget as ProtoDocumentsTarget,\n  FieldFilterOp as ProtoFieldFilterOp,\n  FieldReference as ProtoFieldReference,\n  FieldTransform as ProtoFieldTransform,\n  Filter as ProtoFilter,\n  ListenResponse as ProtoListenResponse,\n  Order as ProtoOrder,\n  OrderDirection as ProtoOrderDirection,\n  Precondition as ProtoPrecondition,\n  QueryTarget as ProtoQueryTarget,\n  RunAggregationQueryRequest as ProtoRunAggregationQueryRequest,\n  Aggregation as ProtoAggregation,\n  Status as ProtoStatus,\n  Target as ProtoTarget,\n  TargetChangeTargetChangeType as ProtoTargetChangeTargetChangeType,\n  Timestamp as ProtoTimestamp,\n  Write as ProtoWrite,\n  WriteResult as ProtoWriteResult\n} from '../protos/firestore_proto_api';\nimport { debugAssert, fail, hardAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\nimport { Code, FirestoreError } from '../util/error';\nimport { isNullOrUndefined } from '../util/types';\n\nimport { ExistenceFilter } from './existence_filter';\nimport { Serializer } from './number_serializer';\nimport { mapCodeFromRpcCode } from './rpc_error';\nimport {\n  DocumentWatchChange,\n  ExistenceFilterChange,\n  WatchChange,\n  WatchTargetChange,\n  WatchTargetChangeState\n} from './watch_change';\n\nconst DIRECTIONS = (() => {\n  const dirs: { [dir: string]: ProtoOrderDirection } = {};\n  dirs[Direction.ASCENDING] = 'ASCENDING';\n  dirs[Direction.DESCENDING] = 'DESCENDING';\n  return dirs;\n})();\n\nconst OPERATORS = (() => {\n  const ops: { [op: string]: ProtoFieldFilterOp } = {};\n  ops[Operator.LESS_THAN] = 'LESS_THAN';\n  ops[Operator.LESS_THAN_OR_EQUAL] = 'LESS_THAN_OR_EQUAL';\n  ops[Operator.GREATER_THAN] = 'GREATER_THAN';\n  ops[Operator.GREATER_THAN_OR_EQUAL] = 'GREATER_THAN_OR_EQUAL';\n  ops[Operator.EQUAL] = 'EQUAL';\n  ops[Operator.NOT_EQUAL] = 'NOT_EQUAL';\n  ops[Operator.ARRAY_CONTAINS] = 'ARRAY_CONTAINS';\n  ops[Operator.IN] = 'IN';\n  ops[Operator.NOT_IN] = 'NOT_IN';\n  ops[Operator.ARRAY_CONTAINS_ANY] = 'ARRAY_CONTAINS_ANY';\n  return ops;\n})();\n\nconst COMPOSITE_OPERATORS = (() => {\n  const ops: { [op: string]: ProtoCompositeFilterOp } = {};\n  ops[CompositeOperator.AND] = 'AND';\n  ops[CompositeOperator.OR] = 'OR';\n  return ops;\n})();\n\nfunction assertPresent(value: unknown, description: string): asserts value {\n  debugAssert(!isNullOrUndefined(value), description + ' is missing');\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 */\nexport class JsonProtoSerializer implements Serializer {\n  constructor(\n    readonly databaseId: DatabaseId,\n    readonly useProto3Json: boolean\n  ) {}\n}\n\nfunction fromRpcStatus(status: ProtoStatus): FirestoreError {\n  const code =\n    status.code === undefined ? Code.UNKNOWN : mapCodeFromRpcCode(status.code);\n  return new FirestoreError(code, status.message || '');\n}\n\n/**\n * Returns a value for a number (or null) that's appropriate to put into\n * a google.protobuf.Int32Value proto.\n * DO NOT USE THIS FOR ANYTHING ELSE.\n * This method cheats. It's typed as returning \"number\" because that's what\n * our generated proto interfaces say Int32Value must be. But GRPC actually\n * expects a { value: <number> } struct.\n */\nfunction toInt32Proto(\n  serializer: JsonProtoSerializer,\n  val: number | null\n): number | { value: number } | null {\n  if (serializer.useProto3Json || isNullOrUndefined(val)) {\n    return val;\n  } else {\n    return { value: val };\n  }\n}\n\n/**\n * Returns a number (or null) from a google.protobuf.Int32Value proto.\n */\nfunction fromInt32Proto(\n  val: number | { value: number } | undefined\n): number | null {\n  let result;\n  if (typeof val === 'object') {\n    result = val.value;\n  } else {\n    result = val;\n  }\n  return isNullOrUndefined(result) ? null : result;\n}\n\n/**\n * Returns a value for a Date that's appropriate to put into a proto.\n */\nexport function toTimestamp(\n  serializer: JsonProtoSerializer,\n  timestamp: Timestamp\n): ProtoTimestamp {\n  if (serializer.useProto3Json) {\n    // Serialize to ISO-8601 date format, but with full nano resolution.\n    // Since JS Date has only millis, let's only use it for the seconds and\n    // then manually add the fractions to the end.\n    const jsDateStr = new Date(timestamp.seconds * 1000).toISOString();\n    // Remove .xxx frac part and Z in the end.\n    const strUntilSeconds = jsDateStr.replace(/\\.\\d*/, '').replace('Z', '');\n    // Pad the fraction out to 9 digits (nanos).\n    const nanoStr = ('000000000' + timestamp.nanoseconds).slice(-9);\n\n    return `${strUntilSeconds}.${nanoStr}Z`;\n  } else {\n    return {\n      seconds: '' + timestamp.seconds,\n      nanos: timestamp.nanoseconds\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    } as any;\n  }\n}\n\nfunction fromTimestamp(date: ProtoTimestamp): Timestamp {\n  const timestamp = normalizeTimestamp(date);\n  return new Timestamp(timestamp.seconds, timestamp.nanos);\n}\n\n/**\n * Returns a value for bytes that's appropriate to put in a proto.\n *\n * Visible for testing.\n */\nexport function toBytes(\n  serializer: JsonProtoSerializer,\n  bytes: ByteString\n): string | Uint8Array {\n  if (serializer.useProto3Json) {\n    return bytes.toBase64();\n  } else {\n    return bytes.toUint8Array();\n  }\n}\n\n/**\n * Returns a ByteString based on the proto string value.\n */\nexport function fromBytes(\n  serializer: JsonProtoSerializer,\n  value: string | Uint8Array | undefined\n): ByteString {\n  if (serializer.useProto3Json) {\n    hardAssert(\n      value === undefined || typeof value === 'string',\n      'value must be undefined or a string when using proto3 Json'\n    );\n    return ByteString.fromBase64String(value ? value : '');\n  } else {\n    hardAssert(\n      value === undefined ||\n        // Check if the value is an instance of both Buffer and Uint8Array,\n        // despite the fact that Buffer extends Uint8Array. In some\n        // environments, such as jsdom, the prototype chain of Buffer\n        // does not indicate that it extends Uint8Array.\n        value instanceof Buffer ||\n        value instanceof Uint8Array,\n      'value must be undefined, Buffer, or Uint8Array'\n    );\n    return ByteString.fromUint8Array(value ? value : new Uint8Array());\n  }\n}\n\nexport function toVersion(\n  serializer: JsonProtoSerializer,\n  version: SnapshotVersion\n): ProtoTimestamp {\n  return toTimestamp(serializer, version.toTimestamp());\n}\n\nexport function fromVersion(version: ProtoTimestamp): SnapshotVersion {\n  hardAssert(!!version, \"Trying to deserialize version that isn't set\");\n  return SnapshotVersion.fromTimestamp(fromTimestamp(version));\n}\n\nexport function toResourceName(\n  databaseId: DatabaseId,\n  path: ResourcePath\n): string {\n  return toResourcePath(databaseId, path).canonicalString();\n}\n\nexport function toResourcePath(\n  databaseId: DatabaseId,\n  path?: ResourcePath\n): ResourcePath {\n  const resourcePath = fullyQualifiedPrefixPath(databaseId).child('documents');\n  return path === undefined ? resourcePath : resourcePath.child(path);\n}\n\nfunction fromResourceName(name: string): ResourcePath {\n  const resource = ResourcePath.fromString(name);\n  hardAssert(\n    isValidResourceName(resource),\n    'Tried to deserialize invalid key ' + resource.toString()\n  );\n  return resource;\n}\n\nexport function toName(\n  serializer: JsonProtoSerializer,\n  key: DocumentKey\n): string {\n  return toResourceName(serializer.databaseId, key.path);\n}\n\nexport function fromName(\n  serializer: JsonProtoSerializer,\n  name: string\n): DocumentKey {\n  const resource = fromResourceName(name);\n\n  if (resource.get(1) !== serializer.databaseId.projectId) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'Tried to deserialize key from different project: ' +\n        resource.get(1) +\n        ' vs ' +\n        serializer.databaseId.projectId\n    );\n  }\n\n  if (resource.get(3) !== serializer.databaseId.database) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'Tried to deserialize key from different database: ' +\n        resource.get(3) +\n        ' vs ' +\n        serializer.databaseId.database\n    );\n  }\n  return new DocumentKey(extractLocalPathFromResourceName(resource));\n}\n\nfunction toQueryPath(\n  serializer: JsonProtoSerializer,\n  path: ResourcePath\n): string {\n  return toResourceName(serializer.databaseId, path);\n}\n\nfunction fromQueryPath(name: string): ResourcePath {\n  const resourceName = fromResourceName(name);\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  if (resourceName.length === 4) {\n    return ResourcePath.emptyPath();\n  }\n  return extractLocalPathFromResourceName(resourceName);\n}\n\nexport function getEncodedDatabaseId(serializer: JsonProtoSerializer): string {\n  const path = new ResourcePath([\n    'projects',\n    serializer.databaseId.projectId,\n    'databases',\n    serializer.databaseId.database\n  ]);\n  return path.canonicalString();\n}\n\nfunction fullyQualifiedPrefixPath(databaseId: DatabaseId): ResourcePath {\n  return new ResourcePath([\n    'projects',\n    databaseId.projectId,\n    'databases',\n    databaseId.database\n  ]);\n}\n\nfunction extractLocalPathFromResourceName(\n  resourceName: ResourcePath\n): ResourcePath {\n  hardAssert(\n    resourceName.length > 4 && resourceName.get(4) === 'documents',\n    'tried to deserialize invalid key ' + resourceName.toString()\n  );\n  return resourceName.popFirst(5);\n}\n\n/** Creates a Document proto from key and fields (but no create/update time) */\nexport function toMutationDocument(\n  serializer: JsonProtoSerializer,\n  key: DocumentKey,\n  fields: ObjectValue\n): ProtoDocument {\n  return {\n    name: toName(serializer, key),\n    fields: fields.value.mapValue.fields\n  };\n}\n\nexport function toDocument(\n  serializer: JsonProtoSerializer,\n  document: MutableDocument\n): ProtoDocument {\n  debugAssert(\n    !document.hasLocalMutations,\n    \"Can't serialize documents with mutations.\"\n  );\n  return {\n    name: toName(serializer, document.key),\n    fields: document.data.value.mapValue.fields,\n    updateTime: toTimestamp(serializer, document.version.toTimestamp()),\n    createTime: toTimestamp(serializer, document.createTime.toTimestamp())\n  };\n}\n\nexport function fromDocument(\n  serializer: JsonProtoSerializer,\n  document: ProtoDocument,\n  hasCommittedMutations?: boolean\n): MutableDocument {\n  const key = fromName(serializer, document.name!);\n  const version = fromVersion(document.updateTime!);\n  // If we read a document from persistence that is missing createTime, it's due\n  // to older SDK versions not storing this information. In such cases, we'll\n  // set the createTime to zero. This can be removed in the long term.\n  const createTime = document.createTime\n    ? fromVersion(document.createTime)\n    : SnapshotVersion.min();\n  const data = new ObjectValue({ mapValue: { fields: document.fields } });\n  const result = MutableDocument.newFoundDocument(\n    key,\n    version,\n    createTime,\n    data\n  );\n  if (hasCommittedMutations) {\n    result.setHasCommittedMutations();\n  }\n  return hasCommittedMutations ? result.setHasCommittedMutations() : result;\n}\n\nfunction fromFound(\n  serializer: JsonProtoSerializer,\n  doc: ProtoBatchGetDocumentsResponse\n): MutableDocument {\n  hardAssert(\n    !!doc.found,\n    'Tried to deserialize a found document from a missing document.'\n  );\n  assertPresent(doc.found.name, 'doc.found.name');\n  assertPresent(doc.found.updateTime, 'doc.found.updateTime');\n  const key = fromName(serializer, doc.found.name);\n  const version = fromVersion(doc.found.updateTime);\n  const createTime = doc.found.createTime\n    ? fromVersion(doc.found.createTime)\n    : SnapshotVersion.min();\n  const data = new ObjectValue({ mapValue: { fields: doc.found.fields } });\n  return MutableDocument.newFoundDocument(key, version, createTime, data);\n}\n\nfunction fromMissing(\n  serializer: JsonProtoSerializer,\n  result: ProtoBatchGetDocumentsResponse\n): MutableDocument {\n  hardAssert(\n    !!result.missing,\n    'Tried to deserialize a missing document from a found document.'\n  );\n  hardAssert(\n    !!result.readTime,\n    'Tried to deserialize a missing document without a read time.'\n  );\n  const key = fromName(serializer, result.missing);\n  const version = fromVersion(result.readTime);\n  return MutableDocument.newNoDocument(key, version);\n}\n\nexport function fromBatchGetDocumentsResponse(\n  serializer: JsonProtoSerializer,\n  result: ProtoBatchGetDocumentsResponse\n): MutableDocument {\n  if ('found' in result) {\n    return fromFound(serializer, result);\n  } else if ('missing' in result) {\n    return fromMissing(serializer, result);\n  }\n  return fail('invalid batch get response: ' + JSON.stringify(result));\n}\n\nexport function fromWatchChange(\n  serializer: JsonProtoSerializer,\n  change: ProtoListenResponse\n): WatchChange {\n  let watchChange: WatchChange;\n  if ('targetChange' in change) {\n    assertPresent(change.targetChange, 'targetChange');\n    // proto3 default value is unset in JSON (undefined), so use 'NO_CHANGE'\n    // if unset\n    const state = fromWatchTargetChangeState(\n      change.targetChange.targetChangeType || 'NO_CHANGE'\n    );\n    const targetIds: TargetId[] = change.targetChange.targetIds || [];\n\n    const resumeToken = fromBytes(serializer, change.targetChange.resumeToken);\n    const causeProto = change.targetChange!.cause;\n    const cause = causeProto && fromRpcStatus(causeProto);\n    watchChange = new WatchTargetChange(\n      state,\n      targetIds,\n      resumeToken,\n      cause || null\n    );\n  } else if ('documentChange' in change) {\n    assertPresent(change.documentChange, 'documentChange');\n    const entityChange = change.documentChange;\n    assertPresent(entityChange.document, 'documentChange.name');\n    assertPresent(entityChange.document.name, 'documentChange.document.name');\n    assertPresent(\n      entityChange.document.updateTime,\n      'documentChange.document.updateTime'\n    );\n    const key = fromName(serializer, entityChange.document.name);\n    const version = fromVersion(entityChange.document.updateTime);\n    const createTime = entityChange.document.createTime\n      ? fromVersion(entityChange.document.createTime)\n      : SnapshotVersion.min();\n    const data = new ObjectValue({\n      mapValue: { fields: entityChange.document.fields }\n    });\n    const doc = MutableDocument.newFoundDocument(\n      key,\n      version,\n      createTime,\n      data\n    );\n    const updatedTargetIds = entityChange.targetIds || [];\n    const removedTargetIds = entityChange.removedTargetIds || [];\n    watchChange = new DocumentWatchChange(\n      updatedTargetIds,\n      removedTargetIds,\n      doc.key,\n      doc\n    );\n  } else if ('documentDelete' in change) {\n    assertPresent(change.documentDelete, 'documentDelete');\n    const docDelete = change.documentDelete;\n    assertPresent(docDelete.document, 'documentDelete.document');\n    const key = fromName(serializer, docDelete.document);\n    const version = docDelete.readTime\n      ? fromVersion(docDelete.readTime)\n      : SnapshotVersion.min();\n    const doc = MutableDocument.newNoDocument(key, version);\n    const removedTargetIds = docDelete.removedTargetIds || [];\n    watchChange = new DocumentWatchChange([], removedTargetIds, doc.key, doc);\n  } else if ('documentRemove' in change) {\n    assertPresent(change.documentRemove, 'documentRemove');\n    const docRemove = change.documentRemove;\n    assertPresent(docRemove.document, 'documentRemove');\n    const key = fromName(serializer, docRemove.document);\n    const removedTargetIds = docRemove.removedTargetIds || [];\n    watchChange = new DocumentWatchChange([], removedTargetIds, key, null);\n  } else if ('filter' in change) {\n    // TODO(dimond): implement existence filter parsing with strategy.\n    assertPresent(change.filter, 'filter');\n    const filter = change.filter;\n    assertPresent(filter.targetId, 'filter.targetId');\n    const { count = 0, unchangedNames } = filter;\n    const existenceFilter = new ExistenceFilter(count, unchangedNames);\n    const targetId = filter.targetId;\n    watchChange = new ExistenceFilterChange(targetId, existenceFilter);\n  } else {\n    return fail('Unknown change type ' + JSON.stringify(change));\n  }\n  return watchChange;\n}\n\nfunction fromWatchTargetChangeState(\n  state: ProtoTargetChangeTargetChangeType\n): WatchTargetChangeState {\n  if (state === 'NO_CHANGE') {\n    return WatchTargetChangeState.NoChange;\n  } else if (state === 'ADD') {\n    return WatchTargetChangeState.Added;\n  } else if (state === 'REMOVE') {\n    return WatchTargetChangeState.Removed;\n  } else if (state === 'CURRENT') {\n    return WatchTargetChangeState.Current;\n  } else if (state === 'RESET') {\n    return WatchTargetChangeState.Reset;\n  } else {\n    return fail('Got unexpected TargetChange.state: ' + state);\n  }\n}\n\nexport function versionFromListenResponse(\n  change: ProtoListenResponse\n): SnapshotVersion {\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 change)) {\n    return SnapshotVersion.min();\n  }\n  const targetChange = change.targetChange!;\n  if (targetChange.targetIds && targetChange.targetIds.length) {\n    return SnapshotVersion.min();\n  }\n  if (!targetChange.readTime) {\n    return SnapshotVersion.min();\n  }\n  return fromVersion(targetChange.readTime);\n}\n\nexport function toMutation(\n  serializer: JsonProtoSerializer,\n  mutation: Mutation\n): ProtoWrite {\n  let result: ProtoWrite;\n  if (mutation instanceof SetMutation) {\n    result = {\n      update: toMutationDocument(serializer, mutation.key, mutation.value)\n    };\n  } else if (mutation instanceof DeleteMutation) {\n    result = { delete: toName(serializer, mutation.key) };\n  } else if (mutation instanceof PatchMutation) {\n    result = {\n      update: toMutationDocument(serializer, mutation.key, mutation.data),\n      updateMask: toDocumentMask(mutation.fieldMask)\n    };\n  } else if (mutation instanceof VerifyMutation) {\n    result = {\n      verify: toName(serializer, mutation.key)\n    };\n  } else {\n    return fail('Unknown mutation type ' + mutation.type);\n  }\n\n  if (mutation.fieldTransforms.length > 0) {\n    result.updateTransforms = mutation.fieldTransforms.map(transform =>\n      toFieldTransform(serializer, transform)\n    );\n  }\n\n  if (!mutation.precondition.isNone) {\n    result.currentDocument = toPrecondition(serializer, mutation.precondition);\n  }\n\n  return result;\n}\n\nexport function fromMutation(\n  serializer: JsonProtoSerializer,\n  proto: ProtoWrite\n): Mutation {\n  const precondition = proto.currentDocument\n    ? fromPrecondition(proto.currentDocument)\n    : Precondition.none();\n\n  const fieldTransforms = proto.updateTransforms\n    ? proto.updateTransforms.map(transform =>\n        fromFieldTransform(serializer, transform)\n      )\n    : [];\n\n  if (proto.update) {\n    assertPresent(proto.update.name, 'name');\n    const key = fromName(serializer, proto.update.name);\n    const value = new ObjectValue({\n      mapValue: { fields: proto.update.fields }\n    });\n\n    if (proto.updateMask) {\n      const fieldMask = fromDocumentMask(proto.updateMask);\n      return new PatchMutation(\n        key,\n        value,\n        fieldMask,\n        precondition,\n        fieldTransforms\n      );\n    } else {\n      return new SetMutation(key, value, precondition, fieldTransforms);\n    }\n  } else if (proto.delete) {\n    const key = fromName(serializer, proto.delete);\n    return new DeleteMutation(key, precondition);\n  } else if (proto.verify) {\n    const key = fromName(serializer, proto.verify);\n    return new VerifyMutation(key, precondition);\n  } else {\n    return fail('unknown mutation proto: ' + JSON.stringify(proto));\n  }\n}\n\nfunction toPrecondition(\n  serializer: JsonProtoSerializer,\n  precondition: Precondition\n): ProtoPrecondition {\n  debugAssert(!precondition.isNone, \"Can't serialize an empty precondition\");\n  if (precondition.updateTime !== undefined) {\n    return {\n      updateTime: toVersion(serializer, precondition.updateTime)\n    };\n  } else if (precondition.exists !== undefined) {\n    return { exists: precondition.exists };\n  } else {\n    return fail('Unknown precondition');\n  }\n}\n\nfunction fromPrecondition(precondition: ProtoPrecondition): Precondition {\n  if (precondition.updateTime !== undefined) {\n    return Precondition.updateTime(fromVersion(precondition.updateTime));\n  } else if (precondition.exists !== undefined) {\n    return Precondition.exists(precondition.exists);\n  } else {\n    return Precondition.none();\n  }\n}\n\nfunction fromWriteResult(\n  proto: ProtoWriteResult,\n  commitTime: ProtoTimestamp\n): MutationResult {\n  // NOTE: Deletes don't have an updateTime.\n  let version = proto.updateTime\n    ? fromVersion(proto.updateTime)\n    : fromVersion(commitTime);\n\n  if (version.isEqual(SnapshotVersion.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    version = fromVersion(commitTime);\n  }\n\n  return new MutationResult(version, proto.transformResults || []);\n}\n\nexport function fromWriteResults(\n  protos: ProtoWriteResult[] | undefined,\n  commitTime?: ProtoTimestamp\n): MutationResult[] {\n  if (protos && protos.length > 0) {\n    hardAssert(\n      commitTime !== undefined,\n      'Received a write result without a commit time'\n    );\n    return protos.map(proto => fromWriteResult(proto, commitTime));\n  } else {\n    return [];\n  }\n}\n\nfunction toFieldTransform(\n  serializer: JsonProtoSerializer,\n  fieldTransform: FieldTransform\n): ProtoFieldTransform {\n  const transform = fieldTransform.transform;\n  if (transform instanceof ServerTimestampTransform) {\n    return {\n      fieldPath: fieldTransform.field.canonicalString(),\n      setToServerValue: 'REQUEST_TIME'\n    };\n  } else if (transform instanceof ArrayUnionTransformOperation) {\n    return {\n      fieldPath: fieldTransform.field.canonicalString(),\n      appendMissingElements: {\n        values: transform.elements\n      }\n    };\n  } else if (transform instanceof ArrayRemoveTransformOperation) {\n    return {\n      fieldPath: fieldTransform.field.canonicalString(),\n      removeAllFromArray: {\n        values: transform.elements\n      }\n    };\n  } else if (transform instanceof NumericIncrementTransformOperation) {\n    return {\n      fieldPath: fieldTransform.field.canonicalString(),\n      increment: transform.operand\n    };\n  } else {\n    throw fail('Unknown transform: ' + fieldTransform.transform);\n  }\n}\n\nfunction fromFieldTransform(\n  serializer: JsonProtoSerializer,\n  proto: ProtoFieldTransform\n): FieldTransform {\n  let transform: TransformOperation | null = null;\n  if ('setToServerValue' in proto) {\n    hardAssert(\n      proto.setToServerValue === 'REQUEST_TIME',\n      'Unknown server value transform proto: ' + JSON.stringify(proto)\n    );\n    transform = new ServerTimestampTransform();\n  } else if ('appendMissingElements' in proto) {\n    const values = proto.appendMissingElements!.values || [];\n    transform = new ArrayUnionTransformOperation(values);\n  } else if ('removeAllFromArray' in proto) {\n    const values = proto.removeAllFromArray!.values || [];\n    transform = new ArrayRemoveTransformOperation(values);\n  } else if ('increment' in proto) {\n    transform = new NumericIncrementTransformOperation(\n      serializer,\n      proto.increment!\n    );\n  } else {\n    fail('Unknown transform proto: ' + JSON.stringify(proto));\n  }\n  const fieldPath = FieldPath.fromServerFormat(proto.fieldPath!);\n  return new FieldTransform(fieldPath, transform!);\n}\n\nexport function toDocumentsTarget(\n  serializer: JsonProtoSerializer,\n  target: Target\n): ProtoDocumentsTarget {\n  return { documents: [toQueryPath(serializer, target.path)] };\n}\n\nexport function fromDocumentsTarget(\n  documentsTarget: ProtoDocumentsTarget\n): Target {\n  const count = documentsTarget.documents!.length;\n  hardAssert(\n    count === 1,\n    'DocumentsTarget contained other than 1 document: ' + count\n  );\n  const name = documentsTarget.documents![0];\n  return queryToTarget(newQueryForPath(fromQueryPath(name)));\n}\n\nexport function toQueryTarget(\n  serializer: JsonProtoSerializer,\n  target: Target\n): { queryTarget: ProtoQueryTarget; parent: ResourcePath } {\n  // Dissect the path into parent, collectionId, and optional key filter.\n  const queryTarget: ProtoQueryTarget = { structuredQuery: {} };\n  const path = target.path;\n  let parent: ResourcePath;\n  if (target.collectionGroup !== null) {\n    debugAssert(\n      path.length % 2 === 0,\n      'Collection Group queries should be within a document path or root.'\n    );\n    parent = path;\n    queryTarget.structuredQuery!.from = [\n      {\n        collectionId: target.collectionGroup,\n        allDescendants: true\n      }\n    ];\n  } else {\n    debugAssert(\n      path.length % 2 !== 0,\n      'Document queries with filters are not supported.'\n    );\n    parent = path.popLast();\n    queryTarget.structuredQuery!.from = [{ collectionId: path.lastSegment() }];\n  }\n  queryTarget.parent = toQueryPath(serializer, parent);\n\n  const where = toFilters(target.filters);\n  if (where) {\n    queryTarget.structuredQuery!.where = where;\n  }\n\n  const orderBy = toOrder(target.orderBy);\n  if (orderBy) {\n    queryTarget.structuredQuery!.orderBy = orderBy;\n  }\n\n  const limit = toInt32Proto(serializer, target.limit);\n  if (limit !== null) {\n    queryTarget.structuredQuery!.limit = limit;\n  }\n\n  if (target.startAt) {\n    queryTarget.structuredQuery!.startAt = toStartAtCursor(target.startAt);\n  }\n  if (target.endAt) {\n    queryTarget.structuredQuery!.endAt = toEndAtCursor(target.endAt);\n  }\n\n  return { queryTarget, parent };\n}\n\nexport function toRunAggregationQueryRequest(\n  serializer: JsonProtoSerializer,\n  target: Target,\n  aggregates: Aggregate[],\n  skipAliasing?: boolean\n): {\n  request: ProtoRunAggregationQueryRequest;\n  aliasMap: Record<string, string>;\n  parent: ResourcePath;\n} {\n  const { queryTarget, parent } = toQueryTarget(serializer, target);\n  const aliasMap: Record<string, string> = {};\n\n  const aggregations: ProtoAggregation[] = [];\n  let aggregationNum = 0;\n\n  aggregates.forEach(aggregate => {\n    // Map all client-side aliases to a unique short-form\n    // alias. This avoids issues with client-side aliases that\n    // exceed the 1500-byte string size limit.\n    const serverAlias = skipAliasing\n      ? aggregate.alias\n      : `aggregate_${aggregationNum++}`;\n    aliasMap[serverAlias] = aggregate.alias;\n\n    if (aggregate.aggregateType === 'count') {\n      aggregations.push({\n        alias: serverAlias,\n        count: {}\n      });\n    } else if (aggregate.aggregateType === 'avg') {\n      aggregations.push({\n        alias: serverAlias,\n        avg: {\n          field: toFieldPathReference(aggregate.fieldPath!)\n        }\n      });\n    } else if (aggregate.aggregateType === 'sum') {\n      aggregations.push({\n        alias: serverAlias,\n        sum: {\n          field: toFieldPathReference(aggregate.fieldPath!)\n        }\n      });\n    }\n  });\n\n  return {\n    request: {\n      structuredAggregationQuery: {\n        aggregations,\n        structuredQuery: queryTarget.structuredQuery\n      },\n      parent: queryTarget.parent\n    },\n    aliasMap,\n    parent\n  };\n}\n\nexport function convertQueryTargetToQuery(target: ProtoQueryTarget): Query {\n  let path = fromQueryPath(target.parent!);\n\n  const query = target.structuredQuery!;\n  const fromCount = query.from ? query.from.length : 0;\n  let collectionGroup: string | null = null;\n  if (fromCount > 0) {\n    hardAssert(\n      fromCount === 1,\n      'StructuredQuery.from with more than one collection is not supported.'\n    );\n    const from = query.from![0];\n    if (from.allDescendants) {\n      collectionGroup = from.collectionId!;\n    } else {\n      path = path.child(from.collectionId!);\n    }\n  }\n\n  let filterBy: Filter[] = [];\n  if (query.where) {\n    filterBy = fromFilters(query.where);\n  }\n\n  let orderBy: OrderBy[] = [];\n  if (query.orderBy) {\n    orderBy = fromOrder(query.orderBy);\n  }\n\n  let limit: number | null = null;\n  if (query.limit) {\n    limit = fromInt32Proto(query.limit);\n  }\n\n  let startAt: Bound | null = null;\n  if (query.startAt) {\n    startAt = fromStartAtCursor(query.startAt);\n  }\n\n  let endAt: Bound | null = null;\n  if (query.endAt) {\n    endAt = fromEndAtCursor(query.endAt);\n  }\n\n  return newQuery(\n    path,\n    collectionGroup,\n    orderBy,\n    filterBy,\n    limit,\n    LimitType.First,\n    startAt,\n    endAt\n  );\n}\n\nexport function fromQueryTarget(target: ProtoQueryTarget): Target {\n  return queryToTarget(convertQueryTargetToQuery(target));\n}\n\nexport function toListenRequestLabels(\n  serializer: JsonProtoSerializer,\n  targetData: TargetData\n): ProtoApiClientObjectMap<string> | null {\n  const value = toLabel(targetData.purpose);\n  if (value == null) {\n    return null;\n  } else {\n    return {\n      'goog-listen-tags': value\n    };\n  }\n}\n\nexport function toLabel(purpose: TargetPurpose): string | null {\n  switch (purpose) {\n    case TargetPurpose.Listen:\n      return null;\n    case TargetPurpose.ExistenceFilterMismatch:\n      return 'existence-filter-mismatch';\n    case TargetPurpose.ExistenceFilterMismatchBloom:\n      return 'existence-filter-mismatch-bloom';\n    case TargetPurpose.LimboResolution:\n      return 'limbo-document';\n    default:\n      return fail('Unrecognized query purpose: ' + purpose);\n  }\n}\n\nexport function toTarget(\n  serializer: JsonProtoSerializer,\n  targetData: TargetData\n): ProtoTarget {\n  let result: ProtoTarget;\n  const target = targetData.target;\n\n  if (targetIsDocumentTarget(target)) {\n    result = { documents: toDocumentsTarget(serializer, target) };\n  } else {\n    result = { query: toQueryTarget(serializer, target).queryTarget };\n  }\n\n  result.targetId = targetData.targetId;\n\n  if (targetData.resumeToken.approximateByteSize() > 0) {\n    result.resumeToken = toBytes(serializer, targetData.resumeToken);\n    const expectedCount = toInt32Proto(serializer, targetData.expectedCount);\n    if (expectedCount !== null) {\n      result.expectedCount = expectedCount;\n    }\n  } else if (targetData.snapshotVersion.compareTo(SnapshotVersion.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    result.readTime = toTimestamp(\n      serializer,\n      targetData.snapshotVersion.toTimestamp()\n    );\n    const expectedCount = toInt32Proto(serializer, targetData.expectedCount);\n    if (expectedCount !== null) {\n      result.expectedCount = expectedCount;\n    }\n  }\n\n  return result;\n}\n\nfunction toFilters(filters: Filter[]): ProtoFilter | undefined {\n  if (filters.length === 0) {\n    return;\n  }\n\n  return toFilter(CompositeFilter.create(filters, CompositeOperator.AND));\n}\n\nfunction fromFilters(filter: ProtoFilter): Filter[] {\n  const result = fromFilter(filter);\n\n  if (\n    result instanceof CompositeFilter &&\n    compositeFilterIsFlatConjunction(result)\n  ) {\n    return result.getFilters();\n  }\n\n  return [result];\n}\n\nfunction fromFilter(filter: ProtoFilter): Filter {\n  if (filter.unaryFilter !== undefined) {\n    return fromUnaryFilter(filter);\n  } else if (filter.fieldFilter !== undefined) {\n    return fromFieldFilter(filter);\n  } else if (filter.compositeFilter !== undefined) {\n    return fromCompositeFilter(filter);\n  } else {\n    return fail('Unknown filter: ' + JSON.stringify(filter));\n  }\n}\n\nfunction toOrder(orderBys: OrderBy[]): ProtoOrder[] | undefined {\n  if (orderBys.length === 0) {\n    return;\n  }\n  return orderBys.map(order => toPropertyOrder(order));\n}\n\nfunction fromOrder(orderBys: ProtoOrder[]): OrderBy[] {\n  return orderBys.map(order => fromPropertyOrder(order));\n}\n\nfunction toStartAtCursor(cursor: Bound): ProtoCursor {\n  return {\n    before: cursor.inclusive,\n    values: cursor.position\n  };\n}\n\nfunction toEndAtCursor(cursor: Bound): ProtoCursor {\n  return {\n    before: !cursor.inclusive,\n    values: cursor.position\n  };\n}\n\nfunction fromStartAtCursor(cursor: ProtoCursor): Bound {\n  const inclusive = !!cursor.before;\n  const position = cursor.values || [];\n  return new Bound(position, inclusive);\n}\n\nfunction fromEndAtCursor(cursor: ProtoCursor): Bound {\n  const inclusive = !cursor.before;\n  const position = cursor.values || [];\n  return new Bound(position, inclusive);\n}\n\n// visible for testing\nexport function toDirection(dir: Direction): ProtoOrderDirection {\n  return DIRECTIONS[dir];\n}\n\n// visible for testing\nexport function fromDirection(\n  dir: ProtoOrderDirection | undefined\n): Direction | undefined {\n  switch (dir) {\n    case 'ASCENDING':\n      return Direction.ASCENDING;\n    case 'DESCENDING':\n      return Direction.DESCENDING;\n    default:\n      return undefined;\n  }\n}\n\n// visible for testing\nexport function toOperatorName(op: Operator): ProtoFieldFilterOp {\n  return OPERATORS[op];\n}\n\nexport function toCompositeOperatorName(\n  op: CompositeOperator\n): ProtoCompositeFilterOp {\n  return COMPOSITE_OPERATORS[op];\n}\n\nexport function fromOperatorName(op: ProtoFieldFilterOp): Operator {\n  switch (op) {\n    case 'EQUAL':\n      return Operator.EQUAL;\n    case 'NOT_EQUAL':\n      return Operator.NOT_EQUAL;\n    case 'GREATER_THAN':\n      return Operator.GREATER_THAN;\n    case 'GREATER_THAN_OR_EQUAL':\n      return Operator.GREATER_THAN_OR_EQUAL;\n    case 'LESS_THAN':\n      return Operator.LESS_THAN;\n    case 'LESS_THAN_OR_EQUAL':\n      return Operator.LESS_THAN_OR_EQUAL;\n    case 'ARRAY_CONTAINS':\n      return Operator.ARRAY_CONTAINS;\n    case 'IN':\n      return Operator.IN;\n    case 'NOT_IN':\n      return Operator.NOT_IN;\n    case 'ARRAY_CONTAINS_ANY':\n      return Operator.ARRAY_CONTAINS_ANY;\n    case 'OPERATOR_UNSPECIFIED':\n      return fail('Unspecified operator');\n    default:\n      return fail('Unknown operator');\n  }\n}\n\nexport function fromCompositeOperatorName(\n  op: ProtoCompositeFilterOp\n): CompositeOperator {\n  switch (op) {\n    case 'AND':\n      return CompositeOperator.AND;\n    case 'OR':\n      return CompositeOperator.OR;\n    default:\n      return fail('Unknown operator');\n  }\n}\n\nexport function toFieldPathReference(path: FieldPath): ProtoFieldReference {\n  return { fieldPath: path.canonicalString() };\n}\n\nexport function fromFieldPathReference(\n  fieldReference: ProtoFieldReference\n): FieldPath {\n  return FieldPath.fromServerFormat(fieldReference.fieldPath!);\n}\n\n// visible for testing\nexport function toPropertyOrder(orderBy: OrderBy): ProtoOrder {\n  return {\n    field: toFieldPathReference(orderBy.field),\n    direction: toDirection(orderBy.dir)\n  };\n}\n\nexport function fromPropertyOrder(orderBy: ProtoOrder): OrderBy {\n  return new OrderBy(\n    fromFieldPathReference(orderBy.field!),\n    fromDirection(orderBy.direction)\n  );\n}\n\n// visible for testing\nexport function toFilter(filter: Filter): ProtoFilter {\n  if (filter instanceof FieldFilter) {\n    return toUnaryOrFieldFilter(filter);\n  } else if (filter instanceof CompositeFilter) {\n    return toCompositeFilter(filter);\n  } else {\n    return fail('Unrecognized filter type ' + JSON.stringify(filter));\n  }\n}\n\nexport function toCompositeFilter(filter: CompositeFilter): ProtoFilter {\n  const protos = filter.getFilters().map(filter => toFilter(filter));\n\n  if (protos.length === 1) {\n    return protos[0];\n  }\n\n  return {\n    compositeFilter: {\n      op: toCompositeOperatorName(filter.op),\n      filters: protos\n    }\n  };\n}\n\nexport function toUnaryOrFieldFilter(filter: FieldFilter): ProtoFilter {\n  if (filter.op === Operator.EQUAL) {\n    if (isNanValue(filter.value)) {\n      return {\n        unaryFilter: {\n          field: toFieldPathReference(filter.field),\n          op: 'IS_NAN'\n        }\n      };\n    } else if (isNullValue(filter.value)) {\n      return {\n        unaryFilter: {\n          field: toFieldPathReference(filter.field),\n          op: 'IS_NULL'\n        }\n      };\n    }\n  } else if (filter.op === Operator.NOT_EQUAL) {\n    if (isNanValue(filter.value)) {\n      return {\n        unaryFilter: {\n          field: toFieldPathReference(filter.field),\n          op: 'IS_NOT_NAN'\n        }\n      };\n    } else if (isNullValue(filter.value)) {\n      return {\n        unaryFilter: {\n          field: toFieldPathReference(filter.field),\n          op: 'IS_NOT_NULL'\n        }\n      };\n    }\n  }\n  return {\n    fieldFilter: {\n      field: toFieldPathReference(filter.field),\n      op: toOperatorName(filter.op),\n      value: filter.value\n    }\n  };\n}\n\nexport function fromUnaryFilter(filter: ProtoFilter): Filter {\n  switch (filter.unaryFilter!.op!) {\n    case 'IS_NAN':\n      const nanField = fromFieldPathReference(filter.unaryFilter!.field!);\n      return FieldFilter.create(nanField, Operator.EQUAL, {\n        doubleValue: NaN\n      });\n    case 'IS_NULL':\n      const nullField = fromFieldPathReference(filter.unaryFilter!.field!);\n      return FieldFilter.create(nullField, Operator.EQUAL, {\n        nullValue: 'NULL_VALUE'\n      });\n    case 'IS_NOT_NAN':\n      const notNanField = fromFieldPathReference(filter.unaryFilter!.field!);\n      return FieldFilter.create(notNanField, Operator.NOT_EQUAL, {\n        doubleValue: NaN\n      });\n    case 'IS_NOT_NULL':\n      const notNullField = fromFieldPathReference(filter.unaryFilter!.field!);\n      return FieldFilter.create(notNullField, Operator.NOT_EQUAL, {\n        nullValue: 'NULL_VALUE'\n      });\n    case 'OPERATOR_UNSPECIFIED':\n      return fail('Unspecified filter');\n    default:\n      return fail('Unknown filter');\n  }\n}\n\nexport function fromFieldFilter(filter: ProtoFilter): FieldFilter {\n  return FieldFilter.create(\n    fromFieldPathReference(filter.fieldFilter!.field!),\n    fromOperatorName(filter.fieldFilter!.op!),\n    filter.fieldFilter!.value!\n  );\n}\n\nexport function fromCompositeFilter(filter: ProtoFilter): CompositeFilter {\n  return CompositeFilter.create(\n    filter.compositeFilter!.filters!.map(filter => fromFilter(filter)),\n    fromCompositeOperatorName(filter.compositeFilter!.op!)\n  );\n}\n\nexport function toDocumentMask(fieldMask: FieldMask): ProtoDocumentMask {\n  const canonicalFields: string[] = [];\n  fieldMask.fields.forEach(field =>\n    canonicalFields.push(field.canonicalString())\n  );\n  return {\n    fieldPaths: canonicalFields\n  };\n}\n\nexport function fromDocumentMask(proto: ProtoDocumentMask): FieldMask {\n  const paths = proto.fieldPaths || [];\n  return new FieldMask(paths.map(path => FieldPath.fromServerFormat(path)));\n}\n\nexport function isValidResourceName(path: ResourcePath): boolean {\n  // Resource names have at least 4 components (project ID, database ID)\n  return (\n    path.length >= 4 &&\n    path.get(0) === 'projects' &&\n    path.get(2) === 'databases'\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { Target } from '../core/target';\nimport { ListenSequenceNumber, TargetId } from '../core/types';\nimport { ByteString } from '../util/byte_string';\n\n/** An enumeration of the different purposes we have for targets. */\nexport const enum TargetPurpose {\n  /** A regular, normal query target. */\n  Listen = 'TargetPurposeListen',\n\n  /**\n   * The query target was used to refill a query after an existence filter\n   * mismatch.\n   */\n  ExistenceFilterMismatch = 'TargetPurposeExistenceFilterMismatch',\n\n  /**\n   * The query target was used if the query is the result of a false positive in\n   * the bloom filter.\n   */\n  ExistenceFilterMismatchBloom = 'TargetPurposeExistenceFilterMismatchBloom',\n\n  /** The query target was used to resolve a limbo document. */\n  LimboResolution = 'TargetPurposeLimboResolution'\n}\n\n/**\n * An immutable set of metadata that the local store tracks for each target.\n */\nexport class TargetData {\n  constructor(\n    /** The target being listened to. */\n    readonly target: Target,\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    readonly targetId: TargetId,\n    /** The purpose of the target. */\n    readonly purpose: TargetPurpose,\n    /**\n     * The sequence number of the last transaction during which this target data\n     * was modified.\n     */\n    readonly sequenceNumber: ListenSequenceNumber,\n    /** The latest snapshot version seen for this target. */\n    readonly snapshotVersion: SnapshotVersion = SnapshotVersion.min(),\n    /**\n     * The maximum snapshot version at which the associated view\n     * contained no limbo documents.\n     */\n    readonly lastLimboFreeSnapshotVersion: SnapshotVersion = SnapshotVersion.min(),\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     */\n    readonly resumeToken: ByteString = ByteString.EMPTY_BYTE_STRING,\n    /**\n     * The number of documents that last matched the query at the resume token or\n     * read time. Documents are counted only when making a listen request with\n     * resume token or read time, otherwise, keep it null.\n     */\n    readonly expectedCount: number | null = null\n  ) {}\n\n  /** Creates a new target data instance with an updated sequence number. */\n  withSequenceNumber(sequenceNumber: number): TargetData {\n    return new TargetData(\n      this.target,\n      this.targetId,\n      this.purpose,\n      sequenceNumber,\n      this.snapshotVersion,\n      this.lastLimboFreeSnapshotVersion,\n      this.resumeToken,\n      this.expectedCount\n    );\n  }\n\n  /**\n   * Creates a new target data instance with an updated resume token and\n   * snapshot version.\n   */\n  withResumeToken(\n    resumeToken: ByteString,\n    snapshotVersion: SnapshotVersion\n  ): TargetData {\n    return new TargetData(\n      this.target,\n      this.targetId,\n      this.purpose,\n      this.sequenceNumber,\n      snapshotVersion,\n      this.lastLimboFreeSnapshotVersion,\n      resumeToken,\n      /* expectedCount= */ null\n    );\n  }\n\n  /**\n   * Creates a new target data instance with an updated expected count.\n   */\n  withExpectedCount(expectedCount: number): TargetData {\n    return new TargetData(\n      this.target,\n      this.targetId,\n      this.purpose,\n      this.sequenceNumber,\n      this.snapshotVersion,\n      this.lastLimboFreeSnapshotVersion,\n      this.resumeToken,\n      expectedCount\n    );\n  }\n\n  /**\n   * Creates a new target data instance with an updated last limbo free\n   * snapshot version number.\n   */\n  withLastLimboFreeSnapshotVersion(\n    lastLimboFreeSnapshotVersion: SnapshotVersion\n  ): TargetData {\n    return new TargetData(\n      this.target,\n      this.targetId,\n      this.purpose,\n      this.sequenceNumber,\n      this.snapshotVersion,\n      lastLimboFreeSnapshotVersion,\n      this.resumeToken,\n      this.expectedCount\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 { Timestamp } from '../api/timestamp';\nimport { BundleMetadata, NamedQuery } from '../core/bundle';\nimport { LimitType, Query, queryWithLimit } from '../core/query';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { canonifyTarget, Target, targetIsDocumentTarget } from '../core/target';\nimport { MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport {\n  FieldIndex,\n  IndexOffset,\n  IndexSegment,\n  IndexState\n} from '../model/field_index';\nimport { MutationBatch } from '../model/mutation_batch';\nimport { Overlay } from '../model/overlay';\nimport { FieldPath } from '../model/path';\nimport {\n  BundledQuery as ProtoBundledQuery,\n  BundleMetadata as ProtoBundleMetadata,\n  NamedQuery as ProtoNamedQuery\n} from '../protos/firestore_bundle_proto';\nimport { DocumentsTarget as PublicDocumentsTarget } from '../protos/firestore_proto_api';\nimport {\n  convertQueryTargetToQuery,\n  fromDocument,\n  fromDocumentsTarget,\n  fromMutation,\n  fromQueryTarget,\n  fromVersion,\n  JsonProtoSerializer,\n  toDocument,\n  toDocumentsTarget,\n  toMutation,\n  toQueryTarget\n} from '../remote/serializer';\nimport { debugAssert, fail } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\n\nimport {\n  decodeResourcePath,\n  encodeResourcePath\n} from './encoded_resource_path';\nimport {\n  DbBundle,\n  DbDocumentOverlay,\n  DbIndexConfiguration,\n  DbIndexState,\n  DbMutationBatch,\n  DbNamedQuery,\n  DbQuery,\n  DbRemoteDocument,\n  DbTarget,\n  DbTimestamp\n} from './indexeddb_schema';\nimport { DbDocumentOverlayKey, DbTimestampKey } from './indexeddb_sentinels';\nimport { TargetData, TargetPurpose } from './target_data';\n\n/** Serializer for values stored in the LocalStore. */\nexport class LocalSerializer {\n  constructor(readonly remoteSerializer: JsonProtoSerializer) {}\n}\n\n/** Decodes a remote document from storage locally to a Document. */\nexport function fromDbRemoteDocument(\n  localSerializer: LocalSerializer,\n  remoteDoc: DbRemoteDocument\n): MutableDocument {\n  let doc: MutableDocument;\n  if (remoteDoc.document) {\n    doc = fromDocument(\n      localSerializer.remoteSerializer,\n      remoteDoc.document,\n      !!remoteDoc.hasCommittedMutations\n    );\n  } else if (remoteDoc.noDocument) {\n    const key = DocumentKey.fromSegments(remoteDoc.noDocument.path);\n    const version = fromDbTimestamp(remoteDoc.noDocument.readTime);\n    doc = MutableDocument.newNoDocument(key, version);\n    if (remoteDoc.hasCommittedMutations) {\n      doc.setHasCommittedMutations();\n    }\n  } else if (remoteDoc.unknownDocument) {\n    const key = DocumentKey.fromSegments(remoteDoc.unknownDocument.path);\n    const version = fromDbTimestamp(remoteDoc.unknownDocument.version);\n    doc = MutableDocument.newUnknownDocument(key, version);\n  } else {\n    return fail('Unexpected DbRemoteDocument');\n  }\n\n  if (remoteDoc.readTime) {\n    doc.setReadTime(fromDbTimestampKey(remoteDoc.readTime));\n  }\n\n  return doc;\n}\n\n/** Encodes a document for storage locally. */\nexport function toDbRemoteDocument(\n  localSerializer: LocalSerializer,\n  document: MutableDocument\n): DbRemoteDocument {\n  const key = document.key;\n  const remoteDoc: DbRemoteDocument = {\n    prefixPath: key.getCollectionPath().popLast().toArray(),\n    collectionGroup: key.collectionGroup,\n    documentId: key.path.lastSegment(),\n    readTime: toDbTimestampKey(document.readTime),\n    hasCommittedMutations: document.hasCommittedMutations\n  };\n\n  if (document.isFoundDocument()) {\n    remoteDoc.document = toDocument(localSerializer.remoteSerializer, document);\n  } else if (document.isNoDocument()) {\n    remoteDoc.noDocument = {\n      path: key.path.toArray(),\n      readTime: toDbTimestamp(document.version)\n    };\n  } else if (document.isUnknownDocument()) {\n    remoteDoc.unknownDocument = {\n      path: key.path.toArray(),\n      version: toDbTimestamp(document.version)\n    };\n  } else {\n    return fail('Unexpected Document ' + document);\n  }\n  return remoteDoc;\n}\n\nexport function toDbTimestampKey(\n  snapshotVersion: SnapshotVersion\n): DbTimestampKey {\n  const timestamp = snapshotVersion.toTimestamp();\n  return [timestamp.seconds, timestamp.nanoseconds];\n}\n\nexport function fromDbTimestampKey(\n  dbTimestampKey: DbTimestampKey\n): SnapshotVersion {\n  const timestamp = new Timestamp(dbTimestampKey[0], dbTimestampKey[1]);\n  return SnapshotVersion.fromTimestamp(timestamp);\n}\n\nexport function toDbTimestamp(snapshotVersion: SnapshotVersion): DbTimestamp {\n  const timestamp = snapshotVersion.toTimestamp();\n  return { seconds: timestamp.seconds, nanoseconds: timestamp.nanoseconds };\n}\n\nfunction fromDbTimestamp(dbTimestamp: DbTimestamp): SnapshotVersion {\n  const timestamp = new Timestamp(dbTimestamp.seconds, dbTimestamp.nanoseconds);\n  return SnapshotVersion.fromTimestamp(timestamp);\n}\n\n/** Encodes a batch of mutations into a DbMutationBatch for local storage. */\nexport function toDbMutationBatch(\n  localSerializer: LocalSerializer,\n  userId: string,\n  batch: MutationBatch\n): DbMutationBatch {\n  const serializedBaseMutations = batch.baseMutations.map(m =>\n    toMutation(localSerializer.remoteSerializer, m)\n  );\n  const serializedMutations = batch.mutations.map(m =>\n    toMutation(localSerializer.remoteSerializer, m)\n  );\n  return {\n    userId,\n    batchId: batch.batchId,\n    localWriteTimeMs: batch.localWriteTime.toMillis(),\n    baseMutations: serializedBaseMutations,\n    mutations: serializedMutations\n  };\n}\n\n/** Decodes a DbMutationBatch into a MutationBatch */\nexport function fromDbMutationBatch(\n  localSerializer: LocalSerializer,\n  dbBatch: DbMutationBatch\n): MutationBatch {\n  const baseMutations = (dbBatch.baseMutations || []).map(m =>\n    fromMutation(localSerializer.remoteSerializer, m)\n  );\n\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 (let i = 0; i < dbBatch.mutations.length - 1; ++i) {\n    const currentMutation = dbBatch.mutations[i];\n    const hasTransform =\n      i + 1 < dbBatch.mutations.length &&\n      dbBatch.mutations[i + 1].transform !== undefined;\n    if (hasTransform) {\n      debugAssert(\n        dbBatch.mutations[i].transform === undefined &&\n          dbBatch.mutations[i].update !== undefined,\n        'TransformMutation should be preceded by a patch or set mutation'\n      );\n      const transformMutation = dbBatch.mutations[i + 1];\n      currentMutation.updateTransforms =\n        transformMutation.transform!.fieldTransforms;\n      dbBatch.mutations.splice(i + 1, 1);\n      ++i;\n    }\n  }\n\n  const mutations = dbBatch.mutations.map(m =>\n    fromMutation(localSerializer.remoteSerializer, m)\n  );\n  const timestamp = Timestamp.fromMillis(dbBatch.localWriteTimeMs);\n  return new MutationBatch(\n    dbBatch.batchId,\n    timestamp,\n    baseMutations,\n    mutations\n  );\n}\n\n/** Decodes a DbTarget into TargetData */\nexport function fromDbTarget(dbTarget: DbTarget): TargetData {\n  const version = fromDbTimestamp(dbTarget.readTime);\n  const lastLimboFreeSnapshotVersion =\n    dbTarget.lastLimboFreeSnapshotVersion !== undefined\n      ? fromDbTimestamp(dbTarget.lastLimboFreeSnapshotVersion)\n      : SnapshotVersion.min();\n\n  let target: Target;\n  if (isDocumentQuery(dbTarget.query)) {\n    target = fromDocumentsTarget(dbTarget.query);\n  } else {\n    target = fromQueryTarget(dbTarget.query);\n  }\n  return new TargetData(\n    target,\n    dbTarget.targetId,\n    TargetPurpose.Listen,\n    dbTarget.lastListenSequenceNumber,\n    version,\n    lastLimboFreeSnapshotVersion,\n    ByteString.fromBase64String(dbTarget.resumeToken)\n  );\n}\n\n/** Encodes TargetData into a DbTarget for storage locally. */\nexport function toDbTarget(\n  localSerializer: LocalSerializer,\n  targetData: TargetData\n): DbTarget {\n  debugAssert(\n    TargetPurpose.Listen === targetData.purpose,\n    'Only queries with purpose ' +\n      TargetPurpose.Listen +\n      ' may be stored, got ' +\n      targetData.purpose\n  );\n  const dbTimestamp = toDbTimestamp(targetData.snapshotVersion);\n  const dbLastLimboFreeTimestamp = toDbTimestamp(\n    targetData.lastLimboFreeSnapshotVersion\n  );\n  let queryProto: DbQuery;\n  if (targetIsDocumentTarget(targetData.target)) {\n    queryProto = toDocumentsTarget(\n      localSerializer.remoteSerializer,\n      targetData.target\n    );\n  } else {\n    queryProto = toQueryTarget(\n      localSerializer.remoteSerializer,\n      targetData.target\n    ).queryTarget;\n  }\n\n  // We can't store the resumeToken as a ByteString in IndexedDb, so we\n  // convert it to a base64 string for storage.\n  const resumeToken = targetData.resumeToken.toBase64();\n\n  // lastListenSequenceNumber is always 0 until we do real GC.\n  return {\n    targetId: targetData.targetId,\n    canonicalId: canonifyTarget(targetData.target),\n    readTime: dbTimestamp,\n    resumeToken,\n    lastListenSequenceNumber: targetData.sequenceNumber,\n    lastLimboFreeSnapshotVersion: dbLastLimboFreeTimestamp,\n    query: queryProto\n  };\n}\n\n/**\n * A helper function for figuring out what kind of query has been stored.\n */\nfunction isDocumentQuery(dbQuery: DbQuery): dbQuery is PublicDocumentsTarget {\n  return (dbQuery as PublicDocumentsTarget).documents !== undefined;\n}\n\n/** Encodes a DbBundle to a BundleMetadata object. */\nexport function fromDbBundle(dbBundle: DbBundle): BundleMetadata {\n  return {\n    id: dbBundle.bundleId,\n    createTime: fromDbTimestamp(dbBundle.createTime),\n    version: dbBundle.version\n  };\n}\n\n/** Encodes a BundleMetadata to a DbBundle. */\nexport function toDbBundle(metadata: ProtoBundleMetadata): DbBundle {\n  return {\n    bundleId: metadata.id!,\n    createTime: toDbTimestamp(fromVersion(metadata.createTime!)),\n    version: metadata.version!\n  };\n}\n\n/** Encodes a DbNamedQuery to a NamedQuery. */\nexport function fromDbNamedQuery(dbNamedQuery: DbNamedQuery): NamedQuery {\n  return {\n    name: dbNamedQuery.name,\n    query: fromBundledQuery(dbNamedQuery.bundledQuery),\n    readTime: fromDbTimestamp(dbNamedQuery.readTime)\n  };\n}\n\n/** Encodes a NamedQuery from a bundle proto to a DbNamedQuery. */\nexport function toDbNamedQuery(query: ProtoNamedQuery): DbNamedQuery {\n  return {\n    name: query.name!,\n    readTime: toDbTimestamp(fromVersion(query.readTime!)),\n    bundledQuery: query.bundledQuery!\n  };\n}\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 */\nexport function fromBundledQuery(bundledQuery: ProtoBundledQuery): Query {\n  const query = convertQueryTargetToQuery({\n    parent: bundledQuery.parent!,\n    structuredQuery: bundledQuery.structuredQuery!\n  });\n  if (bundledQuery.limitType === 'LAST') {\n    debugAssert(\n      !!query.limit,\n      'Bundled query has limitType LAST, but limit is null'\n    );\n    return queryWithLimit(query, query.limit, LimitType.Last);\n  }\n  return query;\n}\n\n/** Encodes a NamedQuery proto object to a NamedQuery model object. */\nexport function fromProtoNamedQuery(namedQuery: ProtoNamedQuery): NamedQuery {\n  return {\n    name: namedQuery.name!,\n    query: fromBundledQuery(namedQuery.bundledQuery!),\n    readTime: fromVersion(namedQuery.readTime!)\n  };\n}\n\n/** Decodes a BundleMetadata proto into a BundleMetadata object. */\nexport function fromBundleMetadata(\n  metadata: ProtoBundleMetadata\n): BundleMetadata {\n  return {\n    id: metadata.id!,\n    version: metadata.version!,\n    createTime: fromVersion(metadata.createTime!)\n  };\n}\n\n/** Encodes a DbDocumentOverlay object to an Overlay model object. */\nexport function fromDbDocumentOverlay(\n  localSerializer: LocalSerializer,\n  dbDocumentOverlay: DbDocumentOverlay\n): Overlay {\n  return new Overlay(\n    dbDocumentOverlay.largestBatchId,\n    fromMutation(\n      localSerializer.remoteSerializer,\n      dbDocumentOverlay.overlayMutation\n    )\n  );\n}\n\n/** Decodes an Overlay model object into a DbDocumentOverlay object. */\nexport function toDbDocumentOverlay(\n  localSerializer: LocalSerializer,\n  userId: string,\n  overlay: Overlay\n): DbDocumentOverlay {\n  const [_, collectionPath, documentId] = toDbDocumentOverlayKey(\n    userId,\n    overlay.mutation.key\n  );\n  return {\n    userId,\n    collectionPath,\n    documentId,\n    collectionGroup: overlay.mutation.key.getCollectionGroup(),\n    largestBatchId: overlay.largestBatchId,\n    overlayMutation: toMutation(\n      localSerializer.remoteSerializer,\n      overlay.mutation\n    )\n  };\n}\n\n/**\n * Returns the DbDocumentOverlayKey corresponding to the given user and\n * document key.\n */\nexport function toDbDocumentOverlayKey(\n  userId: string,\n  docKey: DocumentKey\n): DbDocumentOverlayKey {\n  const docId = docKey.path.lastSegment();\n  const collectionPath = encodeResourcePath(docKey.path.popLast());\n  return [userId, collectionPath, docId];\n}\n\nexport function toDbIndexConfiguration(\n  index: FieldIndex\n): DbIndexConfiguration {\n  return {\n    indexId: index.indexId,\n    collectionGroup: index.collectionGroup,\n    fields: index.fields.map(s => [s.fieldPath.canonicalString(), s.kind])\n  };\n}\n\nexport function fromDbIndexConfiguration(\n  index: DbIndexConfiguration,\n  state: DbIndexState | null\n): FieldIndex {\n  const decodedState = state\n    ? new IndexState(\n        state.sequenceNumber,\n        new IndexOffset(\n          fromDbTimestamp(state.readTime),\n          new DocumentKey(decodeResourcePath(state.documentKey)),\n          state.largestBatchId\n        )\n      )\n    : IndexState.empty();\n  const decodedSegments = index.fields.map(\n    ([fieldPath, kind]) =>\n      new IndexSegment(FieldPath.fromServerFormat(fieldPath), kind)\n  );\n  return new FieldIndex(\n    index.indexId!,\n    index.collectionGroup,\n    decodedSegments,\n    decodedState\n  );\n}\n\nexport function toDbIndexState(\n  indexId: number,\n  uid: string,\n  sequenceNumber: number,\n  offset: IndexOffset\n): DbIndexState {\n  return {\n    indexId,\n    uid,\n    sequenceNumber,\n    readTime: toDbTimestamp(offset.readTime),\n    documentKey: encodeResourcePath(offset.documentKey.path),\n    largestBatchId: offset.largestBatchId\n  };\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { DocumentKey } from '../model/document_key';\nimport {\n  normalizeByteString,\n  normalizeNumber,\n  normalizeTimestamp\n} from '../model/normalize';\nimport {\n  isVectorValue,\n  VECTOR_MAP_VECTORS_KEY,\n  isMaxValue\n} from '../model/values';\nimport { ArrayValue, MapValue, Value } from '../protos/firestore_proto_api';\nimport { fail } from '../util/assert';\nimport { isNegativeZero } from '../util/types';\n\nimport { DirectionalIndexByteEncoder } from './directional_index_byte_encoder';\n\n// Note: This code is copied from the backend. Code that is not used by\n// Firestore was removed.\n\nconst INDEX_TYPE_NULL = 5;\nconst INDEX_TYPE_BOOLEAN = 10;\nconst INDEX_TYPE_NAN = 13;\nconst INDEX_TYPE_NUMBER = 15;\nconst INDEX_TYPE_TIMESTAMP = 20;\nconst INDEX_TYPE_STRING = 25;\nconst INDEX_TYPE_BLOB = 30;\nconst INDEX_TYPE_REFERENCE = 37;\nconst INDEX_TYPE_GEOPOINT = 45;\nconst INDEX_TYPE_ARRAY = 50;\nconst INDEX_TYPE_VECTOR = 53;\nconst INDEX_TYPE_MAP = 55;\nconst INDEX_TYPE_REFERENCE_SEGMENT = 60;\n\n// A terminator that indicates that a truncatable value was not truncated.\n// This must be smaller than all other type labels.\nconst NOT_TRUNCATED = 2;\n\n/** Firestore index value writer.  */\nexport class FirestoreIndexValueWriter {\n  static INSTANCE = new FirestoreIndexValueWriter();\n\n  private constructor() {}\n\n  // The write methods below short-circuit writing terminators for values\n  // containing a (terminating) truncated value.\n  //\n  // As an example, consider the resulting encoding for:\n  //\n  // [\"bar\", [2, \"foo\"]] -> (STRING, \"bar\", TERM, ARRAY, NUMBER, 2, STRING, \"foo\", TERM, TERM, TERM)\n  // [\"bar\", [2, truncated(\"foo\")]] -> (STRING, \"bar\", TERM, ARRAY, NUMBER, 2, STRING, \"foo\", TRUNC)\n  // [\"bar\", truncated([\"foo\"])] -> (STRING, \"bar\", TERM, ARRAY. STRING, \"foo\", TERM, TRUNC)\n\n  /** Writes an index value.  */\n  writeIndexValue(value: Value, encoder: DirectionalIndexByteEncoder): void {\n    this.writeIndexValueAux(value, encoder);\n    // Write separator to split index values\n    // (see go/firestore-storage-format#encodings).\n    encoder.writeInfinity();\n  }\n\n  private writeIndexValueAux(\n    indexValue: Value,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    if ('nullValue' in indexValue) {\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_NULL);\n    } else if ('booleanValue' in indexValue) {\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_BOOLEAN);\n      encoder.writeNumber(indexValue.booleanValue ? 1 : 0);\n    } else if ('integerValue' in indexValue) {\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_NUMBER);\n      encoder.writeNumber(normalizeNumber(indexValue.integerValue));\n    } else if ('doubleValue' in indexValue) {\n      const n = normalizeNumber(indexValue.doubleValue);\n      if (isNaN(n)) {\n        this.writeValueTypeLabel(encoder, INDEX_TYPE_NAN);\n      } else {\n        this.writeValueTypeLabel(encoder, INDEX_TYPE_NUMBER);\n        if (isNegativeZero(n)) {\n          // -0.0, 0 and 0.0 are all considered the same\n          encoder.writeNumber(0.0);\n        } else {\n          encoder.writeNumber(n);\n        }\n      }\n    } else if ('timestampValue' in indexValue) {\n      let timestamp = indexValue.timestampValue!;\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_TIMESTAMP);\n      if (typeof timestamp === 'string') {\n        timestamp = normalizeTimestamp(timestamp);\n      }\n      encoder.writeString(`${timestamp.seconds || ''}`);\n      encoder.writeNumber(timestamp.nanos || 0);\n    } else if ('stringValue' in indexValue) {\n      this.writeIndexString(indexValue.stringValue!, encoder);\n      this.writeTruncationMarker(encoder);\n    } else if ('bytesValue' in indexValue) {\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_BLOB);\n      encoder.writeBytes(normalizeByteString(indexValue.bytesValue!));\n      this.writeTruncationMarker(encoder);\n    } else if ('referenceValue' in indexValue) {\n      this.writeIndexEntityRef(indexValue.referenceValue!, encoder);\n    } else if ('geoPointValue' in indexValue) {\n      const geoPoint = indexValue.geoPointValue!;\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_GEOPOINT);\n      encoder.writeNumber(geoPoint.latitude || 0);\n      encoder.writeNumber(geoPoint.longitude || 0);\n    } else if ('mapValue' in indexValue) {\n      if (isMaxValue(indexValue)) {\n        this.writeValueTypeLabel(encoder, Number.MAX_SAFE_INTEGER);\n      } else if (isVectorValue(indexValue)) {\n        this.writeIndexVector(indexValue.mapValue!, encoder);\n      } else {\n        this.writeIndexMap(indexValue.mapValue!, encoder);\n        this.writeTruncationMarker(encoder);\n      }\n    } else if ('arrayValue' in indexValue) {\n      this.writeIndexArray(indexValue.arrayValue!, encoder);\n      this.writeTruncationMarker(encoder);\n    } else {\n      fail('unknown index value type ' + indexValue);\n    }\n  }\n\n  private writeIndexString(\n    stringIndexValue: string,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_STRING);\n    this.writeUnlabeledIndexString(stringIndexValue, encoder);\n  }\n\n  private writeUnlabeledIndexString(\n    stringIndexValue: string,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    encoder.writeString(stringIndexValue);\n  }\n\n  private writeIndexMap(\n    mapIndexValue: MapValue,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    const map = mapIndexValue.fields || {};\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_MAP);\n    for (const key of Object.keys(map)) {\n      this.writeIndexString(key, encoder);\n      this.writeIndexValueAux(map[key], encoder);\n    }\n  }\n\n  private writeIndexVector(\n    mapIndexValue: MapValue,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    const map = mapIndexValue.fields || {};\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_VECTOR);\n\n    // Vectors sort first by length\n    const key = VECTOR_MAP_VECTORS_KEY;\n    const length = map[key].arrayValue?.values?.length || 0;\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_NUMBER);\n    encoder.writeNumber(normalizeNumber(length));\n\n    // Vectors then sort by position value\n    this.writeIndexString(key, encoder);\n    this.writeIndexValueAux(map[key], encoder);\n  }\n\n  private writeIndexArray(\n    arrayIndexValue: ArrayValue,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    const values = arrayIndexValue.values || [];\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_ARRAY);\n    for (const element of values) {\n      this.writeIndexValueAux(element, encoder);\n    }\n  }\n\n  private writeIndexEntityRef(\n    referenceValue: string,\n    encoder: DirectionalIndexByteEncoder\n  ): void {\n    this.writeValueTypeLabel(encoder, INDEX_TYPE_REFERENCE);\n    const path = DocumentKey.fromName(referenceValue).path;\n    path.forEach(segment => {\n      this.writeValueTypeLabel(encoder, INDEX_TYPE_REFERENCE_SEGMENT);\n      this.writeUnlabeledIndexString(segment, encoder);\n    });\n  }\n\n  private writeValueTypeLabel(\n    encoder: DirectionalIndexByteEncoder,\n    typeOrder: number\n  ): void {\n    encoder.writeNumber(typeOrder);\n  }\n\n  private writeTruncationMarker(encoder: DirectionalIndexByteEncoder): void {\n    // While the SDK does not implement truncation, the truncation marker is\n    // used to terminate all variable length values (which are strings, bytes,\n    // references, arrays and maps).\n    encoder.writeNumber(NOT_TRUNCATED);\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 { Target } from '../core/target';\nimport { DocumentMap } from '../model/collections';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldIndex, IndexOffset } from '../model/field_index';\nimport { ResourcePath } from '../model/path';\nimport { debugAssert } from '../util/assert';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { IndexManager, IndexType } from './index_manager';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\n\n/**\n * An in-memory implementation of IndexManager.\n */\nexport class MemoryIndexManager implements IndexManager {\n  private collectionParentIndex = new MemoryCollectionParentIndex();\n\n  addToCollectionParentIndex(\n    transaction: PersistenceTransaction,\n    collectionPath: ResourcePath\n  ): PersistencePromise<void> {\n    this.collectionParentIndex.add(collectionPath);\n    return PersistencePromise.resolve();\n  }\n\n  getCollectionParents(\n    transaction: PersistenceTransaction,\n    collectionId: string\n  ): PersistencePromise<ResourcePath[]> {\n    return PersistencePromise.resolve(\n      this.collectionParentIndex.getEntries(collectionId)\n    );\n  }\n\n  addFieldIndex(\n    transaction: PersistenceTransaction,\n    index: FieldIndex\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\n\n  deleteFieldIndex(\n    transaction: PersistenceTransaction,\n    index: FieldIndex\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\n\n  deleteAllFieldIndexes(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\n\n  createTargetIndexes(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\n\n  getDocumentsMatchingTarget(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<DocumentKey[] | null> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve<DocumentKey[] | null>(null);\n  }\n\n  getIndexType(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<IndexType> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve<IndexType>(IndexType.NONE);\n  }\n\n  getFieldIndexes(\n    transaction: PersistenceTransaction,\n    collectionGroup?: string\n  ): PersistencePromise<FieldIndex[]> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve<FieldIndex[]>([]);\n  }\n\n  getNextCollectionGroupToUpdate(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<string | null> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve<string | null>(null);\n  }\n\n  getMinOffset(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<IndexOffset> {\n    return PersistencePromise.resolve(IndexOffset.min());\n  }\n\n  getMinOffsetFromCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string\n  ): PersistencePromise<IndexOffset> {\n    return PersistencePromise.resolve(IndexOffset.min());\n  }\n\n  updateCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string,\n    offset: IndexOffset\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\n\n  updateIndexEntries(\n    transaction: PersistenceTransaction,\n    documents: DocumentMap\n  ): PersistencePromise<void> {\n    // Field indices are not supported with memory persistence.\n    return PersistencePromise.resolve();\n  }\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 */\nexport class MemoryCollectionParentIndex {\n  private index = {} as {\n    [collectionId: string]: SortedSet<ResourcePath>;\n  };\n\n  // Returns false if the entry already existed.\n  add(collectionPath: ResourcePath): boolean {\n    debugAssert(collectionPath.length % 2 === 1, 'Expected a collection path.');\n    const collectionId = collectionPath.lastSegment();\n    const parentPath = collectionPath.popLast();\n    const existingParents =\n      this.index[collectionId] ||\n      new SortedSet<ResourcePath>(ResourcePath.comparator);\n    const added = !existingParents.has(parentPath);\n    this.index[collectionId] = existingParents.add(parentPath);\n    return added;\n  }\n\n  has(collectionPath: ResourcePath): boolean {\n    const collectionId = collectionPath.lastSegment();\n    const parentPath = collectionPath.popLast();\n    const existingParents = this.index[collectionId];\n    return existingParents && existingParents.has(parentPath);\n  }\n\n  getEntries(collectionId: string): ResourcePath[] {\n    const parentPaths =\n      this.index[collectionId] ||\n      new SortedSet<ResourcePath>(ResourcePath.comparator);\n    return parentPaths.toArray();\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 { User } from '../auth/user';\nimport { Bound } from '../core/bound';\nimport { DatabaseId } from '../core/database_info';\nimport {\n  CompositeFilter,\n  CompositeOperator,\n  FieldFilter,\n  Filter,\n  Operator\n} from '../core/filter';\nimport {\n  canonifyTarget,\n  newTarget,\n  Target,\n  targetEquals,\n  targetGetArrayValues,\n  targetGetLowerBound,\n  targetGetNotInValues,\n  targetGetSegmentCount,\n  targetGetUpperBound,\n  targetHasLimit\n} from '../core/target';\nimport { FirestoreIndexValueWriter } from '../index/firestore_index_value_writer';\nimport { IndexByteEncoder } from '../index/index_byte_encoder';\nimport { IndexEntry, indexEntryComparator } from '../index/index_entry';\nimport { documentKeySet, DocumentMap } from '../model/collections';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport {\n  FieldIndex,\n  fieldIndexGetArraySegment,\n  fieldIndexGetDirectionalSegments,\n  fieldIndexGetKeyOrder,\n  fieldIndexToString,\n  IndexKind,\n  IndexOffset,\n  indexOffsetComparator,\n  IndexSegment\n} from '../model/field_index';\nimport { FieldPath, ResourcePath } from '../model/path';\nimport { TargetIndexMatcher } from '../model/target_index_matcher';\nimport { isArray, refValue } from '../model/values';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { debugAssert, fail, hardAssert } from '../util/assert';\nimport { logDebug } from '../util/log';\nimport { getDnfTerms } from '../util/logic_utils';\nimport { immediateSuccessor, primitiveComparator } from '../util/misc';\nimport { ObjectMap } from '../util/obj_map';\nimport { diffSortedSets, SortedSet } from '../util/sorted_set';\n\nimport {\n  decodeResourcePath,\n  encodeResourcePath\n} from './encoded_resource_path';\nimport { IndexManager, IndexType } from './index_manager';\nimport {\n  DbCollectionParent,\n  DbIndexConfiguration,\n  DbIndexEntry,\n  DbIndexState\n} from './indexeddb_schema';\nimport {\n  DbCollectionParentKey,\n  DbCollectionParentStore,\n  DbIndexConfigurationCollectionGroupIndex,\n  DbIndexConfigurationKey,\n  DbIndexConfigurationStore,\n  DbIndexEntryDocumentKeyIndex,\n  DbIndexEntryKey,\n  DbIndexEntryStore,\n  DbIndexStateKey,\n  DbIndexStateSequenceNumberIndex,\n  DbIndexStateStore\n} from './indexeddb_sentinels';\nimport { getStore } from './indexeddb_transaction';\nimport {\n  fromDbIndexConfiguration,\n  toDbIndexConfiguration,\n  toDbIndexState\n} from './local_serializer';\nimport { MemoryCollectionParentIndex } from './memory_index_manager';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { SimpleDbStore } from './simple_db';\n\nconst LOG_TAG = 'IndexedDbIndexManager';\n\nconst EMPTY_VALUE = new Uint8Array(0);\n\n/**\n * A persisted implementation of IndexManager.\n *\n * PORTING NOTE: Unlike iOS and Android, the Web SDK does not memoize index\n * data as it supports multi-tab access.\n */\nexport class IndexedDbIndexManager implements IndexManager {\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\n   * used to satisfy reads.\n   */\n  private collectionParentsCache = new MemoryCollectionParentIndex();\n\n  private readonly uid: string;\n\n  /**\n   * Maps from a target to its equivalent list of sub-targets. Each sub-target\n   * contains only one term from the target's disjunctive normal form (DNF).\n   */\n  private targetToDnfSubTargets = new ObjectMap<Target, Target[]>(\n    t => canonifyTarget(t),\n    (l, r) => targetEquals(l, r)\n  );\n\n  constructor(user: User, private readonly databaseId: DatabaseId) {\n    this.uid = user.uid || '';\n  }\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   */\n  addToCollectionParentIndex(\n    transaction: PersistenceTransaction,\n    collectionPath: ResourcePath\n  ): PersistencePromise<void> {\n    debugAssert(collectionPath.length % 2 === 1, 'Expected a collection path.');\n    if (!this.collectionParentsCache.has(collectionPath)) {\n      const collectionId = collectionPath.lastSegment();\n      const parentPath = collectionPath.popLast();\n\n      transaction.addOnCommittedListener(() => {\n        // Add the collection to the in memory cache only if the transaction was\n        // successfully committed.\n        this.collectionParentsCache.add(collectionPath);\n      });\n\n      const collectionParent: DbCollectionParent = {\n        collectionId,\n        parent: encodeResourcePath(parentPath)\n      };\n      return collectionParentsStore(transaction).put(collectionParent);\n    }\n    return PersistencePromise.resolve();\n  }\n\n  getCollectionParents(\n    transaction: PersistenceTransaction,\n    collectionId: string\n  ): PersistencePromise<ResourcePath[]> {\n    const parentPaths = [] as ResourcePath[];\n    const range = IDBKeyRange.bound(\n      [collectionId, ''],\n      [immediateSuccessor(collectionId), ''],\n      /*lowerOpen=*/ false,\n      /*upperOpen=*/ true\n    );\n    return collectionParentsStore(transaction)\n      .loadAll(range)\n      .next(entries => {\n        for (const entry of entries) {\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 (entry.collectionId !== collectionId) {\n            break;\n          }\n          parentPaths.push(decodeResourcePath(entry.parent));\n        }\n        return parentPaths;\n      });\n  }\n\n  addFieldIndex(\n    transaction: PersistenceTransaction,\n    index: FieldIndex\n  ): PersistencePromise<void> {\n    // TODO(indexing): Verify that the auto-incrementing index ID works in\n    // Safari & Firefox.\n    const indexes = indexConfigurationStore(transaction);\n    const dbIndex = toDbIndexConfiguration(index);\n    delete dbIndex.indexId; // `indexId` is auto-populated by IndexedDb\n    const result = indexes.add(dbIndex);\n    if (index.indexState) {\n      const states = indexStateStore(transaction);\n      return result.next(indexId => {\n        states.put(\n          toDbIndexState(\n            indexId,\n            this.uid,\n            index.indexState.sequenceNumber,\n            index.indexState.offset\n          )\n        );\n      });\n    } else {\n      return result.next();\n    }\n  }\n\n  deleteFieldIndex(\n    transaction: PersistenceTransaction,\n    index: FieldIndex\n  ): PersistencePromise<void> {\n    const indexes = indexConfigurationStore(transaction);\n    const states = indexStateStore(transaction);\n    const entries = indexEntriesStore(transaction);\n    return indexes\n      .delete(index.indexId)\n      .next(() =>\n        states.delete(\n          IDBKeyRange.bound(\n            [index.indexId],\n            [index.indexId + 1],\n            /*lowerOpen=*/ false,\n            /*upperOpen=*/ true\n          )\n        )\n      )\n      .next(() =>\n        entries.delete(\n          IDBKeyRange.bound(\n            [index.indexId],\n            [index.indexId + 1],\n            /*lowerOpen=*/ false,\n            /*upperOpen=*/ true\n          )\n        )\n      );\n  }\n\n  deleteAllFieldIndexes(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<void> {\n    const indexes = indexConfigurationStore(transaction);\n    const entries = indexEntriesStore(transaction);\n    const states = indexStateStore(transaction);\n\n    return indexes\n      .deleteAll()\n      .next(() => entries.deleteAll())\n      .next(() => states.deleteAll());\n  }\n\n  createTargetIndexes(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<void> {\n    return PersistencePromise.forEach(\n      this.getSubTargets(target),\n      (subTarget: Target) => {\n        return this.getIndexType(transaction, subTarget).next(type => {\n          if (type === IndexType.NONE || type === IndexType.PARTIAL) {\n            const targetIndexMatcher = new TargetIndexMatcher(subTarget);\n            const fieldIndex = targetIndexMatcher.buildTargetIndex();\n            if (fieldIndex != null) {\n              return this.addFieldIndex(transaction, fieldIndex);\n            }\n          }\n        });\n      }\n    );\n  }\n\n  getDocumentsMatchingTarget(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<DocumentKey[] | null> {\n    const indexEntries = indexEntriesStore(transaction);\n\n    let canServeTarget = true;\n    const indexes = new Map<Target, FieldIndex | null>();\n\n    return PersistencePromise.forEach(\n      this.getSubTargets(target),\n      (subTarget: Target) => {\n        return this.getFieldIndex(transaction, subTarget).next(index => {\n          canServeTarget &&= !!index;\n          indexes.set(subTarget, index);\n        });\n      }\n    ).next(() => {\n      if (!canServeTarget) {\n        return PersistencePromise.resolve(null as DocumentKey[] | null);\n      } else {\n        let existingKeys = documentKeySet();\n        const result: DocumentKey[] = [];\n        return PersistencePromise.forEach(indexes, (index, subTarget) => {\n          logDebug(\n            LOG_TAG,\n            `Using index ${fieldIndexToString(\n              index!\n            )} to execute ${canonifyTarget(target)}`\n          );\n\n          const arrayValues = targetGetArrayValues(subTarget, index!);\n          const notInValues = targetGetNotInValues(subTarget, index!);\n          const lowerBound = targetGetLowerBound(subTarget, index!);\n          const upperBound = targetGetUpperBound(subTarget, index!);\n\n          const lowerBoundEncoded = this.encodeBound(\n            index!,\n            subTarget,\n            lowerBound\n          );\n          const upperBoundEncoded = this.encodeBound(\n            index!,\n            subTarget,\n            upperBound\n          );\n          const notInEncoded = this.encodeValues(\n            index!,\n            subTarget,\n            notInValues\n          );\n\n          const indexRanges = this.generateIndexRanges(\n            index!.indexId,\n            arrayValues,\n            lowerBoundEncoded,\n            lowerBound.inclusive,\n            upperBoundEncoded,\n            upperBound.inclusive,\n            notInEncoded\n          );\n          return PersistencePromise.forEach(\n            indexRanges,\n            (indexRange: IDBKeyRange) => {\n              return indexEntries\n                .loadFirst(indexRange, target.limit)\n                .next(entries => {\n                  entries.forEach(entry => {\n                    const documentKey = DocumentKey.fromSegments(\n                      entry.documentKey\n                    );\n                    if (!existingKeys.has(documentKey)) {\n                      existingKeys = existingKeys.add(documentKey);\n                      result.push(documentKey);\n                    }\n                  });\n                });\n            }\n          );\n        }).next(() => result as DocumentKey[] | null);\n      }\n    });\n  }\n\n  private getSubTargets(target: Target): Target[] {\n    let subTargets = this.targetToDnfSubTargets.get(target);\n    if (subTargets) {\n      return subTargets;\n    }\n\n    if (target.filters.length === 0) {\n      subTargets = [target];\n    } else {\n      // There is an implicit AND operation between all the filters stored in the target\n      const dnf: Filter[] = getDnfTerms(\n        CompositeFilter.create(target.filters, CompositeOperator.AND)\n      );\n\n      subTargets = dnf.map(term =>\n        newTarget(\n          target.path,\n          target.collectionGroup,\n          target.orderBy,\n          term.getFilters(),\n          target.limit,\n          target.startAt,\n          target.endAt\n        )\n      );\n    }\n\n    this.targetToDnfSubTargets.set(target, subTargets);\n    return subTargets;\n  }\n\n  /**\n   * Constructs a key range query on `DbIndexEntryStore` that unions all\n   * bounds.\n   */\n  private generateIndexRanges(\n    indexId: number,\n    arrayValues: ProtoValue[] | null,\n    lowerBounds: Uint8Array[],\n    lowerBoundInclusive: boolean,\n    upperBounds: Uint8Array[],\n    upperBoundInclusive: boolean,\n    notInValues: Uint8Array[]\n  ): IDBKeyRange[] {\n    // The number of total index scans we union together. This is similar to a\n    // distributed normal form, but adapted for array values. We create a single\n    // index range per value in an ARRAY_CONTAINS or ARRAY_CONTAINS_ANY filter\n    // combined with the values from the query bounds.\n    const totalScans =\n      (arrayValues != null ? arrayValues.length : 1) *\n      Math.max(lowerBounds.length, upperBounds.length);\n    const scansPerArrayElement =\n      totalScans / (arrayValues != null ? arrayValues.length : 1);\n\n    const indexRanges: IDBKeyRange[] = [];\n    for (let i = 0; i < totalScans; ++i) {\n      const arrayValue = arrayValues\n        ? this.encodeSingleElement(arrayValues[i / scansPerArrayElement])\n        : EMPTY_VALUE;\n\n      const lowerBound = this.generateLowerBound(\n        indexId,\n        arrayValue,\n        lowerBounds[i % scansPerArrayElement],\n        lowerBoundInclusive\n      );\n      const upperBound = this.generateUpperBound(\n        indexId,\n        arrayValue,\n        upperBounds[i % scansPerArrayElement],\n        upperBoundInclusive\n      );\n\n      const notInBound = notInValues.map(notIn =>\n        this.generateLowerBound(\n          indexId,\n          arrayValue,\n          notIn,\n          /* inclusive= */ true\n        )\n      );\n\n      indexRanges.push(...this.createRange(lowerBound, upperBound, notInBound));\n    }\n\n    return indexRanges;\n  }\n\n  /** Generates the lower bound for `arrayValue` and `directionalValue`. */\n  private generateLowerBound(\n    indexId: number,\n    arrayValue: Uint8Array,\n    directionalValue: Uint8Array,\n    inclusive: boolean\n  ): IndexEntry {\n    const entry = new IndexEntry(\n      indexId,\n      DocumentKey.empty(),\n      arrayValue,\n      directionalValue\n    );\n    return inclusive ? entry : entry.successor();\n  }\n\n  /** Generates the upper bound for `arrayValue` and `directionalValue`. */\n  private generateUpperBound(\n    indexId: number,\n    arrayValue: Uint8Array,\n    directionalValue: Uint8Array,\n    inclusive: boolean\n  ): IndexEntry {\n    const entry = new IndexEntry(\n      indexId,\n      DocumentKey.empty(),\n      arrayValue,\n      directionalValue\n    );\n    return inclusive ? entry.successor() : entry;\n  }\n\n  private getFieldIndex(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<FieldIndex | null> {\n    const targetIndexMatcher = new TargetIndexMatcher(target);\n    const collectionGroup =\n      target.collectionGroup != null\n        ? target.collectionGroup\n        : target.path.lastSegment();\n\n    return this.getFieldIndexes(transaction, collectionGroup).next(indexes => {\n      // Return the index with the most number of segments.\n      let index: FieldIndex | null = null;\n      for (const candidate of indexes) {\n        const matches = targetIndexMatcher.servedByIndex(candidate);\n        if (\n          matches &&\n          (!index || candidate.fields.length > index.fields.length)\n        ) {\n          index = candidate;\n        }\n      }\n      return index;\n    });\n  }\n\n  getIndexType(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<IndexType> {\n    let indexType = IndexType.FULL;\n    const subTargets = this.getSubTargets(target);\n    return PersistencePromise.forEach(subTargets, (target: Target) => {\n      return this.getFieldIndex(transaction, target).next(index => {\n        if (!index) {\n          indexType = IndexType.NONE;\n        } else if (\n          indexType !== IndexType.NONE &&\n          index.fields.length < targetGetSegmentCount(target)\n        ) {\n          indexType = IndexType.PARTIAL;\n        }\n      });\n    }).next(() => {\n      // OR queries have more than one sub-target (one sub-target per DNF term). We currently consider\n      // OR queries that have a `limit` to have a partial index. For such queries we perform sorting\n      // and apply the limit in memory as a post-processing step.\n      if (\n        targetHasLimit(target) &&\n        subTargets.length > 1 &&\n        indexType === IndexType.FULL\n      ) {\n        return IndexType.PARTIAL;\n      }\n\n      return indexType;\n    });\n  }\n\n  /**\n   * Returns the byte encoded form of the directional values in the field index.\n   * Returns `null` if the document does not have all fields specified in the\n   * index.\n   */\n  private encodeDirectionalElements(\n    fieldIndex: FieldIndex,\n    document: Document\n  ): Uint8Array | null {\n    const encoder = new IndexByteEncoder();\n    for (const segment of fieldIndexGetDirectionalSegments(fieldIndex)) {\n      const field = document.data.field(segment.fieldPath);\n      if (field == null) {\n        return null;\n      }\n      const directionalEncoder = encoder.forKind(segment.kind);\n      FirestoreIndexValueWriter.INSTANCE.writeIndexValue(\n        field,\n        directionalEncoder\n      );\n    }\n    return encoder.encodedBytes();\n  }\n\n  /** Encodes a single value to the ascending index format. */\n  private encodeSingleElement(value: ProtoValue): Uint8Array {\n    const encoder = new IndexByteEncoder();\n    FirestoreIndexValueWriter.INSTANCE.writeIndexValue(\n      value,\n      encoder.forKind(IndexKind.ASCENDING)\n    );\n    return encoder.encodedBytes();\n  }\n\n  /**\n   * Returns an encoded form of the document key that sorts based on the key\n   * ordering of the field index.\n   */\n  private encodeDirectionalKey(\n    fieldIndex: FieldIndex,\n    documentKey: DocumentKey\n  ): Uint8Array {\n    const encoder = new IndexByteEncoder();\n    FirestoreIndexValueWriter.INSTANCE.writeIndexValue(\n      refValue(this.databaseId, documentKey),\n      encoder.forKind(fieldIndexGetKeyOrder(fieldIndex))\n    );\n    return encoder.encodedBytes();\n  }\n\n  /**\n   * Encodes the given field values according to the specification in `target`.\n   * For IN queries, a list of possible values is returned.\n   */\n  private encodeValues(\n    fieldIndex: FieldIndex,\n    target: Target,\n    values: ProtoValue[] | null\n  ): Uint8Array[] {\n    if (values === null) {\n      return [];\n    }\n\n    let encoders: IndexByteEncoder[] = [];\n    encoders.push(new IndexByteEncoder());\n\n    let valueIdx = 0;\n    for (const segment of fieldIndexGetDirectionalSegments(fieldIndex)) {\n      const value = values[valueIdx++];\n      for (const encoder of encoders) {\n        if (this.isInFilter(target, segment.fieldPath) && isArray(value)) {\n          encoders = this.expandIndexValues(encoders, segment, value);\n        } else {\n          const directionalEncoder = encoder.forKind(segment.kind);\n          FirestoreIndexValueWriter.INSTANCE.writeIndexValue(\n            value,\n            directionalEncoder\n          );\n        }\n      }\n    }\n    return this.getEncodedBytes(encoders);\n  }\n\n  /**\n   * Encodes the given bounds according to the specification in `target`. For IN\n   * queries, a list of possible values is returned.\n   */\n  private encodeBound(\n    fieldIndex: FieldIndex,\n    target: Target,\n    bound: Bound\n  ): Uint8Array[] {\n    return this.encodeValues(fieldIndex, target, bound.position);\n  }\n\n  /** Returns the byte representation for the provided encoders. */\n  private getEncodedBytes(encoders: IndexByteEncoder[]): Uint8Array[] {\n    const result: Uint8Array[] = [];\n    for (let i = 0; i < encoders.length; ++i) {\n      result[i] = encoders[i].encodedBytes();\n    }\n    return result;\n  }\n\n  /**\n   * Creates a separate encoder for each element of an array.\n   *\n   * The method appends each value to all existing encoders (e.g. filter(\"a\",\n   * \"==\", \"a1\").filter(\"b\", \"in\", [\"b1\", \"b2\"]) becomes [\"a1,b1\", \"a1,b2\"]). A\n   * list of new encoders is returned.\n   */\n  private expandIndexValues(\n    encoders: IndexByteEncoder[],\n    segment: IndexSegment,\n    value: ProtoValue\n  ): IndexByteEncoder[] {\n    const prefixes = [...encoders];\n    const results: IndexByteEncoder[] = [];\n    for (const arrayElement of value.arrayValue!.values || []) {\n      for (const prefix of prefixes) {\n        const clonedEncoder = new IndexByteEncoder();\n        clonedEncoder.seed(prefix.encodedBytes());\n        FirestoreIndexValueWriter.INSTANCE.writeIndexValue(\n          arrayElement,\n          clonedEncoder.forKind(segment.kind)\n        );\n        results.push(clonedEncoder);\n      }\n    }\n    return results;\n  }\n\n  private isInFilter(target: Target, fieldPath: FieldPath): boolean {\n    return !!target.filters.find(\n      f =>\n        f instanceof FieldFilter &&\n        f.field.isEqual(fieldPath) &&\n        (f.op === Operator.IN || f.op === Operator.NOT_IN)\n    );\n  }\n\n  getFieldIndexes(\n    transaction: PersistenceTransaction,\n    collectionGroup?: string\n  ): PersistencePromise<FieldIndex[]> {\n    const indexes = indexConfigurationStore(transaction);\n    const states = indexStateStore(transaction);\n\n    return (\n      collectionGroup\n        ? indexes.loadAll(\n            DbIndexConfigurationCollectionGroupIndex,\n            IDBKeyRange.bound(collectionGroup, collectionGroup)\n          )\n        : indexes.loadAll()\n    ).next(indexConfigs => {\n      const result: FieldIndex[] = [];\n      return PersistencePromise.forEach(\n        indexConfigs,\n        (indexConfig: DbIndexConfiguration) => {\n          return states\n            .get([indexConfig.indexId!, this.uid])\n            .next(indexState => {\n              result.push(fromDbIndexConfiguration(indexConfig, indexState));\n            });\n        }\n      ).next(() => result);\n    });\n  }\n\n  getNextCollectionGroupToUpdate(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<string | null> {\n    return this.getFieldIndexes(transaction).next(indexes => {\n      if (indexes.length === 0) {\n        return null;\n      }\n      indexes.sort((l, r) => {\n        const cmp = l.indexState.sequenceNumber - r.indexState.sequenceNumber;\n        return cmp !== 0\n          ? cmp\n          : primitiveComparator(l.collectionGroup, r.collectionGroup);\n      });\n      return indexes[0].collectionGroup;\n    });\n  }\n\n  updateCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string,\n    offset: IndexOffset\n  ): PersistencePromise<void> {\n    const indexes = indexConfigurationStore(transaction);\n    const states = indexStateStore(transaction);\n    return this.getNextSequenceNumber(transaction).next(nextSequenceNumber =>\n      indexes\n        .loadAll(\n          DbIndexConfigurationCollectionGroupIndex,\n          IDBKeyRange.bound(collectionGroup, collectionGroup)\n        )\n        .next(configs =>\n          PersistencePromise.forEach(configs, (config: DbIndexConfiguration) =>\n            states.put(\n              toDbIndexState(\n                config.indexId!,\n                this.uid,\n                nextSequenceNumber,\n                offset\n              )\n            )\n          )\n        )\n    );\n  }\n\n  updateIndexEntries(\n    transaction: PersistenceTransaction,\n    documents: DocumentMap\n  ): PersistencePromise<void> {\n    // Porting Note: `getFieldIndexes()` on Web does not cache index lookups as\n    // it could be used across different IndexedDB transactions. As any cached\n    // data might be invalidated by other multi-tab clients, we can only trust\n    // data within a single IndexedDB transaction. We therefore add a cache\n    // here.\n    const memoizedIndexes = new Map<string, FieldIndex[]>();\n    return PersistencePromise.forEach(documents, (key, doc) => {\n      const memoizedCollectionIndexes = memoizedIndexes.get(\n        key.collectionGroup\n      );\n      const fieldIndexes = memoizedCollectionIndexes\n        ? PersistencePromise.resolve(memoizedCollectionIndexes)\n        : this.getFieldIndexes(transaction, key.collectionGroup);\n\n      return fieldIndexes.next(fieldIndexes => {\n        memoizedIndexes.set(key.collectionGroup, fieldIndexes);\n        return PersistencePromise.forEach(\n          fieldIndexes,\n          (fieldIndex: FieldIndex) => {\n            return this.getExistingIndexEntries(\n              transaction,\n              key,\n              fieldIndex\n            ).next(existingEntries => {\n              const newEntries = this.computeIndexEntries(doc, fieldIndex);\n              if (!existingEntries.isEqual(newEntries)) {\n                return this.updateEntries(\n                  transaction,\n                  doc,\n                  fieldIndex,\n                  existingEntries,\n                  newEntries\n                );\n              }\n              return PersistencePromise.resolve();\n            });\n          }\n        );\n      });\n    });\n  }\n\n  private addIndexEntry(\n    transaction: PersistenceTransaction,\n    document: Document,\n    fieldIndex: FieldIndex,\n    indexEntry: IndexEntry\n  ): PersistencePromise<void> {\n    const indexEntries = indexEntriesStore(transaction);\n    return indexEntries.put({\n      indexId: indexEntry.indexId,\n      uid: this.uid,\n      arrayValue: indexEntry.arrayValue,\n      directionalValue: indexEntry.directionalValue,\n      orderedDocumentKey: this.encodeDirectionalKey(fieldIndex, document.key),\n      documentKey: document.key.path.toArray()\n    });\n  }\n\n  private deleteIndexEntry(\n    transaction: PersistenceTransaction,\n    document: Document,\n    fieldIndex: FieldIndex,\n    indexEntry: IndexEntry\n  ): PersistencePromise<void> {\n    const indexEntries = indexEntriesStore(transaction);\n    return indexEntries.delete([\n      indexEntry.indexId,\n      this.uid,\n      indexEntry.arrayValue,\n      indexEntry.directionalValue,\n      this.encodeDirectionalKey(fieldIndex, document.key),\n      document.key.path.toArray()\n    ]);\n  }\n\n  private getExistingIndexEntries(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey,\n    fieldIndex: FieldIndex\n  ): PersistencePromise<SortedSet<IndexEntry>> {\n    const indexEntries = indexEntriesStore(transaction);\n    let results = new SortedSet<IndexEntry>(indexEntryComparator);\n    return indexEntries\n      .iterate(\n        {\n          index: DbIndexEntryDocumentKeyIndex,\n          range: IDBKeyRange.only([\n            fieldIndex.indexId,\n            this.uid,\n            this.encodeDirectionalKey(fieldIndex, documentKey)\n          ])\n        },\n        (_, entry) => {\n          results = results.add(\n            new IndexEntry(\n              fieldIndex.indexId,\n              documentKey,\n              entry.arrayValue,\n              entry.directionalValue\n            )\n          );\n        }\n      )\n      .next(() => results);\n  }\n\n  /** Creates the index entries for the given document. */\n  private computeIndexEntries(\n    document: Document,\n    fieldIndex: FieldIndex\n  ): SortedSet<IndexEntry> {\n    let results = new SortedSet<IndexEntry>(indexEntryComparator);\n\n    const directionalValue = this.encodeDirectionalElements(\n      fieldIndex,\n      document\n    );\n    if (directionalValue == null) {\n      return results;\n    }\n\n    const arraySegment = fieldIndexGetArraySegment(fieldIndex);\n    if (arraySegment != null) {\n      const value = document.data.field(arraySegment.fieldPath);\n      if (isArray(value)) {\n        for (const arrayValue of value.arrayValue!.values || []) {\n          results = results.add(\n            new IndexEntry(\n              fieldIndex.indexId,\n              document.key,\n              this.encodeSingleElement(arrayValue),\n              directionalValue\n            )\n          );\n        }\n      }\n    } else {\n      results = results.add(\n        new IndexEntry(\n          fieldIndex.indexId,\n          document.key,\n          EMPTY_VALUE,\n          directionalValue\n        )\n      );\n    }\n\n    return results;\n  }\n\n  /**\n   * Updates the index entries for the provided document by deleting entries\n   * that are no longer referenced in `newEntries` and adding all newly added\n   * entries.\n   */\n  private updateEntries(\n    transaction: PersistenceTransaction,\n    document: Document,\n    fieldIndex: FieldIndex,\n    existingEntries: SortedSet<IndexEntry>,\n    newEntries: SortedSet<IndexEntry>\n  ): PersistencePromise<void> {\n    logDebug(LOG_TAG, \"Updating index entries for document '%s'\", document.key);\n\n    const promises: Array<PersistencePromise<void>> = [];\n    diffSortedSets(\n      existingEntries,\n      newEntries,\n      indexEntryComparator,\n      /* onAdd= */ entry => {\n        promises.push(\n          this.addIndexEntry(transaction, document, fieldIndex, entry)\n        );\n      },\n      /* onRemove= */ entry => {\n        promises.push(\n          this.deleteIndexEntry(transaction, document, fieldIndex, entry)\n        );\n      }\n    );\n\n    return PersistencePromise.waitFor(promises);\n  }\n\n  private getNextSequenceNumber(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<number> {\n    let nextSequenceNumber = 1;\n    const states = indexStateStore(transaction);\n    return states\n      .iterate(\n        {\n          index: DbIndexStateSequenceNumberIndex,\n          reverse: true,\n          range: IDBKeyRange.upperBound([this.uid, Number.MAX_SAFE_INTEGER])\n        },\n        (_, state, controller) => {\n          controller.done();\n          nextSequenceNumber = state.sequenceNumber + 1;\n        }\n      )\n      .next(() => nextSequenceNumber);\n  }\n\n  /**\n   * Returns a new set of IDB ranges that splits the existing range and excludes\n   * any values that match the `notInValue` from these ranges. As an example,\n   * '[foo > 2 && foo != 3]` becomes  `[foo > 2 && < 3, foo > 3]`.\n   */\n  private createRange(\n    lower: IndexEntry,\n    upper: IndexEntry,\n    notInValues: IndexEntry[]\n  ): IDBKeyRange[] {\n    // The notIn values need to be sorted and unique so that we can return a\n    // sorted set of non-overlapping ranges.\n    notInValues = notInValues\n      .sort((l, r) => indexEntryComparator(l, r))\n      .filter(\n        (el, i, values) => !i || indexEntryComparator(el, values[i - 1]) !== 0\n      );\n\n    const bounds: IndexEntry[] = [];\n    bounds.push(lower);\n    for (const notInValue of notInValues) {\n      const cmpToLower = indexEntryComparator(notInValue, lower);\n      const cmpToUpper = indexEntryComparator(notInValue, upper);\n\n      if (cmpToLower === 0) {\n        // `notInValue` is the lower bound. We therefore need to raise the bound\n        // to the next value.\n        bounds[0] = lower.successor();\n      } else if (cmpToLower > 0 && cmpToUpper < 0) {\n        // `notInValue` is in the middle of the range\n        bounds.push(notInValue);\n        bounds.push(notInValue.successor());\n      } else if (cmpToUpper > 0) {\n        // `notInValue` (and all following values) are out of the range\n        break;\n      }\n    }\n    bounds.push(upper);\n\n    const ranges: IDBKeyRange[] = [];\n    for (let i = 0; i < bounds.length; i += 2) {\n      // If we encounter two bounds that will create an unmatchable key range,\n      // then we return an empty set of key ranges.\n      if (this.isRangeMatchable(bounds[i], bounds[i + 1])) {\n        return [];\n      }\n\n      const lowerBound = [\n        bounds[i].indexId,\n        this.uid,\n        bounds[i].arrayValue,\n        bounds[i].directionalValue,\n        EMPTY_VALUE,\n        []\n      ] as DbIndexEntryKey;\n\n      const upperBound = [\n        bounds[i + 1].indexId,\n        this.uid,\n        bounds[i + 1].arrayValue,\n        bounds[i + 1].directionalValue,\n        EMPTY_VALUE,\n        []\n      ] as DbIndexEntryKey;\n\n      ranges.push(IDBKeyRange.bound(lowerBound, upperBound));\n    }\n    return ranges;\n  }\n\n  isRangeMatchable(lowerBound: IndexEntry, upperBound: IndexEntry): boolean {\n    // If lower bound is greater than the upper bound, then the key\n    // range can never be matched.\n    return indexEntryComparator(lowerBound, upperBound) > 0;\n  }\n\n  getMinOffsetFromCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string\n  ): PersistencePromise<IndexOffset> {\n    return this.getFieldIndexes(transaction, collectionGroup).next(\n      getMinOffsetFromFieldIndexes\n    );\n  }\n\n  getMinOffset(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<IndexOffset> {\n    return PersistencePromise.mapArray(\n      this.getSubTargets(target),\n      (subTarget: Target) =>\n        this.getFieldIndex(transaction, subTarget).next(index =>\n          index ? index : fail('Target cannot be served from index')\n        )\n    ).next(getMinOffsetFromFieldIndexes);\n  }\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the collectionParents\n * document store.\n */\nfunction collectionParentsStore(\n  txn: PersistenceTransaction\n): SimpleDbStore<DbCollectionParentKey, DbCollectionParent> {\n  return getStore<DbCollectionParentKey, DbCollectionParent>(\n    txn,\n    DbCollectionParentStore\n  );\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the index entry object store.\n */\nfunction indexEntriesStore(\n  txn: PersistenceTransaction\n): SimpleDbStore<DbIndexEntryKey, DbIndexEntry> {\n  return getStore<DbIndexEntryKey, DbIndexEntry>(txn, DbIndexEntryStore);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the index configuration object store.\n */\nfunction indexConfigurationStore(\n  txn: PersistenceTransaction\n): SimpleDbStore<DbIndexConfigurationKey, DbIndexConfiguration> {\n  return getStore<DbIndexConfigurationKey, DbIndexConfiguration>(\n    txn,\n    DbIndexConfigurationStore\n  );\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the index state object store.\n */\nfunction indexStateStore(\n  txn: PersistenceTransaction\n): SimpleDbStore<DbIndexStateKey, DbIndexState> {\n  return getStore<DbIndexStateKey, DbIndexState>(txn, DbIndexStateStore);\n}\n\nfunction getMinOffsetFromFieldIndexes(fieldIndexes: FieldIndex[]): IndexOffset {\n  hardAssert(\n    fieldIndexes.length !== 0,\n    'Found empty index group when looking for least recent index offset.'\n  );\n\n  let minOffset: IndexOffset = fieldIndexes[0].indexState.offset;\n  let maxBatchId: number = minOffset.largestBatchId;\n  for (let i = 1; i < fieldIndexes.length; i++) {\n    const newOffset: IndexOffset = fieldIndexes[i].indexState.offset;\n    if (indexOffsetComparator(newOffset, minOffset) < 0) {\n      minOffset = newOffset;\n    }\n    if (maxBatchId < newOffset.largestBatchId) {\n      maxBatchId = newOffset.largestBatchId;\n    }\n  }\n  return new IndexOffset(minOffset.readTime, minOffset.documentKey, maxBatchId);\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 { ListenSequenceNumber, TargetId } from '../core/types';\nimport { SortedMap } from '../util/sorted_map';\n\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { TargetData } from './target_data';\n\n/**\n * Describes a map whose keys are active target ids. We do not care about the type of the\n * values.\n */\nexport type ActiveTargets = SortedMap<TargetId, unknown>;\n\nexport const GC_DID_NOT_RUN: LruResults = {\n  didRun: false,\n  sequenceNumbersCollected: 0,\n  targetsRemoved: 0,\n  documentsRemoved: 0\n};\n\nexport const LRU_COLLECTION_DISABLED = -1;\nexport const LRU_DEFAULT_CACHE_SIZE_BYTES = 40 * 1024 * 1024;\n\nexport class LruParams {\n  private static readonly DEFAULT_COLLECTION_PERCENTILE = 10;\n  private static readonly DEFAULT_MAX_SEQUENCE_NUMBERS_TO_COLLECT = 1000;\n\n  static withCacheSize(cacheSize: number): LruParams {\n    return new LruParams(\n      cacheSize,\n      LruParams.DEFAULT_COLLECTION_PERCENTILE,\n      LruParams.DEFAULT_MAX_SEQUENCE_NUMBERS_TO_COLLECT\n    );\n  }\n\n  static readonly DEFAULT: LruParams = new LruParams(\n    LRU_DEFAULT_CACHE_SIZE_BYTES,\n    LruParams.DEFAULT_COLLECTION_PERCENTILE,\n    LruParams.DEFAULT_MAX_SEQUENCE_NUMBERS_TO_COLLECT\n  );\n\n  static readonly DISABLED: LruParams = new LruParams(\n    LRU_COLLECTION_DISABLED,\n    0,\n    0\n  );\n\n  constructor(\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    readonly cacheSizeCollectionThreshold: number,\n    // The percentage of sequence numbers that we will attempt to collect\n    readonly percentileToCollect: number,\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    readonly maximumSequenceNumbersToCollect: number\n  ) {}\n}\n\nexport interface LruGarbageCollector {\n  readonly params: LruParams;\n\n  collect(\n    txn: PersistenceTransaction,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<LruResults>;\n\n  /** Given a percentile of target to collect, returns the number of targets to collect. */\n  calculateTargetCount(\n    txn: PersistenceTransaction,\n    percentile: number\n  ): PersistencePromise<number>;\n\n  /** Returns the nth sequence number, counting in order from the smallest. */\n  nthSequenceNumber(\n    txn: PersistenceTransaction,\n    n: number\n  ): PersistencePromise<number>;\n\n  /**\n   * Removes documents that have a sequence number equal to or less than the\n   * upper bound and are not otherwise pinned.\n   */\n  removeOrphanedDocuments(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber\n  ): PersistencePromise<number>;\n\n  getCacheSize(txn: PersistenceTransaction): PersistencePromise<number>;\n\n  /**\n   * Removes targets with a sequence number equal to or less than the given\n   * upper bound, and removes document associations with those targets.\n   */\n  removeTargets(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<number>;\n}\n\n/**\n * Describes the results of a garbage collection run. `didRun` will be set to\n * `false` if collection was skipped (either it is disabled or the cache size\n * has not hit the threshold). If collection ran, the other fields will be\n * filled in with the details of the results.\n */\nexport interface LruResults {\n  readonly didRun: boolean;\n  readonly sequenceNumbersCollected: number;\n  readonly targetsRemoved: number;\n  readonly documentsRemoved: number;\n}\n\n/**\n * Persistence layers intending to use LRU Garbage collection should have\n * reference delegates that implement this interface. This interface defines the\n * operations that the LRU garbage collector needs from the persistence layer.\n */\nexport interface LruDelegate {\n  readonly garbageCollector: LruGarbageCollector;\n\n  /** Enumerates all the targets in the TargetCache. */\n  forEachTarget(\n    txn: PersistenceTransaction,\n    f: (target: TargetData) => void\n  ): PersistencePromise<void>;\n\n  getSequenceNumberCount(\n    txn: PersistenceTransaction\n  ): PersistencePromise<number>;\n\n  /**\n   * Enumerates sequence numbers for documents not associated with a target.\n   * Note that this may include duplicate sequence numbers.\n   */\n  forEachOrphanedDocumentSequenceNumber(\n    txn: PersistenceTransaction,\n    f: (sequenceNumber: ListenSequenceNumber) => void\n  ): PersistencePromise<void>;\n\n  /**\n   * Removes all targets that have a sequence number less than or equal to\n   * `upperBound`, and are not present in the `activeTargetIds` set.\n   *\n   * @returns the number of targets removed.\n   */\n  removeTargets(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<number>;\n\n  /**\n   * Removes all unreferenced documents from the cache that have a sequence\n   * number less than or equal to the given `upperBound`.\n   *\n   * @returns the number of documents removed.\n   */\n  removeOrphanedDocuments(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber\n  ): PersistencePromise<number>;\n\n  getCacheSize(txn: PersistenceTransaction): PersistencePromise<number>;\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 { TargetId } from './types';\n\n/** Offset to ensure non-overlapping target ids. */\nconst OFFSET = 2;\n\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 */\nexport class TargetIdGenerator {\n  constructor(private lastId: number) {}\n\n  next(): TargetId {\n    this.lastId += OFFSET;\n    return this.lastId;\n  }\n\n  static forTargetCache(): TargetIdGenerator {\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 TargetIdGenerator(2 - OFFSET);\n  }\n\n  static forSyncEngine(): TargetIdGenerator {\n    // Sync engine assigns target IDs for limbo document detection.\n    return new TargetIdGenerator(1 - OFFSET);\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 { FirestoreError } from '../api';\nimport { ListenSequence } from '../core/listen_sequence';\nimport { ListenSequenceNumber } from '../core/types';\nimport { debugAssert } from '../util/assert';\nimport { AsyncQueue, DelayedOperation, TimerId } from '../util/async_queue';\nimport { getLogLevel, logDebug, LogLevel } from '../util/log';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { ignoreIfPrimaryLeaseLoss, LocalStore } from './local_store';\nimport {\n  ActiveTargets,\n  GC_DID_NOT_RUN,\n  LRU_COLLECTION_DISABLED,\n  LruDelegate,\n  LruGarbageCollector,\n  LruParams,\n  LruResults\n} from './lru_garbage_collector';\nimport { Scheduler } from './persistence';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { isIndexedDbTransactionError } from './simple_db';\n\nconst LOG_TAG = 'LruGarbageCollector';\n\nexport const LRU_MINIMUM_CACHE_SIZE_BYTES = 1 * 1024 * 1024;\n\n/** How long we wait to try running LRU GC after SDK initialization. */\nconst INITIAL_GC_DELAY_MS = 1 * 60 * 1000;\n/** Minimum amount of time between GC checks, after the first one. */\nconst REGULAR_GC_DELAY_MS = 5 * 60 * 1000;\n\n// The type and comparator for the items contained in the SortedSet used in\n// place of a priority queue for the RollingSequenceNumberBuffer.\ntype BufferEntry = [ListenSequenceNumber, number];\n\nfunction bufferEntryComparator(\n  [aSequence, aIndex]: BufferEntry,\n  [bSequence, bIndex]: BufferEntry\n): number {\n  const seqCmp = primitiveComparator(aSequence, bSequence);\n  if (seqCmp === 0) {\n    // This order doesn't matter, but we can bias against churn by sorting\n    // entries created earlier as less than newer entries.\n    return primitiveComparator(aIndex, bIndex);\n  } else {\n    return seqCmp;\n  }\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 */\nclass RollingSequenceNumberBuffer {\n  private buffer: SortedSet<BufferEntry> = new SortedSet<BufferEntry>(\n    bufferEntryComparator\n  );\n\n  private previousIndex = 0;\n\n  constructor(private readonly maxElements: number) {}\n\n  private nextIndex(): number {\n    return ++this.previousIndex;\n  }\n\n  addElement(sequenceNumber: ListenSequenceNumber): void {\n    const entry: BufferEntry = [sequenceNumber, this.nextIndex()];\n    if (this.buffer.size < this.maxElements) {\n      this.buffer = this.buffer.add(entry);\n    } else {\n      const highestValue = this.buffer.last()!;\n      if (bufferEntryComparator(entry, highestValue) < 0) {\n        this.buffer = this.buffer.delete(highestValue).add(entry);\n      }\n    }\n  }\n\n  get maxValue(): ListenSequenceNumber {\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}\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 */\nexport class LruScheduler implements Scheduler {\n  private gcTask: DelayedOperation<void> | null;\n\n  constructor(\n    private readonly garbageCollector: LruGarbageCollector,\n    private readonly asyncQueue: AsyncQueue,\n    private readonly localStore: LocalStore\n  ) {\n    this.gcTask = null;\n  }\n\n  start(): void {\n    debugAssert(\n      this.gcTask === null,\n      'Cannot start an already started LruScheduler'\n    );\n    if (\n      this.garbageCollector.params.cacheSizeCollectionThreshold !==\n      LRU_COLLECTION_DISABLED\n    ) {\n      this.scheduleGC(INITIAL_GC_DELAY_MS);\n    }\n  }\n\n  stop(): void {\n    if (this.gcTask) {\n      this.gcTask.cancel();\n      this.gcTask = null;\n    }\n  }\n\n  get started(): boolean {\n    return this.gcTask !== null;\n  }\n\n  private scheduleGC(delay: number): void {\n    debugAssert(\n      this.gcTask === null,\n      'Cannot schedule GC while a task is pending'\n    );\n    logDebug(LOG_TAG, `Garbage collection scheduled in ${delay}ms`);\n    this.gcTask = this.asyncQueue.enqueueAfterDelay(\n      TimerId.LruGarbageCollection,\n      delay,\n      async () => {\n        this.gcTask = null;\n        try {\n          await this.localStore.collectGarbage(this.garbageCollector);\n        } catch (e) {\n          if (isIndexedDbTransactionError(e as Error)) {\n            logDebug(\n              LOG_TAG,\n              'Ignoring IndexedDB error during garbage collection: ',\n              e\n            );\n          } else {\n            await ignoreIfPrimaryLeaseLoss(e as FirestoreError);\n          }\n        }\n        await this.scheduleGC(REGULAR_GC_DELAY_MS);\n      }\n    );\n  }\n}\n\n/**\n * Implements the steps for LRU garbage collection.\n */\nclass LruGarbageCollectorImpl implements LruGarbageCollector {\n  constructor(\n    private readonly delegate: LruDelegate,\n    readonly params: LruParams\n  ) {}\n\n  calculateTargetCount(\n    txn: PersistenceTransaction,\n    percentile: number\n  ): PersistencePromise<number> {\n    return this.delegate.getSequenceNumberCount(txn).next(targetCount => {\n      return Math.floor((percentile / 100.0) * targetCount);\n    });\n  }\n\n  nthSequenceNumber(\n    txn: PersistenceTransaction,\n    n: number\n  ): PersistencePromise<ListenSequenceNumber> {\n    if (n === 0) {\n      return PersistencePromise.resolve(ListenSequence.INVALID);\n    }\n\n    const buffer = new RollingSequenceNumberBuffer(n);\n    return this.delegate\n      .forEachTarget(txn, target => buffer.addElement(target.sequenceNumber))\n      .next(() => {\n        return this.delegate.forEachOrphanedDocumentSequenceNumber(\n          txn,\n          sequenceNumber => buffer.addElement(sequenceNumber)\n        );\n      })\n      .next(() => buffer.maxValue);\n  }\n\n  removeTargets(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<number> {\n    return this.delegate.removeTargets(txn, upperBound, activeTargetIds);\n  }\n\n  removeOrphanedDocuments(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber\n  ): PersistencePromise<number> {\n    return this.delegate.removeOrphanedDocuments(txn, upperBound);\n  }\n\n  collect(\n    txn: PersistenceTransaction,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<LruResults> {\n    if (this.params.cacheSizeCollectionThreshold === LRU_COLLECTION_DISABLED) {\n      logDebug('LruGarbageCollector', 'Garbage collection skipped; disabled');\n      return PersistencePromise.resolve(GC_DID_NOT_RUN);\n    }\n\n    return this.getCacheSize(txn).next(cacheSize => {\n      if (cacheSize < this.params.cacheSizeCollectionThreshold) {\n        logDebug(\n          'LruGarbageCollector',\n          `Garbage collection skipped; Cache size ${cacheSize} ` +\n            `is lower than threshold ${this.params.cacheSizeCollectionThreshold}`\n        );\n        return GC_DID_NOT_RUN;\n      } else {\n        return this.runGarbageCollection(txn, activeTargetIds);\n      }\n    });\n  }\n\n  getCacheSize(txn: PersistenceTransaction): PersistencePromise<number> {\n    return this.delegate.getCacheSize(txn);\n  }\n\n  private runGarbageCollection(\n    txn: PersistenceTransaction,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<LruResults> {\n    let upperBoundSequenceNumber: number;\n    let sequenceNumbersToCollect: number, targetsRemoved: number;\n    // Timestamps for various pieces of the process\n    let countedTargetsTs: number,\n      foundUpperBoundTs: number,\n      removedTargetsTs: number,\n      removedDocumentsTs: number;\n    const startTs = Date.now();\n    return this.calculateTargetCount(txn, this.params.percentileToCollect)\n      .next(sequenceNumbers => {\n        // Cap at the configured max\n        if (sequenceNumbers > this.params.maximumSequenceNumbersToCollect) {\n          logDebug(\n            'LruGarbageCollector',\n            'Capping sequence numbers to collect down ' +\n              `to the maximum of ${this.params.maximumSequenceNumbersToCollect} ` +\n              `from ${sequenceNumbers}`\n          );\n          sequenceNumbersToCollect =\n            this.params.maximumSequenceNumbersToCollect;\n        } else {\n          sequenceNumbersToCollect = sequenceNumbers;\n        }\n        countedTargetsTs = Date.now();\n\n        return this.nthSequenceNumber(txn, sequenceNumbersToCollect);\n      })\n      .next(upperBound => {\n        upperBoundSequenceNumber = upperBound;\n        foundUpperBoundTs = Date.now();\n\n        return this.removeTargets(\n          txn,\n          upperBoundSequenceNumber,\n          activeTargetIds\n        );\n      })\n      .next(numTargetsRemoved => {\n        targetsRemoved = numTargetsRemoved;\n        removedTargetsTs = Date.now();\n\n        return this.removeOrphanedDocuments(txn, upperBoundSequenceNumber);\n      })\n      .next(documentsRemoved => {\n        removedDocumentsTs = Date.now();\n\n        if (getLogLevel() <= LogLevel.DEBUG) {\n          const desc =\n            'LRU Garbage Collection\\n' +\n            `\\tCounted targets in ${countedTargetsTs - startTs}ms\\n` +\n            `\\tDetermined least recently used ${sequenceNumbersToCollect} in ` +\n            `${foundUpperBoundTs - countedTargetsTs}ms\\n` +\n            `\\tRemoved ${targetsRemoved} targets in ` +\n            `${removedTargetsTs - foundUpperBoundTs}ms\\n` +\n            `\\tRemoved ${documentsRemoved} documents in ` +\n            `${removedDocumentsTs - removedTargetsTs}ms\\n` +\n            `Total Duration: ${removedDocumentsTs - startTs}ms`;\n          logDebug('LruGarbageCollector', desc);\n        }\n\n        return PersistencePromise.resolve<LruResults>({\n          didRun: true,\n          sequenceNumbersCollected: sequenceNumbersToCollect,\n          targetsRemoved,\n          documentsRemoved\n        });\n      });\n  }\n}\n\nexport function newLruGarbageCollector(\n  delegate: LruDelegate,\n  params: LruParams\n): LruGarbageCollector {\n  return new LruGarbageCollectorImpl(delegate, params);\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { DocumentKeySet, MutableDocumentMap } from '../model/collections';\nimport { MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { debugAssert } from '../util/assert';\nimport { ObjectMap } from '../util/obj_map';\n\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\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 */\nexport abstract class RemoteDocumentChangeBuffer {\n  // A mapping of document key to the new cache entry that should be written.\n  protected changes: ObjectMap<DocumentKey, MutableDocument> = new ObjectMap(\n    key => key.toString(),\n    (l, r) => l.isEqual(r)\n  );\n\n  private changesApplied = false;\n\n  protected abstract getFromCache(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey\n  ): PersistencePromise<MutableDocument>;\n\n  protected abstract getAllFromCache(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet\n  ): PersistencePromise<MutableDocumentMap>;\n\n  protected abstract applyChanges(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<void>;\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  addEntry(document: MutableDocument): void {\n    this.assertNotApplied();\n    this.changes.set(document.key, document);\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  removeEntry(key: DocumentKey, readTime: SnapshotVersion): void {\n    this.assertNotApplied();\n    this.changes.set(\n      key,\n      MutableDocument.newInvalidDocument(key).setReadTime(readTime)\n    );\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 an invalid document if we have nothing\n   * cached.\n   */\n  getEntry(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey\n  ): PersistencePromise<MutableDocument> {\n    this.assertNotApplied();\n    const bufferedEntry = this.changes.get(documentKey);\n    if (bufferedEntry !== undefined) {\n      return PersistencePromise.resolve(bufferedEntry);\n    } else {\n      return this.getFromCache(transaction, documentKey);\n    }\n  }\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 documents, indexed by key. If an entry cannot be\n   *     found, the corresponding key will be mapped to an invalid document.\n   */\n  getEntries(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet\n  ): PersistencePromise<MutableDocumentMap> {\n    return this.getAllFromCache(transaction, documentKeys);\n  }\n\n  /**\n   * Applies buffered changes to the underlying RemoteDocumentCache, using\n   * the provided transaction.\n   */\n  apply(transaction: PersistenceTransaction): PersistencePromise<void> {\n    this.assertNotApplied();\n    this.changesApplied = true;\n    return this.applyChanges(transaction);\n  }\n\n  /** Helper to assert this.changes is not null  */\n  protected assertNotApplied(): void {\n    debugAssert(!this.changesApplied, 'Changes have already been applied.');\n  }\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { Document } from '../model/document';\nimport { FieldMask } from '../model/field_mask';\n\n/**\n * Represents a local view (overlay) of a document, and the fields that are\n * locally mutated.\n */\nexport class OverlayedDocument {\n  constructor(\n    readonly overlayedDocument: Document,\n\n    /**\n     * The fields that are locally mutated by patch mutations.\n     *\n     * If the overlayed\tdocument is from set or delete mutations, this is `null`.\n     * If there is no overlay (mutation) for the document, this is an empty `FieldMask`.\n     */\n    readonly mutatedFields: FieldMask | 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 {\n  asCollectionQueryAtPath,\n  isCollectionGroupQuery,\n  isDocumentQuery,\n  Query,\n  queryMatches\n} from '../core/query';\nimport { Timestamp } from '../lite-api/timestamp';\nimport {\n  DocumentKeySet,\n  OverlayMap,\n  DocumentMap,\n  MutableDocumentMap,\n  newDocumentKeyMap,\n  newMutationMap,\n  newOverlayMap,\n  documentMap,\n  mutableDocumentMap,\n  documentKeySet,\n  DocumentKeyMap,\n  convertOverlayedDocumentMapToDocumentMap,\n  OverlayedDocumentMap,\n  newOverlayedDocumentMap\n} from '../model/collections';\nimport { Document, MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { IndexOffset, INITIAL_LARGEST_BATCH_ID } from '../model/field_index';\nimport { FieldMask } from '../model/field_mask';\nimport {\n  calculateOverlayMutation,\n  mutationApplyToLocalView,\n  PatchMutation\n} from '../model/mutation';\nimport { Overlay } from '../model/overlay';\nimport { ResourcePath } from '../model/path';\nimport { debugAssert } from '../util/assert';\nimport { SortedMap } from '../util/sorted_map';\n\nimport { DocumentOverlayCache } from './document_overlay_cache';\nimport { IndexManager } from './index_manager';\nimport { LocalWriteResult } from './local_store_impl';\nimport { MutationQueue } from './mutation_queue';\nimport { OverlayedDocument } from './overlayed_document';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { QueryContext } from './query_context';\nimport { RemoteDocumentCache } from './remote_document_cache';\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 */\nexport class LocalDocumentsView {\n  constructor(\n    readonly remoteDocumentCache: RemoteDocumentCache,\n    readonly mutationQueue: MutationQueue,\n    readonly documentOverlayCache: DocumentOverlayCache,\n    readonly indexManager: IndexManager\n  ) {}\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  getDocument(\n    transaction: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<Document> {\n    let overlay: Overlay | null = null;\n    return this.documentOverlayCache\n      .getOverlay(transaction, key)\n      .next(value => {\n        overlay = value;\n        return this.remoteDocumentCache.getEntry(transaction, key);\n      })\n      .next(document => {\n        if (overlay !== null) {\n          mutationApplyToLocalView(\n            overlay.mutation,\n            document,\n            FieldMask.empty(),\n            Timestamp.now()\n          );\n        }\n        return document as Document;\n      });\n  }\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  getDocuments(\n    transaction: PersistenceTransaction,\n    keys: DocumentKeySet\n  ): PersistencePromise<DocumentMap> {\n    return this.remoteDocumentCache\n      .getEntries(transaction, keys)\n      .next(docs =>\n        this.getLocalViewOfDocuments(transaction, docs, documentKeySet()).next(\n          () => docs as DocumentMap\n        )\n      );\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   * @param transaction - The transaction this operation is scoped to.\n   * @param docs - The documents to apply local mutations to get the local views.\n   * @param existenceStateChanged - The set of document keys whose existence state\n   *   is changed. This is useful to determine if some documents overlay needs\n   *   to be recalculated.\n   */\n  getLocalViewOfDocuments(\n    transaction: PersistenceTransaction,\n    docs: MutableDocumentMap,\n    existenceStateChanged: DocumentKeySet = documentKeySet()\n  ): PersistencePromise<DocumentMap> {\n    const overlays = newOverlayMap();\n    return this.populateOverlays(transaction, overlays, docs).next(() => {\n      return this.computeViews(\n        transaction,\n        docs,\n        overlays,\n        existenceStateChanged\n      ).next(computeViewsResult => {\n        let result = documentMap();\n        computeViewsResult.forEach((documentKey, overlayedDocument) => {\n          result = result.insert(\n            documentKey,\n            overlayedDocument.overlayedDocument\n          );\n        });\n        return result;\n      });\n    });\n  }\n\n  /**\n   * Gets the overlayed documents for the given document map, which will include\n   * the local view of those documents and a `FieldMask` indicating which fields\n   * are mutated locally, `null` if overlay is a Set or Delete mutation.\n   */\n  getOverlayedDocuments(\n    transaction: PersistenceTransaction,\n    docs: MutableDocumentMap\n  ): PersistencePromise<OverlayedDocumentMap> {\n    const overlays = newOverlayMap();\n    return this.populateOverlays(transaction, overlays, docs).next(() =>\n      this.computeViews(transaction, docs, overlays, documentKeySet())\n    );\n  }\n\n  /**\n   * Fetches the overlays for {@code docs} and adds them to provided overlay map\n   * if the map does not already contain an entry for the given document key.\n   */\n  private populateOverlays(\n    transaction: PersistenceTransaction,\n    overlays: OverlayMap,\n    docs: MutableDocumentMap\n  ): PersistencePromise<void> {\n    const missingOverlays: DocumentKey[] = [];\n    docs.forEach(key => {\n      if (!overlays.has(key)) {\n        missingOverlays.push(key);\n      }\n    });\n    return this.documentOverlayCache\n      .getOverlays(transaction, missingOverlays)\n      .next(result => {\n        result.forEach((key, val) => {\n          overlays.set(key, val);\n        });\n      });\n  }\n\n  /**\n   * Computes the local view for the given documents.\n   *\n   * @param docs - The documents to compute views for. It also has the base\n   *   version of the documents.\n   * @param overlays - The overlays that need to be applied to the given base\n   *   version of the documents.\n   * @param existenceStateChanged - A set of documents whose existence states\n   *   might have changed. This is used to determine if we need to re-calculate\n   *   overlays from mutation queues.\n   * @return A map represents the local documents view.\n   */\n  computeViews(\n    transaction: PersistenceTransaction,\n    docs: MutableDocumentMap,\n    overlays: OverlayMap,\n    existenceStateChanged: DocumentKeySet\n  ): PersistencePromise<OverlayedDocumentMap> {\n    let recalculateDocuments = mutableDocumentMap();\n    const mutatedFields = newDocumentKeyMap<FieldMask | null>();\n    const results = newOverlayedDocumentMap();\n    docs.forEach((_, doc) => {\n      const overlay = overlays.get(doc.key);\n      // Recalculate an overlay if the document's existence state changed due to\n      // a remote event *and* the overlay is a PatchMutation. This is because\n      // document existence state can change if some patch mutation's\n      // preconditions are met.\n      // NOTE: we recalculate when `overlay` is undefined as well, because there\n      // might be a patch mutation whose precondition does not match before the\n      // change (hence overlay is undefined), but would now match.\n      if (\n        existenceStateChanged.has(doc.key) &&\n        (overlay === undefined || overlay.mutation instanceof PatchMutation)\n      ) {\n        recalculateDocuments = recalculateDocuments.insert(doc.key, doc);\n      } else if (overlay !== undefined) {\n        mutatedFields.set(doc.key, overlay.mutation.getFieldMask());\n        mutationApplyToLocalView(\n          overlay.mutation,\n          doc,\n          overlay.mutation.getFieldMask(),\n          Timestamp.now()\n        );\n      } else {\n        // no overlay exists\n        // Using EMPTY to indicate there is no overlay for the document.\n        mutatedFields.set(doc.key, FieldMask.empty());\n      }\n    });\n\n    return this.recalculateAndSaveOverlays(\n      transaction,\n      recalculateDocuments\n    ).next(recalculatedFields => {\n      recalculatedFields.forEach((documentKey, mask) =>\n        mutatedFields.set(documentKey, mask)\n      );\n      docs.forEach((documentKey, document) =>\n        results.set(\n          documentKey,\n          new OverlayedDocument(\n            document,\n            mutatedFields.get(documentKey) ?? null\n          )\n        )\n      );\n      return results;\n    });\n  }\n\n  private recalculateAndSaveOverlays(\n    transaction: PersistenceTransaction,\n    docs: MutableDocumentMap\n  ): PersistencePromise<DocumentKeyMap<FieldMask | null>> {\n    const masks = newDocumentKeyMap<FieldMask | null>();\n    // A reverse lookup map from batch id to the documents within that batch.\n    let documentsByBatchId = new SortedMap<number, DocumentKeySet>(\n      (key1: number, key2: number) => key1 - key2\n    );\n    let processed = documentKeySet();\n    return this.mutationQueue\n      .getAllMutationBatchesAffectingDocumentKeys(transaction, docs)\n      .next(batches => {\n        for (const batch of batches) {\n          batch.keys().forEach(key => {\n            const baseDoc = docs.get(key);\n            if (baseDoc === null) {\n              return;\n            }\n            let mask: FieldMask | null = masks.get(key) || FieldMask.empty();\n            mask = batch.applyToLocalView(baseDoc, mask);\n            masks.set(key, mask);\n            const newSet = (\n              documentsByBatchId.get(batch.batchId) || documentKeySet()\n            ).add(key);\n            documentsByBatchId = documentsByBatchId.insert(\n              batch.batchId,\n              newSet\n            );\n          });\n        }\n      })\n      .next(() => {\n        const promises: Array<PersistencePromise<void>> = [];\n        // Iterate in descending order of batch IDs, and skip documents that are\n        // already saved.\n        const iter = documentsByBatchId.getReverseIterator();\n        while (iter.hasNext()) {\n          const entry = iter.getNext();\n          const batchId = entry.key;\n          const keys = entry.value;\n          const overlays = newMutationMap();\n          keys.forEach(key => {\n            if (!processed.has(key)) {\n              const overlayMutation = calculateOverlayMutation(\n                docs.get(key)!,\n                masks.get(key)!\n              );\n              if (overlayMutation !== null) {\n                overlays.set(key, overlayMutation);\n              }\n              processed = processed.add(key);\n            }\n          });\n          promises.push(\n            this.documentOverlayCache.saveOverlays(\n              transaction,\n              batchId,\n              overlays\n            )\n          );\n        }\n        return PersistencePromise.waitFor(promises);\n      })\n      .next(() => masks);\n  }\n\n  /**\n   * Recalculates overlays by reading the documents from remote document cache\n   * first, and saves them after they are calculated.\n   */\n  recalculateAndSaveOverlaysForDocumentKeys(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet\n  ): PersistencePromise<DocumentKeyMap<FieldMask | null>> {\n    return this.remoteDocumentCache\n      .getEntries(transaction, documentKeys)\n      .next(docs => this.recalculateAndSaveOverlays(transaction, docs));\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 offset - Read time and key to start scanning by (exclusive).\n   * @param context - A optional tracker to keep a record of important details\n   *   during database local query execution.\n   */\n  getDocumentsMatchingQuery(\n    transaction: PersistenceTransaction,\n    query: Query,\n    offset: IndexOffset,\n    context?: QueryContext\n  ): PersistencePromise<DocumentMap> {\n    if (isDocumentQuery(query)) {\n      return this.getDocumentsMatchingDocumentQuery(transaction, query.path);\n    } else if (isCollectionGroupQuery(query)) {\n      return this.getDocumentsMatchingCollectionGroupQuery(\n        transaction,\n        query,\n        offset,\n        context\n      );\n    } else {\n      return this.getDocumentsMatchingCollectionQuery(\n        transaction,\n        query,\n        offset,\n        context\n      );\n    }\n  }\n\n  /**\n   * Given a collection group, returns the next documents that follow the provided offset, along\n   * with an updated batch ID.\n   *\n   * <p>The documents returned by this method are ordered by remote version from the provided\n   * offset. If there are no more remote documents after the provided offset, documents with\n   * mutations in order of batch id from the offset are returned. Since all documents in a batch are\n   * returned together, the total number of documents returned can exceed {@code count}.\n   *\n   * @param transaction\n   * @param collectionGroup The collection group for the documents.\n   * @param offset The offset to index into.\n   * @param count The number of documents to return\n   * @return A LocalWriteResult with the documents that follow the provided offset and the last processed batch id.\n   */\n  getNextDocuments(\n    transaction: PersistenceTransaction,\n    collectionGroup: string,\n    offset: IndexOffset,\n    count: number\n  ): PersistencePromise<LocalWriteResult> {\n    return this.remoteDocumentCache\n      .getAllFromCollectionGroup(transaction, collectionGroup, offset, count)\n      .next((originalDocs: MutableDocumentMap) => {\n        const overlaysPromise: PersistencePromise<OverlayMap> =\n          count - originalDocs.size > 0\n            ? this.documentOverlayCache.getOverlaysForCollectionGroup(\n                transaction,\n                collectionGroup,\n                offset.largestBatchId,\n                count - originalDocs.size\n              )\n            : PersistencePromise.resolve(newOverlayMap());\n        // The callsite will use the largest batch ID together with the latest read time to create\n        // a new index offset. Since we only process batch IDs if all remote documents have been read,\n        // no overlay will increase the overall read time. This is why we only need to special case\n        // the batch id.\n        let largestBatchId = INITIAL_LARGEST_BATCH_ID;\n        let modifiedDocs = originalDocs;\n        return overlaysPromise.next(overlays => {\n          return PersistencePromise.forEach(\n            overlays,\n            (key: DocumentKey, overlay: Overlay) => {\n              if (largestBatchId < overlay.largestBatchId) {\n                largestBatchId = overlay.largestBatchId;\n              }\n              if (originalDocs.get(key)) {\n                return PersistencePromise.resolve();\n              }\n              return this.remoteDocumentCache\n                .getEntry(transaction, key)\n                .next(doc => {\n                  modifiedDocs = modifiedDocs.insert(key, doc);\n                });\n            }\n          )\n            .next(() =>\n              this.populateOverlays(transaction, overlays, originalDocs)\n            )\n            .next(() =>\n              this.computeViews(\n                transaction,\n                modifiedDocs,\n                overlays,\n                documentKeySet()\n              )\n            )\n            .next(localDocs => ({\n              batchId: largestBatchId,\n              changes: convertOverlayedDocumentMapToDocumentMap(localDocs)\n            }));\n        });\n      });\n  }\n\n  private getDocumentsMatchingDocumentQuery(\n    transaction: PersistenceTransaction,\n    docPath: ResourcePath\n  ): PersistencePromise<DocumentMap> {\n    // Just do a simple document lookup.\n    return this.getDocument(transaction, new DocumentKey(docPath)).next(\n      document => {\n        let result = documentMap();\n        if (document.isFoundDocument()) {\n          result = result.insert(document.key, document);\n        }\n        return result;\n      }\n    );\n  }\n\n  private getDocumentsMatchingCollectionGroupQuery(\n    transaction: PersistenceTransaction,\n    query: Query,\n    offset: IndexOffset,\n    context?: QueryContext\n  ): PersistencePromise<DocumentMap> {\n    debugAssert(\n      query.path.isEmpty(),\n      'Currently we only support collection group queries at the root.'\n    );\n    const collectionId = query.collectionGroup!;\n    let results = documentMap();\n    return this.indexManager\n      .getCollectionParents(transaction, collectionId)\n      .next(parents => {\n        // Perform a collection query against each parent that contains the\n        // collectionId and aggregate the results.\n        return PersistencePromise.forEach(parents, (parent: ResourcePath) => {\n          const collectionQuery = asCollectionQueryAtPath(\n            query,\n            parent.child(collectionId)\n          );\n          return this.getDocumentsMatchingCollectionQuery(\n            transaction,\n            collectionQuery,\n            offset,\n            context\n          ).next(r => {\n            r.forEach((key, doc) => {\n              results = results.insert(key, doc);\n            });\n          });\n        }).next(() => results);\n      });\n  }\n\n  private getDocumentsMatchingCollectionQuery(\n    transaction: PersistenceTransaction,\n    query: Query,\n    offset: IndexOffset,\n    context?: QueryContext\n  ): PersistencePromise<DocumentMap> {\n    // Query the remote documents and overlay mutations.\n    let overlays: OverlayMap;\n    return this.documentOverlayCache\n      .getOverlaysForCollection(transaction, query.path, offset.largestBatchId)\n      .next(result => {\n        overlays = result;\n        return this.remoteDocumentCache.getDocumentsMatchingQuery(\n          transaction,\n          query,\n          offset,\n          overlays,\n          context\n        );\n      })\n      .next(remoteDocuments => {\n        // As documents might match the query because of their overlay we need to\n        // include documents for all overlays in the initial document set.\n        overlays.forEach((_, overlay) => {\n          const key = overlay.getKey();\n          if (remoteDocuments.get(key) === null) {\n            remoteDocuments = remoteDocuments.insert(\n              key,\n              MutableDocument.newInvalidDocument(key)\n            );\n          }\n        });\n\n        // Apply the overlays and match against the query.\n        let results = documentMap();\n        remoteDocuments.forEach((key, document) => {\n          const overlay = overlays.get(key);\n          if (overlay !== undefined) {\n            mutationApplyToLocalView(\n              overlay.mutation,\n              document,\n              FieldMask.empty(),\n              Timestamp.now()\n            );\n          }\n          // Finally, insert the documents that still match the query\n          if (queryMatches(query, document)) {\n            results = results.insert(key, document);\n          }\n        });\n        return results;\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 { BundleMetadata, NamedQuery } from '../core/bundle';\nimport {\n  NamedQuery as ProtoNamedQuery,\n  BundleMetadata as ProtoBundleMetadata\n} from '../protos/firestore_bundle_proto';\n\nimport { BundleCache } from './bundle_cache';\nimport {\n  fromBundleMetadata,\n  fromProtoNamedQuery,\n  LocalSerializer\n} from './local_serializer';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\n\nexport class MemoryBundleCache implements BundleCache {\n  private bundles = new Map<string, BundleMetadata>();\n  private namedQueries = new Map<string, NamedQuery>();\n\n  constructor(private serializer: LocalSerializer) {}\n\n  getBundleMetadata(\n    transaction: PersistenceTransaction,\n    bundleId: string\n  ): PersistencePromise<BundleMetadata | undefined> {\n    return PersistencePromise.resolve(this.bundles.get(bundleId));\n  }\n\n  saveBundleMetadata(\n    transaction: PersistenceTransaction,\n    bundleMetadata: ProtoBundleMetadata\n  ): PersistencePromise<void> {\n    this.bundles.set(bundleMetadata.id!, fromBundleMetadata(bundleMetadata));\n    return PersistencePromise.resolve();\n  }\n\n  getNamedQuery(\n    transaction: PersistenceTransaction,\n    queryName: string\n  ): PersistencePromise<NamedQuery | undefined> {\n    return PersistencePromise.resolve(this.namedQueries.get(queryName));\n  }\n\n  saveNamedQuery(\n    transaction: PersistenceTransaction,\n    query: ProtoNamedQuery\n  ): PersistencePromise<void> {\n    this.namedQueries.set(query.name!, fromProtoNamedQuery(query));\n    return PersistencePromise.resolve();\n  }\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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  documentKeySet,\n  DocumentKeySet,\n  MutationMap,\n  OverlayMap,\n  newOverlayMap\n} from '../model/collections';\nimport { DocumentKey } from '../model/document_key';\nimport { Mutation } from '../model/mutation';\nimport { Overlay } from '../model/overlay';\nimport { ResourcePath } from '../model/path';\nimport { SortedMap } from '../util/sorted_map';\n\nimport { DocumentOverlayCache } from './document_overlay_cache';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\n\n/**\n * An in-memory implementation of DocumentOverlayCache.\n */\nexport class MemoryDocumentOverlayCache implements DocumentOverlayCache {\n  // A map sorted by DocumentKey, whose value is a pair of the largest batch id\n  // for the overlay and the overlay itself.\n  private overlays = new SortedMap<DocumentKey, Overlay>(\n    DocumentKey.comparator\n  );\n  private overlayByBatchId = new Map<number, DocumentKeySet>();\n\n  getOverlay(\n    transaction: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<Overlay | null> {\n    return PersistencePromise.resolve(this.overlays.get(key));\n  }\n\n  getOverlays(\n    transaction: PersistenceTransaction,\n    keys: DocumentKey[]\n  ): PersistencePromise<OverlayMap> {\n    const result = newOverlayMap();\n    return PersistencePromise.forEach(keys, (key: DocumentKey) => {\n      return this.getOverlay(transaction, key).next(overlay => {\n        if (overlay !== null) {\n          result.set(key, overlay);\n        }\n      });\n    }).next(() => result);\n  }\n\n  saveOverlays(\n    transaction: PersistenceTransaction,\n    largestBatchId: number,\n    overlays: MutationMap\n  ): PersistencePromise<void> {\n    overlays.forEach((_, mutation) => {\n      this.saveOverlay(transaction, largestBatchId, mutation);\n    });\n    return PersistencePromise.resolve();\n  }\n\n  removeOverlaysForBatchId(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet,\n    batchId: number\n  ): PersistencePromise<void> {\n    const keys = this.overlayByBatchId.get(batchId);\n    if (keys !== undefined) {\n      keys.forEach(key => (this.overlays = this.overlays.remove(key)));\n      this.overlayByBatchId.delete(batchId);\n    }\n    return PersistencePromise.resolve();\n  }\n\n  getOverlaysForCollection(\n    transaction: PersistenceTransaction,\n    collection: ResourcePath,\n    sinceBatchId: number\n  ): PersistencePromise<OverlayMap> {\n    const result = newOverlayMap();\n\n    const immediateChildrenPathLength = collection.length + 1;\n    const prefix = new DocumentKey(collection.child(''));\n    const iter = this.overlays.getIteratorFrom(prefix);\n    while (iter.hasNext()) {\n      const entry = iter.getNext();\n      const overlay = entry.value;\n      const key = overlay.getKey();\n      if (!collection.isPrefixOf(key.path)) {\n        break;\n      }\n      // Documents from sub-collections\n      if (key.path.length !== immediateChildrenPathLength) {\n        continue;\n      }\n      if (overlay.largestBatchId > sinceBatchId) {\n        result.set(overlay.getKey(), overlay);\n      }\n    }\n\n    return PersistencePromise.resolve(result);\n  }\n\n  getOverlaysForCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string,\n    sinceBatchId: number,\n    count: number\n  ): PersistencePromise<OverlayMap> {\n    let batchIdToOverlays = new SortedMap<number, OverlayMap>(\n      (key1: number, key2: number) => key1 - key2\n    );\n\n    const iter = this.overlays.getIterator();\n    while (iter.hasNext()) {\n      const entry = iter.getNext();\n      const overlay = entry.value;\n      const key = overlay.getKey();\n      if (key.getCollectionGroup() !== collectionGroup) {\n        continue;\n      }\n      if (overlay.largestBatchId > sinceBatchId) {\n        let overlaysForBatchId = batchIdToOverlays.get(overlay.largestBatchId);\n        if (overlaysForBatchId === null) {\n          overlaysForBatchId = newOverlayMap();\n          batchIdToOverlays = batchIdToOverlays.insert(\n            overlay.largestBatchId,\n            overlaysForBatchId\n          );\n        }\n        overlaysForBatchId.set(overlay.getKey(), overlay);\n      }\n    }\n\n    const result = newOverlayMap();\n    const batchIter = batchIdToOverlays.getIterator();\n    while (batchIter.hasNext()) {\n      const entry = batchIter.getNext();\n      const overlays = entry.value;\n      overlays.forEach((key, overlay) => result.set(key, overlay));\n      if (result.size() >= count) {\n        break;\n      }\n    }\n    return PersistencePromise.resolve(result);\n  }\n\n  private saveOverlay(\n    transaction: PersistenceTransaction,\n    largestBatchId: number,\n    mutation: Mutation\n  ): void {\n    // Remove the association of the overlay to its batch id.\n    const existing = this.overlays.get(mutation.key);\n    if (existing !== null) {\n      const newSet = this.overlayByBatchId\n        .get(existing.largestBatchId)!\n        .delete(mutation.key);\n      this.overlayByBatchId.set(existing.largestBatchId, newSet);\n    }\n\n    this.overlays = this.overlays.insert(\n      mutation.key,\n      new Overlay(largestBatchId, mutation)\n    );\n\n    // Create the association of this overlay to the given largestBatchId.\n    let batch = this.overlayByBatchId.get(largestBatchId);\n    if (batch === undefined) {\n      batch = documentKeySet();\n      this.overlayByBatchId.set(largestBatchId, batch);\n    }\n    this.overlayByBatchId.set(largestBatchId, batch.add(mutation.key));\n  }\n}\n","/**\n * @license\n * Copyright 2024 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS 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 { ByteString } from '../util/byte_string';\n\nimport { GlobalsCache } from './globals_cache';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\n\nexport class MemoryGlobalsCache implements GlobalsCache {\n  private sessionToken: ByteString = ByteString.EMPTY_BYTE_STRING;\n\n  getSessionToken(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<ByteString> {\n    return PersistencePromise.resolve(this.sessionToken);\n  }\n\n  setSessionToken(\n    transaction: PersistenceTransaction,\n    sessionToken: ByteString\n  ): PersistencePromise<void> {\n    this.sessionToken = sessionToken;\n    return PersistencePromise.resolve();\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 { BatchId, TargetId } from '../core/types';\nimport { documentKeySet, DocumentKeySet } from '../model/collections';\nimport { DocumentKey } from '../model/document_key';\nimport { ResourcePath } from '../model/path';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedSet } from '../util/sorted_set';\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 */\nexport class ReferenceSet {\n  // A set of outstanding references to a document sorted by key.\n  private refsByKey = new SortedSet(DocReference.compareByKey);\n\n  // A set of outstanding references to a document sorted by target id.\n  private refsByTarget = new SortedSet(DocReference.compareByTargetId);\n\n  /** Returns true if the reference set contains no references. */\n  isEmpty(): boolean {\n    return this.refsByKey.isEmpty();\n  }\n\n  /** Adds a reference to the given document key for the given ID. */\n  addReference(key: DocumentKey, id: TargetId | BatchId): void {\n    const ref = new DocReference(key, id);\n    this.refsByKey = this.refsByKey.add(ref);\n    this.refsByTarget = this.refsByTarget.add(ref);\n  }\n\n  /** Add references to the given document keys for the given ID. */\n  addReferences(keys: DocumentKeySet, id: TargetId | BatchId): void {\n    keys.forEach(key => this.addReference(key, id));\n  }\n\n  /**\n   * Removes a reference to the given document key for the given\n   * ID.\n   */\n  removeReference(key: DocumentKey, id: TargetId | BatchId): void {\n    this.removeRef(new DocReference(key, id));\n  }\n\n  removeReferences(keys: DocumentKeySet, id: TargetId | BatchId): void {\n    keys.forEach(key => this.removeReference(key, id));\n  }\n\n  /**\n   * Clears all references with a given ID. Calls removeRef() for each key\n   * removed.\n   */\n  removeReferencesForId(id: TargetId | BatchId): DocumentKey[] {\n    const emptyKey = new DocumentKey(new ResourcePath([]));\n    const startRef = new DocReference(emptyKey, id);\n    const endRef = new DocReference(emptyKey, id + 1);\n    const keys: DocumentKey[] = [];\n    this.refsByTarget.forEachInRange([startRef, endRef], ref => {\n      this.removeRef(ref);\n      keys.push(ref.key);\n    });\n    return keys;\n  }\n\n  removeAllReferences(): void {\n    this.refsByKey.forEach(ref => this.removeRef(ref));\n  }\n\n  private removeRef(ref: DocReference): void {\n    this.refsByKey = this.refsByKey.delete(ref);\n    this.refsByTarget = this.refsByTarget.delete(ref);\n  }\n\n  referencesForId(id: TargetId | BatchId): DocumentKeySet {\n    const emptyKey = new DocumentKey(new ResourcePath([]));\n    const startRef = new DocReference(emptyKey, id);\n    const endRef = new DocReference(emptyKey, id + 1);\n    let keys = documentKeySet();\n    this.refsByTarget.forEachInRange([startRef, endRef], ref => {\n      keys = keys.add(ref.key);\n    });\n    return keys;\n  }\n\n  containsKey(key: DocumentKey): boolean {\n    const ref = new DocReference(key, 0);\n    const firstRef = this.refsByKey.firstAfterOrEqual(ref);\n    return firstRef !== null && key.isEqual(firstRef.key);\n  }\n}\n\nexport class DocReference {\n  constructor(\n    public key: DocumentKey,\n    public targetOrBatchId: TargetId | BatchId\n  ) {}\n\n  /** Compare by key then by ID */\n  static compareByKey(left: DocReference, right: DocReference): number {\n    return (\n      DocumentKey.comparator(left.key, right.key) ||\n      primitiveComparator(left.targetOrBatchId, right.targetOrBatchId)\n    );\n  }\n\n  /** Compare by ID then by key */\n  static compareByTargetId(left: DocReference, right: DocReference): number {\n    return (\n      primitiveComparator(left.targetOrBatchId, right.targetOrBatchId) ||\n      DocumentKey.comparator(left.key, right.key)\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 { isCollectionGroupQuery, Query } from '../core/query';\nimport { BatchId } from '../core/types';\nimport { Timestamp } from '../lite-api/timestamp';\nimport { DocumentKey } from '../model/document_key';\nimport { Mutation } from '../model/mutation';\nimport { MutationBatch } from '../model/mutation_batch';\nimport { debugAssert, hardAssert } from '../util/assert';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedMap } from '../util/sorted_map';\nimport { SortedSet } from '../util/sorted_set';\nimport { BATCHID_UNKNOWN } from '../util/types';\n\nimport { IndexManager } from './index_manager';\nimport { MutationQueue } from './mutation_queue';\nimport { ReferenceDelegate } from './persistence';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { DocReference } from './reference_set';\n\nexport class MemoryMutationQueue implements MutationQueue {\n  /**\n   * The set of all mutations that have been sent but not yet been applied to\n   * the backend.\n   */\n  private mutationQueue: MutationBatch[] = [];\n\n  /** Next value to use when assigning sequential IDs to each mutation batch. */\n  private nextBatchId: BatchId = 1;\n\n  /** An ordered mapping between documents and the mutations batch IDs. */\n  private batchesByDocumentKey = new SortedSet(DocReference.compareByKey);\n\n  constructor(\n    private readonly indexManager: IndexManager,\n    private readonly referenceDelegate: ReferenceDelegate\n  ) {}\n\n  checkEmpty(transaction: PersistenceTransaction): PersistencePromise<boolean> {\n    return PersistencePromise.resolve(this.mutationQueue.length === 0);\n  }\n\n  addMutationBatch(\n    transaction: PersistenceTransaction,\n    localWriteTime: Timestamp,\n    baseMutations: Mutation[],\n    mutations: Mutation[]\n  ): PersistencePromise<MutationBatch> {\n    debugAssert(mutations.length !== 0, 'Mutation batches should not be empty');\n\n    const batchId = this.nextBatchId;\n    this.nextBatchId++;\n\n    if (this.mutationQueue.length > 0) {\n      const prior = this.mutationQueue[this.mutationQueue.length - 1];\n      debugAssert(\n        prior.batchId < batchId,\n        'Mutation batchIDs must be monotonically increasing order'\n      );\n    }\n\n    const batch = new MutationBatch(\n      batchId,\n      localWriteTime,\n      baseMutations,\n      mutations\n    );\n    this.mutationQueue.push(batch);\n\n    // Track references by document key and index collection parents.\n    for (const mutation of mutations) {\n      this.batchesByDocumentKey = this.batchesByDocumentKey.add(\n        new DocReference(mutation.key, batchId)\n      );\n\n      this.indexManager.addToCollectionParentIndex(\n        transaction,\n        mutation.key.path.popLast()\n      );\n    }\n\n    return PersistencePromise.resolve(batch);\n  }\n\n  lookupMutationBatch(\n    transaction: PersistenceTransaction,\n    batchId: BatchId\n  ): PersistencePromise<MutationBatch | null> {\n    return PersistencePromise.resolve(this.findMutationBatch(batchId));\n  }\n\n  getNextMutationBatchAfterBatchId(\n    transaction: PersistenceTransaction,\n    batchId: BatchId\n  ): PersistencePromise<MutationBatch | null> {\n    const nextBatchId = batchId + 1;\n\n    // The requested batchId may still be out of range so normalize it to the\n    // start of the queue.\n    const rawIndex = this.indexOfBatchId(nextBatchId);\n    const index = rawIndex < 0 ? 0 : rawIndex;\n    return PersistencePromise.resolve(\n      this.mutationQueue.length > index ? this.mutationQueue[index] : null\n    );\n  }\n\n  getHighestUnacknowledgedBatchId(): PersistencePromise<BatchId> {\n    return PersistencePromise.resolve(\n      this.mutationQueue.length === 0 ? BATCHID_UNKNOWN : this.nextBatchId - 1\n    );\n  }\n\n  getAllMutationBatches(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<MutationBatch[]> {\n    return PersistencePromise.resolve(this.mutationQueue.slice());\n  }\n\n  getAllMutationBatchesAffectingDocumentKey(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey\n  ): PersistencePromise<MutationBatch[]> {\n    const start = new DocReference(documentKey, 0);\n    const end = new DocReference(documentKey, Number.POSITIVE_INFINITY);\n    const result: MutationBatch[] = [];\n    this.batchesByDocumentKey.forEachInRange([start, end], ref => {\n      debugAssert(\n        documentKey.isEqual(ref.key),\n        \"Should only iterate over a single key's batches\"\n      );\n      const batch = this.findMutationBatch(ref.targetOrBatchId);\n      debugAssert(\n        batch !== null,\n        'Batches in the index must exist in the main table'\n      );\n      result.push(batch!);\n    });\n\n    return PersistencePromise.resolve(result);\n  }\n\n  getAllMutationBatchesAffectingDocumentKeys(\n    transaction: PersistenceTransaction,\n    documentKeys: SortedMap<DocumentKey, unknown>\n  ): PersistencePromise<MutationBatch[]> {\n    let uniqueBatchIDs = new SortedSet<number>(primitiveComparator);\n\n    documentKeys.forEach(documentKey => {\n      const start = new DocReference(documentKey, 0);\n      const end = new DocReference(documentKey, Number.POSITIVE_INFINITY);\n      this.batchesByDocumentKey.forEachInRange([start, end], ref => {\n        debugAssert(\n          documentKey.isEqual(ref.key),\n          \"For each key, should only iterate over a single key's batches\"\n        );\n\n        uniqueBatchIDs = uniqueBatchIDs.add(ref.targetOrBatchId);\n      });\n    });\n\n    return PersistencePromise.resolve(this.findMutationBatches(uniqueBatchIDs));\n  }\n\n  getAllMutationBatchesAffectingQuery(\n    transaction: PersistenceTransaction,\n    query: Query\n  ): PersistencePromise<MutationBatch[]> {\n    debugAssert(\n      !isCollectionGroupQuery(query),\n      'CollectionGroup queries should be handled in LocalDocumentsView'\n    );\n    // Use the query path as a prefix for testing if a document matches the\n    // query.\n    const prefix = query.path;\n    const immediateChildrenPathLength = prefix.length + 1;\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    let startPath = prefix;\n    if (!DocumentKey.isDocumentKey(startPath)) {\n      startPath = startPath.child('');\n    }\n\n    const start = new DocReference(new DocumentKey(startPath), 0);\n\n    // Find unique batchIDs referenced by all documents potentially matching the\n    // query.\n    let uniqueBatchIDs = new SortedSet<number>(primitiveComparator);\n\n    this.batchesByDocumentKey.forEachWhile(ref => {\n      const rowKeyPath = ref.key.path;\n      if (!prefix.isPrefixOf(rowKeyPath)) {\n        return false;\n      } else {\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        if (rowKeyPath.length === immediateChildrenPathLength) {\n          uniqueBatchIDs = uniqueBatchIDs.add(ref.targetOrBatchId);\n        }\n        return true;\n      }\n    }, start);\n\n    return PersistencePromise.resolve(this.findMutationBatches(uniqueBatchIDs));\n  }\n\n  private findMutationBatches(batchIDs: SortedSet<number>): MutationBatch[] {\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    const result: MutationBatch[] = [];\n    batchIDs.forEach(batchId => {\n      const batch = this.findMutationBatch(batchId);\n      if (batch !== null) {\n        result.push(batch);\n      }\n    });\n    return result;\n  }\n\n  removeMutationBatch(\n    transaction: PersistenceTransaction,\n    batch: MutationBatch\n  ): PersistencePromise<void> {\n    // Find the position of the first batch for removal.\n    const batchIndex = this.indexOfExistingBatchId(batch.batchId, 'removed');\n    hardAssert(\n      batchIndex === 0,\n      'Can only remove the first entry of the mutation queue'\n    );\n    this.mutationQueue.shift();\n\n    let references = this.batchesByDocumentKey;\n    return PersistencePromise.forEach(batch.mutations, (mutation: Mutation) => {\n      const ref = new DocReference(mutation.key, batch.batchId);\n      references = references.delete(ref);\n      return this.referenceDelegate.markPotentiallyOrphaned(\n        transaction,\n        mutation.key\n      );\n    }).next(() => {\n      this.batchesByDocumentKey = references;\n    });\n  }\n\n  removeCachedMutationKeys(batchId: BatchId): void {\n    // No-op since the memory mutation queue does not maintain a separate cache.\n  }\n\n  containsKey(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<boolean> {\n    const ref = new DocReference(key, 0);\n    const firstRef = this.batchesByDocumentKey.firstAfterOrEqual(ref);\n    return PersistencePromise.resolve(key.isEqual(firstRef && firstRef.key));\n  }\n\n  performConsistencyCheck(\n    txn: PersistenceTransaction\n  ): PersistencePromise<void> {\n    if (this.mutationQueue.length === 0) {\n      debugAssert(\n        this.batchesByDocumentKey.isEmpty(),\n        'Document leak -- detected dangling mutation references when queue is empty.'\n      );\n    }\n    return PersistencePromise.resolve();\n  }\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  private indexOfExistingBatchId(batchId: BatchId, action: string): number {\n    const index = this.indexOfBatchId(batchId);\n    debugAssert(\n      index >= 0 && index < this.mutationQueue.length,\n      'Batches must exist to be ' + action\n    );\n    return index;\n  }\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 removed from the queue or past the end of the\n   * queue if the batchId is larger than the last added batch.\n   */\n  private indexOfBatchId(batchId: BatchId): number {\n    if (this.mutationQueue.length === 0) {\n      // As an index this is past the end of the queue\n      return 0;\n    }\n\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    const firstBatchId = this.mutationQueue[0].batchId;\n    return batchId - firstBatchId;\n  }\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 efficient.\n   */\n  private findMutationBatch(batchId: BatchId): MutationBatch | null {\n    const index = this.indexOfBatchId(batchId);\n    if (index < 0 || index >= this.mutationQueue.length) {\n      return null;\n    }\n\n    const batch = this.mutationQueue[index];\n    debugAssert(batch.batchId === batchId, 'If found batch must match');\n    return batch;\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, queryMatches } from '../core/query';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport {\n  DocumentKeySet,\n  MutableDocumentMap,\n  mutableDocumentMap,\n  OverlayMap\n} from '../model/collections';\nimport { Document, MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport {\n  IndexOffset,\n  indexOffsetComparator,\n  newIndexOffsetFromDocument\n} from '../model/field_index';\nimport { debugAssert, fail } from '../util/assert';\nimport { SortedMap } from '../util/sorted_map';\n\nimport { IndexManager } from './index_manager';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { RemoteDocumentCache } from './remote_document_cache';\nimport { RemoteDocumentChangeBuffer } from './remote_document_change_buffer';\n\nexport type DocumentSizer = (doc: Document) => number;\n\n/** Miscellaneous collection types / constants. */\ninterface MemoryRemoteDocumentCacheEntry {\n  document: Document;\n  size: number;\n}\n\ntype DocumentEntryMap = SortedMap<DocumentKey, MemoryRemoteDocumentCacheEntry>;\nfunction documentEntryMap(): DocumentEntryMap {\n  return new SortedMap<DocumentKey, MemoryRemoteDocumentCacheEntry>(\n    DocumentKey.comparator\n  );\n}\n\nexport interface MemoryRemoteDocumentCache extends RemoteDocumentCache {\n  forEachDocumentKey(\n    transaction: PersistenceTransaction,\n    f: (key: DocumentKey) => PersistencePromise<void>\n  ): PersistencePromise<void>;\n}\n\n/**\n * The memory-only RemoteDocumentCache for IndexedDb. To construct, invoke\n * `newMemoryRemoteDocumentCache()`.\n */\nclass MemoryRemoteDocumentCacheImpl implements MemoryRemoteDocumentCache {\n  /** Underlying cache of documents and their read times. */\n  private docs = documentEntryMap();\n  private indexManager!: IndexManager;\n\n  /** Size of all cached documents. */\n  private size = 0;\n\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  constructor(private readonly sizer: DocumentSizer) {}\n\n  setIndexManager(indexManager: IndexManager): void {\n    this.indexManager = indexManager;\n  }\n\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  addEntry(\n    transaction: PersistenceTransaction,\n    doc: MutableDocument\n  ): PersistencePromise<void> {\n    debugAssert(\n      !doc.readTime.isEqual(SnapshotVersion.min()),\n      'Cannot add a document with a read time of zero'\n    );\n\n    const key = doc.key;\n    const entry = this.docs.get(key);\n    const previousSize = entry ? entry.size : 0;\n    const currentSize = this.sizer(doc);\n\n    this.docs = this.docs.insert(key, {\n      document: doc.mutableCopy(),\n      size: currentSize\n    });\n\n    this.size += currentSize - previousSize;\n\n    return this.indexManager.addToCollectionParentIndex(\n      transaction,\n      key.path.popLast()\n    );\n  }\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  removeEntry(documentKey: DocumentKey): void {\n    const entry = this.docs.get(documentKey);\n    if (entry) {\n      this.docs = this.docs.remove(documentKey);\n      this.size -= entry.size;\n    }\n  }\n\n  getEntry(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey\n  ): PersistencePromise<MutableDocument> {\n    const entry = this.docs.get(documentKey);\n    return PersistencePromise.resolve(\n      entry\n        ? entry.document.mutableCopy()\n        : MutableDocument.newInvalidDocument(documentKey)\n    );\n  }\n\n  getEntries(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet\n  ): PersistencePromise<MutableDocumentMap> {\n    let results = mutableDocumentMap();\n    documentKeys.forEach(documentKey => {\n      const entry = this.docs.get(documentKey);\n      results = results.insert(\n        documentKey,\n        entry\n          ? entry.document.mutableCopy()\n          : MutableDocument.newInvalidDocument(documentKey)\n      );\n    });\n    return PersistencePromise.resolve(results);\n  }\n\n  getDocumentsMatchingQuery(\n    transaction: PersistenceTransaction,\n    query: Query,\n    offset: IndexOffset,\n    mutatedDocs: OverlayMap\n  ): PersistencePromise<MutableDocumentMap> {\n    let results = mutableDocumentMap();\n\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    const collectionPath = query.path;\n    const prefix = new DocumentKey(collectionPath.child(''));\n    const iterator = this.docs.getIteratorFrom(prefix);\n    while (iterator.hasNext()) {\n      const {\n        key,\n        value: { document }\n      } = iterator.getNext();\n      if (!collectionPath.isPrefixOf(key.path)) {\n        break;\n      }\n      if (key.path.length > collectionPath.length + 1) {\n        // Exclude entries from subcollections.\n        continue;\n      }\n      if (\n        indexOffsetComparator(newIndexOffsetFromDocument(document), offset) <= 0\n      ) {\n        // The document sorts before the offset.\n        continue;\n      }\n      if (!mutatedDocs.has(document.key) && !queryMatches(query, document)) {\n        // The document cannot possibly match the query.\n        continue;\n      }\n\n      results = results.insert(document.key, document.mutableCopy());\n    }\n    return PersistencePromise.resolve(results);\n  }\n\n  getAllFromCollectionGroup(\n    transaction: PersistenceTransaction,\n    collectionGroup: string,\n    offset: IndexOffset,\n    limit: number\n  ): PersistencePromise<MutableDocumentMap> {\n    // This method should only be called from the IndexBackfiller if persistence\n    // is enabled.\n    fail('getAllFromCollectionGroup() is not supported.');\n  }\n\n  forEachDocumentKey(\n    transaction: PersistenceTransaction,\n    f: (key: DocumentKey) => PersistencePromise<void>\n  ): PersistencePromise<void> {\n    return PersistencePromise.forEach(this.docs, (key: DocumentKey) => f(key));\n  }\n\n  newChangeBuffer(options?: {\n    trackRemovals: boolean;\n  }): RemoteDocumentChangeBuffer {\n    // `trackRemovals` is ignores since the MemoryRemoteDocumentCache keeps\n    // a separate changelog and does not need special handling for removals.\n    return new MemoryRemoteDocumentChangeBuffer(this);\n  }\n\n  getSize(txn: PersistenceTransaction): PersistencePromise<number> {\n    return PersistencePromise.resolve(this.size);\n  }\n}\n\n/**\n * Creates a new memory-only RemoteDocumentCache.\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 */\nexport function newMemoryRemoteDocumentCache(\n  sizer: DocumentSizer\n): MemoryRemoteDocumentCache {\n  return new MemoryRemoteDocumentCacheImpl(sizer);\n}\n\n/**\n * Handles the details of adding and updating documents in the MemoryRemoteDocumentCache.\n */\nclass MemoryRemoteDocumentChangeBuffer extends RemoteDocumentChangeBuffer {\n  constructor(private readonly documentCache: MemoryRemoteDocumentCacheImpl) {\n    super();\n  }\n\n  protected applyChanges(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<void> {\n    const promises: Array<PersistencePromise<void>> = [];\n    this.changes.forEach((key, doc) => {\n      if (doc.isValidDocument()) {\n        promises.push(this.documentCache.addEntry(transaction, doc));\n      } else {\n        this.documentCache.removeEntry(key);\n      }\n    });\n    return PersistencePromise.waitFor(promises);\n  }\n\n  protected getFromCache(\n    transaction: PersistenceTransaction,\n    documentKey: DocumentKey\n  ): PersistencePromise<MutableDocument> {\n    return this.documentCache.getEntry(transaction, documentKey);\n  }\n\n  protected getAllFromCache(\n    transaction: PersistenceTransaction,\n    documentKeys: DocumentKeySet\n  ): PersistencePromise<MutableDocumentMap> {\n    return this.documentCache.getEntries(transaction, documentKeys);\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 { SnapshotVersion } from '../core/snapshot_version';\nimport { canonifyTarget, Target, targetEquals } from '../core/target';\nimport { TargetIdGenerator } from '../core/target_id_generator';\nimport { ListenSequenceNumber, TargetId } from '../core/types';\nimport { DocumentKeySet } from '../model/collections';\nimport { DocumentKey } from '../model/document_key';\nimport { debugAssert } from '../util/assert';\nimport { ObjectMap } from '../util/obj_map';\n\nimport { ActiveTargets } from './lru_garbage_collector';\nimport { Persistence } from './persistence';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { ReferenceSet } from './reference_set';\nimport { TargetCache } from './target_cache';\nimport { TargetData } from './target_data';\n\nexport class MemoryTargetCache implements TargetCache {\n  /**\n   * Maps a target to the data about that target\n   */\n  private targets = new ObjectMap<Target, TargetData>(\n    t => canonifyTarget(t),\n    targetEquals\n  );\n\n  /** The last received snapshot version. */\n  private lastRemoteSnapshotVersion = SnapshotVersion.min();\n  /** The highest numbered target ID encountered. */\n  private highestTargetId: TargetId = 0;\n  /** The highest sequence number encountered. */\n  private highestSequenceNumber: ListenSequenceNumber = 0;\n  /**\n   * A ordered bidirectional mapping between documents and the remote target\n   * IDs.\n   */\n  private references = new ReferenceSet();\n\n  private targetCount = 0;\n\n  private targetIdGenerator = TargetIdGenerator.forTargetCache();\n\n  constructor(private readonly persistence: Persistence) {}\n\n  forEachTarget(\n    txn: PersistenceTransaction,\n    f: (q: TargetData) => void\n  ): PersistencePromise<void> {\n    this.targets.forEach((_, targetData) => f(targetData));\n    return PersistencePromise.resolve();\n  }\n\n  getLastRemoteSnapshotVersion(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<SnapshotVersion> {\n    return PersistencePromise.resolve(this.lastRemoteSnapshotVersion);\n  }\n\n  getHighestSequenceNumber(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<ListenSequenceNumber> {\n    return PersistencePromise.resolve(this.highestSequenceNumber);\n  }\n\n  allocateTargetId(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<TargetId> {\n    this.highestTargetId = this.targetIdGenerator.next();\n    return PersistencePromise.resolve(this.highestTargetId);\n  }\n\n  setTargetsMetadata(\n    transaction: PersistenceTransaction,\n    highestListenSequenceNumber: number,\n    lastRemoteSnapshotVersion?: SnapshotVersion\n  ): PersistencePromise<void> {\n    if (lastRemoteSnapshotVersion) {\n      this.lastRemoteSnapshotVersion = lastRemoteSnapshotVersion;\n    }\n    if (highestListenSequenceNumber > this.highestSequenceNumber) {\n      this.highestSequenceNumber = highestListenSequenceNumber;\n    }\n    return PersistencePromise.resolve();\n  }\n\n  private saveTargetData(targetData: TargetData): void {\n    this.targets.set(targetData.target, targetData);\n    const targetId = targetData.targetId;\n    if (targetId > this.highestTargetId) {\n      this.targetIdGenerator = new TargetIdGenerator(targetId);\n      this.highestTargetId = targetId;\n    }\n    if (targetData.sequenceNumber > this.highestSequenceNumber) {\n      this.highestSequenceNumber = targetData.sequenceNumber;\n    }\n  }\n\n  addTargetData(\n    transaction: PersistenceTransaction,\n    targetData: TargetData\n  ): PersistencePromise<void> {\n    debugAssert(\n      !this.targets.has(targetData.target),\n      'Adding a target that already exists'\n    );\n    this.saveTargetData(targetData);\n    this.targetCount += 1;\n    return PersistencePromise.resolve();\n  }\n\n  updateTargetData(\n    transaction: PersistenceTransaction,\n    targetData: TargetData\n  ): PersistencePromise<void> {\n    debugAssert(\n      this.targets.has(targetData.target),\n      'Updating a nonexistent target'\n    );\n    this.saveTargetData(targetData);\n    return PersistencePromise.resolve();\n  }\n\n  removeTargetData(\n    transaction: PersistenceTransaction,\n    targetData: TargetData\n  ): PersistencePromise<void> {\n    debugAssert(this.targetCount > 0, 'Removing a target from an empty cache');\n    debugAssert(\n      this.targets.has(targetData.target),\n      'Removing a nonexistent target from the cache'\n    );\n    this.targets.delete(targetData.target);\n    this.references.removeReferencesForId(targetData.targetId);\n    this.targetCount -= 1;\n    return PersistencePromise.resolve();\n  }\n\n  removeTargets(\n    transaction: PersistenceTransaction,\n    upperBound: ListenSequenceNumber,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<number> {\n    let count = 0;\n    const removals: Array<PersistencePromise<void>> = [];\n    this.targets.forEach((key, targetData) => {\n      if (\n        targetData.sequenceNumber <= upperBound &&\n        activeTargetIds.get(targetData.targetId) === null\n      ) {\n        this.targets.delete(key);\n        removals.push(\n          this.removeMatchingKeysForTargetId(transaction, targetData.targetId)\n        );\n        count++;\n      }\n    });\n    return PersistencePromise.waitFor(removals).next(() => count);\n  }\n\n  getTargetCount(\n    transaction: PersistenceTransaction\n  ): PersistencePromise<number> {\n    return PersistencePromise.resolve(this.targetCount);\n  }\n\n  getTargetData(\n    transaction: PersistenceTransaction,\n    target: Target\n  ): PersistencePromise<TargetData | null> {\n    const targetData = this.targets.get(target) || null;\n    return PersistencePromise.resolve(targetData);\n  }\n\n  addMatchingKeys(\n    txn: PersistenceTransaction,\n    keys: DocumentKeySet,\n    targetId: TargetId\n  ): PersistencePromise<void> {\n    this.references.addReferences(keys, targetId);\n    return PersistencePromise.resolve();\n  }\n\n  removeMatchingKeys(\n    txn: PersistenceTransaction,\n    keys: DocumentKeySet,\n    targetId: TargetId\n  ): PersistencePromise<void> {\n    this.references.removeReferences(keys, targetId);\n    const referenceDelegate = this.persistence.referenceDelegate;\n    const promises: Array<PersistencePromise<void>> = [];\n    if (referenceDelegate) {\n      keys.forEach(key => {\n        promises.push(referenceDelegate.markPotentiallyOrphaned(txn, key));\n      });\n    }\n    return PersistencePromise.waitFor(promises);\n  }\n\n  removeMatchingKeysForTargetId(\n    txn: PersistenceTransaction,\n    targetId: TargetId\n  ): PersistencePromise<void> {\n    this.references.removeReferencesForId(targetId);\n    return PersistencePromise.resolve();\n  }\n\n  getMatchingKeysForTargetId(\n    txn: PersistenceTransaction,\n    targetId: TargetId\n  ): PersistencePromise<DocumentKeySet> {\n    const matchingKeys = this.references.referencesForId(targetId);\n    return PersistencePromise.resolve(matchingKeys);\n  }\n\n  containsKey(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<boolean> {\n    return PersistencePromise.resolve(this.references.containsKey(key));\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 { User } from '../auth/user';\nimport { ListenSequence } from '../core/listen_sequence';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { ListenSequenceNumber, TargetId } from '../core/types';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { estimateByteSize } from '../model/values';\nimport { JsonProtoSerializer } from '../remote/serializer';\nimport { fail } from '../util/assert';\nimport { logDebug } from '../util/log';\nimport { ObjectMap } from '../util/obj_map';\n\nimport { DocumentOverlayCache } from './document_overlay_cache';\nimport { encodeResourcePath } from './encoded_resource_path';\nimport { GlobalsCache } from './globals_cache';\nimport { IndexManager } from './index_manager';\nimport { LocalSerializer } from './local_serializer';\nimport {\n  ActiveTargets,\n  LruDelegate,\n  LruGarbageCollector,\n  LruParams\n} from './lru_garbage_collector';\nimport { newLruGarbageCollector } from './lru_garbage_collector_impl';\nimport { MemoryBundleCache } from './memory_bundle_cache';\nimport { MemoryDocumentOverlayCache } from './memory_document_overlay_cache';\nimport { MemoryGlobalsCache } from './memory_globals_cache';\nimport { MemoryIndexManager } from './memory_index_manager';\nimport { MemoryMutationQueue } from './memory_mutation_queue';\nimport {\n  MemoryRemoteDocumentCache,\n  newMemoryRemoteDocumentCache\n} from './memory_remote_document_cache';\nimport { MemoryTargetCache } from './memory_target_cache';\nimport { MutationQueue } from './mutation_queue';\nimport { Persistence, ReferenceDelegate } from './persistence';\nimport { PersistencePromise } from './persistence_promise';\nimport {\n  PersistenceTransaction,\n  PersistenceTransactionMode\n} from './persistence_transaction';\nimport { ReferenceSet } from './reference_set';\nimport { TargetData } from './target_data';\n\nconst LOG_TAG = 'MemoryPersistence';\n/**\n * A memory-backed instance of Persistence. Data is stored only in RAM and\n * not persisted across sessions.\n */\nexport class MemoryPersistence implements Persistence {\n  /**\n   * Note that these are retained here to make it easier to write tests\n   * affecting both the in-memory and IndexedDB-backed persistence layers. Tests\n   * can create a new LocalStore wrapping this Persistence instance and this\n   * will make the in-memory persistence layer behave as if it were actually\n   * persisting values.\n   */\n  private readonly indexManager: MemoryIndexManager;\n  private readonly globalsCache: MemoryGlobalsCache;\n  private mutationQueues: { [user: string]: MemoryMutationQueue } = {};\n  private overlays: { [user: string]: MemoryDocumentOverlayCache } = {};\n  private readonly remoteDocumentCache: MemoryRemoteDocumentCache;\n  private readonly targetCache: MemoryTargetCache;\n  private readonly bundleCache: MemoryBundleCache;\n  private readonly listenSequence = new ListenSequence(0);\n  private serializer: LocalSerializer;\n\n  private _started = false;\n\n  readonly referenceDelegate: MemoryReferenceDelegate;\n\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  constructor(\n    referenceDelegateFactory: (p: MemoryPersistence) => MemoryReferenceDelegate,\n    serializer: JsonProtoSerializer\n  ) {\n    this._started = true;\n    this.globalsCache = new MemoryGlobalsCache();\n    this.referenceDelegate = referenceDelegateFactory(this);\n    this.targetCache = new MemoryTargetCache(this);\n    const sizer = (doc: Document): number =>\n      this.referenceDelegate.documentSize(doc);\n    this.indexManager = new MemoryIndexManager();\n    this.remoteDocumentCache = newMemoryRemoteDocumentCache(sizer);\n    this.serializer = new LocalSerializer(serializer);\n    this.bundleCache = new MemoryBundleCache(this.serializer);\n  }\n\n  start(): Promise<void> {\n    return Promise.resolve();\n  }\n\n  shutdown(): Promise<void> {\n    // No durable state to ensure is closed on shutdown.\n    this._started = false;\n    return Promise.resolve();\n  }\n\n  get started(): boolean {\n    return this._started;\n  }\n\n  setDatabaseDeletedListener(): void {\n    // No op.\n  }\n\n  setNetworkEnabled(): void {\n    // No op.\n  }\n\n  getIndexManager(user: User): MemoryIndexManager {\n    // We do not currently support indices for memory persistence, so we can\n    // return the same shared instance of the memory index manager.\n    return this.indexManager;\n  }\n\n  getDocumentOverlayCache(user: User): DocumentOverlayCache {\n    let overlay = this.overlays[user.toKey()];\n    if (!overlay) {\n      overlay = new MemoryDocumentOverlayCache();\n      this.overlays[user.toKey()] = overlay;\n    }\n    return overlay;\n  }\n\n  getMutationQueue(user: User, indexManager: IndexManager): MutationQueue {\n    let queue = this.mutationQueues[user.toKey()];\n    if (!queue) {\n      queue = new MemoryMutationQueue(indexManager, this.referenceDelegate);\n      this.mutationQueues[user.toKey()] = queue;\n    }\n    return queue;\n  }\n\n  getGlobalsCache(): GlobalsCache {\n    return this.globalsCache;\n  }\n\n  getTargetCache(): MemoryTargetCache {\n    return this.targetCache;\n  }\n\n  getRemoteDocumentCache(): MemoryRemoteDocumentCache {\n    return this.remoteDocumentCache;\n  }\n\n  getBundleCache(): MemoryBundleCache {\n    return this.bundleCache;\n  }\n\n  runTransaction<T>(\n    action: string,\n    mode: PersistenceTransactionMode,\n    transactionOperation: (\n      transaction: PersistenceTransaction\n    ) => PersistencePromise<T>\n  ): Promise<T> {\n    logDebug(LOG_TAG, 'Starting transaction:', action);\n    const txn = new MemoryTransaction(this.listenSequence.next());\n    this.referenceDelegate.onTransactionStarted();\n    return transactionOperation(txn)\n      .next(result => {\n        return this.referenceDelegate\n          .onTransactionCommitted(txn)\n          .next(() => result);\n      })\n      .toPromise()\n      .then(result => {\n        txn.raiseOnCommittedEvent();\n        return result;\n      });\n  }\n\n  mutationQueuesContainKey(\n    transaction: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<boolean> {\n    return PersistencePromise.or(\n      Object.values(this.mutationQueues).map(\n        queue => () => queue.containsKey(transaction, key)\n      )\n    );\n  }\n}\n\n/**\n * Memory persistence is not actually transactional, but future implementations\n * may have transaction-scoped state.\n */\nexport class MemoryTransaction extends PersistenceTransaction {\n  constructor(readonly currentSequenceNumber: ListenSequenceNumber) {\n    super();\n  }\n}\n\nexport interface MemoryReferenceDelegate extends ReferenceDelegate {\n  documentSize(doc: Document): number;\n  onTransactionStarted(): void;\n  onTransactionCommitted(txn: PersistenceTransaction): PersistencePromise<void>;\n}\n\nexport class MemoryEagerDelegate implements MemoryReferenceDelegate {\n  /** Tracks all documents that are active in Query views. */\n  private localViewReferences: ReferenceSet = new ReferenceSet();\n  /** The list of documents that are potentially GCed after each transaction. */\n  private _orphanedDocuments: Set</* path= */ string> | null = null;\n\n  private constructor(private readonly persistence: MemoryPersistence) {}\n\n  static factory(persistence: MemoryPersistence): MemoryEagerDelegate {\n    return new MemoryEagerDelegate(persistence);\n  }\n\n  private get orphanedDocuments(): Set<string> {\n    if (!this._orphanedDocuments) {\n      throw fail('orphanedDocuments is only valid during a transaction.');\n    } else {\n      return this._orphanedDocuments;\n    }\n  }\n\n  addReference(\n    txn: PersistenceTransaction,\n    targetId: TargetId,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.localViewReferences.addReference(key, targetId);\n    this.orphanedDocuments.delete(key.toString());\n    return PersistencePromise.resolve();\n  }\n\n  removeReference(\n    txn: PersistenceTransaction,\n    targetId: TargetId,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.localViewReferences.removeReference(key, targetId);\n    this.orphanedDocuments.add(key.toString());\n    return PersistencePromise.resolve();\n  }\n\n  markPotentiallyOrphaned(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.orphanedDocuments.add(key.toString());\n    return PersistencePromise.resolve();\n  }\n\n  removeTarget(\n    txn: PersistenceTransaction,\n    targetData: TargetData\n  ): PersistencePromise<void> {\n    const orphaned = this.localViewReferences.removeReferencesForId(\n      targetData.targetId\n    );\n    orphaned.forEach(key => this.orphanedDocuments.add(key.toString()));\n    const cache = this.persistence.getTargetCache();\n    return cache\n      .getMatchingKeysForTargetId(txn, targetData.targetId)\n      .next(keys => {\n        keys.forEach(key => this.orphanedDocuments.add(key.toString()));\n      })\n      .next(() => cache.removeTargetData(txn, targetData));\n  }\n\n  onTransactionStarted(): void {\n    this._orphanedDocuments = new Set<string>();\n  }\n\n  onTransactionCommitted(\n    txn: PersistenceTransaction\n  ): PersistencePromise<void> {\n    // Remove newly orphaned documents.\n    const cache = this.persistence.getRemoteDocumentCache();\n    const changeBuffer = cache.newChangeBuffer();\n    return PersistencePromise.forEach(\n      this.orphanedDocuments,\n      (path: string) => {\n        const key = DocumentKey.fromPath(path);\n        return this.isReferenced(txn, key).next(isReferenced => {\n          if (!isReferenced) {\n            changeBuffer.removeEntry(key, SnapshotVersion.min());\n          }\n        });\n      }\n    ).next(() => {\n      this._orphanedDocuments = null;\n      return changeBuffer.apply(txn);\n    });\n  }\n\n  updateLimboDocument(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    return this.isReferenced(txn, key).next(isReferenced => {\n      if (isReferenced) {\n        this.orphanedDocuments.delete(key.toString());\n      } else {\n        this.orphanedDocuments.add(key.toString());\n      }\n    });\n  }\n\n  documentSize(doc: Document): number {\n    // For eager GC, we don't care about the document size, there are no size thresholds.\n    return 0;\n  }\n\n  private isReferenced(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<boolean> {\n    return PersistencePromise.or([\n      () =>\n        PersistencePromise.resolve(this.localViewReferences.containsKey(key)),\n      () => this.persistence.getTargetCache().containsKey(txn, key),\n      () => this.persistence.mutationQueuesContainKey(txn, key)\n    ]);\n  }\n}\n\nexport class MemoryLruDelegate implements ReferenceDelegate, LruDelegate {\n  private orphanedSequenceNumbers: ObjectMap<\n    DocumentKey,\n    ListenSequenceNumber\n  > = new ObjectMap(\n    k => encodeResourcePath(k.path),\n    (l, r) => l.isEqual(r)\n  );\n\n  readonly garbageCollector: LruGarbageCollector;\n\n  constructor(\n    private readonly persistence: MemoryPersistence,\n    lruParams: LruParams\n  ) {\n    this.garbageCollector = newLruGarbageCollector(this, lruParams);\n  }\n\n  static factory(\n    persistence: MemoryPersistence,\n    lruParams: LruParams\n  ): MemoryLruDelegate {\n    return new MemoryLruDelegate(persistence, lruParams);\n  }\n\n  // No-ops, present so memory persistence doesn't have to care which delegate\n  // it has.\n  onTransactionStarted(): void {}\n\n  onTransactionCommitted(\n    txn: PersistenceTransaction\n  ): PersistencePromise<void> {\n    return PersistencePromise.resolve();\n  }\n\n  forEachTarget(\n    txn: PersistenceTransaction,\n    f: (q: TargetData) => void\n  ): PersistencePromise<void> {\n    return this.persistence.getTargetCache().forEachTarget(txn, f);\n  }\n\n  getSequenceNumberCount(\n    txn: PersistenceTransaction\n  ): PersistencePromise<number> {\n    const docCountPromise = this.orphanedDocumentCount(txn);\n    const targetCountPromise = this.persistence\n      .getTargetCache()\n      .getTargetCount(txn);\n    return targetCountPromise.next(targetCount =>\n      docCountPromise.next(docCount => targetCount + docCount)\n    );\n  }\n\n  private orphanedDocumentCount(\n    txn: PersistenceTransaction\n  ): PersistencePromise<number> {\n    let orphanedCount = 0;\n    return this.forEachOrphanedDocumentSequenceNumber(txn, _ => {\n      orphanedCount++;\n    }).next(() => orphanedCount);\n  }\n\n  forEachOrphanedDocumentSequenceNumber(\n    txn: PersistenceTransaction,\n    f: (sequenceNumber: ListenSequenceNumber) => void\n  ): PersistencePromise<void> {\n    return PersistencePromise.forEach(\n      this.orphanedSequenceNumbers,\n      (key, sequenceNumber) => {\n        // Pass in the exact sequence number as the upper bound so we know it won't be pinned by\n        // being too recent.\n        return this.isPinned(txn, key, sequenceNumber).next(isPinned => {\n          if (!isPinned) {\n            return f(sequenceNumber);\n          } else {\n            return PersistencePromise.resolve();\n          }\n        });\n      }\n    );\n  }\n\n  removeTargets(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber,\n    activeTargetIds: ActiveTargets\n  ): PersistencePromise<number> {\n    return this.persistence\n      .getTargetCache()\n      .removeTargets(txn, upperBound, activeTargetIds);\n  }\n\n  removeOrphanedDocuments(\n    txn: PersistenceTransaction,\n    upperBound: ListenSequenceNumber\n  ): PersistencePromise<number> {\n    let count = 0;\n    const cache = this.persistence.getRemoteDocumentCache();\n    const changeBuffer = cache.newChangeBuffer();\n    const p = cache.forEachDocumentKey(txn, key => {\n      return this.isPinned(txn, key, upperBound).next(isPinned => {\n        if (!isPinned) {\n          count++;\n          changeBuffer.removeEntry(key, SnapshotVersion.min());\n        }\n      });\n    });\n    return p.next(() => changeBuffer.apply(txn)).next(() => count);\n  }\n\n  markPotentiallyOrphaned(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.orphanedSequenceNumbers.set(key, txn.currentSequenceNumber);\n    return PersistencePromise.resolve();\n  }\n\n  removeTarget(\n    txn: PersistenceTransaction,\n    targetData: TargetData\n  ): PersistencePromise<void> {\n    const updated = targetData.withSequenceNumber(txn.currentSequenceNumber);\n    return this.persistence.getTargetCache().updateTargetData(txn, updated);\n  }\n\n  addReference(\n    txn: PersistenceTransaction,\n    targetId: TargetId,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.orphanedSequenceNumbers.set(key, txn.currentSequenceNumber);\n    return PersistencePromise.resolve();\n  }\n\n  removeReference(\n    txn: PersistenceTransaction,\n    targetId: TargetId,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.orphanedSequenceNumbers.set(key, txn.currentSequenceNumber);\n    return PersistencePromise.resolve();\n  }\n\n  updateLimboDocument(\n    txn: PersistenceTransaction,\n    key: DocumentKey\n  ): PersistencePromise<void> {\n    this.orphanedSequenceNumbers.set(key, txn.currentSequenceNumber);\n    return PersistencePromise.resolve();\n  }\n\n  documentSize(document: Document): number {\n    let documentSize = document.key.toString().length;\n    if (document.isFoundDocument()) {\n      documentSize += estimateByteSize(document.data.value);\n    }\n    return documentSize;\n  }\n\n  private isPinned(\n    txn: PersistenceTransaction,\n    key: DocumentKey,\n    upperBound: ListenSequenceNumber\n  ): PersistencePromise<boolean> {\n    return PersistencePromise.or([\n      () => this.persistence.mutationQueuesContainKey(txn, key),\n      () => this.persistence.getTargetCache().containsKey(txn, key),\n      () => {\n        const orphanedAt = this.orphanedSequenceNumbers.get(key);\n        return PersistencePromise.resolve(\n          orphanedAt !== undefined && orphanedAt > upperBound\n        );\n      }\n    ]);\n  }\n\n  getCacheSize(txn: PersistenceTransaction): PersistencePromise<number> {\n    return this.persistence.getRemoteDocumentCache().getSize(txn);\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 { TargetId } from '../core/types';\nimport { ChangeType, ViewSnapshot } from '../core/view_snapshot';\nimport { documentKeySet, DocumentKeySet } from '../model/collections';\n\n/**\n * A set of changes to what documents are currently in view and out of view for\n * a given query. These changes are sent to the LocalStore by the View (via\n * the SyncEngine) and are used to pin / unpin documents as appropriate.\n */\nexport class LocalViewChanges {\n  constructor(\n    readonly targetId: TargetId,\n    readonly fromCache: boolean,\n    readonly addedKeys: DocumentKeySet,\n    readonly removedKeys: DocumentKeySet\n  ) {}\n\n  static fromSnapshot(\n    targetId: TargetId,\n    viewSnapshot: ViewSnapshot\n  ): LocalViewChanges {\n    let addedKeys = documentKeySet();\n    let removedKeys = documentKeySet();\n\n    for (const docChange of viewSnapshot.docChanges) {\n      switch (docChange.type) {\n        case ChangeType.Added:\n          addedKeys = addedKeys.add(docChange.doc.key);\n          break;\n        case ChangeType.Removed:\n          removedKeys = removedKeys.add(docChange.doc.key);\n          break;\n        default:\n        // do nothing\n      }\n    }\n\n    return new LocalViewChanges(\n      targetId,\n      viewSnapshot.fromCache,\n      addedKeys,\n      removedKeys\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * A tracker to keep a record of important details during database local query\n * execution.\n */\nexport class QueryContext {\n  /**\n   * Counts the number of documents passed through during local query execution.\n   */\n  private _documentReadCount = 0;\n\n  get documentReadCount(): number {\n    return this._documentReadCount;\n  }\n\n  incrementDocumentReadCount(amount: number): void {\n    this._documentReadCount += amount;\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 { getUA, isSafari } from '@firebase/util';\n\nimport {\n  LimitType,\n  newQueryComparator,\n  Query,\n  queryMatches,\n  queryMatchesAllDocuments,\n  queryToTarget,\n  queryWithLimit,\n  stringifyQuery\n} from '../core/query';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport {\n  documentKeySet,\n  DocumentKeySet,\n  DocumentMap\n} from '../model/collections';\nimport { Document } from '../model/document';\nimport {\n  IndexOffset,\n  INITIAL_LARGEST_BATCH_ID,\n  newIndexOffsetSuccessorFromReadTime\n} from '../model/field_index';\nimport { debugAssert } from '../util/assert';\nimport { getLogLevel, logDebug, LogLevel } from '../util/log';\nimport { Iterable } from '../util/misc';\nimport { SortedSet } from '../util/sorted_set';\n\nimport { IndexManager, IndexType } from './index_manager';\nimport { LocalDocumentsView } from './local_documents_view';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { QueryContext } from './query_context';\nimport { getAndroidVersion } from './simple_db';\n\nconst DEFAULT_INDEX_AUTO_CREATION_MIN_COLLECTION_SIZE = 100;\n\n/**\n * This cost represents the evaluation result of\n * (([index, docKey] + [docKey, docContent]) per document in the result set)\n * / ([docKey, docContent] per documents in full collection scan) coming from\n * experiment [enter PR experiment URL here].\n */\nfunction getDefaultRelativeIndexReadCostPerDocument(): number {\n  // These values were derived from an experiment where several members of the\n  // Firestore SDK team ran a performance test in various environments.\n  // Googlers can see b/299284287 for details.\n  if (isSafari()) {\n    return 8;\n  } else if (getAndroidVersion(getUA()) > 0) {\n    return 6;\n  } else {\n    return 4;\n  }\n}\n\n/**\n * The Firestore query engine.\n *\n * Firestore queries can be executed in three modes. The Query Engine determines\n * what mode to use based on what data is persisted. The mode only determines\n * the runtime complexity of the query - the result set is equivalent across all\n * implementations.\n *\n * The Query engine will use indexed-based execution if a user has configured\n * any index that can be used to execute query (via `setIndexConfiguration()`).\n * Otherwise, the engine will try to optimize the query by re-using a previously\n * persisted query result. If that is not possible, the query will be executed\n * via a full collection scan.\n *\n * Index-based execution is the default when available. The query engine\n * supports partial indexed execution and merges the result from the index\n * lookup with documents that have not yet been indexed. The index evaluation\n * matches the backend's format and as such, the SDK can use indexing for all\n * queries that the backend supports.\n *\n * If no index exists, the query engine tries to take advantage of the target\n * document mapping in the TargetCache. These mappings exists for all queries\n * that have been synced with the backend at least once and allow the query\n * engine to only read documents that previously matched a query plus any\n * documents that were edited after the query was last listened to.\n *\n * There are some cases when this optimization is not guaranteed to produce\n * the same results as full collection scans. In these cases, query\n * processing falls back to full scans. These cases are:\n *\n * - Limit queries where a document that matched the query previously no longer\n *   matches the query.\n *\n * - Limit queries where a document edit may cause the document to sort below\n *   another document that is in the local cache.\n *\n * - Queries that have never been CURRENT or free of limbo documents.\n */\nexport class QueryEngine {\n  private localDocumentsView!: LocalDocumentsView;\n  private indexManager!: IndexManager;\n  private initialized = false;\n\n  indexAutoCreationEnabled = false;\n\n  /**\n   * SDK only decides whether it should create index when collection size is\n   * larger than this.\n   */\n  indexAutoCreationMinCollectionSize =\n    DEFAULT_INDEX_AUTO_CREATION_MIN_COLLECTION_SIZE;\n\n  relativeIndexReadCostPerDocument =\n    getDefaultRelativeIndexReadCostPerDocument();\n\n  /** Sets the document view to query against. */\n  initialize(\n    localDocuments: LocalDocumentsView,\n    indexManager: IndexManager\n  ): void {\n    this.localDocumentsView = localDocuments;\n    this.indexManager = indexManager;\n    this.initialized = true;\n  }\n\n  /** Returns all local documents matching the specified query. */\n  getDocumentsMatchingQuery(\n    transaction: PersistenceTransaction,\n    query: Query,\n    lastLimboFreeSnapshotVersion: SnapshotVersion,\n    remoteKeys: DocumentKeySet\n  ): PersistencePromise<DocumentMap> {\n    debugAssert(this.initialized, 'initialize() not called');\n\n    // Stores the result from executing the query; using this object is more\n    // convenient than passing the result between steps of the persistence\n    // transaction and improves readability comparatively.\n    const queryResult: { result: DocumentMap | null } = { result: null };\n\n    return this.performQueryUsingIndex(transaction, query)\n      .next(result => {\n        queryResult.result = result;\n      })\n      .next(() => {\n        if (queryResult.result) {\n          return;\n        }\n        return this.performQueryUsingRemoteKeys(\n          transaction,\n          query,\n          remoteKeys,\n          lastLimboFreeSnapshotVersion\n        ).next(result => {\n          queryResult.result = result;\n        });\n      })\n      .next(() => {\n        if (queryResult.result) {\n          return;\n        }\n        const context = new QueryContext();\n        return this.executeFullCollectionScan(transaction, query, context).next(\n          result => {\n            queryResult.result = result;\n            if (this.indexAutoCreationEnabled) {\n              return this.createCacheIndexes(\n                transaction,\n                query,\n                context,\n                result.size\n              );\n            }\n          }\n        );\n      })\n      .next(() => queryResult.result!);\n  }\n\n  createCacheIndexes(\n    transaction: PersistenceTransaction,\n    query: Query,\n    context: QueryContext,\n    resultSize: number\n  ): PersistencePromise<void> {\n    if (context.documentReadCount < this.indexAutoCreationMinCollectionSize) {\n      if (getLogLevel() <= LogLevel.DEBUG) {\n        logDebug(\n          'QueryEngine',\n          'SDK will not create cache indexes for query:',\n          stringifyQuery(query),\n          'since it only creates cache indexes for collection contains',\n          'more than or equal to',\n          this.indexAutoCreationMinCollectionSize,\n          'documents'\n        );\n      }\n      return PersistencePromise.resolve();\n    }\n\n    if (getLogLevel() <= LogLevel.DEBUG) {\n      logDebug(\n        'QueryEngine',\n        'Query:',\n        stringifyQuery(query),\n        'scans',\n        context.documentReadCount,\n        'local documents and returns',\n        resultSize,\n        'documents as results.'\n      );\n    }\n\n    if (\n      context.documentReadCount >\n      this.relativeIndexReadCostPerDocument * resultSize\n    ) {\n      if (getLogLevel() <= LogLevel.DEBUG) {\n        logDebug(\n          'QueryEngine',\n          'The SDK decides to create cache indexes for query:',\n          stringifyQuery(query),\n          'as using cache indexes may help improve performance.'\n        );\n      }\n      return this.indexManager.createTargetIndexes(\n        transaction,\n        queryToTarget(query)\n      );\n    }\n\n    return PersistencePromise.resolve();\n  }\n\n  /**\n   * Performs an indexed query that evaluates the query based on a collection's\n   * persisted index values. Returns `null` if an index is not available.\n   */\n  private performQueryUsingIndex(\n    transaction: PersistenceTransaction,\n    query: Query\n  ): PersistencePromise<DocumentMap | null> {\n    if (queryMatchesAllDocuments(query)) {\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 PersistencePromise.resolve<DocumentMap | null>(null);\n    }\n\n    let target = queryToTarget(query);\n    return this.indexManager\n      .getIndexType(transaction, target)\n      .next(indexType => {\n        if (indexType === IndexType.NONE) {\n          // The target cannot be served from any index.\n          return null;\n        }\n\n        if (query.limit !== null && indexType === IndexType.PARTIAL) {\n          // We cannot apply a limit for targets that are served using a partial\n          // index. If a partial index will be used to serve the target, the\n          // query may return a superset of documents that match the target\n          // (e.g. if the index doesn't include all the target's filters), or\n          // may return the correct set of documents in the wrong order (e.g. if\n          // the index doesn't include a segment for one of the orderBys).\n          // Therefore, a limit should not be applied in such cases.\n          query = queryWithLimit(query, null, LimitType.First);\n          target = queryToTarget(query);\n        }\n\n        return this.indexManager\n          .getDocumentsMatchingTarget(transaction, target)\n          .next(keys => {\n            debugAssert(\n              !!keys,\n              'Index manager must return results for partial and full indexes.'\n            );\n            const sortedKeys = documentKeySet(...keys);\n            return this.localDocumentsView\n              .getDocuments(transaction, sortedKeys)\n              .next(indexedDocuments => {\n                return this.indexManager\n                  .getMinOffset(transaction, target)\n                  .next(offset => {\n                    const previousResults = this.applyQuery(\n                      query,\n                      indexedDocuments\n                    );\n\n                    if (\n                      this.needsRefill(\n                        query,\n                        previousResults,\n                        sortedKeys,\n                        offset.readTime\n                      )\n                    ) {\n                      // A limit query whose boundaries change due to local\n                      // edits can be re-run against the cache by excluding the\n                      // limit. This ensures that all documents that match the\n                      // query's filters are included in the result set. The SDK\n                      // can then apply the limit once all local edits are\n                      // incorporated.\n                      return this.performQueryUsingIndex(\n                        transaction,\n                        queryWithLimit(query, null, LimitType.First)\n                      );\n                    }\n\n                    return this.appendRemainingResults(\n                      transaction,\n                      previousResults,\n                      query,\n                      offset\n                    ) as PersistencePromise<DocumentMap | null>;\n                  });\n              });\n          });\n      });\n  }\n\n  /**\n   * Performs a query based on the target's persisted query mapping. Returns\n   * `null` if the mapping is not available or cannot be used.\n   */\n  private performQueryUsingRemoteKeys(\n    transaction: PersistenceTransaction,\n    query: Query,\n    remoteKeys: DocumentKeySet,\n    lastLimboFreeSnapshotVersion: SnapshotVersion\n  ): PersistencePromise<DocumentMap | null> {\n    if (queryMatchesAllDocuments(query)) {\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 PersistencePromise.resolve<DocumentMap | null>(null);\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    if (lastLimboFreeSnapshotVersion.isEqual(SnapshotVersion.min())) {\n      return PersistencePromise.resolve<DocumentMap | null>(null);\n    }\n\n    return this.localDocumentsView!.getDocuments(transaction, remoteKeys).next(\n      documents => {\n        const previousResults = this.applyQuery(query, documents);\n\n        if (\n          this.needsRefill(\n            query,\n            previousResults,\n            remoteKeys,\n            lastLimboFreeSnapshotVersion\n          )\n        ) {\n          return PersistencePromise.resolve<DocumentMap | null>(null);\n        }\n\n        if (getLogLevel() <= LogLevel.DEBUG) {\n          logDebug(\n            'QueryEngine',\n            'Re-using previous result from %s to execute query: %s',\n            lastLimboFreeSnapshotVersion.toString(),\n            stringifyQuery(query)\n          );\n        }\n\n        // Retrieve all results for documents that were updated since the last\n        // limbo-document free remote snapshot.\n        return this.appendRemainingResults(\n          transaction,\n          previousResults,\n          query,\n          newIndexOffsetSuccessorFromReadTime(\n            lastLimboFreeSnapshotVersion,\n            INITIAL_LARGEST_BATCH_ID\n          )\n        ).next<DocumentMap | null>(results => results);\n      }\n    );\n  }\n\n  /** Applies the query filter and sorting to the provided documents.  */\n  private applyQuery(\n    query: Query,\n    documents: DocumentMap\n  ): SortedSet<Document> {\n    // Sort the documents and re-apply the query filter since previously\n    // matching documents do not necessarily still match the query.\n    let queryResults = new SortedSet<Document>(newQueryComparator(query));\n    documents.forEach((_, maybeDoc) => {\n      if (queryMatches(query, maybeDoc)) {\n        queryResults = queryResults.add(maybeDoc);\n      }\n    });\n    return queryResults;\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 query - The query.\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  private needsRefill(\n    query: Query,\n    sortedPreviousResults: SortedSet<Document>,\n    remoteKeys: DocumentKeySet,\n    limboFreeSnapshotVersion: SnapshotVersion\n  ): boolean {\n    if (query.limit === null) {\n      // Queries without limits do not need to be refilled.\n      return false;\n    }\n\n    if (remoteKeys.size !== sortedPreviousResults.size) {\n      // The query needs to be refilled if a previously matching document no\n      // longer matches.\n      return true;\n    }\n\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    const docAtLimitEdge =\n      query.limitType === LimitType.First\n        ? sortedPreviousResults.last()\n        : sortedPreviousResults.first();\n    if (!docAtLimitEdge) {\n      // We don't need to refill the query if there were already no documents.\n      return false;\n    }\n    return (\n      docAtLimitEdge.hasPendingWrites ||\n      docAtLimitEdge.version.compareTo(limboFreeSnapshotVersion) > 0\n    );\n  }\n\n  private executeFullCollectionScan(\n    transaction: PersistenceTransaction,\n    query: Query,\n    context: QueryContext\n  ): PersistencePromise<DocumentMap> {\n    if (getLogLevel() <= LogLevel.DEBUG) {\n      logDebug(\n        'QueryEngine',\n        'Using full collection scan to execute query:',\n        stringifyQuery(query)\n      );\n    }\n\n    return this.localDocumentsView!.getDocumentsMatchingQuery(\n      transaction,\n      query,\n      IndexOffset.min(),\n      context\n    );\n  }\n\n  /**\n   * Combines the results from an indexed execution with the remaining documents\n   * that have not yet been indexed.\n   */\n  private appendRemainingResults(\n    transaction: PersistenceTransaction,\n    indexedResults: Iterable<Document>,\n    query: Query,\n    offset: IndexOffset\n  ): PersistencePromise<DocumentMap> {\n    // Retrieve all results for documents that were updated since the offset.\n    return this.localDocumentsView\n      .getDocumentsMatchingQuery(transaction, query, offset)\n      .next(remainingResults => {\n        // Merge with existing results\n        indexedResults.forEach(d => {\n          remainingResults = remainingResults.insert(d.key, d);\n        });\n        return remainingResults;\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 { User } from '../auth/user';\nimport { BundleConverter, BundledDocuments, NamedQuery } from '../core/bundle';\nimport {\n  newQueryForPath,\n  Query,\n  queryCollectionGroup,\n  queryToTarget\n} from '../core/query';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { canonifyTarget, Target, targetEquals } from '../core/target';\nimport { BatchId, TargetId } from '../core/types';\nimport { Timestamp } from '../lite-api/timestamp';\nimport {\n  convertOverlayedDocumentMapToDocumentMap,\n  documentKeySet,\n  DocumentKeySet,\n  DocumentMap,\n  mutableDocumentMap,\n  MutableDocumentMap,\n  OverlayedDocumentMap\n} from '../model/collections';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport {\n  FieldIndex,\n  fieldIndexSemanticComparator,\n  INITIAL_LARGEST_BATCH_ID,\n  newIndexOffsetSuccessorFromReadTime\n} from '../model/field_index';\nimport {\n  mutationExtractBaseValue,\n  Mutation,\n  PatchMutation,\n  Precondition\n} from '../model/mutation';\nimport { MutationBatch, MutationBatchResult } from '../model/mutation_batch';\nimport { extractFieldMask } from '../model/object_value';\nimport { ResourcePath } from '../model/path';\nimport {\n  BundleMetadata,\n  NamedQuery as ProtoNamedQuery\n} from '../protos/firestore_bundle_proto';\nimport { RemoteEvent, TargetChange } from '../remote/remote_event';\nimport { fromVersion, JsonProtoSerializer } from '../remote/serializer';\nimport { diffArrays } from '../util/array';\nimport { debugAssert, debugCast, hardAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\nimport { logDebug } from '../util/log';\nimport { primitiveComparator } from '../util/misc';\nimport { ObjectMap } from '../util/obj_map';\nimport { SortedMap } from '../util/sorted_map';\nimport { BATCHID_UNKNOWN } from '../util/types';\n\nimport { BundleCache } from './bundle_cache';\nimport { DocumentOverlayCache } from './document_overlay_cache';\nimport { IndexManager } from './index_manager';\nimport { IndexedDbMutationQueue } from './indexeddb_mutation_queue';\nimport { IndexedDbPersistence } from './indexeddb_persistence';\nimport { IndexedDbTargetCache } from './indexeddb_target_cache';\nimport { LocalDocumentsView } from './local_documents_view';\nimport { fromBundledQuery } from './local_serializer';\nimport { LocalStore } from './local_store';\nimport { LocalViewChanges } from './local_view_changes';\nimport { LruGarbageCollector, LruResults } from './lru_garbage_collector';\nimport { MutationQueue } from './mutation_queue';\nimport { Persistence } from './persistence';\nimport { PersistencePromise } from './persistence_promise';\nimport { PersistenceTransaction } from './persistence_transaction';\nimport { QueryEngine } from './query_engine';\nimport { RemoteDocumentCache } from './remote_document_cache';\nimport { RemoteDocumentChangeBuffer } from './remote_document_change_buffer';\nimport { ClientId } from './shared_client_state';\nimport { isIndexedDbTransactionError } from './simple_db';\nimport { TargetCache } from './target_cache';\nimport { TargetData, TargetPurpose } from './target_data';\n\nexport const LOG_TAG = 'LocalStore';\n\n/**\n * The maximum time to leave a resume token buffered without writing it out.\n * This value is arbitrary: it's long enough to avoid several writes\n * (possibly indefinitely if updates come more frequently than this) but\n * short enough that restarting after crashing will still have a pretty\n * recent resume token.\n */\nconst RESUME_TOKEN_MAX_AGE_MICROS = 5 * 60 * 1e6;\n\n/** The result of a write to the local store. */\nexport interface LocalWriteResult {\n  batchId: BatchId;\n  changes: DocumentMap;\n}\n\n/** The result of a user-change operation in the local store. */\nexport interface UserChangeResult {\n  readonly affectedDocuments: DocumentMap;\n  readonly removedBatchIds: BatchId[];\n  readonly addedBatchIds: BatchId[];\n}\n\n/** The result of executing a query against the local store. */\nexport interface QueryResult {\n  readonly documents: DocumentMap;\n  readonly remoteKeys: DocumentKeySet;\n}\n\n/**\n * Implements `LocalStore` interface.\n *\n * Note: some field defined in this class might have public access level, but\n * the class is not exported so they are only accessible from this module.\n * This is useful to implement optional features (like bundles) in free\n * functions, such that they are tree-shakeable.\n */\nclass LocalStoreImpl implements LocalStore {\n  /**\n   * The set of all mutations that have been sent but not yet been applied to\n   * the backend.\n   */\n  mutationQueue!: MutationQueue;\n\n  /**\n   * The overlays that can be used to short circuit applying all mutations from\n   * mutation queue.\n   */\n  documentOverlayCache!: DocumentOverlayCache;\n\n  /** The set of all cached remote documents. */\n  remoteDocuments: RemoteDocumentCache;\n\n  /**\n   * The \"local\" view of all documents (layering mutationQueue on top of\n   * remoteDocumentCache).\n   */\n  localDocuments!: LocalDocumentsView;\n\n  /** Manages the list of active field and collection indices. */\n  indexManager!: IndexManager;\n\n  /** The set of all cached bundle metadata and named queries. */\n  bundleCache: BundleCache;\n\n  /** Maps a target to its `TargetData`. */\n  targetCache: TargetCache;\n\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  targetDataByTarget = new SortedMap<TargetId, TargetData>(primitiveComparator);\n\n  /** Maps a target to its targetID. */\n  // TODO(wuandy): Evaluate if TargetId can be part of Target.\n  targetIdByTarget = new ObjectMap<Target, TargetId>(\n    t => canonifyTarget(t),\n    targetEquals\n  );\n\n  /**\n   * A per collection group index of the last read time processed by\n   * `getNewDocumentChanges()`.\n   *\n   * PORTING NOTE: This is only used for multi-tab synchronization.\n   */\n  collectionGroupReadTime = new Map<string, SnapshotVersion>();\n\n  constructor(\n    /** Manages our in-memory or durable persistence. */\n    readonly persistence: Persistence,\n    readonly queryEngine: QueryEngine,\n    initialUser: User,\n    readonly serializer: JsonProtoSerializer\n  ) {\n    debugAssert(\n      persistence.started,\n      'LocalStore was passed an unstarted persistence implementation'\n    );\n    this.remoteDocuments = persistence.getRemoteDocumentCache();\n    this.targetCache = persistence.getTargetCache();\n    this.bundleCache = persistence.getBundleCache();\n\n    this.initializeUserComponents(initialUser);\n  }\n\n  initializeUserComponents(user: User): void {\n    // TODO(indexing): Add spec tests that test these components change after a\n    // user change\n    this.documentOverlayCache = this.persistence.getDocumentOverlayCache(user);\n    this.indexManager = this.persistence.getIndexManager(user);\n    this.mutationQueue = this.persistence.getMutationQueue(\n      user,\n      this.indexManager\n    );\n    this.localDocuments = new LocalDocumentsView(\n      this.remoteDocuments,\n      this.mutationQueue,\n      this.documentOverlayCache,\n      this.indexManager\n    );\n    this.remoteDocuments.setIndexManager(this.indexManager);\n    this.queryEngine.initialize(this.localDocuments, this.indexManager);\n  }\n\n  collectGarbage(garbageCollector: LruGarbageCollector): Promise<LruResults> {\n    return this.persistence.runTransaction(\n      'Collect garbage',\n      'readwrite-primary',\n      txn => garbageCollector.collect(txn, this.targetDataByTarget)\n    );\n  }\n}\n\ninterface DocumentChangeResult {\n  changedDocuments: MutableDocumentMap;\n  existenceChangedKeys: DocumentKeySet;\n}\n\nexport function newLocalStore(\n  /** Manages our in-memory or durable persistence. */\n  persistence: Persistence,\n  queryEngine: QueryEngine,\n  initialUser: User,\n  serializer: JsonProtoSerializer\n): LocalStore {\n  return new LocalStoreImpl(persistence, queryEngine, initialUser, serializer);\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.\nexport async function localStoreHandleUserChange(\n  localStore: LocalStore,\n  user: User\n): Promise<UserChangeResult> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n\n  const result = await localStoreImpl.persistence.runTransaction(\n    'Handle user change',\n    'readonly',\n    txn => {\n      // Swap out the mutation queue, grabbing the pending mutation batches\n      // before and after.\n      let oldBatches: MutationBatch[];\n      return localStoreImpl.mutationQueue\n        .getAllMutationBatches(txn)\n        .next(promisedOldBatches => {\n          oldBatches = promisedOldBatches;\n          localStoreImpl.initializeUserComponents(user);\n          return localStoreImpl.mutationQueue.getAllMutationBatches(txn);\n        })\n        .next(newBatches => {\n          const removedBatchIds: BatchId[] = [];\n          const addedBatchIds: BatchId[] = [];\n\n          // Union the old/new changed keys.\n          let changedKeys = documentKeySet();\n\n          for (const batch of oldBatches) {\n            removedBatchIds.push(batch.batchId);\n            for (const mutation of batch.mutations) {\n              changedKeys = changedKeys.add(mutation.key);\n            }\n          }\n\n          for (const batch of newBatches) {\n            addedBatchIds.push(batch.batchId);\n            for (const mutation of batch.mutations) {\n              changedKeys = changedKeys.add(mutation.key);\n            }\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 localStoreImpl.localDocuments\n            .getDocuments(txn, changedKeys)\n            .next(affectedDocuments => {\n              return {\n                affectedDocuments,\n                removedBatchIds,\n                addedBatchIds\n              };\n            });\n        });\n    }\n  );\n\n  return result;\n}\n\n/* Accepts locally generated Mutations and commit them to storage. */\nexport function localStoreWriteLocally(\n  localStore: LocalStore,\n  mutations: Mutation[]\n): Promise<LocalWriteResult> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const localWriteTime = Timestamp.now();\n  const keys = mutations.reduce((keys, m) => keys.add(m.key), documentKeySet());\n\n  let overlayedDocuments: OverlayedDocumentMap;\n  let mutationBatch: MutationBatch;\n\n  return localStoreImpl.persistence\n    .runTransaction('Locally write mutations', 'readwrite', txn => {\n      // Figure out which keys do not have a remote version in the cache, this\n      // is needed to create the right overlay mutation: if no remote version\n      // presents, we do not need to create overlays as patch mutations.\n      // TODO(Overlay): Is there a better way to determine this? Using the\n      //  document version does not work because local mutations set them back\n      //  to 0.\n      let remoteDocs = mutableDocumentMap();\n      let docsWithoutRemoteVersion = documentKeySet();\n      return localStoreImpl.remoteDocuments\n        .getEntries(txn, keys)\n        .next(docs => {\n          remoteDocs = docs;\n          remoteDocs.forEach((key, doc) => {\n            if (!doc.isValidDocument()) {\n              docsWithoutRemoteVersion = docsWithoutRemoteVersion.add(key);\n            }\n          });\n        })\n        .next(() => {\n          // Load and apply all existing mutations. This lets us compute the\n          // current base state for all non-idempotent transforms before applying\n          // any additional user-provided writes.\n          return localStoreImpl.localDocuments.getOverlayedDocuments(\n            txn,\n            remoteDocs\n          );\n        })\n        .next((docs: OverlayedDocumentMap) => {\n          overlayedDocuments = docs;\n\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          const baseMutations: Mutation[] = [];\n\n          for (const mutation of mutations) {\n            const baseValue = mutationExtractBaseValue(\n              mutation,\n              overlayedDocuments.get(mutation.key)!.overlayedDocument\n            );\n            if (baseValue != null) {\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              baseMutations.push(\n                new PatchMutation(\n                  mutation.key,\n                  baseValue,\n                  extractFieldMask(baseValue.value.mapValue),\n                  Precondition.exists(true)\n                )\n              );\n            }\n          }\n\n          return localStoreImpl.mutationQueue.addMutationBatch(\n            txn,\n            localWriteTime,\n            baseMutations,\n            mutations\n          );\n        })\n        .next(batch => {\n          mutationBatch = batch;\n          const overlays = batch.applyToLocalDocumentSet(\n            overlayedDocuments,\n            docsWithoutRemoteVersion\n          );\n          return localStoreImpl.documentOverlayCache.saveOverlays(\n            txn,\n            batch.batchId,\n            overlays\n          );\n        });\n    })\n    .then(() => ({\n      batchId: mutationBatch.batchId,\n      changes: convertOverlayedDocumentMapToDocumentMap(overlayedDocuments)\n    }));\n}\n\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 */\nexport function localStoreAcknowledgeBatch(\n  localStore: LocalStore,\n  batchResult: MutationBatchResult\n): Promise<DocumentMap> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Acknowledge batch',\n    'readwrite-primary',\n    txn => {\n      const affected = batchResult.batch.keys();\n      const documentBuffer = localStoreImpl.remoteDocuments.newChangeBuffer({\n        trackRemovals: true // Make sure document removals show up in `getNewDocumentChanges()`\n      });\n      return applyWriteToRemoteDocuments(\n        localStoreImpl,\n        txn,\n        batchResult,\n        documentBuffer\n      )\n        .next(() => documentBuffer.apply(txn))\n        .next(() => localStoreImpl.mutationQueue.performConsistencyCheck(txn))\n        .next(() =>\n          localStoreImpl.documentOverlayCache.removeOverlaysForBatchId(\n            txn,\n            affected,\n            batchResult.batch.batchId\n          )\n        )\n        .next(() =>\n          localStoreImpl.localDocuments.recalculateAndSaveOverlaysForDocumentKeys(\n            txn,\n            getKeysWithTransformResults(batchResult)\n          )\n        )\n        .next(() => localStoreImpl.localDocuments.getDocuments(txn, affected));\n    }\n  );\n}\n\nfunction getKeysWithTransformResults(\n  batchResult: MutationBatchResult\n): DocumentKeySet {\n  let result = documentKeySet();\n\n  for (let i = 0; i < batchResult.mutationResults.length; ++i) {\n    const mutationResult = batchResult.mutationResults[i];\n    if (mutationResult.transformResults.length > 0) {\n      result = result.add(batchResult.batch.mutations[i].key);\n    }\n  }\n  return result;\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 */\nexport function localStoreRejectBatch(\n  localStore: LocalStore,\n  batchId: BatchId\n): Promise<DocumentMap> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Reject batch',\n    'readwrite-primary',\n    txn => {\n      let affectedKeys: DocumentKeySet;\n      return localStoreImpl.mutationQueue\n        .lookupMutationBatch(txn, batchId)\n        .next((batch: MutationBatch | null) => {\n          hardAssert(batch !== null, 'Attempt to reject nonexistent batch!');\n          affectedKeys = batch.keys();\n          return localStoreImpl.mutationQueue.removeMutationBatch(txn, batch);\n        })\n        .next(() => localStoreImpl.mutationQueue.performConsistencyCheck(txn))\n        .next(() =>\n          localStoreImpl.documentOverlayCache.removeOverlaysForBatchId(\n            txn,\n            affectedKeys,\n            batchId\n          )\n        )\n        .next(() =>\n          localStoreImpl.localDocuments.recalculateAndSaveOverlaysForDocumentKeys(\n            txn,\n            affectedKeys\n          )\n        )\n        .next(() =>\n          localStoreImpl.localDocuments.getDocuments(txn, affectedKeys)\n        );\n    }\n  );\n}\n\n/**\n * Returns the largest (latest) batch id in mutation queue that is pending\n * server response.\n *\n * Returns `BATCHID_UNKNOWN` if the queue is empty.\n */\nexport function localStoreGetHighestUnacknowledgedBatchId(\n  localStore: LocalStore\n): Promise<BatchId> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Get highest unacknowledged batch id',\n    'readonly',\n    txn => localStoreImpl.mutationQueue.getHighestUnacknowledgedBatchId(txn)\n  );\n}\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 */\nexport function localStoreGetLastRemoteSnapshotVersion(\n  localStore: LocalStore\n): Promise<SnapshotVersion> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Get last remote snapshot version',\n    'readonly',\n    txn => localStoreImpl.targetCache.getLastRemoteSnapshotVersion(txn)\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 */\nexport function localStoreApplyRemoteEventToLocalCache(\n  localStore: LocalStore,\n  remoteEvent: RemoteEvent\n): Promise<DocumentMap> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const remoteVersion = remoteEvent.snapshotVersion;\n  let newTargetDataByTargetMap = localStoreImpl.targetDataByTarget;\n\n  return localStoreImpl.persistence\n    .runTransaction('Apply remote event', 'readwrite-primary', txn => {\n      const documentBuffer = localStoreImpl.remoteDocuments.newChangeBuffer({\n        trackRemovals: true // Make sure document removals show up in `getNewDocumentChanges()`\n      });\n\n      // Reset newTargetDataByTargetMap in case this transaction gets re-run.\n      newTargetDataByTargetMap = localStoreImpl.targetDataByTarget;\n\n      const promises = [] as Array<PersistencePromise<void>>;\n      remoteEvent.targetChanges.forEach((change, targetId) => {\n        const oldTargetData = newTargetDataByTargetMap.get(targetId);\n        if (!oldTargetData) {\n          return;\n        }\n\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        promises.push(\n          localStoreImpl.targetCache\n            .removeMatchingKeys(txn, change.removedDocuments, targetId)\n            .next(() => {\n              return localStoreImpl.targetCache.addMatchingKeys(\n                txn,\n                change.addedDocuments,\n                targetId\n              );\n            })\n        );\n\n        let newTargetData = oldTargetData.withSequenceNumber(\n          txn.currentSequenceNumber\n        );\n        if (remoteEvent.targetMismatches.get(targetId) !== null) {\n          newTargetData = newTargetData\n            .withResumeToken(\n              ByteString.EMPTY_BYTE_STRING,\n              SnapshotVersion.min()\n            )\n            .withLastLimboFreeSnapshotVersion(SnapshotVersion.min());\n        } else if (change.resumeToken.approximateByteSize() > 0) {\n          newTargetData = newTargetData.withResumeToken(\n            change.resumeToken,\n            remoteVersion\n          );\n        }\n\n        newTargetDataByTargetMap = newTargetDataByTargetMap.insert(\n          targetId,\n          newTargetData\n        );\n\n        // Update the target data if there are target changes (or if\n        // sufficient time has passed since the last update).\n        if (shouldPersistTargetData(oldTargetData, newTargetData, change)) {\n          promises.push(\n            localStoreImpl.targetCache.updateTargetData(txn, newTargetData)\n          );\n        }\n      });\n\n      let changedDocs = mutableDocumentMap();\n      let existenceChangedKeys = documentKeySet();\n      remoteEvent.documentUpdates.forEach(key => {\n        if (remoteEvent.resolvedLimboDocuments.has(key)) {\n          promises.push(\n            localStoreImpl.persistence.referenceDelegate.updateLimboDocument(\n              txn,\n              key\n            )\n          );\n        }\n      });\n\n      // Each loop iteration only affects its \"own\" doc, so it's safe to get all\n      // the remote documents in advance in a single call.\n      promises.push(\n        populateDocumentChangeBuffer(\n          txn,\n          documentBuffer,\n          remoteEvent.documentUpdates\n        ).next(result => {\n          changedDocs = result.changedDocuments;\n          existenceChangedKeys = result.existenceChangedKeys;\n        })\n      );\n\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 (!remoteVersion.isEqual(SnapshotVersion.min())) {\n        const updateRemoteVersion = localStoreImpl.targetCache\n          .getLastRemoteSnapshotVersion(txn)\n          .next(lastRemoteSnapshotVersion => {\n            debugAssert(\n              remoteVersion.compareTo(lastRemoteSnapshotVersion) >= 0,\n              'Watch stream reverted to previous snapshot?? ' +\n                remoteVersion +\n                ' < ' +\n                lastRemoteSnapshotVersion\n            );\n            return localStoreImpl.targetCache.setTargetsMetadata(\n              txn,\n              txn.currentSequenceNumber,\n              remoteVersion\n            );\n          });\n        promises.push(updateRemoteVersion);\n      }\n\n      return PersistencePromise.waitFor(promises)\n        .next(() => documentBuffer.apply(txn))\n        .next(() =>\n          localStoreImpl.localDocuments.getLocalViewOfDocuments(\n            txn,\n            changedDocs,\n            existenceChangedKeys\n          )\n        )\n        .next(() => changedDocs);\n    })\n    .then(changedDocs => {\n      localStoreImpl.targetDataByTarget = newTargetDataByTargetMap;\n      return changedDocs;\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, and\n * also a set of documents whose existence state are changed as a result.\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 */\nfunction populateDocumentChangeBuffer(\n  txn: PersistenceTransaction,\n  documentBuffer: RemoteDocumentChangeBuffer,\n  documents: MutableDocumentMap\n): PersistencePromise<DocumentChangeResult> {\n  let updatedKeys = documentKeySet();\n  let existenceChangedKeys = documentKeySet();\n  documents.forEach(k => (updatedKeys = updatedKeys.add(k)));\n  return documentBuffer.getEntries(txn, updatedKeys).next(existingDocs => {\n    let changedDocuments = mutableDocumentMap();\n    documents.forEach((key, doc) => {\n      const existingDoc = existingDocs.get(key)!;\n\n      // Check if see if there is a existence state change for this document.\n      if (doc.isFoundDocument() !== existingDoc.isFoundDocument()) {\n        existenceChangedKeys = existenceChangedKeys.add(key);\n      }\n\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      if (doc.isNoDocument() && doc.version.isEqual(SnapshotVersion.min())) {\n        // NoDocuments with SnapshotVersion.min() are used in manufactured\n        // events. We remove these documents from cache since we lost\n        // access.\n        documentBuffer.removeEntry(key, doc.readTime);\n        changedDocuments = changedDocuments.insert(key, doc);\n      } else if (\n        !existingDoc.isValidDocument() ||\n        doc.version.compareTo(existingDoc.version) > 0 ||\n        (doc.version.compareTo(existingDoc.version) === 0 &&\n          existingDoc.hasPendingWrites)\n      ) {\n        debugAssert(\n          !SnapshotVersion.min().isEqual(doc.readTime),\n          'Cannot add a document when the remote version is zero'\n        );\n        documentBuffer.addEntry(doc);\n        changedDocuments = changedDocuments.insert(key, doc);\n      } else {\n        logDebug(\n          LOG_TAG,\n          'Ignoring outdated watch update for ',\n          key,\n          '. Current version:',\n          existingDoc.version,\n          ' Watch version:',\n          doc.version\n        );\n      }\n    });\n    return { changedDocuments, existenceChangedKeys };\n  });\n}\n\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 */\nfunction shouldPersistTargetData(\n  oldTargetData: TargetData,\n  newTargetData: TargetData,\n  change: TargetChange\n): boolean {\n  // Always persist target data if we don't already have a resume token.\n  if (oldTargetData.resumeToken.approximateByteSize() === 0) {\n    return true;\n  }\n\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  const timeDelta =\n    newTargetData.snapshotVersion.toMicroseconds() -\n    oldTargetData.snapshotVersion.toMicroseconds();\n  if (timeDelta >= RESUME_TOKEN_MAX_AGE_MICROS) {\n    return true;\n  }\n\n  // Otherwise if the only thing that has changed about a target is its resume\n  // token it's not worth persisting. Note that the RemoteStore keeps an\n  // in-memory view of the currently active targets which includes the current\n  // resume token, so stream failure or user changes will still use an\n  // up-to-date resume token regardless of what we do here.\n  const changes =\n    change.addedDocuments.size +\n    change.modifiedDocuments.size +\n    change.removedDocuments.size;\n  return changes > 0;\n}\n\n/**\n * Notifies local store of the changed views to locally pin documents.\n */\nexport async function localStoreNotifyLocalViewChanges(\n  localStore: LocalStore,\n  viewChanges: LocalViewChanges[]\n): Promise<void> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  try {\n    await localStoreImpl.persistence.runTransaction(\n      'notifyLocalViewChanges',\n      'readwrite',\n      txn => {\n        return PersistencePromise.forEach(\n          viewChanges,\n          (viewChange: LocalViewChanges) => {\n            return PersistencePromise.forEach(\n              viewChange.addedKeys,\n              (key: DocumentKey) =>\n                localStoreImpl.persistence.referenceDelegate.addReference(\n                  txn,\n                  viewChange.targetId,\n                  key\n                )\n            ).next(() =>\n              PersistencePromise.forEach(\n                viewChange.removedKeys,\n                (key: DocumentKey) =>\n                  localStoreImpl.persistence.referenceDelegate.removeReference(\n                    txn,\n                    viewChange.targetId,\n                    key\n                  )\n              )\n            );\n          }\n        );\n      }\n    );\n  } catch (e) {\n    if (isIndexedDbTransactionError(e as Error)) {\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      logDebug(LOG_TAG, 'Failed to update sequence numbers: ' + e);\n    } else {\n      throw e;\n    }\n  }\n\n  for (const viewChange of viewChanges) {\n    const targetId = viewChange.targetId;\n\n    if (!viewChange.fromCache) {\n      const targetData = localStoreImpl.targetDataByTarget.get(targetId);\n      debugAssert(\n        targetData !== null,\n        `Can't set limbo-free snapshot version for unknown target: ${targetId}`\n      );\n\n      // Advance the last limbo free snapshot version\n      const lastLimboFreeSnapshotVersion = targetData.snapshotVersion;\n      const updatedTargetData = targetData.withLastLimboFreeSnapshotVersion(\n        lastLimboFreeSnapshotVersion\n      );\n      localStoreImpl.targetDataByTarget =\n        localStoreImpl.targetDataByTarget.insert(targetId, updatedTargetData);\n\n      // TODO(b/272564316): Apply the optimization done on other platforms.\n      // This is a problem for web because saving the updated targetData from\n      // non-primary client conflicts with what primary client saved.\n    }\n  }\n}\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 */\nexport function localStoreGetNextMutationBatch(\n  localStore: LocalStore,\n  afterBatchId?: BatchId\n): Promise<MutationBatch | null> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Get next mutation batch',\n    'readonly',\n    txn => {\n      if (afterBatchId === undefined) {\n        afterBatchId = BATCHID_UNKNOWN;\n      }\n      return localStoreImpl.mutationQueue.getNextMutationBatchAfterBatchId(\n        txn,\n        afterBatchId\n      );\n    }\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 */\nexport function localStoreReadDocument(\n  localStore: LocalStore,\n  key: DocumentKey\n): Promise<Document> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'read document',\n    'readonly',\n    txn => localStoreImpl.localDocuments.getDocument(txn, key)\n  );\n}\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 */\nexport function localStoreAllocateTarget(\n  localStore: LocalStore,\n  target: Target\n): Promise<TargetData> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence\n    .runTransaction('Allocate target', 'readwrite', txn => {\n      let targetData: TargetData;\n      return localStoreImpl.targetCache\n        .getTargetData(txn, target)\n        .next((cached: TargetData | null) => {\n          if (cached) {\n            // This target has been listened to previously, so reuse the\n            // previous targetID.\n            // TODO(mcg): freshen last accessed date?\n            targetData = cached;\n            return PersistencePromise.resolve(targetData);\n          } else {\n            return localStoreImpl.targetCache\n              .allocateTargetId(txn)\n              .next(targetId => {\n                targetData = new TargetData(\n                  target,\n                  targetId,\n                  TargetPurpose.Listen,\n                  txn.currentSequenceNumber\n                );\n                return localStoreImpl.targetCache\n                  .addTargetData(txn, targetData)\n                  .next(() => targetData);\n              });\n          }\n        });\n    })\n    .then(targetData => {\n      // If Multi-Tab is enabled, the existing target data may be newer than\n      // the in-memory data\n      const cachedTargetData = localStoreImpl.targetDataByTarget.get(\n        targetData.targetId\n      );\n      if (\n        cachedTargetData === null ||\n        targetData.snapshotVersion.compareTo(cachedTargetData.snapshotVersion) >\n          0\n      ) {\n        localStoreImpl.targetDataByTarget =\n          localStoreImpl.targetDataByTarget.insert(\n            targetData.targetId,\n            targetData\n          );\n        localStoreImpl.targetIdByTarget.set(target, targetData.targetId);\n      }\n      return targetData;\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.\nexport function localStoreGetTargetData(\n  localStore: LocalStore,\n  transaction: PersistenceTransaction,\n  target: Target\n): PersistencePromise<TargetData | null> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const targetId = localStoreImpl.targetIdByTarget.get(target);\n  if (targetId !== undefined) {\n    return PersistencePromise.resolve<TargetData | null>(\n      localStoreImpl.targetDataByTarget.get(targetId)\n    );\n  } else {\n    return localStoreImpl.targetCache.getTargetData(transaction, target);\n  }\n}\n\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.\nexport async function localStoreReleaseTarget(\n  localStore: LocalStore,\n  targetId: number,\n  keepPersistedTargetData: boolean\n): Promise<void> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const targetData = localStoreImpl.targetDataByTarget.get(targetId);\n  debugAssert(\n    targetData !== null,\n    `Tried to release nonexistent target: ${targetId}`\n  );\n\n  const mode = keepPersistedTargetData ? 'readwrite' : 'readwrite-primary';\n\n  try {\n    if (!keepPersistedTargetData) {\n      await localStoreImpl.persistence.runTransaction(\n        'Release target',\n        mode,\n        txn => {\n          return localStoreImpl.persistence.referenceDelegate.removeTarget(\n            txn,\n            targetData!\n          );\n        }\n      );\n    }\n  } catch (e) {\n    if (isIndexedDbTransactionError(e as Error)) {\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      logDebug(\n        LOG_TAG,\n        `Failed to update sequence numbers for target ${targetId}: ${e}`\n      );\n    } else {\n      throw e;\n    }\n  }\n\n  localStoreImpl.targetDataByTarget =\n    localStoreImpl.targetDataByTarget.remove(targetId);\n  localStoreImpl.targetIdByTarget.delete(targetData!.target);\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 */\nexport function localStoreExecuteQuery(\n  localStore: LocalStore,\n  query: Query,\n  usePreviousResults: boolean\n): Promise<QueryResult> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  let lastLimboFreeSnapshotVersion = SnapshotVersion.min();\n  let remoteKeys = documentKeySet();\n\n  return localStoreImpl.persistence.runTransaction(\n    'Execute query',\n    'readwrite', // Use readwrite instead of readonly so indexes can be created\n    txn => {\n      return localStoreGetTargetData(localStoreImpl, txn, queryToTarget(query))\n        .next(targetData => {\n          if (targetData) {\n            lastLimboFreeSnapshotVersion =\n              targetData.lastLimboFreeSnapshotVersion;\n            return localStoreImpl.targetCache\n              .getMatchingKeysForTargetId(txn, targetData.targetId)\n              .next(result => {\n                remoteKeys = result;\n              });\n          }\n        })\n        .next(() =>\n          localStoreImpl.queryEngine.getDocumentsMatchingQuery(\n            txn,\n            query,\n            usePreviousResults\n              ? lastLimboFreeSnapshotVersion\n              : SnapshotVersion.min(),\n            usePreviousResults ? remoteKeys : documentKeySet()\n          )\n        )\n        .next(documents => {\n          setMaxReadTime(\n            localStoreImpl,\n            queryCollectionGroup(query),\n            documents\n          );\n          return { documents, remoteKeys };\n        });\n    }\n  );\n}\n\nfunction applyWriteToRemoteDocuments(\n  localStoreImpl: LocalStoreImpl,\n  txn: PersistenceTransaction,\n  batchResult: MutationBatchResult,\n  documentBuffer: RemoteDocumentChangeBuffer\n): PersistencePromise<void> {\n  const batch = batchResult.batch;\n  const docKeys = batch.keys();\n  let promiseChain = PersistencePromise.resolve();\n  docKeys.forEach(docKey => {\n    promiseChain = promiseChain\n      .next(() => documentBuffer.getEntry(txn, docKey))\n      .next(doc => {\n        const ackVersion = batchResult.docVersions.get(docKey);\n        hardAssert(\n          ackVersion !== null,\n          'ackVersions should contain every doc in the write.'\n        );\n        if (doc.version.compareTo(ackVersion!) < 0) {\n          batch.applyToRemoteDocument(doc, batchResult);\n          if (doc.isValidDocument()) {\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            doc.setReadTime(batchResult.commitVersion);\n            documentBuffer.addEntry(doc);\n          }\n        }\n      });\n  });\n  return promiseChain.next(() =>\n    localStoreImpl.mutationQueue.removeMutationBatch(txn, batch)\n  );\n}\n\n/** Returns the local view of the documents affected by a mutation batch. */\n// PORTING NOTE: Multi-Tab only.\nexport function localStoreLookupMutationDocuments(\n  localStore: LocalStore,\n  batchId: BatchId\n): Promise<DocumentMap | null> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const mutationQueueImpl = debugCast(\n    localStoreImpl.mutationQueue,\n    IndexedDbMutationQueue // We only support IndexedDb in multi-tab mode.\n  );\n  return localStoreImpl.persistence.runTransaction(\n    'Lookup mutation documents',\n    'readonly',\n    txn => {\n      return mutationQueueImpl.lookupMutationKeys(txn, batchId).next(keys => {\n        if (keys) {\n          return localStoreImpl.localDocuments.getDocuments(\n            txn,\n            keys\n          ) as PersistencePromise<DocumentMap | null>;\n        } else {\n          return PersistencePromise.resolve<DocumentMap | null>(null);\n        }\n      });\n    }\n  );\n}\n\n// PORTING NOTE: Multi-Tab only.\nexport function localStoreRemoveCachedMutationBatchMetadata(\n  localStore: LocalStore,\n  batchId: BatchId\n): void {\n  const mutationQueueImpl = debugCast(\n    debugCast(localStore, LocalStoreImpl).mutationQueue,\n    IndexedDbMutationQueue // We only support IndexedDb in multi-tab mode.\n  );\n  mutationQueueImpl.removeCachedMutationKeys(batchId);\n}\n\n// PORTING NOTE: Multi-Tab only.\nexport function localStoreGetActiveClients(\n  localStore: LocalStore\n): Promise<ClientId[]> {\n  const persistenceImpl = debugCast(\n    debugCast(localStore, LocalStoreImpl).persistence,\n    IndexedDbPersistence // We only support IndexedDb in multi-tab mode.\n  );\n  return persistenceImpl.getActiveClients();\n}\n\n// PORTING NOTE: Multi-Tab only.\nexport function localStoreGetCachedTarget(\n  localStore: LocalStore,\n  targetId: TargetId\n): Promise<Target | null> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const targetCacheImpl = debugCast(\n    localStoreImpl.targetCache,\n    IndexedDbTargetCache // We only support IndexedDb in multi-tab mode.\n  );\n  const cachedTargetData = localStoreImpl.targetDataByTarget.get(targetId);\n  if (cachedTargetData) {\n    return Promise.resolve(cachedTargetData.target);\n  } else {\n    return localStoreImpl.persistence.runTransaction(\n      'Get target data',\n      'readonly',\n      txn => {\n        return targetCacheImpl\n          .getTargetDataForTarget(txn, targetId)\n          .next(targetData => (targetData ? targetData.target : null));\n      }\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.\nexport function localStoreGetNewDocumentChanges(\n  localStore: LocalStore,\n  collectionGroup: string\n): Promise<DocumentMap> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n\n  // Get the current maximum read time for the collection. This should always\n  // exist, but to reduce the chance for regressions we default to\n  // SnapshotVersion.Min()\n  // TODO(indexing): Consider removing the default value.\n  const readTime =\n    localStoreImpl.collectionGroupReadTime.get(collectionGroup) ||\n    SnapshotVersion.min();\n\n  return localStoreImpl.persistence\n    .runTransaction('Get new document changes', 'readonly', txn =>\n      localStoreImpl.remoteDocuments.getAllFromCollectionGroup(\n        txn,\n        collectionGroup,\n        newIndexOffsetSuccessorFromReadTime(readTime, INITIAL_LARGEST_BATCH_ID),\n        /* limit= */ Number.MAX_SAFE_INTEGER\n      )\n    )\n    .then(changedDocs => {\n      setMaxReadTime(localStoreImpl, collectionGroup, changedDocs);\n      return changedDocs;\n    });\n}\n\n/** Sets the collection group's maximum read time from the given documents. */\n// PORTING NOTE: Multi-Tab only.\nfunction setMaxReadTime(\n  localStoreImpl: LocalStoreImpl,\n  collectionGroup: string,\n  changedDocs: SortedMap<DocumentKey, Document>\n): void {\n  let readTime =\n    localStoreImpl.collectionGroupReadTime.get(collectionGroup) ||\n    SnapshotVersion.min();\n  changedDocs.forEach((_, doc) => {\n    if (doc.readTime.compareTo(readTime) > 0) {\n      readTime = doc.readTime;\n    }\n  });\n  localStoreImpl.collectionGroupReadTime.set(collectionGroup, readTime);\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 */\nfunction umbrellaTarget(bundleName: string): Target {\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 queryToTarget(\n    newQueryForPath(ResourcePath.fromString(`__bundle__/docs/${bundleName}`))\n  );\n}\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 */\nexport async function localStoreApplyBundledDocuments(\n  localStore: LocalStore,\n  bundleConverter: BundleConverter,\n  documents: BundledDocuments,\n  bundleName: string\n): Promise<DocumentMap> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  let documentKeys = documentKeySet();\n  let documentMap = mutableDocumentMap();\n  for (const bundleDoc of documents) {\n    const documentKey = bundleConverter.toDocumentKey(bundleDoc.metadata.name!);\n    if (bundleDoc.document) {\n      documentKeys = documentKeys.add(documentKey);\n    }\n    const doc = bundleConverter.toMutableDocument(bundleDoc);\n    doc.setReadTime(\n      bundleConverter.toSnapshotVersion(bundleDoc.metadata.readTime!)\n    );\n    documentMap = documentMap.insert(documentKey, doc);\n  }\n\n  const documentBuffer = localStoreImpl.remoteDocuments.newChangeBuffer({\n    trackRemovals: true // Make sure document removals show up in `getNewDocumentChanges()`\n  });\n\n  // Allocates a target to hold all document keys from the bundle, such that\n  // they will not get garbage collected right away.\n  const umbrellaTargetData = await localStoreAllocateTarget(\n    localStoreImpl,\n    umbrellaTarget(bundleName)\n  );\n  return localStoreImpl.persistence.runTransaction(\n    'Apply bundle documents',\n    'readwrite',\n    txn => {\n      return populateDocumentChangeBuffer(txn, documentBuffer, documentMap)\n        .next(documentChangeResult => {\n          documentBuffer.apply(txn);\n          return documentChangeResult;\n        })\n        .next(documentChangeResult => {\n          return localStoreImpl.targetCache\n            .removeMatchingKeysForTargetId(txn, umbrellaTargetData.targetId)\n            .next(() =>\n              localStoreImpl.targetCache.addMatchingKeys(\n                txn,\n                documentKeys,\n                umbrellaTargetData.targetId\n              )\n            )\n            .next(() =>\n              localStoreImpl.localDocuments.getLocalViewOfDocuments(\n                txn,\n                documentChangeResult.changedDocuments,\n                documentChangeResult.existenceChangedKeys\n              )\n            )\n            .next(() => documentChangeResult.changedDocuments);\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 */\nexport function localStoreHasNewerBundle(\n  localStore: LocalStore,\n  bundleMetadata: BundleMetadata\n): Promise<boolean> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const currentReadTime = fromVersion(bundleMetadata.createTime!);\n  return localStoreImpl.persistence\n    .runTransaction('hasNewerBundle', 'readonly', transaction => {\n      return localStoreImpl.bundleCache.getBundleMetadata(\n        transaction,\n        bundleMetadata.id!\n      );\n    })\n    .then(cached => {\n      return !!cached && cached.createTime!.compareTo(currentReadTime) >= 0;\n    });\n}\n\n/**\n * Saves the given `BundleMetadata` to local persistence.\n */\nexport function localStoreSaveBundle(\n  localStore: LocalStore,\n  bundleMetadata: BundleMetadata\n): Promise<void> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Save bundle',\n    'readwrite',\n    transaction => {\n      return localStoreImpl.bundleCache.saveBundleMetadata(\n        transaction,\n        bundleMetadata\n      );\n    }\n  );\n}\n\n/**\n * Returns a promise of a `NamedQuery` associated with given query name. Promise\n * resolves to undefined if no persisted data can be found.\n */\nexport function localStoreGetNamedQuery(\n  localStore: LocalStore,\n  queryName: string\n): Promise<NamedQuery | undefined> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Get named query',\n    'readonly',\n    transaction =>\n      localStoreImpl.bundleCache.getNamedQuery(transaction, queryName)\n  );\n}\n\n/**\n * Saves the given `NamedQuery` to local persistence.\n */\nexport async function localStoreSaveNamedQuery(\n  localStore: LocalStore,\n  query: ProtoNamedQuery,\n  documents: DocumentKeySet = documentKeySet()\n): Promise<void> {\n  // Allocate a target for the named query such that it can be resumed\n  // from associated read time if users use it to listen.\n  // NOTE: this also means if no corresponding target exists, the new target\n  // will remain active and will not get collected, unless users happen to\n  // unlisten the query somehow.\n  const allocated = await localStoreAllocateTarget(\n    localStore,\n    queryToTarget(fromBundledQuery(query.bundledQuery!))\n  );\n\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  return localStoreImpl.persistence.runTransaction(\n    'Save named query',\n    'readwrite',\n    transaction => {\n      const readTime = fromVersion(query.readTime!);\n      // Simply save the query itself if it is older than what the SDK already\n      // has.\n      if (allocated.snapshotVersion.compareTo(readTime) >= 0) {\n        return localStoreImpl.bundleCache.saveNamedQuery(transaction, query);\n      }\n\n      // Update existing target data because the query from the bundle is newer.\n      const newTargetData = allocated.withResumeToken(\n        ByteString.EMPTY_BYTE_STRING,\n        readTime\n      );\n      localStoreImpl.targetDataByTarget =\n        localStoreImpl.targetDataByTarget.insert(\n          newTargetData.targetId,\n          newTargetData\n        );\n      return localStoreImpl.targetCache\n        .updateTargetData(transaction, newTargetData)\n        .next(() =>\n          localStoreImpl.targetCache.removeMatchingKeysForTargetId(\n            transaction,\n            allocated.targetId\n          )\n        )\n        .next(() =>\n          localStoreImpl.targetCache.addMatchingKeys(\n            transaction,\n            documents,\n            allocated.targetId\n          )\n        )\n        .next(() =>\n          localStoreImpl.bundleCache.saveNamedQuery(transaction, query)\n        );\n    }\n  );\n}\n\nexport async function localStoreConfigureFieldIndexes(\n  localStore: LocalStore,\n  newFieldIndexes: FieldIndex[]\n): Promise<void> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const indexManager = localStoreImpl.indexManager;\n  const promises: Array<PersistencePromise<void>> = [];\n  return localStoreImpl.persistence.runTransaction(\n    'Configure indexes',\n    'readwrite',\n    transaction =>\n      indexManager\n        .getFieldIndexes(transaction)\n        .next(oldFieldIndexes =>\n          diffArrays(\n            oldFieldIndexes,\n            newFieldIndexes,\n            fieldIndexSemanticComparator,\n            fieldIndex => {\n              promises.push(\n                indexManager.addFieldIndex(transaction, fieldIndex)\n              );\n            },\n            fieldIndex => {\n              promises.push(\n                indexManager.deleteFieldIndex(transaction, fieldIndex)\n              );\n            }\n          )\n        )\n        .next(() => PersistencePromise.waitFor(promises))\n  );\n}\n\nexport function localStoreSetIndexAutoCreationEnabled(\n  localStore: LocalStore,\n  isEnabled: boolean\n): void {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  localStoreImpl.queryEngine.indexAutoCreationEnabled = isEnabled;\n}\n\nexport function localStoreDeleteAllFieldIndexes(\n  localStore: LocalStore\n): Promise<void> {\n  const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n  const indexManager = localStoreImpl.indexManager;\n  return localStoreImpl.persistence.runTransaction(\n    'Delete All Indexes',\n    'readwrite',\n    transaction => indexManager.deleteAllFieldIndexes(transaction)\n  );\n}\n\n/**\n * Test-only hooks into the SDK for use exclusively by tests.\n */\nexport class TestingHooks {\n  private constructor() {\n    throw new Error('creating instances is not supported');\n  }\n\n  static setIndexAutoCreationSettings(\n    localStore: LocalStore,\n    settings: {\n      indexAutoCreationMinCollectionSize?: number;\n      relativeIndexReadCostPerDocument?: number;\n    }\n  ): void {\n    const localStoreImpl = debugCast(localStore, LocalStoreImpl);\n    if (settings.indexAutoCreationMinCollectionSize !== undefined) {\n      localStoreImpl.queryEngine.indexAutoCreationMinCollectionSize =\n        settings.indexAutoCreationMinCollectionSize;\n    }\n    if (settings.relativeIndexReadCostPerDocument !== undefined) {\n      localStoreImpl.queryEngine.relativeIndexReadCostPerDocument =\n        settings.relativeIndexReadCostPerDocument;\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 { User } from '../auth/user';\nimport { ListenSequence } from '../core/listen_sequence';\nimport {\n  BatchId,\n  ListenSequenceNumber,\n  MutationBatchState,\n  OnlineState,\n  TargetId\n} from '../core/types';\nimport { TargetIdSet, targetIdSet } from '../model/collections';\nimport { hardAssert, debugAssert } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\nimport { logError, logDebug } from '../util/log';\nimport { primitiveComparator } from '../util/misc';\nimport { SortedMap } from '../util/sorted_map';\nimport { SortedSet } from '../util/sorted_set';\nimport { isSafeInteger, WindowLike } from '../util/types';\n\nimport {\n  CLIENT_STATE_KEY_PREFIX,\n  ClientStateSchema,\n  createBundleLoadedKey,\n  createWebStorageClientStateKey,\n  createWebStorageMutationBatchKey,\n  createWebStorageOnlineStateKey,\n  createWebStorageQueryTargetMetadataKey,\n  createWebStorageSequenceNumberKey,\n  MUTATION_BATCH_KEY_PREFIX,\n  MutationMetadataSchema,\n  QUERY_TARGET_KEY_PREFIX,\n  QueryTargetStateSchema,\n  SharedOnlineStateSchema\n} from './shared_client_state_schema';\nimport {\n  QueryTargetState,\n  SharedClientStateSyncer\n} from './shared_client_state_syncer';\n\nconst LOG_TAG = 'SharedClientState';\n\n/**\n * A randomly-generated key assigned to each Firestore instance at startup.\n */\nexport type ClientId = string;\n\n/**\n * A `SharedClientState` keeps track of the global state of the mutations\n * and query targets for all active clients with the same persistence key (i.e.\n * project ID and FirebaseApp name). It relays local changes to other clients\n * and updates its local state as new state is observed.\n *\n * `SharedClientState` is primarily used for synchronization in Multi-Tab\n * environments. Each tab is responsible for registering its active query\n * targets and mutations. `SharedClientState` will then notify the listener\n * assigned to `.syncEngine` for updates to mutations and queries that\n * originated in other clients.\n *\n * To receive notifications, `.syncEngine` and `.onlineStateHandler` has to be\n * assigned before calling `start()`.\n */\nexport interface SharedClientState {\n  onlineStateHandler: ((onlineState: OnlineState) => void) | null;\n  sequenceNumberHandler:\n    | ((sequenceNumber: ListenSequenceNumber) => void)\n    | null;\n\n  /** Registers the Mutation Batch ID of a newly pending mutation. */\n  addPendingMutation(batchId: BatchId): void;\n\n  /**\n   * Records that a pending mutation has been acknowledged or rejected.\n   * Called by the primary client to notify secondary clients of mutation\n   * results as they come back from the backend.\n   */\n  updateMutationState(\n    batchId: BatchId,\n    state: 'acknowledged' | 'rejected',\n    error?: FirestoreError\n  ): void;\n\n  /**\n   * Associates a new Query Target ID with the local Firestore client. Returns\n   * the new query state for the query (which can be 'current' if the query is\n   * already associated with another tab).\n   *\n   * If the target id is already associated with local client, the method simply\n   * returns its `QueryTargetState`.\n   */\n  addLocalQueryTarget(\n    targetId: TargetId,\n    addToActiveTargetIds?: boolean\n  ): QueryTargetState;\n\n  /** Removes the Query Target ID association from the local client. */\n  removeLocalQueryTarget(targetId: TargetId): void;\n\n  /** Checks whether the target is associated with the local client. */\n  isLocalQueryTarget(targetId: TargetId): boolean;\n\n  /**\n   * Processes an update to a query target.\n   *\n   * Called by the primary client to notify secondary clients of document\n   * changes or state transitions that affect the provided query target.\n   */\n  updateQueryState(\n    targetId: TargetId,\n    state: QueryTargetState,\n    error?: FirestoreError\n  ): void;\n\n  /**\n   * Removes the target's metadata entry.\n   *\n   * Called by the primary client when all clients stopped listening to a query\n   * target.\n   */\n  clearQueryState(targetId: TargetId): void;\n\n  /**\n   * Gets the active Query Targets IDs for all active clients.\n   *\n   * The implementation for this may require O(n) runtime, where 'n' is the size\n   * of the result set.\n   */\n  // Visible for testing\n  getAllActiveQueryTargets(): SortedSet<TargetId>;\n\n  /**\n   * Checks whether the provided target ID is currently being listened to by\n   * any of the active clients.\n   *\n   * The implementation may require O(n*log m) runtime, where 'n' is the number\n   * of clients and 'm' the number of targets.\n   */\n  isActiveQueryTarget(targetId: TargetId): boolean;\n\n  /**\n   * Starts the SharedClientState, reads existing client data and registers\n   * listeners for updates to new and existing clients.\n   */\n  start(): Promise<void>;\n\n  /** Shuts down the `SharedClientState` and its listeners. */\n  shutdown(): void;\n\n  /**\n   * Changes the active user and removes all existing user-specific data. The\n   * user change does not call back into SyncEngine (for example, no mutations\n   * will be marked as removed).\n   */\n  handleUserChange(\n    user: User,\n    removedBatchIds: BatchId[],\n    addedBatchIds: BatchId[]\n  ): void;\n\n  /** Changes the shared online state of all clients. */\n  setOnlineState(onlineState: OnlineState): void;\n\n  writeSequenceNumber(sequenceNumber: ListenSequenceNumber): void;\n\n  /**\n   * Notifies other clients when remote documents have changed due to loading\n   * a bundle.\n   *\n   * @param collectionGroups The collection groups affected by this bundle.\n   */\n  notifyBundleLoaded(collectionGroups: Set<string>): void;\n}\n\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\nexport class MutationMetadata {\n  constructor(\n    readonly user: User,\n    readonly batchId: BatchId,\n    readonly state: MutationBatchState,\n    readonly error?: FirestoreError\n  ) {\n    debugAssert(\n      (error !== undefined) === (state === 'rejected'),\n      `MutationMetadata must contain an error iff state is 'rejected'`\n    );\n  }\n\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  static fromWebStorageEntry(\n    user: User,\n    batchId: BatchId,\n    value: string\n  ): MutationMetadata | null {\n    const mutationBatch = JSON.parse(value) as MutationMetadataSchema;\n\n    let validData =\n      typeof mutationBatch === 'object' &&\n      ['pending', 'acknowledged', 'rejected'].indexOf(mutationBatch.state) !==\n        -1 &&\n      (mutationBatch.error === undefined ||\n        typeof mutationBatch.error === 'object');\n\n    let firestoreError: FirestoreError | undefined = undefined;\n\n    if (validData && mutationBatch.error) {\n      validData =\n        typeof mutationBatch.error.message === 'string' &&\n        typeof mutationBatch.error.code === 'string';\n      if (validData) {\n        firestoreError = new FirestoreError(\n          mutationBatch.error.code as Code,\n          mutationBatch.error.message\n        );\n      }\n    }\n\n    if (validData) {\n      return new MutationMetadata(\n        user,\n        batchId,\n        mutationBatch.state,\n        firestoreError\n      );\n    } else {\n      logError(\n        LOG_TAG,\n        `Failed to parse mutation state for ID '${batchId}': ${value}`\n      );\n      return null;\n    }\n  }\n\n  toWebStorageJSON(): string {\n    const batchMetadata: MutationMetadataSchema = {\n      state: this.state,\n      updateTimeMs: Date.now() // Modify the existing value to trigger update.\n    };\n\n    if (this.error) {\n      batchMetadata.error = {\n        code: this.error.code,\n        message: this.error.message\n      };\n    }\n\n    return JSON.stringify(batchMetadata);\n  }\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\nexport class QueryTargetMetadata {\n  constructor(\n    readonly targetId: TargetId,\n    readonly state: QueryTargetState,\n    readonly error?: FirestoreError\n  ) {\n    debugAssert(\n      (error !== undefined) === (state === 'rejected'),\n      `QueryTargetMetadata must contain an error iff state is 'rejected'`\n    );\n  }\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  static fromWebStorageEntry(\n    targetId: TargetId,\n    value: string\n  ): QueryTargetMetadata | null {\n    const targetState = JSON.parse(value) as QueryTargetStateSchema;\n\n    let validData =\n      typeof targetState === 'object' &&\n      ['not-current', 'current', 'rejected'].indexOf(targetState.state) !==\n        -1 &&\n      (targetState.error === undefined ||\n        typeof targetState.error === 'object');\n\n    let firestoreError: FirestoreError | undefined = undefined;\n\n    if (validData && targetState.error) {\n      validData =\n        typeof targetState.error.message === 'string' &&\n        typeof targetState.error.code === 'string';\n      if (validData) {\n        firestoreError = new FirestoreError(\n          targetState.error.code as Code,\n          targetState.error.message\n        );\n      }\n    }\n\n    if (validData) {\n      return new QueryTargetMetadata(\n        targetId,\n        targetState.state,\n        firestoreError\n      );\n    } else {\n      logError(\n        LOG_TAG,\n        `Failed to parse target state for ID '${targetId}': ${value}`\n      );\n      return null;\n    }\n  }\n\n  toWebStorageJSON(): string {\n    const targetState: QueryTargetStateSchema = {\n      state: this.state,\n      updateTimeMs: Date.now() // Modify the existing value to trigger update.\n    };\n\n    if (this.error) {\n      targetState.error = {\n        code: this.error.code,\n        message: this.error.message\n      };\n    }\n\n    return JSON.stringify(targetState);\n  }\n}\n\n/**\n * Metadata state of a single client denoting the query targets it is actively\n * listening to the watch.\n */\n// Visible for testing.\nexport interface ClientState {\n  readonly activeTargetIds: TargetIdSet;\n}\n\n/**\n * This class represents the immutable ClientState for a client read from\n * WebStorage, containing the list of active query targets.\n */\nclass RemoteClientState implements ClientState {\n  private constructor(\n    readonly clientId: ClientId,\n    readonly activeTargetIds: TargetIdSet\n  ) {}\n\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  static fromWebStorageEntry(\n    clientId: ClientId,\n    value: string\n  ): RemoteClientState | null {\n    const clientState = JSON.parse(value) as ClientStateSchema;\n\n    let validData =\n      typeof clientState === 'object' &&\n      clientState.activeTargetIds instanceof Array;\n\n    let activeTargetIdsSet = targetIdSet();\n\n    for (let i = 0; validData && i < clientState.activeTargetIds.length; ++i) {\n      validData = isSafeInteger(clientState.activeTargetIds[i]);\n      activeTargetIdsSet = activeTargetIdsSet.add(\n        clientState.activeTargetIds[i]\n      );\n    }\n\n    if (validData) {\n      return new RemoteClientState(clientId, activeTargetIdsSet);\n    } else {\n      logError(\n        LOG_TAG,\n        `Failed to parse client data for instance '${clientId}': ${value}`\n      );\n      return null;\n    }\n  }\n}\n\n/**\n * This class represents the online state for all clients participating in\n * multi-tab. The online state is only written to by the primary client, and\n * used in secondary clients to update their query views.\n */\nexport class SharedOnlineState {\n  constructor(readonly clientId: string, readonly onlineState: OnlineState) {}\n\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  static fromWebStorageEntry(value: string): SharedOnlineState | null {\n    const onlineState = JSON.parse(value) as SharedOnlineStateSchema;\n\n    const validData =\n      typeof onlineState === 'object' &&\n      ['Unknown', 'Online', 'Offline'].indexOf(onlineState.onlineState) !==\n        -1 &&\n      typeof onlineState.clientId === 'string';\n\n    if (validData) {\n      return new SharedOnlineState(\n        onlineState.clientId,\n        onlineState.onlineState as OnlineState\n      );\n    } else {\n      logError(LOG_TAG, `Failed to parse online state: ${value}`);\n      return null;\n    }\n  }\n}\n\n/**\n * Metadata state of the local client. Unlike `RemoteClientState`, this class is\n * mutable and keeps track of all pending mutations, which allows us to\n * update the range of pending mutation batch IDs as new mutations are added or\n * removed.\n *\n * The data in `LocalClientState` is not read from WebStorage and instead\n * updated via its instance methods. The updated state can be serialized via\n * `toWebStorageJSON()`.\n */\n// Visible for testing.\nexport class LocalClientState implements ClientState {\n  activeTargetIds = targetIdSet();\n\n  addQueryTarget(targetId: TargetId): void {\n    this.activeTargetIds = this.activeTargetIds.add(targetId);\n  }\n\n  removeQueryTarget(targetId: TargetId): void {\n    this.activeTargetIds = this.activeTargetIds.delete(targetId);\n  }\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  toWebStorageJSON(): string {\n    const data: ClientStateSchema = {\n      activeTargetIds: this.activeTargetIds.toArray(),\n      updateTimeMs: Date.now() // Modify the existing value to trigger update.\n    };\n    return JSON.stringify(data);\n  }\n}\n\n/**\n * `WebStorageSharedClientState` uses WebStorage (window.localStorage) as the\n * backing store for the SharedClientState. It keeps track of all active\n * clients and supports modifications of the local client's data.\n */\nexport class WebStorageSharedClientState implements SharedClientState {\n  syncEngine: SharedClientStateSyncer | null = null;\n  onlineStateHandler: ((onlineState: OnlineState) => void) | null = null;\n  sequenceNumberHandler:\n    | ((sequenceNumber: ListenSequenceNumber) => void)\n    | null = null;\n\n  private readonly storage: Storage;\n  private readonly localClientStorageKey: string;\n  private readonly sequenceNumberKey: string;\n  private readonly storageListener = this.handleWebStorageEvent.bind(this);\n  private readonly onlineStateKey: string;\n  private readonly bundleLoadedKey: string;\n  private readonly clientStateKeyRe: RegExp;\n  private readonly mutationBatchKeyRe: RegExp;\n  private readonly queryTargetKeyRe: RegExp;\n  private activeClients = new SortedMap<string, ClientState>(\n    primitiveComparator\n  );\n  private started = false;\n  private currentUser: User;\n\n  /**\n   * Captures WebStorage events that occur before `start()` is called. These\n   * events are replayed once `WebStorageSharedClientState` is started.\n   */\n  private earlyEvents: StorageEvent[] = [];\n\n  constructor(\n    private readonly window: WindowLike,\n    private readonly queue: AsyncQueue,\n    private readonly persistenceKey: string,\n    private readonly localClientId: ClientId,\n    initialUser: User\n  ) {\n    // Escape the special characters mentioned here:\n    // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions\n    const escapedPersistenceKey = persistenceKey.replace(\n      /[.*+?^${}()|[\\]\\\\]/g,\n      '\\\\$&'\n    );\n\n    this.storage = this.window.localStorage;\n    this.currentUser = initialUser;\n    this.localClientStorageKey = createWebStorageClientStateKey(\n      this.persistenceKey,\n      this.localClientId\n    );\n    this.sequenceNumberKey = createWebStorageSequenceNumberKey(\n      this.persistenceKey\n    );\n    this.activeClients = this.activeClients.insert(\n      this.localClientId,\n      new LocalClientState()\n    );\n\n    this.clientStateKeyRe = new RegExp(\n      `^${CLIENT_STATE_KEY_PREFIX}_${escapedPersistenceKey}_([^_]*)$`\n    );\n    this.mutationBatchKeyRe = new RegExp(\n      `^${MUTATION_BATCH_KEY_PREFIX}_${escapedPersistenceKey}_(\\\\d+)(?:_(.*))?$`\n    );\n    this.queryTargetKeyRe = new RegExp(\n      `^${QUERY_TARGET_KEY_PREFIX}_${escapedPersistenceKey}_(\\\\d+)$`\n    );\n\n    this.onlineStateKey = createWebStorageOnlineStateKey(this.persistenceKey);\n\n    this.bundleLoadedKey = createBundleLoadedKey(this.persistenceKey);\n\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.storageListener);\n  }\n\n  /** Returns 'true' if WebStorage is available in the current environment. */\n  static isAvailable(window: WindowLike | null): window is WindowLike {\n    return !!(window && window.localStorage);\n  }\n\n  async start(): Promise<void> {\n    debugAssert(!this.started, 'WebStorageSharedClientState already started');\n    debugAssert(\n      this.syncEngine !== null,\n      'syncEngine property must be set before calling start()'\n    );\n    debugAssert(\n      this.onlineStateHandler !== null,\n      'onlineStateHandler property must be set before calling start()'\n    );\n\n    // Retrieve the list of existing clients to backfill the data in\n    // SharedClientState.\n    const existingClients = await this.syncEngine!.getActiveClients();\n\n    for (const clientId of existingClients) {\n      if (clientId === this.localClientId) {\n        continue;\n      }\n\n      const storageItem = this.getItem(\n        createWebStorageClientStateKey(this.persistenceKey, clientId)\n      );\n      if (storageItem) {\n        const clientState = RemoteClientState.fromWebStorageEntry(\n          clientId,\n          storageItem\n        );\n        if (clientState) {\n          this.activeClients = this.activeClients.insert(\n            clientState.clientId,\n            clientState\n          );\n        }\n      }\n    }\n\n    this.persistClientState();\n\n    // Check if there is an existing online state and call the callback handler\n    // if applicable.\n    const onlineStateJSON = this.storage.getItem(this.onlineStateKey);\n    if (onlineStateJSON) {\n      const onlineState = this.fromWebStorageOnlineState(onlineStateJSON);\n      if (onlineState) {\n        this.handleOnlineStateEvent(onlineState);\n      }\n    }\n\n    for (const event of this.earlyEvents) {\n      this.handleWebStorageEvent(event);\n    }\n\n    this.earlyEvents = [];\n\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('pagehide', () => this.shutdown());\n\n    this.started = true;\n  }\n\n  writeSequenceNumber(sequenceNumber: ListenSequenceNumber): void {\n    this.setItem(this.sequenceNumberKey, JSON.stringify(sequenceNumber));\n  }\n\n  getAllActiveQueryTargets(): TargetIdSet {\n    return this.extractActiveQueryTargets(this.activeClients);\n  }\n\n  isActiveQueryTarget(targetId: TargetId): boolean {\n    let found = false;\n    this.activeClients.forEach((key, value) => {\n      if (value.activeTargetIds.has(targetId)) {\n        found = true;\n      }\n    });\n    return found;\n  }\n\n  addPendingMutation(batchId: BatchId): void {\n    this.persistMutationState(batchId, 'pending');\n  }\n\n  updateMutationState(\n    batchId: BatchId,\n    state: 'acknowledged' | 'rejected',\n    error?: FirestoreError\n  ): void {\n    this.persistMutationState(batchId, state, error);\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.removeMutationState(batchId);\n  }\n\n  addLocalQueryTarget(\n    targetId: TargetId,\n    addToActiveTargetIds: boolean = true\n  ): QueryTargetState {\n    let queryState: QueryTargetState = 'not-current';\n\n    // Lookup an existing query state if the target ID was already registered\n    // by another tab\n    if (this.isActiveQueryTarget(targetId)) {\n      const storageItem = this.storage.getItem(\n        createWebStorageQueryTargetMetadataKey(this.persistenceKey, targetId)\n      );\n\n      if (storageItem) {\n        const metadata = QueryTargetMetadata.fromWebStorageEntry(\n          targetId,\n          storageItem\n        );\n        if (metadata) {\n          queryState = metadata.state;\n        }\n      }\n    }\n\n    // If the query is listening to cache only, the target ID should not be registered with the\n    // local Firestore client as an active watch target.\n    if (addToActiveTargetIds) {\n      this.localClientState.addQueryTarget(targetId);\n    }\n\n    this.persistClientState();\n    return queryState;\n  }\n\n  removeLocalQueryTarget(targetId: TargetId): void {\n    this.localClientState.removeQueryTarget(targetId);\n    this.persistClientState();\n  }\n\n  isLocalQueryTarget(targetId: TargetId): boolean {\n    return this.localClientState.activeTargetIds.has(targetId);\n  }\n\n  clearQueryState(targetId: TargetId): void {\n    this.removeItem(\n      createWebStorageQueryTargetMetadataKey(this.persistenceKey, targetId)\n    );\n  }\n\n  updateQueryState(\n    targetId: TargetId,\n    state: QueryTargetState,\n    error?: FirestoreError\n  ): void {\n    this.persistQueryTargetState(targetId, state, error);\n  }\n\n  handleUserChange(\n    user: User,\n    removedBatchIds: BatchId[],\n    addedBatchIds: BatchId[]\n  ): void {\n    removedBatchIds.forEach(batchId => {\n      this.removeMutationState(batchId);\n    });\n    this.currentUser = user;\n    addedBatchIds.forEach(batchId => {\n      this.addPendingMutation(batchId);\n    });\n  }\n\n  setOnlineState(onlineState: OnlineState): void {\n    this.persistOnlineState(onlineState);\n  }\n\n  notifyBundleLoaded(collectionGroups: Set<string>): void {\n    this.persistBundleLoadedState(collectionGroups);\n  }\n\n  shutdown(): void {\n    if (this.started) {\n      this.window.removeEventListener('storage', this.storageListener);\n      this.removeItem(this.localClientStorageKey);\n      this.started = false;\n    }\n  }\n\n  private getItem(key: string): string | null {\n    const value = this.storage.getItem(key);\n    logDebug(LOG_TAG, 'READ', key, value);\n    return value;\n  }\n\n  private setItem(key: string, value: string): void {\n    logDebug(LOG_TAG, 'SET', key, value);\n    this.storage.setItem(key, value);\n  }\n\n  private removeItem(key: string): void {\n    logDebug(LOG_TAG, 'REMOVE', key);\n    this.storage.removeItem(key);\n  }\n\n  private handleWebStorageEvent(event: Event): void {\n    // Note: The function is typed to take Event to be interface-compatible with\n    // `Window.addEventListener`.\n    const storageEvent = event as StorageEvent;\n    if (storageEvent.storageArea === this.storage) {\n      logDebug(LOG_TAG, 'EVENT', storageEvent.key, storageEvent.newValue);\n\n      if (storageEvent.key === this.localClientStorageKey) {\n        logError(\n          'Received WebStorage notification for local change. Another client might have ' +\n            'garbage-collected our state'\n        );\n        return;\n      }\n\n      this.queue.enqueueRetryable(async () => {\n        if (!this.started) {\n          this.earlyEvents.push(storageEvent);\n          return;\n        }\n\n        if (storageEvent.key === null) {\n          return;\n        }\n\n        if (this.clientStateKeyRe.test(storageEvent.key)) {\n          if (storageEvent.newValue != null) {\n            const clientState = this.fromWebStorageClientState(\n              storageEvent.key,\n              storageEvent.newValue\n            );\n            if (clientState) {\n              return this.handleClientStateEvent(\n                clientState.clientId,\n                clientState\n              );\n            }\n          } else {\n            const clientId = this.fromWebStorageClientStateKey(\n              storageEvent.key\n            )!;\n            return this.handleClientStateEvent(clientId, null);\n          }\n        } else if (this.mutationBatchKeyRe.test(storageEvent.key)) {\n          if (storageEvent.newValue !== null) {\n            const mutationMetadata = this.fromWebStorageMutationMetadata(\n              storageEvent.key,\n              storageEvent.newValue\n            );\n            if (mutationMetadata) {\n              return this.handleMutationBatchEvent(mutationMetadata);\n            }\n          }\n        } else if (this.queryTargetKeyRe.test(storageEvent.key)) {\n          if (storageEvent.newValue !== null) {\n            const queryTargetMetadata = this.fromWebStorageQueryTargetMetadata(\n              storageEvent.key,\n              storageEvent.newValue\n            );\n            if (queryTargetMetadata) {\n              return this.handleQueryTargetEvent(queryTargetMetadata);\n            }\n          }\n        } else if (storageEvent.key === this.onlineStateKey) {\n          if (storageEvent.newValue !== null) {\n            const onlineState = this.fromWebStorageOnlineState(\n              storageEvent.newValue\n            );\n            if (onlineState) {\n              return this.handleOnlineStateEvent(onlineState);\n            }\n          }\n        } else if (storageEvent.key === this.sequenceNumberKey) {\n          debugAssert(\n            !!this.sequenceNumberHandler,\n            'Missing sequenceNumberHandler'\n          );\n          const sequenceNumber = fromWebStorageSequenceNumber(\n            storageEvent.newValue\n          );\n          if (sequenceNumber !== ListenSequence.INVALID) {\n            this.sequenceNumberHandler!(sequenceNumber);\n          }\n        } else if (storageEvent.key === this.bundleLoadedKey) {\n          const collectionGroups = this.fromWebStoreBundleLoadedState(\n            storageEvent.newValue!\n          );\n          await Promise.all(\n            collectionGroups.map(cg =>\n              this.syncEngine!.synchronizeWithChangedDocuments(cg)\n            )\n          );\n        }\n      });\n    }\n  }\n\n  private get localClientState(): LocalClientState {\n    return this.activeClients.get(this.localClientId) as LocalClientState;\n  }\n\n  private persistClientState(): void {\n    this.setItem(\n      this.localClientStorageKey,\n      this.localClientState.toWebStorageJSON()\n    );\n  }\n\n  private persistMutationState(\n    batchId: BatchId,\n    state: MutationBatchState,\n    error?: FirestoreError\n  ): void {\n    const mutationState = new MutationMetadata(\n      this.currentUser,\n      batchId,\n      state,\n      error\n    );\n    const mutationKey = createWebStorageMutationBatchKey(\n      this.persistenceKey,\n      this.currentUser,\n      batchId\n    );\n    this.setItem(mutationKey, mutationState.toWebStorageJSON());\n  }\n\n  private removeMutationState(batchId: BatchId): void {\n    const mutationKey = createWebStorageMutationBatchKey(\n      this.persistenceKey,\n      this.currentUser,\n      batchId\n    );\n    this.removeItem(mutationKey);\n  }\n\n  private persistOnlineState(onlineState: OnlineState): void {\n    const entry: SharedOnlineStateSchema = {\n      clientId: this.localClientId,\n      onlineState\n    };\n    this.storage.setItem(this.onlineStateKey, JSON.stringify(entry));\n  }\n\n  private persistQueryTargetState(\n    targetId: TargetId,\n    state: QueryTargetState,\n    error?: FirestoreError\n  ): void {\n    const targetKey = createWebStorageQueryTargetMetadataKey(\n      this.persistenceKey,\n      targetId\n    );\n    const targetMetadata = new QueryTargetMetadata(targetId, state, error);\n    this.setItem(targetKey, targetMetadata.toWebStorageJSON());\n  }\n\n  private persistBundleLoadedState(collectionGroups: Set<string>): void {\n    const json = JSON.stringify(Array.from(collectionGroups));\n    this.setItem(this.bundleLoadedKey, json);\n  }\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  private fromWebStorageClientStateKey(key: string): ClientId | null {\n    const match = this.clientStateKeyRe.exec(key);\n    return match ? match[1] : null;\n  }\n\n  /**\n   * Parses a client state in WebStorage. Returns 'null' if the value could not\n   * be parsed.\n   */\n  private fromWebStorageClientState(\n    key: string,\n    value: string\n  ): RemoteClientState | null {\n    const clientId = this.fromWebStorageClientStateKey(key);\n    debugAssert(clientId !== null, `Cannot parse client state key '${key}'`);\n    return RemoteClientState.fromWebStorageEntry(clientId, value);\n  }\n\n  /**\n   * Parses a mutation batch state in WebStorage. Returns 'null' if the value\n   * could not be parsed.\n   */\n  private fromWebStorageMutationMetadata(\n    key: string,\n    value: string\n  ): MutationMetadata | null {\n    const match = this.mutationBatchKeyRe.exec(key);\n    debugAssert(match !== null, `Cannot parse mutation batch key '${key}'`);\n\n    const batchId = Number(match[1]);\n    const userId = match[2] !== undefined ? match[2] : null;\n    return MutationMetadata.fromWebStorageEntry(\n      new User(userId),\n      batchId,\n      value\n    );\n  }\n\n  /**\n   * Parses a query target state from WebStorage. Returns 'null' if the value\n   * could not be parsed.\n   */\n  private fromWebStorageQueryTargetMetadata(\n    key: string,\n    value: string\n  ): QueryTargetMetadata | null {\n    const match = this.queryTargetKeyRe.exec(key);\n    debugAssert(match !== null, `Cannot parse query target key '${key}'`);\n\n    const targetId = Number(match[1]);\n    return QueryTargetMetadata.fromWebStorageEntry(targetId, value);\n  }\n\n  /**\n   * Parses an online state from WebStorage. Returns 'null' if the value\n   * could not be parsed.\n   */\n  private fromWebStorageOnlineState(value: string): SharedOnlineState | null {\n    return SharedOnlineState.fromWebStorageEntry(value);\n  }\n\n  private fromWebStoreBundleLoadedState(value: string): string[] {\n    return JSON.parse(value) as string[];\n  }\n\n  private async handleMutationBatchEvent(\n    mutationBatch: MutationMetadata\n  ): Promise<void> {\n    if (mutationBatch.user.uid !== this.currentUser.uid) {\n      logDebug(\n        LOG_TAG,\n        `Ignoring mutation for non-active user ${mutationBatch.user.uid}`\n      );\n      return;\n    }\n\n    return this.syncEngine!.applyBatchState(\n      mutationBatch.batchId,\n      mutationBatch.state,\n      mutationBatch.error\n    );\n  }\n\n  private handleQueryTargetEvent(\n    targetMetadata: QueryTargetMetadata\n  ): Promise<void> {\n    return this.syncEngine!.applyTargetState(\n      targetMetadata.targetId,\n      targetMetadata.state,\n      targetMetadata.error\n    );\n  }\n\n  private handleClientStateEvent(\n    clientId: ClientId,\n    clientState: RemoteClientState | null\n  ): Promise<void> {\n    const updatedClients = clientState\n      ? this.activeClients.insert(clientId, clientState)\n      : this.activeClients.remove(clientId);\n\n    const existingTargets = this.extractActiveQueryTargets(this.activeClients);\n    const newTargets = this.extractActiveQueryTargets(updatedClients);\n\n    const addedTargets: TargetId[] = [];\n    const removedTargets: TargetId[] = [];\n\n    newTargets.forEach(targetId => {\n      if (!existingTargets.has(targetId)) {\n        addedTargets.push(targetId);\n      }\n    });\n\n    existingTargets.forEach(targetId => {\n      if (!newTargets.has(targetId)) {\n        removedTargets.push(targetId);\n      }\n    });\n\n    return this.syncEngine!.applyActiveTargetsChange(\n      addedTargets,\n      removedTargets\n    ).then(() => {\n      this.activeClients = updatedClients;\n    });\n  }\n\n  private handleOnlineStateEvent(onlineState: SharedOnlineState): void {\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    if (this.activeClients.get(onlineState.clientId)) {\n      this.onlineStateHandler!(onlineState.onlineState);\n    }\n  }\n\n  private extractActiveQueryTargets(\n    clients: SortedMap<string, ClientState>\n  ): SortedSet<TargetId> {\n    let activeTargets = targetIdSet();\n    clients.forEach((kev, value) => {\n      activeTargets = activeTargets.unionWith(value.activeTargetIds);\n    });\n    return activeTargets;\n  }\n}\n\nfunction fromWebStorageSequenceNumber(\n  seqString: string | null\n): ListenSequenceNumber {\n  let sequenceNumber = ListenSequence.INVALID;\n  if (seqString != null) {\n    try {\n      const parsed = JSON.parse(seqString);\n      hardAssert(\n        typeof parsed === 'number',\n        'Found non-numeric sequence number'\n      );\n      sequenceNumber = parsed;\n    } catch (e) {\n      logError(LOG_TAG, 'Failed to read sequence number from WebStorage', e);\n    }\n  }\n  return sequenceNumber;\n}\n\n/**\n * `MemorySharedClientState` is a simple implementation of SharedClientState for\n * clients using memory persistence. The state in this class remains fully\n * isolated and no synchronization is performed.\n */\nexport class MemorySharedClientState implements SharedClientState {\n  private localState = new LocalClientState();\n  private queryState: { [targetId: number]: QueryTargetState } = {};\n  onlineStateHandler: ((onlineState: OnlineState) => void) | null = null;\n  sequenceNumberHandler:\n    | ((sequenceNumber: ListenSequenceNumber) => void)\n    | null = null;\n\n  addPendingMutation(batchId: BatchId): void {\n    // No op.\n  }\n\n  updateMutationState(\n    batchId: BatchId,\n    state: 'acknowledged' | 'rejected',\n    error?: FirestoreError\n  ): void {\n    // No op.\n  }\n\n  addLocalQueryTarget(\n    targetId: TargetId,\n    addToActiveTargetIds: boolean = true\n  ): QueryTargetState {\n    if (addToActiveTargetIds) {\n      this.localState.addQueryTarget(targetId);\n    }\n    return this.queryState[targetId] || 'not-current';\n  }\n\n  updateQueryState(\n    targetId: TargetId,\n    state: QueryTargetState,\n    error?: FirestoreError\n  ): void {\n    this.queryState[targetId] = state;\n  }\n\n  removeLocalQueryTarget(targetId: TargetId): void {\n    this.localState.removeQueryTarget(targetId);\n  }\n\n  isLocalQueryTarget(targetId: TargetId): boolean {\n    return this.localState.activeTargetIds.has(targetId);\n  }\n\n  clearQueryState(targetId: TargetId): void {\n    delete this.queryState[targetId];\n  }\n\n  getAllActiveQueryTargets(): TargetIdSet {\n    return this.localState.activeTargetIds;\n  }\n\n  isActiveQueryTarget(targetId: TargetId): boolean {\n    return this.localState.activeTargetIds.has(targetId);\n  }\n\n  start(): Promise<void> {\n    this.localState = new LocalClientState();\n    return Promise.resolve();\n  }\n\n  handleUserChange(\n    user: User,\n    removedBatchIds: BatchId[],\n    addedBatchIds: BatchId[]\n  ): void {\n    // No op.\n  }\n\n  setOnlineState(onlineState: OnlineState): void {\n    // No op.\n  }\n\n  shutdown(): void {}\n\n  writeSequenceNumber(sequenceNumber: ListenSequenceNumber): void {}\n\n  notifyBundleLoaded(collectionGroups: Set<string>): void {\n    // No op.\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 { ConnectivityMonitor, NetworkStatus } from './connectivity_monitor';\n\nexport class NoopConnectivityMonitor implements ConnectivityMonitor {\n  addCallback(callback: (status: NetworkStatus) => void): void {\n    // No-op.\n  }\n\n  shutdown(): void {\n    // No-op.\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  ConnectivityMonitor,\n  ConnectivityMonitorCallback,\n  NetworkStatus\n} from '../../remote/connectivity_monitor';\nimport { logDebug } from '../../util/log';\n\n// References to `window` are guarded by BrowserConnectivityMonitor.isAvailable()\n/* eslint-disable no-restricted-globals */\n\nconst LOG_TAG = 'ConnectivityMonitor';\n\n/**\n * Browser implementation of ConnectivityMonitor.\n */\nexport class BrowserConnectivityMonitor implements ConnectivityMonitor {\n  private readonly networkAvailableListener = (): void =>\n    this.onNetworkAvailable();\n  private readonly networkUnavailableListener = (): void =>\n    this.onNetworkUnavailable();\n  private callbacks: ConnectivityMonitorCallback[] = [];\n\n  constructor() {\n    this.configureNetworkMonitoring();\n  }\n\n  addCallback(callback: (status: NetworkStatus) => void): void {\n    this.callbacks.push(callback);\n  }\n\n  shutdown(): void {\n    window.removeEventListener('online', this.networkAvailableListener);\n    window.removeEventListener('offline', this.networkUnavailableListener);\n  }\n\n  private configureNetworkMonitoring(): void {\n    window.addEventListener('online', this.networkAvailableListener);\n    window.addEventListener('offline', this.networkUnavailableListener);\n  }\n\n  private onNetworkAvailable(): void {\n    logDebug(LOG_TAG, 'Network connectivity changed: AVAILABLE');\n    for (const callback of this.callbacks) {\n      callback(NetworkStatus.AVAILABLE);\n    }\n  }\n\n  private onNetworkUnavailable(): void {\n    logDebug(LOG_TAG, 'Network connectivity changed: UNAVAILABLE');\n    for (const callback of this.callbacks) {\n      callback(NetworkStatus.UNAVAILABLE);\n    }\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  static isAvailable(): boolean {\n    return (\n      typeof window !== 'undefined' &&\n      window.addEventListener !== undefined &&\n      window.removeEventListener !== undefined\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 value returned from the most recent invocation of\n * `generateUniqueDebugId()`, or null if it has never been invoked.\n */\nlet lastUniqueDebugId: number | null = null;\n\n/**\n * Generates and returns an initial value for `lastUniqueDebugId`.\n *\n * The returned value is randomly selected from a range of integers that are\n * represented as 8 hexadecimal digits. This means that (within reason) any\n * numbers generated by incrementing the returned number by 1 will also be\n * represented by 8 hexadecimal digits. This leads to all \"IDs\" having the same\n * length when converted to a hexadecimal string, making reading logs containing\n * these IDs easier to follow. And since the return value is randomly selected\n * it will help to differentiate between logs from different executions.\n */\nfunction generateInitialUniqueDebugId(): number {\n  const minResult = 0x10000000;\n  const maxResult = 0x90000000;\n  const resultRange = maxResult - minResult;\n  const resultOffset = Math.round(resultRange * Math.random());\n  return minResult + resultOffset;\n}\n\n/**\n * Generates and returns a unique ID as a hexadecimal string.\n *\n * The returned ID is intended to be used in debug logging messages to help\n * correlate log messages that may be spatially separated in the logs, but\n * logically related. For example, a network connection could include the same\n * \"debug ID\" string in all of its log messages to help trace a specific\n * connection over time.\n *\n * @return the 10-character generated ID (e.g. \"0xa1b2c3d4\").\n */\nexport function generateUniqueDebugId(): string {\n  if (lastUniqueDebugId === null) {\n    lastUniqueDebugId = generateInitialUniqueDebugId();\n  } else {\n    lastUniqueDebugId++;\n  }\n  return '0x' + lastUniqueDebugId.toString(16);\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 { SDK_VERSION } from '../../src/core/version';\nimport { Token } from '../api/credentials';\nimport {\n  DatabaseId,\n  DatabaseInfo,\n  DEFAULT_DATABASE_NAME\n} from '../core/database_info';\nimport { ResourcePath } from '../model/path';\nimport { debugAssert } from '../util/assert';\nimport { generateUniqueDebugId } from '../util/debug_uid';\nimport { FirestoreError } from '../util/error';\nimport { logDebug, logWarn } from '../util/log';\nimport { StringMap } from '../util/types';\n\nimport { Connection, Stream } from './connection';\n\nconst LOG_TAG = 'RestConnection';\n\n/**\n * Maps RPC names to the corresponding REST endpoint name.\n *\n * We use array notation to avoid mangling.\n */\nconst RPC_NAME_URL_MAPPING: StringMap = {};\n\nRPC_NAME_URL_MAPPING['BatchGetDocuments'] = 'batchGet';\nRPC_NAME_URL_MAPPING['Commit'] = 'commit';\nRPC_NAME_URL_MAPPING['RunQuery'] = 'runQuery';\nRPC_NAME_URL_MAPPING['RunAggregationQuery'] = 'runAggregationQuery';\n\nconst RPC_URL_VERSION = 'v1';\n\n// SDK_VERSION is updated to different value at runtime depending on the entry point,\n// so we need to get its value when we need it in a function.\nfunction getGoogApiClientValue(): string {\n  return 'gl-js/ fire/' + SDK_VERSION;\n}\n/**\n * Base class for all Rest-based connections to the backend (WebChannel and\n * HTTP).\n */\nexport abstract class RestConnection implements Connection {\n  protected readonly databaseId: DatabaseId;\n  protected readonly baseUrl: string;\n  private readonly databasePath: string;\n  private readonly requestParams: string;\n\n  get shouldResourcePathBeIncludedInRequest(): boolean {\n    // Both `invokeRPC()` and `invokeStreamingRPC()` use their `path` arguments to determine\n    // where to run the query, and expect the `request` to NOT specify the \"path\".\n    return false;\n  }\n\n  constructor(private readonly databaseInfo: DatabaseInfo) {\n    this.databaseId = databaseInfo.databaseId;\n    const proto = databaseInfo.ssl ? 'https' : 'http';\n    const projectId = encodeURIComponent(this.databaseId.projectId);\n    const databaseId = encodeURIComponent(this.databaseId.database);\n    this.baseUrl = proto + '://' + databaseInfo.host;\n    this.databasePath = `projects/${projectId}/databases/${databaseId}`;\n    this.requestParams =\n      this.databaseId.database === DEFAULT_DATABASE_NAME\n        ? `project_id=${projectId}`\n        : `project_id=${projectId}&database_id=${databaseId}`;\n  }\n\n  invokeRPC<Req, Resp>(\n    rpcName: string,\n    path: ResourcePath,\n    req: Req,\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Promise<Resp> {\n    const streamId = generateUniqueDebugId();\n    const url = this.makeUrl(rpcName, path.toUriEncodedString());\n    logDebug(LOG_TAG, `Sending RPC '${rpcName}' ${streamId}:`, url, req);\n\n    const headers: StringMap = {\n      'google-cloud-resource-prefix': this.databasePath,\n      'x-goog-request-params': this.requestParams\n    };\n    this.modifyHeadersForRequest(headers, authToken, appCheckToken);\n\n    return this.performRPCRequest<Req, Resp>(rpcName, url, headers, req).then(\n      response => {\n        logDebug(LOG_TAG, `Received RPC '${rpcName}' ${streamId}: `, response);\n        return response;\n      },\n      (err: FirestoreError) => {\n        logWarn(\n          LOG_TAG,\n          `RPC '${rpcName}' ${streamId} failed with error: `,\n          err,\n          'url: ',\n          url,\n          'request:',\n          req\n        );\n        throw err;\n      }\n    );\n  }\n\n  invokeStreamingRPC<Req, Resp>(\n    rpcName: string,\n    path: ResourcePath,\n    request: Req,\n    authToken: Token | null,\n    appCheckToken: Token | null,\n    expectedResponseCount?: number\n  ): Promise<Resp[]> {\n    // The REST API automatically aggregates all of the streamed results, so we\n    // can just use the normal invoke() method.\n    return this.invokeRPC<Req, Resp[]>(\n      rpcName,\n      path,\n      request,\n      authToken,\n      appCheckToken\n    );\n  }\n\n  abstract openStream<Req, Resp>(\n    rpcName: string,\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Stream<Req, Resp>;\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  protected modifyHeadersForRequest(\n    headers: StringMap,\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): void {\n    headers['X-Goog-Api-Client'] = getGoogApiClientValue();\n\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    headers['Content-Type'] = 'text/plain';\n\n    if (this.databaseInfo.appId) {\n      headers['X-Firebase-GMPID'] = this.databaseInfo.appId;\n    }\n\n    if (authToken) {\n      authToken.headers.forEach((value, key) => (headers[key] = value));\n    }\n    if (appCheckToken) {\n      appCheckToken.headers.forEach((value, key) => (headers[key] = value));\n    }\n  }\n\n  /**\n   * Performs an RPC request using an implementation specific networking layer.\n   */\n  protected abstract performRPCRequest<Req, Resp>(\n    rpcName: string,\n    url: string,\n    headers: StringMap,\n    body: Req\n  ): Promise<Resp>;\n\n  private makeUrl(rpcName: string, path: string): string {\n    const urlRpcName = RPC_NAME_URL_MAPPING[rpcName];\n    debugAssert(\n      urlRpcName !== undefined,\n      'Unknown REST mapping for: ' + rpcName\n    );\n    return `${this.baseUrl}/${RPC_URL_VERSION}/${path}:${urlRpcName}`;\n  }\n\n  /**\n   * Closes and cleans up any resources associated with the connection. This\n   * implementation is a no-op because there are no resources associated\n   * with the RestConnection that need to be cleaned up.\n   */\n  terminate(): void {\n    // No-op\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 { debugAssert } from '../util/assert';\nimport { FirestoreError } from '../util/error';\n\nimport { Stream } from './connection';\n\n/**\n * Provides a simple helper class that implements the Stream interface to\n * bridge to other implementations that are streams but do not implement the\n * interface. The stream callbacks are invoked with the callOn... methods.\n */\nexport class StreamBridge<I, O> implements Stream<I, O> {\n  private wrappedOnConnected: (() => void) | undefined;\n  private wrappedOnOpen: (() => void) | undefined;\n  private wrappedOnClose: ((err?: FirestoreError) => void) | undefined;\n  private wrappedOnMessage: ((msg: O) => void) | undefined;\n\n  private sendFn: (msg: I) => void;\n  private closeFn: () => void;\n\n  constructor(args: { sendFn: (msg: I) => void; closeFn: () => void }) {\n    this.sendFn = args.sendFn;\n    this.closeFn = args.closeFn;\n  }\n\n  onConnected(callback: () => void): void {\n    debugAssert(\n      !this.wrappedOnConnected,\n      'Called onConnected on stream twice!'\n    );\n    this.wrappedOnConnected = callback;\n  }\n\n  onOpen(callback: () => void): void {\n    debugAssert(!this.wrappedOnOpen, 'Called onOpen on stream twice!');\n    this.wrappedOnOpen = callback;\n  }\n\n  onClose(callback: (err?: FirestoreError) => void): void {\n    debugAssert(!this.wrappedOnClose, 'Called onClose on stream twice!');\n    this.wrappedOnClose = callback;\n  }\n\n  onMessage(callback: (msg: O) => void): void {\n    debugAssert(!this.wrappedOnMessage, 'Called onMessage on stream twice!');\n    this.wrappedOnMessage = callback;\n  }\n\n  close(): void {\n    this.closeFn();\n  }\n\n  send(msg: I): void {\n    this.sendFn(msg);\n  }\n\n  callOnConnected(): void {\n    debugAssert(\n      this.wrappedOnConnected !== undefined,\n      'Cannot call onConnected because no callback was set'\n    );\n    this.wrappedOnConnected();\n  }\n\n  callOnOpen(): void {\n    debugAssert(\n      this.wrappedOnOpen !== undefined,\n      'Cannot call onOpen because no callback was set'\n    );\n    this.wrappedOnOpen();\n  }\n\n  callOnClose(err?: FirestoreError): void {\n    debugAssert(\n      this.wrappedOnClose !== undefined,\n      'Cannot call onClose because no callback was set'\n    );\n    this.wrappedOnClose(err);\n  }\n\n  callOnMessage(msg: O): void {\n    debugAssert(\n      this.wrappedOnMessage !== undefined,\n      'Cannot call onMessage because no callback was set'\n    );\n    this.wrappedOnMessage(msg);\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  createWebChannelTransport,\n  ErrorCode,\n  EventType,\n  WebChannel,\n  WebChannelError,\n  WebChannelOptions,\n  XhrIo,\n  getStatEventTarget,\n  EventTarget,\n  StatEvent,\n  Event,\n  Stat\n} from '@firebase/webchannel-wrapper/webchannel-blob';\n\nimport { Token } from '../../api/credentials';\nimport { ExperimentalLongPollingOptions } from '../../api/long_polling_options';\nimport { DatabaseInfo } from '../../core/database_info';\nimport { Stream } from '../../remote/connection';\nimport { RestConnection } from '../../remote/rest_connection';\nimport {\n  mapCodeFromRpcStatus,\n  mapCodeFromHttpResponseErrorStatus\n} from '../../remote/rpc_error';\nimport { StreamBridge } from '../../remote/stream_bridge';\nimport { fail, hardAssert } from '../../util/assert';\nimport { generateUniqueDebugId } from '../../util/debug_uid';\nimport { Code, FirestoreError } from '../../util/error';\nimport { logDebug, logWarn } from '../../util/log';\nimport { Rejecter, Resolver } from '../../util/promise';\nimport { StringMap } from '../../util/types';\n\nconst LOG_TAG = 'WebChannelConnection';\n\nconst RPC_STREAM_SERVICE = 'google.firestore.v1.Firestore';\n\nconst XHR_TIMEOUT_SECS = 15;\n\nexport class WebChannelConnection extends RestConnection {\n  private readonly forceLongPolling: boolean;\n  private readonly autoDetectLongPolling: boolean;\n  private readonly useFetchStreams: boolean;\n  private readonly longPollingOptions: ExperimentalLongPollingOptions;\n\n  constructor(info: DatabaseInfo) {\n    super(info);\n    this.forceLongPolling = info.forceLongPolling;\n    this.autoDetectLongPolling = info.autoDetectLongPolling;\n    this.useFetchStreams = info.useFetchStreams;\n    this.longPollingOptions = info.longPollingOptions;\n  }\n\n  protected performRPCRequest<Req, Resp>(\n    rpcName: string,\n    url: string,\n    headers: StringMap,\n    body: Req\n  ): Promise<Resp> {\n    const streamId = generateUniqueDebugId();\n    return new Promise((resolve: Resolver<Resp>, reject: Rejecter) => {\n      const xhr = new XhrIo();\n      xhr.setWithCredentials(true);\n      xhr.listenOnce(EventType.COMPLETE, () => {\n        try {\n          switch (xhr.getLastErrorCode()) {\n            case ErrorCode.NO_ERROR:\n              const json = xhr.getResponseJson() as Resp;\n              logDebug(\n                LOG_TAG,\n                `XHR for RPC '${rpcName}' ${streamId} received:`,\n                JSON.stringify(json)\n              );\n              resolve(json);\n              break;\n            case ErrorCode.TIMEOUT:\n              logDebug(LOG_TAG, `RPC '${rpcName}' ${streamId} timed out`);\n              reject(\n                new FirestoreError(Code.DEADLINE_EXCEEDED, 'Request time out')\n              );\n              break;\n            case ErrorCode.HTTP_ERROR:\n              const status = xhr.getStatus();\n              logDebug(\n                LOG_TAG,\n                `RPC '${rpcName}' ${streamId} failed with status:`,\n                status,\n                'response text:',\n                xhr.getResponseText()\n              );\n              if (status > 0) {\n                let response = xhr.getResponseJson();\n                if (Array.isArray(response)) {\n                  response = response[0];\n                }\n                const responseError = (response as WebChannelError)?.error;\n                if (\n                  !!responseError &&\n                  !!responseError.status &&\n                  !!responseError.message\n                ) {\n                  const firestoreErrorCode = mapCodeFromHttpResponseErrorStatus(\n                    responseError.status\n                  );\n                  reject(\n                    new FirestoreError(\n                      firestoreErrorCode,\n                      responseError.message\n                    )\n                  );\n                } else {\n                  reject(\n                    new FirestoreError(\n                      Code.UNKNOWN,\n                      'Server responded with status ' + xhr.getStatus()\n                    )\n                  );\n                }\n              } else {\n                // If we received an HTTP_ERROR but there's no status code,\n                // it's most probably a connection issue\n                reject(\n                  new FirestoreError(Code.UNAVAILABLE, 'Connection failed.')\n                );\n              }\n              break;\n            default:\n              fail(\n                `RPC '${rpcName}' ${streamId} ` +\n                  'failed with unanticipated webchannel error: ' +\n                  xhr.getLastErrorCode() +\n                  ': ' +\n                  xhr.getLastError() +\n                  ', giving up.'\n              );\n          }\n        } finally {\n          logDebug(LOG_TAG, `RPC '${rpcName}' ${streamId} completed.`);\n        }\n      });\n\n      const requestString = JSON.stringify(body);\n      logDebug(LOG_TAG, `RPC '${rpcName}' ${streamId} sending request:`, body);\n      xhr.send(url, 'POST', requestString, headers, XHR_TIMEOUT_SECS);\n    });\n  }\n\n  openStream<Req, Resp>(\n    rpcName: string,\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Stream<Req, Resp> {\n    const streamId = generateUniqueDebugId();\n    const urlParts = [\n      this.baseUrl,\n      '/',\n      RPC_STREAM_SERVICE,\n      '/',\n      rpcName,\n      '/channel'\n    ];\n    const webchannelTransport = createWebChannelTransport();\n    const requestStats = getStatEventTarget();\n    const request: WebChannelOptions = {\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.databaseId.projectId}/databases/${this.databaseId.database}`\n      },\n      sendRawJson: true,\n      supportsCrossDomainXhr: true,\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: 10 * 60 * 1000\n      },\n      forceLongPolling: this.forceLongPolling,\n      detectBufferingProxy: this.autoDetectLongPolling\n    };\n\n    const longPollingTimeoutSeconds = this.longPollingOptions.timeoutSeconds;\n    if (longPollingTimeoutSeconds !== undefined) {\n      request.longPollingTimeout = Math.round(longPollingTimeoutSeconds * 1000);\n    }\n\n    if (this.useFetchStreams) {\n      request.useFetchStreams = true;\n    }\n\n    this.modifyHeadersForRequest(\n      request.initMessageHeaders!,\n      authToken,\n      appCheckToken\n    );\n\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    //\n    // Therefore to avoid the CORS preflight request (an extra network\n    // roundtrip), we use the encodeInitMessageHeaders option to specify that\n    // the headers should instead be encoded in the request's POST payload,\n    // which is recognized by the webchannel backend.\n    request.encodeInitMessageHeaders = true;\n\n    const url = urlParts.join('');\n    logDebug(\n      LOG_TAG,\n      `Creating RPC '${rpcName}' stream ${streamId}: ${url}`,\n      request\n    );\n    const channel = webchannelTransport.createWebChannel(url, request);\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    let opened = false;\n\n    // A flag to determine whether the stream was closed (by us or through an\n    // error/close event) to avoid delivering multiple close events or sending\n    // on a closed stream\n    let closed = false;\n\n    const streamBridge = new StreamBridge<Req, Resp>({\n      sendFn: (msg: Req) => {\n        if (!closed) {\n          if (!opened) {\n            logDebug(\n              LOG_TAG,\n              `Opening RPC '${rpcName}' stream ${streamId} transport.`\n            );\n            channel.open();\n            opened = true;\n          }\n          logDebug(\n            LOG_TAG,\n            `RPC '${rpcName}' stream ${streamId} sending:`,\n            msg\n          );\n          channel.send(msg);\n        } else {\n          logDebug(\n            LOG_TAG,\n            `Not sending because RPC '${rpcName}' stream ${streamId} ` +\n              'is closed:',\n            msg\n          );\n        }\n      },\n      closeFn: () => channel.close()\n    });\n\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    const unguardedEventListen = <T>(\n      target: EventTarget,\n      type: string | number,\n      fn: (param: T) => void\n    ): void => {\n      // TODO(dimond): closure typing seems broken because WebChannel does\n      // not implement goog.events.Listenable\n      target.listen(type, (param: unknown) => {\n        try {\n          fn(param as T);\n        } catch (e) {\n          setTimeout(() => {\n            throw e;\n          }, 0);\n        }\n      });\n    };\n\n    unguardedEventListen(channel, WebChannel.EventType.OPEN, () => {\n      if (!closed) {\n        logDebug(\n          LOG_TAG,\n          `RPC '${rpcName}' stream ${streamId} transport opened.`\n        );\n        streamBridge.callOnConnected();\n      }\n    });\n\n    unguardedEventListen(channel, WebChannel.EventType.CLOSE, () => {\n      if (!closed) {\n        closed = true;\n        logDebug(\n          LOG_TAG,\n          `RPC '${rpcName}' stream ${streamId} transport closed`\n        );\n        streamBridge.callOnClose();\n      }\n    });\n\n    unguardedEventListen<Error>(channel, WebChannel.EventType.ERROR, err => {\n      if (!closed) {\n        closed = true;\n        logWarn(\n          LOG_TAG,\n          `RPC '${rpcName}' stream ${streamId} transport errored:`,\n          err\n        );\n        streamBridge.callOnClose(\n          new FirestoreError(\n            Code.UNAVAILABLE,\n            'The operation could not be completed'\n          )\n        );\n      }\n    });\n\n    // WebChannel delivers message events as array. If batching is not enabled\n    // (it's off by default) each message will be delivered alone, resulting in\n    // a single element array.\n    interface WebChannelResponse {\n      data: Resp[];\n    }\n\n    unguardedEventListen<WebChannelResponse>(\n      channel,\n      WebChannel.EventType.MESSAGE,\n      msg => {\n        if (!closed) {\n          const msgData = msg.data[0];\n          hardAssert(!!msgData, 'Got a webchannel message without data.');\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          const msgDataOrError: WebChannelError | object = msgData;\n          const error =\n            (msgDataOrError as WebChannelError)?.error ||\n            (msgDataOrError as WebChannelError[])[0]?.error;\n          if (error) {\n            logDebug(\n              LOG_TAG,\n              `RPC '${rpcName}' stream ${streamId} received error:`,\n              error\n            );\n            // error.status will be a string like 'OK' or 'NOT_FOUND'.\n            const status: string = error.status;\n            let code = mapCodeFromRpcStatus(status);\n            let message = error.message;\n            if (code === undefined) {\n              code = Code.INTERNAL;\n              message =\n                'Unknown error status: ' +\n                status +\n                ' with message ' +\n                error.message;\n            }\n            // Mark closed so no further events are propagated\n            closed = true;\n            streamBridge.callOnClose(new FirestoreError(code, message));\n            channel.close();\n          } else {\n            logDebug(\n              LOG_TAG,\n              `RPC '${rpcName}' stream ${streamId} received:`,\n              msgData\n            );\n            streamBridge.callOnMessage(msgData);\n          }\n        }\n      }\n    );\n\n    unguardedEventListen<StatEvent>(requestStats, Event.STAT_EVENT, event => {\n      if (event.stat === Stat.PROXY) {\n        logDebug(\n          LOG_TAG,\n          `RPC '${rpcName}' stream ${streamId} detected buffering proxy`\n        );\n      } else if (event.stat === Stat.NOPROXY) {\n        logDebug(\n          LOG_TAG,\n          `RPC '${rpcName}' stream ${streamId} detected no buffering proxy`\n        );\n      }\n    });\n\n    setTimeout(() => {\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      streamBridge.callOnOpen();\n    }, 0);\n    return streamBridge;\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/** The Platform's 'window' implementation or null if not available. */\nexport function getWindow(): Window | null {\n  // `window` is not always available, e.g. in ReactNative and WebWorkers.\n  // eslint-disable-next-line no-restricted-globals\n  return typeof window !== 'undefined' ? window : null;\n}\n\n/** The Platform's 'document' implementation or null if not available. */\nexport function getDocument(): Document | null {\n  // `document` is not always available, e.g. in ReactNative and WebWorkers.\n  // eslint-disable-next-line no-restricted-globals\n  return typeof document !== 'undefined' ? document : 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/** Return the Platform-specific serializer monitor. */\nimport { DatabaseId } from '../../core/database_info';\nimport { JsonProtoSerializer } from '../../remote/serializer';\n\nexport function newSerializer(databaseId: DatabaseId): JsonProtoSerializer {\n  return new JsonProtoSerializer(databaseId, /* useProto3Json= */ 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 { AsyncQueue, DelayedOperation, TimerId } from '../util/async_queue';\nimport { logDebug } from '../util/log';\n\nconst LOG_TAG = 'ExponentialBackoff';\n\n/**\n * Initial backoff time in milliseconds after an error.\n * Set to 1s according to https://cloud.google.com/apis/design/errors.\n */\nconst DEFAULT_BACKOFF_INITIAL_DELAY_MS = 1000;\n\nconst DEFAULT_BACKOFF_FACTOR = 1.5;\n\n/** Maximum backoff time in milliseconds */\nconst DEFAULT_BACKOFF_MAX_DELAY_MS = 60 * 1000;\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 */\nexport class ExponentialBackoff {\n  private currentBaseMs: number = 0;\n  private timerPromise: DelayedOperation<void> | null = null;\n  /** The last backoff attempt, as epoch milliseconds. */\n  private lastAttemptTime = Date.now();\n\n  constructor(\n    /**\n     * The AsyncQueue to run backoff operations on.\n     */\n    private readonly queue: AsyncQueue,\n    /**\n     * The ID to use when scheduling backoff operations on the AsyncQueue.\n     */\n    private readonly timerId: TimerId,\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    private readonly initialDelayMs: number = DEFAULT_BACKOFF_INITIAL_DELAY_MS,\n    /**\n     * The multiplier to use to determine the extended base delay after each\n     * attempt.\n     */\n    private readonly backoffFactor: number = DEFAULT_BACKOFF_FACTOR,\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     */\n    private readonly maxDelayMs: number = DEFAULT_BACKOFF_MAX_DELAY_MS\n  ) {\n    this.reset();\n  }\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   */\n  reset(): void {\n    this.currentBaseMs = 0;\n  }\n\n  /**\n   * Resets the backoff delay to the maximum delay (e.g. for use after a\n   * RESOURCE_EXHAUSTED error).\n   */\n  resetToMax(): void {\n    this.currentBaseMs = this.maxDelayMs;\n  }\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  backoffAndRun(op: () => Promise<void>): void {\n    // Cancel any pending backoff operation.\n    this.cancel();\n\n    // First schedule using the current base (which may be 0 and should be\n    // honored as such).\n    const desiredDelayWithJitterMs = Math.floor(\n      this.currentBaseMs + this.jitterDelayMs()\n    );\n\n    // Guard against lastAttemptTime being in the future due to a clock change.\n    const delaySoFarMs = Math.max(0, Date.now() - this.lastAttemptTime);\n\n    // Guard against the backoff delay already being past.\n    const remainingDelayMs = Math.max(\n      0,\n      desiredDelayWithJitterMs - delaySoFarMs\n    );\n\n    if (remainingDelayMs > 0) {\n      logDebug(\n        LOG_TAG,\n        `Backing off for ${remainingDelayMs} ms ` +\n          `(base delay: ${this.currentBaseMs} ms, ` +\n          `delay with jitter: ${desiredDelayWithJitterMs} ms, ` +\n          `last attempt: ${delaySoFarMs} ms ago)`\n      );\n    }\n\n    this.timerPromise = this.queue.enqueueAfterDelay(\n      this.timerId,\n      remainingDelayMs,\n      () => {\n        this.lastAttemptTime = Date.now();\n        return op();\n      }\n    );\n\n    // Apply backoff factor to determine next delay and ensure it is within\n    // bounds.\n    this.currentBaseMs *= this.backoffFactor;\n    if (this.currentBaseMs < this.initialDelayMs) {\n      this.currentBaseMs = this.initialDelayMs;\n    }\n    if (this.currentBaseMs > this.maxDelayMs) {\n      this.currentBaseMs = this.maxDelayMs;\n    }\n  }\n\n  skipBackoff(): void {\n    if (this.timerPromise !== null) {\n      this.timerPromise.skipDelay();\n      this.timerPromise = null;\n    }\n  }\n\n  cancel(): void {\n    if (this.timerPromise !== null) {\n      this.timerPromise.cancel();\n      this.timerPromise = null;\n    }\n  }\n\n  /** Returns a random value in the range [-currentBaseMs/2, currentBaseMs/2] */\n  private jitterDelayMs(): number {\n    return (Math.random() - 0.5) * this.currentBaseMs;\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 { CredentialsProvider, Token } from '../api/credentials';\nimport { User } from '../auth/user';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { TargetId } from '../core/types';\nimport { TargetData } from '../local/target_data';\nimport { Mutation, MutationResult } from '../model/mutation';\nimport {\n  ListenRequest as ProtoListenRequest,\n  ListenResponse as ProtoListenResponse,\n  WriteRequest as ProtoWriteRequest,\n  WriteResponse as ProtoWriteResponse\n} from '../protos/firestore_proto_api';\nimport { debugAssert, hardAssert } from '../util/assert';\nimport { AsyncQueue, DelayedOperation, TimerId } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug, logError } from '../util/log';\nimport { isNullOrUndefined } from '../util/types';\n\nimport { ExponentialBackoff } from './backoff';\nimport { Connection, Stream } from './connection';\nimport {\n  fromVersion,\n  fromWatchChange,\n  fromWriteResults,\n  getEncodedDatabaseId,\n  JsonProtoSerializer,\n  toListenRequestLabels,\n  toMutation,\n  toTarget,\n  versionFromListenResponse\n} from './serializer';\nimport { WatchChange } from './watch_change';\n\nconst LOG_TAG = 'PersistentStream';\n\n// The generated proto interfaces for these class are missing the database\n// field. So we add it here.\n// TODO(b/36015800): Remove this once the api generator is fixed.\ninterface ListenRequest extends ProtoListenRequest {\n  database?: string;\n}\nexport interface WriteRequest extends ProtoWriteRequest {\n  database?: string;\n}\n/**\n * PersistentStream can be in one of 5 states (each described in detail below)\n * based on the following state transition diagram:\n *\n *          start() called             auth & connection succeeded\n * INITIAL ----------------> STARTING -----------------------------> OPEN\n *                             ^  |                                   |\n *                             |  |                    error occurred |\n *                             |  \\-----------------------------v-----/\n *                             |                                |\n *                    backoff  |                                |\n *                    elapsed  |              start() called    |\n *                             \\--- BACKOFF <---------------- ERROR\n *\n * [any state] --------------------------> INITIAL\n *               stop() called or\n *               idle timer expired\n */\nconst enum PersistentStreamState {\n  /**\n   * The streaming RPC is not yet running and there's no error condition.\n   * Calling start() will start the stream immediately without backoff.\n   * While in this state isStarted() will return false.\n   */\n  Initial,\n\n  /**\n   * The stream is starting, either waiting for an auth token or for the stream\n   * to successfully open. While in this state, isStarted() will return true but\n   * isOpen() will return false.\n   */\n  Starting,\n\n  /**\n   * The streaming RPC is up and running. Requests and responses can flow\n   * freely. Both isStarted() and isOpen() will return true.\n   */\n  Open,\n\n  /**\n   * The stream is healthy and has been connected for more than 10 seconds. We\n   * therefore assume that the credentials we passed were valid. Both\n   * isStarted() and isOpen() will return true.\n   */\n  Healthy,\n\n  /**\n   * The stream encountered an error. The next start attempt will back off.\n   * While in this state isStarted() will return false.\n   */\n  Error,\n\n  /**\n   * An in-between state after an error where the stream is waiting before\n   * re-starting. After waiting is complete, the stream will try to open.\n   * While in this state isStarted() will return true but isOpen() will return\n   * false.\n   */\n  Backoff\n}\n\n/**\n * Provides a common interface that is shared by the listeners for stream\n * events by the concrete implementation classes.\n */\nexport interface PersistentStreamListener {\n  /**\n   * Called after receiving an acknowledgement from the server, confirming that\n   * we are able to connect to it.\n   */\n  onConnected: () => Promise<void>;\n  /**\n   * Called after the stream was established and can accept outgoing\n   * messages\n   */\n  onOpen: () => Promise<void>;\n  /**\n   * Called after the stream has closed. If there was an error, the\n   * FirestoreError will be set.\n   */\n  onClose: (err?: FirestoreError) => Promise<void>;\n}\n\n/** The time a stream stays open after it is marked idle. */\nconst IDLE_TIMEOUT_MS = 60 * 1000;\n\n/** The time a stream stays open until we consider it healthy. */\nconst HEALTHY_TIMEOUT_MS = 10 * 1000;\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 */\nexport abstract class PersistentStream<\n  SendType,\n  ReceiveType,\n  ListenerType extends PersistentStreamListener\n> {\n  private state = PersistentStreamState.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  private closeCount = 0;\n\n  private idleTimer: DelayedOperation<void> | null = null;\n  private healthCheck: DelayedOperation<void> | null = null;\n  private stream: Stream<SendType, ReceiveType> | null = null;\n\n  protected backoff: ExponentialBackoff;\n\n  constructor(\n    private queue: AsyncQueue,\n    connectionTimerId: TimerId,\n    private idleTimerId: TimerId,\n    private healthTimerId: TimerId,\n    protected connection: Connection,\n    private authCredentialsProvider: CredentialsProvider<User>,\n    private appCheckCredentialsProvider: CredentialsProvider<string>,\n    protected listener: ListenerType\n  ) {\n    this.backoff = new ExponentialBackoff(queue, connectionTimerId);\n  }\n\n  /**\n   * Count of response messages received.\n   */\n  protected responseCount: number = 0;\n\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  isStarted(): boolean {\n    return (\n      this.state === PersistentStreamState.Starting ||\n      this.state === PersistentStreamState.Backoff ||\n      this.isOpen()\n    );\n  }\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  isOpen(): boolean {\n    return (\n      this.state === PersistentStreamState.Open ||\n      this.state === PersistentStreamState.Healthy\n    );\n  }\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  start(): void {\n    this.responseCount = 0;\n    if (this.state === PersistentStreamState.Error) {\n      this.performBackoff();\n      return;\n    }\n\n    debugAssert(\n      this.state === PersistentStreamState.Initial,\n      'Already started'\n    );\n    this.auth();\n  }\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  async stop(): Promise<void> {\n    if (this.isStarted()) {\n      await this.close(PersistentStreamState.Initial);\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  inhibitBackoff(): void {\n    debugAssert(\n      !this.isStarted(),\n      'Can only inhibit backoff in a stopped state'\n    );\n\n    this.state = PersistentStreamState.Initial;\n    this.backoff.reset();\n  }\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  markIdle(): void {\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    if (this.isOpen() && this.idleTimer === null) {\n      this.idleTimer = this.queue.enqueueAfterDelay(\n        this.idleTimerId,\n        IDLE_TIMEOUT_MS,\n        () => this.handleIdleCloseTimer()\n      );\n    }\n  }\n\n  /** Sends a message to the underlying stream. */\n  protected sendRequest(msg: SendType): void {\n    this.cancelIdleCheck();\n    this.stream!.send(msg);\n  }\n\n  /** Called by the idle timer when the stream should close due to inactivity. */\n  private async handleIdleCloseTimer(): Promise<void> {\n    if (this.isOpen()) {\n      // When timing out an idle stream there's no reason to force the stream into backoff when\n      // it restarts so set the stream state to Initial instead of Error.\n      return this.close(PersistentStreamState.Initial);\n    }\n  }\n\n  /** Marks the stream as active again. */\n  private cancelIdleCheck(): void {\n    if (this.idleTimer) {\n      this.idleTimer.cancel();\n      this.idleTimer = null;\n    }\n  }\n\n  /** Cancels the health check delayed operation. */\n  private cancelHealthCheck(): void {\n    if (this.healthCheck) {\n      this.healthCheck.cancel();\n      this.healthCheck = null;\n    }\n  }\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  private async close(\n    finalState: PersistentStreamState,\n    error?: FirestoreError\n  ): Promise<void> {\n    debugAssert(this.isStarted(), 'Only started streams should be closed.');\n    debugAssert(\n      finalState === PersistentStreamState.Error || isNullOrUndefined(error),\n      \"Can't provide an error when not in an error state.\"\n    );\n\n    // Cancel any outstanding timers (they're guaranteed not to execute).\n    this.cancelIdleCheck();\n    this.cancelHealthCheck();\n    this.backoff.cancel();\n\n    // Invalidates any stream-related callbacks (e.g. from auth or the\n    // underlying stream), guaranteeing they won't execute.\n    this.closeCount++;\n\n    if (finalState !== PersistentStreamState.Error) {\n      // If this is an intentional close ensure we don't delay our next connection attempt.\n      this.backoff.reset();\n    } else if (error && error.code === Code.RESOURCE_EXHAUSTED) {\n      // Log the error. (Probably either 'quota exceeded' or 'max queue length reached'.)\n      logError(error.toString());\n      logError(\n        'Using maximum backoff delay to prevent overloading the backend.'\n      );\n      this.backoff.resetToMax();\n    } else if (\n      error &&\n      error.code === Code.UNAUTHENTICATED &&\n      this.state !== PersistentStreamState.Healthy\n    ) {\n      // \"unauthenticated\" error means the token was rejected. This should rarely\n      // happen since both Auth and AppCheck ensure a sufficient TTL when we\n      // request a token. If a user manually resets their system clock this can\n      // fail, however. In this case, we should get a Code.UNAUTHENTICATED error\n      // before we received the first message and we need to invalidate the token\n      // to ensure that we fetch a new token.\n      this.authCredentialsProvider.invalidateToken();\n      this.appCheckCredentialsProvider.invalidateToken();\n    }\n\n    // Clean up the underlying stream because we are no longer interested in events.\n    if (this.stream !== null) {\n      this.tearDown();\n      this.stream.close();\n      this.stream = null;\n    }\n\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 = finalState;\n\n    // Notify the listener that the stream closed.\n    await this.listener.onClose(error);\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  protected tearDown(): void {}\n\n  /**\n   * Used by subclasses to start the concrete RPC and return the underlying\n   * connection stream.\n   */\n  protected abstract startRpc(\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Stream<SendType, ReceiveType>;\n\n  /**\n   * Called when the stream receives first message.\n   * The function will be called on the right queue and must return a Promise.\n   * @param message - The message received from the stream.\n   */\n  protected abstract onFirst(message: ReceiveType): Promise<void>;\n\n  /**\n   * Called on subsequent messages after the stream has received first message.\n   * The function will be called on the right queue and must return a Promise.\n   * @param message - The message received from the stream.\n   */\n  protected abstract onNext(message: ReceiveType): Promise<void>;\n\n  private auth(): void {\n    debugAssert(\n      this.state === PersistentStreamState.Initial,\n      'Must be in initial state to auth'\n    );\n\n    this.state = PersistentStreamState.Starting;\n\n    const dispatchIfNotClosed = this.getCloseGuardedDispatcher(this.closeCount);\n\n    // TODO(mikelehen): Just use dispatchIfNotClosed, but see TODO below.\n    const closeCount = this.closeCount;\n\n    Promise.all([\n      this.authCredentialsProvider.getToken(),\n      this.appCheckCredentialsProvider.getToken()\n    ]).then(\n      ([authToken, appCheckToken]) => {\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        if (this.closeCount === closeCount) {\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          this.startStream(authToken, appCheckToken);\n        }\n      },\n      (error: Error) => {\n        dispatchIfNotClosed(() => {\n          const rpcError = new FirestoreError(\n            Code.UNKNOWN,\n            'Fetching auth token failed: ' + error.message\n          );\n          return this.handleStreamClose(rpcError);\n        });\n      }\n    );\n  }\n\n  private startStream(\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): void {\n    debugAssert(\n      this.state === PersistentStreamState.Starting,\n      'Trying to start stream in a non-starting state'\n    );\n\n    const dispatchIfNotClosed = this.getCloseGuardedDispatcher(this.closeCount);\n\n    this.stream = this.startRpc(authToken, appCheckToken);\n    this.stream.onConnected(() => {\n      dispatchIfNotClosed(() => this.listener!.onConnected());\n    });\n    this.stream.onOpen(() => {\n      dispatchIfNotClosed(() => {\n        debugAssert(\n          this.state === PersistentStreamState.Starting,\n          'Expected stream to be in state Starting, but was ' + this.state\n        );\n        this.state = PersistentStreamState.Open;\n        debugAssert(\n          this.healthCheck === null,\n          'Expected healthCheck to be null'\n        );\n        this.healthCheck = this.queue.enqueueAfterDelay(\n          this.healthTimerId,\n          HEALTHY_TIMEOUT_MS,\n          () => {\n            if (this.isOpen()) {\n              this.state = PersistentStreamState.Healthy;\n            }\n            return Promise.resolve();\n          }\n        );\n        return this.listener!.onOpen();\n      });\n    });\n    this.stream.onClose((error?: FirestoreError) => {\n      dispatchIfNotClosed(() => {\n        return this.handleStreamClose(error);\n      });\n    });\n    this.stream.onMessage((msg: ReceiveType) => {\n      dispatchIfNotClosed(() => {\n        if (++this.responseCount === 1) {\n          return this.onFirst(msg);\n        } else {\n          return this.onNext(msg);\n        }\n      });\n    });\n  }\n\n  private performBackoff(): void {\n    debugAssert(\n      this.state === PersistentStreamState.Error,\n      'Should only perform backoff when in Error state'\n    );\n    this.state = PersistentStreamState.Backoff;\n\n    this.backoff.backoffAndRun(async () => {\n      debugAssert(\n        this.state === PersistentStreamState.Backoff,\n        'Backoff elapsed but state is now: ' + this.state\n      );\n\n      this.state = PersistentStreamState.Initial;\n      this.start();\n      debugAssert(this.isStarted(), 'PersistentStream should have started');\n    });\n  }\n\n  // Visible for tests\n  handleStreamClose(error?: FirestoreError): Promise<void> {\n    debugAssert(\n      this.isStarted(),\n      \"Can't handle server close on non-started stream\"\n    );\n    logDebug(LOG_TAG, `close with error: ${error}`);\n\n    this.stream = null;\n\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 this.close(PersistentStreamState.Error, error);\n  }\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  private getCloseGuardedDispatcher(\n    startCloseCount: number\n  ): (fn: () => Promise<void>) => void {\n    return (fn: () => Promise<void>): void => {\n      this.queue.enqueueAndForget(() => {\n        if (this.closeCount === startCloseCount) {\n          return fn();\n        } else {\n          logDebug(\n            LOG_TAG,\n            'stream callback skipped by getCloseGuardedDispatcher.'\n          );\n          return Promise.resolve();\n        }\n      });\n    };\n  }\n}\n\n/** Listener for the PersistentWatchStream */\nexport interface WatchStreamListener extends PersistentStreamListener {\n  /**\n   * Called on a watchChange. The snapshot parameter will be MIN if the watch\n   * change did not have a snapshot associated with it.\n   */\n  onWatchChange: (\n    watchChange: WatchChange,\n    snapshot: SnapshotVersion\n  ) => Promise<void>;\n}\n\n/**\n * A PersistentStream that implements the Listen RPC.\n *\n * Once the Listen stream has called the onOpen() listener, any number of\n * listen() and unlisten() calls can be made to control what changes will be\n * sent from the server for ListenResponses.\n */\nexport class PersistentListenStream extends PersistentStream<\n  ProtoListenRequest,\n  ProtoListenResponse,\n  WatchStreamListener\n> {\n  constructor(\n    queue: AsyncQueue,\n    connection: Connection,\n    authCredentials: CredentialsProvider<User>,\n    appCheckCredentials: CredentialsProvider<string>,\n    private serializer: JsonProtoSerializer,\n    listener: WatchStreamListener\n  ) {\n    super(\n      queue,\n      TimerId.ListenStreamConnectionBackoff,\n      TimerId.ListenStreamIdle,\n      TimerId.HealthCheckTimeout,\n      connection,\n      authCredentials,\n      appCheckCredentials,\n      listener\n    );\n  }\n\n  protected startRpc(\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Stream<ProtoListenRequest, ProtoListenResponse> {\n    return this.connection.openStream<ProtoListenRequest, ProtoListenResponse>(\n      'Listen',\n      authToken,\n      appCheckToken\n    );\n  }\n\n  protected onFirst(watchChangeProto: ProtoListenResponse): Promise<void> {\n    return this.onNext(watchChangeProto);\n  }\n\n  protected onNext(watchChangeProto: ProtoListenResponse): Promise<void> {\n    // A successful response means the stream is healthy\n    this.backoff.reset();\n\n    const watchChange = fromWatchChange(this.serializer, watchChangeProto);\n    const snapshot = versionFromListenResponse(watchChangeProto);\n    return this.listener!.onWatchChange(watchChange, snapshot);\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  watch(targetData: TargetData): void {\n    const request: ListenRequest = {};\n    request.database = getEncodedDatabaseId(this.serializer);\n    request.addTarget = toTarget(this.serializer, targetData);\n\n    const labels = toListenRequestLabels(this.serializer, targetData);\n    if (labels) {\n      request.labels = labels;\n    }\n\n    this.sendRequest(request);\n  }\n\n  /**\n   * Unregisters interest in the results of the target associated with the\n   * given targetId.\n   */\n  unwatch(targetId: TargetId): void {\n    const request: ListenRequest = {};\n    request.database = getEncodedDatabaseId(this.serializer);\n    request.removeTarget = targetId;\n    this.sendRequest(request);\n  }\n}\n\n/** Listener for the PersistentWriteStream */\nexport interface WriteStreamListener extends PersistentStreamListener {\n  /**\n   * Called by the PersistentWriteStream upon a successful handshake response\n   * from the server, which is the receiver's cue to send any pending writes.\n   */\n  onHandshakeComplete: () => Promise<void>;\n\n  /**\n   * Called by the PersistentWriteStream upon receiving a StreamingWriteResponse\n   * from the server that contains a mutation result.\n   */\n  onMutationResult: (\n    commitVersion: SnapshotVersion,\n    results: MutationResult[]\n  ) => Promise<void>;\n}\n\n/**\n * A Stream that implements the Write RPC.\n *\n * The Write RPC requires the caller to maintain special streamToken\n * state in between calls, to help the server understand which responses the\n * client has processed by the time the next request is made. Every response\n * will contain a streamToken; this value must be passed to the next\n * request.\n *\n * After calling start() on this stream, the next request must be a handshake,\n * containing whatever streamToken is on hand. Once a response to this\n * request is received, all pending mutations may be submitted. When\n * submitting multiple batches of mutations at the same time, it's\n * okay to use the same streamToken for the calls to writeMutations.\n *\n * TODO(b/33271235): Use proto types\n */\nexport class PersistentWriteStream extends PersistentStream<\n  ProtoWriteRequest,\n  ProtoWriteResponse,\n  WriteStreamListener\n> {\n  constructor(\n    queue: AsyncQueue,\n    connection: Connection,\n    authCredentials: CredentialsProvider<User>,\n    appCheckCredentials: CredentialsProvider<string>,\n    private serializer: JsonProtoSerializer,\n    listener: WriteStreamListener\n  ) {\n    super(\n      queue,\n      TimerId.WriteStreamConnectionBackoff,\n      TimerId.WriteStreamIdle,\n      TimerId.HealthCheckTimeout,\n      connection,\n      authCredentials,\n      appCheckCredentials,\n      listener\n    );\n  }\n\n  /**\n   * The last received stream token from the server, used to acknowledge which\n   * responses the client has processed. Stream tokens are opaque checkpoint\n   * markers whose only real value is their inclusion in the next request.\n   *\n   * PersistentWriteStream manages propagating this value from responses to the\n   * next request.\n   */\n  private lastStreamToken: string | Uint8Array | undefined;\n\n  /**\n   * Tracks whether or not a handshake has been successfully exchanged and\n   * the stream is ready to accept mutations.\n   */\n  get handshakeComplete(): boolean {\n    return this.responseCount > 0;\n  }\n\n  // Override of PersistentStream.start\n  start(): void {\n    this.lastStreamToken = undefined;\n    super.start();\n  }\n\n  protected tearDown(): void {\n    if (this.handshakeComplete) {\n      this.writeMutations([]);\n    }\n  }\n\n  protected startRpc(\n    authToken: Token | null,\n    appCheckToken: Token | null\n  ): Stream<ProtoWriteRequest, ProtoWriteResponse> {\n    return this.connection.openStream<ProtoWriteRequest, ProtoWriteResponse>(\n      'Write',\n      authToken,\n      appCheckToken\n    );\n  }\n\n  protected onFirst(responseProto: ProtoWriteResponse): Promise<void> {\n    // Always capture the last stream token.\n    hardAssert(\n      !!responseProto.streamToken,\n      'Got a write handshake response without a stream token'\n    );\n    this.lastStreamToken = responseProto.streamToken;\n\n    // The first response is always the handshake response\n    hardAssert(\n      !responseProto.writeResults || responseProto.writeResults.length === 0,\n      'Got mutation results for handshake'\n    );\n    return this.listener!.onHandshakeComplete();\n  }\n\n  protected onNext(responseProto: ProtoWriteResponse): Promise<void> {\n    // Always capture the last stream token.\n    hardAssert(\n      !!responseProto.streamToken,\n      'Got a write response without a stream token'\n    );\n    this.lastStreamToken = responseProto.streamToken;\n\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.backoff.reset();\n\n    const results = fromWriteResults(\n      responseProto.writeResults,\n      responseProto.commitTime\n    );\n    const commitVersion = fromVersion(responseProto.commitTime!);\n    return this.listener!.onMutationResult(commitVersion, results);\n  }\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  writeHandshake(): void {\n    debugAssert(this.isOpen(), 'Writing handshake requires an opened stream');\n    debugAssert(!this.handshakeComplete, 'Handshake already completed');\n    debugAssert(\n      !this.lastStreamToken,\n      'Stream token should be empty during handshake'\n    );\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    const request: WriteRequest = {};\n    request.database = getEncodedDatabaseId(this.serializer);\n    this.sendRequest(request);\n  }\n\n  /** Sends a group of mutations to the Firestore backend to apply. */\n  writeMutations(mutations: Mutation[]): void {\n    debugAssert(this.isOpen(), 'Writing mutations requires an opened stream');\n    debugAssert(\n      this.handshakeComplete,\n      'Handshake must be complete before writing mutations'\n    );\n    debugAssert(\n      !!this.lastStreamToken,\n      'Trying to write mutation without a token'\n    );\n\n    const request: WriteRequest = {\n      streamToken: this.lastStreamToken,\n      writes: mutations.map(mutation => toMutation(this.serializer, mutation))\n    };\n\n    this.sendRequest(request);\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 { CredentialsProvider } from '../api/credentials';\nimport { User } from '../auth/user';\nimport { Aggregate } from '../core/aggregate';\nimport { DatabaseId } from '../core/database_info';\nimport { queryToAggregateTarget, Query, queryToTarget } from '../core/query';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { Mutation } from '../model/mutation';\nimport { ResourcePath } from '../model/path';\nimport {\n  ApiClientObjectMap,\n  BatchGetDocumentsRequest as ProtoBatchGetDocumentsRequest,\n  BatchGetDocumentsResponse as ProtoBatchGetDocumentsResponse,\n  RunAggregationQueryRequest as ProtoRunAggregationQueryRequest,\n  RunAggregationQueryResponse as ProtoRunAggregationQueryResponse,\n  RunQueryRequest as ProtoRunQueryRequest,\n  RunQueryResponse as ProtoRunQueryResponse,\n  Value\n} from '../protos/firestore_proto_api';\nimport { debugAssert, debugCast, hardAssert } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\nimport { isNullOrUndefined } from '../util/types';\n\nimport { Connection } from './connection';\nimport {\n  PersistentListenStream,\n  PersistentWriteStream,\n  WatchStreamListener,\n  WriteStreamListener\n} from './persistent_stream';\nimport {\n  fromDocument,\n  fromBatchGetDocumentsResponse,\n  JsonProtoSerializer,\n  toMutation,\n  toName,\n  toQueryTarget,\n  toResourcePath,\n  toRunAggregationQueryRequest\n} from './serializer';\n\n/**\n * Datastore and its related methods are a wrapper around the external Google\n * Cloud Datastore grpc API, which provides an interface that is more convenient\n * for the rest of the client SDK architecture to consume.\n */\nexport abstract class Datastore {\n  abstract terminate(): void;\n  abstract serializer: JsonProtoSerializer;\n}\n\n/**\n * An implementation of Datastore that exposes additional state for internal\n * consumption.\n */\nclass DatastoreImpl extends Datastore {\n  terminated = false;\n\n  constructor(\n    readonly authCredentials: CredentialsProvider<User>,\n    readonly appCheckCredentials: CredentialsProvider<string>,\n    readonly connection: Connection,\n    readonly serializer: JsonProtoSerializer\n  ) {\n    super();\n  }\n\n  verifyInitialized(): void {\n    debugAssert(!!this.connection, 'Datastore.start() not called');\n    if (this.terminated) {\n      throw new FirestoreError(\n        Code.FAILED_PRECONDITION,\n        'The client has already been terminated.'\n      );\n    }\n  }\n\n  /** Invokes the provided RPC with auth and AppCheck tokens. */\n  invokeRPC<Req, Resp>(\n    rpcName: string,\n    databaseId: DatabaseId,\n    resourcePath: ResourcePath,\n    request: Req\n  ): Promise<Resp> {\n    this.verifyInitialized();\n    return Promise.all([\n      this.authCredentials.getToken(),\n      this.appCheckCredentials.getToken()\n    ])\n      .then(([authToken, appCheckToken]) => {\n        return this.connection.invokeRPC<Req, Resp>(\n          rpcName,\n          toResourcePath(databaseId, resourcePath),\n          request,\n          authToken,\n          appCheckToken\n        );\n      })\n      .catch((error: FirestoreError) => {\n        if (error.name === 'FirebaseError') {\n          if (error.code === Code.UNAUTHENTICATED) {\n            this.authCredentials.invalidateToken();\n            this.appCheckCredentials.invalidateToken();\n          }\n          throw error;\n        } else {\n          throw new FirestoreError(Code.UNKNOWN, error.toString());\n        }\n      });\n  }\n\n  /** Invokes the provided RPC with streamed results with auth and AppCheck tokens. */\n  invokeStreamingRPC<Req, Resp>(\n    rpcName: string,\n    databaseId: DatabaseId,\n    resourcePath: ResourcePath,\n    request: Req,\n    expectedResponseCount?: number\n  ): Promise<Resp[]> {\n    this.verifyInitialized();\n    return Promise.all([\n      this.authCredentials.getToken(),\n      this.appCheckCredentials.getToken()\n    ])\n      .then(([authToken, appCheckToken]) => {\n        return this.connection.invokeStreamingRPC<Req, Resp>(\n          rpcName,\n          toResourcePath(databaseId, resourcePath),\n          request,\n          authToken,\n          appCheckToken,\n          expectedResponseCount\n        );\n      })\n      .catch((error: FirestoreError) => {\n        if (error.name === 'FirebaseError') {\n          if (error.code === Code.UNAUTHENTICATED) {\n            this.authCredentials.invalidateToken();\n            this.appCheckCredentials.invalidateToken();\n          }\n          throw error;\n        } else {\n          throw new FirestoreError(Code.UNKNOWN, error.toString());\n        }\n      });\n  }\n\n  terminate(): void {\n    this.terminated = true;\n    this.connection.terminate();\n  }\n}\n\n// TODO(firestorexp): Make sure there is only one Datastore instance per\n// firestore-exp client.\nexport function newDatastore(\n  authCredentials: CredentialsProvider<User>,\n  appCheckCredentials: CredentialsProvider<string>,\n  connection: Connection,\n  serializer: JsonProtoSerializer\n): Datastore {\n  return new DatastoreImpl(\n    authCredentials,\n    appCheckCredentials,\n    connection,\n    serializer\n  );\n}\n\nexport async function invokeCommitRpc(\n  datastore: Datastore,\n  mutations: Mutation[]\n): Promise<void> {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  const request = {\n    writes: mutations.map(m => toMutation(datastoreImpl.serializer, m))\n  };\n  await datastoreImpl.invokeRPC(\n    'Commit',\n    datastoreImpl.serializer.databaseId,\n    ResourcePath.emptyPath(),\n    request\n  );\n}\n\nexport async function invokeBatchGetDocumentsRpc(\n  datastore: Datastore,\n  keys: DocumentKey[]\n): Promise<Document[]> {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  const request = {\n    documents: keys.map(k => toName(datastoreImpl.serializer, k))\n  };\n  const response = await datastoreImpl.invokeStreamingRPC<\n    ProtoBatchGetDocumentsRequest,\n    ProtoBatchGetDocumentsResponse\n  >(\n    'BatchGetDocuments',\n    datastoreImpl.serializer.databaseId,\n    ResourcePath.emptyPath(),\n    request,\n    keys.length\n  );\n\n  const docs = new Map<string, Document>();\n  response.forEach(proto => {\n    const doc = fromBatchGetDocumentsResponse(datastoreImpl.serializer, proto);\n    docs.set(doc.key.toString(), doc);\n  });\n  const result: Document[] = [];\n  keys.forEach(key => {\n    const doc = docs.get(key.toString());\n    hardAssert(!!doc, 'Missing entity in write response for ' + key);\n    result.push(doc);\n  });\n  return result;\n}\n\nexport async function invokeRunQueryRpc(\n  datastore: Datastore,\n  query: Query\n): Promise<Document[]> {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  const { queryTarget, parent } = toQueryTarget(\n    datastoreImpl.serializer,\n    queryToTarget(query)\n  );\n  const response = await datastoreImpl.invokeStreamingRPC<\n    ProtoRunQueryRequest,\n    ProtoRunQueryResponse\n  >('RunQuery', datastoreImpl.serializer.databaseId, parent, {\n    structuredQuery: queryTarget.structuredQuery\n  });\n  return (\n    response\n      // Omit RunQueryResponses that only contain readTimes.\n      .filter(proto => !!proto.document)\n      .map(proto =>\n        fromDocument(datastoreImpl.serializer, proto.document!, undefined)\n      )\n  );\n}\n\nexport async function invokeRunAggregationQueryRpc(\n  datastore: Datastore,\n  query: Query,\n  aggregates: Aggregate[]\n): Promise<ApiClientObjectMap<Value>> {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  const { request, aliasMap, parent } = toRunAggregationQueryRequest(\n    datastoreImpl.serializer,\n    queryToAggregateTarget(query),\n    aggregates\n  );\n\n  if (!datastoreImpl.connection.shouldResourcePathBeIncludedInRequest) {\n    delete request.parent;\n  }\n  const response = await datastoreImpl.invokeStreamingRPC<\n    ProtoRunAggregationQueryRequest,\n    ProtoRunAggregationQueryResponse\n  >(\n    'RunAggregationQuery',\n    datastoreImpl.serializer.databaseId,\n    parent,\n    request,\n    /*expectedResponseCount=*/ 1\n  );\n\n  // Omit RunAggregationQueryResponse that only contain readTimes.\n  const filteredResult = response.filter(proto => !!proto.result);\n\n  hardAssert(\n    filteredResult.length === 1,\n    'Aggregation fields are missing from result.'\n  );\n  debugAssert(\n    !isNullOrUndefined(filteredResult[0].result),\n    'aggregationQueryResponse.result'\n  );\n  debugAssert(\n    !isNullOrUndefined(filteredResult[0].result.aggregateFields),\n    'aggregationQueryResponse.result.aggregateFields'\n  );\n\n  // Remap the short-form aliases that were sent to the server\n  // to the client-side aliases. Users will access the results\n  // using the client-side alias.\n  const unmappedAggregateFields = filteredResult[0].result?.aggregateFields;\n  const remappedFields = Object.keys(unmappedAggregateFields).reduce<\n    ApiClientObjectMap<Value>\n  >((accumulator, key) => {\n    debugAssert(\n      !isNullOrUndefined(aliasMap[key]),\n      `'${key}' not present in aliasMap result`\n    );\n    accumulator[aliasMap[key]] = unmappedAggregateFields[key]!;\n    return accumulator;\n  }, {});\n\n  return remappedFields;\n}\n\nexport function newPersistentWriteStream(\n  datastore: Datastore,\n  queue: AsyncQueue,\n  listener: WriteStreamListener\n): PersistentWriteStream {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  datastoreImpl.verifyInitialized();\n  return new PersistentWriteStream(\n    queue,\n    datastoreImpl.connection,\n    datastoreImpl.authCredentials,\n    datastoreImpl.appCheckCredentials,\n    datastoreImpl.serializer,\n    listener\n  );\n}\n\nexport function newPersistentWatchStream(\n  datastore: Datastore,\n  queue: AsyncQueue,\n  listener: WatchStreamListener\n): PersistentListenStream {\n  const datastoreImpl = debugCast(datastore, DatastoreImpl);\n  datastoreImpl.verifyInitialized();\n  return new PersistentListenStream(\n    queue,\n    datastoreImpl.connection,\n    datastoreImpl.authCredentials,\n    datastoreImpl.appCheckCredentials,\n    datastoreImpl.serializer,\n    listener\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 { OnlineState } from '../core/types';\nimport { debugAssert } from '../util/assert';\nimport { AsyncQueue, DelayedOperation, TimerId } from '../util/async_queue';\nimport { FirestoreError } from '../util/error';\nimport { logError, logDebug } from '../util/log';\n\nconst LOG_TAG = 'OnlineStateTracker';\n\n// To deal with transient failures, we allow multiple stream attempts before\n// giving up and transitioning from OnlineState.Unknown to Offline.\n// TODO(mikelehen): This used to be set to 2 as a mitigation for b/66228394.\n// @jdimond thinks that bug is sufficiently fixed so that we can set this back\n// to 1. If that works okay, we could potentially remove this logic entirely.\nconst MAX_WATCH_STREAM_FAILURES = 1;\n\n// To deal with stream attempts that don't succeed or fail in a timely manner,\n// we have a timeout for OnlineState to reach Online or Offline.\n// If the timeout is reached, we transition to Offline rather than waiting\n// indefinitely.\nconst ONLINE_STATE_TIMEOUT_MS = 10 * 1000;\n\n/**\n * A component used by the RemoteStore to track the OnlineState (that is,\n * whether or not the client as a whole should be considered to be online or\n * offline), implementing the appropriate heuristics.\n *\n * In particular, when the client is trying to connect to the backend, we\n * allow up to MAX_WATCH_STREAM_FAILURES within ONLINE_STATE_TIMEOUT_MS for\n * a connection to succeed. If we have too many failures or the timeout elapses,\n * then we set the OnlineState to Offline, and the client will behave as if\n * it is offline (get()s will return cached data, etc.).\n */\nexport class OnlineStateTracker {\n  /** The current OnlineState. */\n  private state = OnlineState.Unknown;\n\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  private watchStreamFailures = 0;\n\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  private onlineStateTimer: DelayedOperation<void> | null = null;\n\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  private shouldWarnClientIsOffline = true;\n\n  constructor(\n    private asyncQueue: AsyncQueue,\n    private onlineStateHandler: (onlineState: OnlineState) => void\n  ) {}\n\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  handleWatchStreamStart(): void {\n    if (this.watchStreamFailures === 0) {\n      this.setAndBroadcast(OnlineState.Unknown);\n\n      debugAssert(\n        this.onlineStateTimer === null,\n        `onlineStateTimer shouldn't be started yet`\n      );\n      this.onlineStateTimer = this.asyncQueue.enqueueAfterDelay(\n        TimerId.OnlineStateTimeout,\n        ONLINE_STATE_TIMEOUT_MS,\n        () => {\n          this.onlineStateTimer = null;\n          debugAssert(\n            this.state === OnlineState.Unknown,\n            'Timer should be canceled if we transitioned to a different state.'\n          );\n          this.logClientOfflineWarningIfNecessary(\n            `Backend didn't respond within ${ONLINE_STATE_TIMEOUT_MS / 1000} ` +\n              `seconds.`\n          );\n          this.setAndBroadcast(OnlineState.Offline);\n\n          // NOTE: handleWatchStreamFailure() will continue to increment\n          // watchStreamFailures even though we are already marked Offline,\n          // but this is non-harmful.\n\n          return Promise.resolve();\n        }\n      );\n    }\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  handleWatchStreamFailure(error: FirestoreError): void {\n    if (this.state === OnlineState.Online) {\n      this.setAndBroadcast(OnlineState.Unknown);\n\n      // To get to OnlineState.Online, set() must have been called which would\n      // have reset our heuristics.\n      debugAssert(\n        this.watchStreamFailures === 0,\n        'watchStreamFailures must be 0'\n      );\n      debugAssert(\n        this.onlineStateTimer === null,\n        'onlineStateTimer must be null'\n      );\n    } else {\n      this.watchStreamFailures++;\n      if (this.watchStreamFailures >= MAX_WATCH_STREAM_FAILURES) {\n        this.clearOnlineStateTimer();\n\n        this.logClientOfflineWarningIfNecessary(\n          `Connection failed ${MAX_WATCH_STREAM_FAILURES} ` +\n            `times. Most recent error: ${error.toString()}`\n        );\n\n        this.setAndBroadcast(OnlineState.Offline);\n      }\n    }\n  }\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  set(newState: OnlineState): void {\n    this.clearOnlineStateTimer();\n    this.watchStreamFailures = 0;\n\n    if (newState === OnlineState.Online) {\n      // We've connected to watch at least once. Don't warn the developer\n      // about being offline going forward.\n      this.shouldWarnClientIsOffline = false;\n    }\n\n    this.setAndBroadcast(newState);\n  }\n\n  private setAndBroadcast(newState: OnlineState): void {\n    if (newState !== this.state) {\n      this.state = newState;\n      this.onlineStateHandler(newState);\n    }\n  }\n\n  private logClientOfflineWarningIfNecessary(details: string): void {\n    const message =\n      `Could not reach Cloud Firestore backend. ${details}\\n` +\n      `This typically indicates that your device does not have a healthy ` +\n      `Internet connection at the moment. The client will operate in offline ` +\n      `mode until it is able to successfully connect to the backend.`;\n    if (this.shouldWarnClientIsOffline) {\n      logError(message);\n      this.shouldWarnClientIsOffline = false;\n    } else {\n      logDebug(LOG_TAG, message);\n    }\n  }\n\n  private clearOnlineStateTimer(): void {\n    if (this.onlineStateTimer !== null) {\n      this.onlineStateTimer.cancel();\n      this.onlineStateTimer = 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 { User } from '../auth/user';\nimport { SnapshotVersion } from '../core/snapshot_version';\nimport { OnlineState, TargetId } from '../core/types';\nimport { LocalStore } from '../local/local_store';\nimport {\n  localStoreGetLastRemoteSnapshotVersion,\n  localStoreGetNextMutationBatch\n} from '../local/local_store_impl';\nimport { isIndexedDbTransactionError } from '../local/simple_db';\nimport { TargetData } from '../local/target_data';\nimport { MutationResult } from '../model/mutation';\nimport { MutationBatch, MutationBatchResult } from '../model/mutation_batch';\nimport { debugAssert, debugCast } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { ByteString } from '../util/byte_string';\nimport { FirestoreError } from '../util/error';\nimport { logDebug } from '../util/log';\nimport { BATCHID_UNKNOWN } from '../util/types';\n\nimport { ConnectivityMonitor, NetworkStatus } from './connectivity_monitor';\nimport {\n  Datastore,\n  newPersistentWatchStream,\n  newPersistentWriteStream\n} from './datastore';\nimport { OnlineStateTracker } from './online_state_tracker';\nimport {\n  PersistentListenStream,\n  PersistentWriteStream\n} from './persistent_stream';\nimport { RemoteSyncer } from './remote_syncer';\nimport { isPermanentWriteError } from './rpc_error';\nimport {\n  DocumentWatchChange,\n  ExistenceFilterChange,\n  WatchChange,\n  WatchChangeAggregator,\n  WatchTargetChange,\n  WatchTargetChangeState\n} from './watch_change';\n\nconst LOG_TAG = 'RemoteStore';\n\n// TODO(b/35853402): Negotiate this with the stream.\nconst MAX_PENDING_WRITES = 10;\n\n/** Reasons for why the RemoteStore may be offline. */\nconst enum OfflineCause {\n  /** The user has explicitly disabled the network (via `disableNetwork()`). */\n  UserDisabled,\n  /** An IndexedDb failure occurred while persisting a stream update. */\n  IndexedDbFailed,\n  /** The tab is not the primary tab (only relevant with multi-tab). */\n  IsSecondary,\n  /** We are restarting the streams due to an Auth credential change. */\n  CredentialChange,\n  /** The connectivity state of the environment has changed. */\n  ConnectivityChange,\n  /** The RemoteStore has been shut down. */\n  Shutdown\n}\n\n/**\n * RemoteStore - An interface to remotely stored data, basically providing a\n * wrapper around the Datastore that is more reliable for the rest of the\n * system.\n *\n * RemoteStore is responsible for maintaining the connection to the server.\n * - maintaining a list of active listens.\n * - reconnecting when the connection is dropped.\n * - resuming all the active listens on reconnect.\n *\n * RemoteStore handles all incoming events from the Datastore.\n * - listening to the watch stream and repackaging the events as RemoteEvents\n * - notifying SyncEngine of any changes to the active listens.\n *\n * RemoteStore takes writes from other components and handles them reliably.\n * - pulling pending mutations from LocalStore and sending them to Datastore.\n * - retrying mutations that failed because of network problems.\n * - acking mutations to the SyncEngine once they are accepted or rejected.\n */\nexport interface RemoteStore {\n  /**\n   * SyncEngine to notify of watch and write events. This must be set\n   * immediately after construction.\n   */\n  remoteSyncer: RemoteSyncer;\n}\n\nclass RemoteStoreImpl implements RemoteStore {\n  remoteSyncer: RemoteSyncer = {};\n\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  writePipeline: MutationBatch[] = [];\n\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  listenTargets = new Map<TargetId, TargetData>();\n\n  connectivityMonitor: ConnectivityMonitor;\n  watchStream?: PersistentListenStream;\n  writeStream?: PersistentWriteStream;\n  watchChangeAggregator?: WatchChangeAggregator;\n\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  offlineCauses = new Set<OfflineCause>();\n\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  onNetworkStatusChange: Array<(enabled: boolean) => Promise<void>> = [];\n\n  onlineStateTracker: OnlineStateTracker;\n\n  constructor(\n    /**\n     * The local store, used to fill the write pipeline with outbound mutations.\n     */\n    readonly localStore: LocalStore,\n    /** The client-side proxy for interacting with the backend. */\n    readonly datastore: Datastore,\n    readonly asyncQueue: AsyncQueue,\n    onlineStateHandler: (onlineState: OnlineState) => void,\n    connectivityMonitor: ConnectivityMonitor\n  ) {\n    this.connectivityMonitor = connectivityMonitor;\n    this.connectivityMonitor.addCallback((_: NetworkStatus) => {\n      asyncQueue.enqueueAndForget(async () => {\n        // Porting Note: Unlike iOS, `restartNetwork()` is called even when the\n        // network becomes unreachable as we don't have any other way to tear\n        // down our streams.\n        if (canUseNetwork(this)) {\n          logDebug(\n            LOG_TAG,\n            'Restarting streams for network reachability change.'\n          );\n          await restartNetwork(this);\n        }\n      });\n    });\n\n    this.onlineStateTracker = new OnlineStateTracker(\n      asyncQueue,\n      onlineStateHandler\n    );\n  }\n}\n\nexport function newRemoteStore(\n  localStore: LocalStore,\n  datastore: Datastore,\n  asyncQueue: AsyncQueue,\n  onlineStateHandler: (onlineState: OnlineState) => void,\n  connectivityMonitor: ConnectivityMonitor\n): RemoteStore {\n  return new RemoteStoreImpl(\n    localStore,\n    datastore,\n    asyncQueue,\n    onlineStateHandler,\n    connectivityMonitor\n  );\n}\n\n/** Re-enables the network. Idempotent. */\nexport function remoteStoreEnableNetwork(\n  remoteStore: RemoteStore\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  remoteStoreImpl.offlineCauses.delete(OfflineCause.UserDisabled);\n  return enableNetworkInternal(remoteStoreImpl);\n}\n\nasync function enableNetworkInternal(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  if (canUseNetwork(remoteStoreImpl)) {\n    for (const networkStatusHandler of remoteStoreImpl.onNetworkStatusChange) {\n      await networkStatusHandler(/* enabled= */ true);\n    }\n  }\n}\n\n/**\n * Temporarily disables the network. The network can be re-enabled using\n * enableNetwork().\n */\nexport async function remoteStoreDisableNetwork(\n  remoteStore: RemoteStore\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  remoteStoreImpl.offlineCauses.add(OfflineCause.UserDisabled);\n  await disableNetworkInternal(remoteStoreImpl);\n\n  // Set the OnlineState to Offline so get()s return from cache, etc.\n  remoteStoreImpl.onlineStateTracker.set(OnlineState.Offline);\n}\n\nasync function disableNetworkInternal(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  for (const networkStatusHandler of remoteStoreImpl.onNetworkStatusChange) {\n    await networkStatusHandler(/* enabled= */ false);\n  }\n}\n\nexport async function remoteStoreShutdown(\n  remoteStore: RemoteStore\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  logDebug(LOG_TAG, 'RemoteStore shutting down.');\n  remoteStoreImpl.offlineCauses.add(OfflineCause.Shutdown);\n  await disableNetworkInternal(remoteStoreImpl);\n  remoteStoreImpl.connectivityMonitor.shutdown();\n\n  // Set the OnlineState to Unknown (rather than Offline) to avoid potentially\n  // triggering spurious listener events with cached data, etc.\n  remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\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 */\nexport function remoteStoreListen(\n  remoteStore: RemoteStore,\n  targetData: TargetData\n): void {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n\n  if (remoteStoreImpl.listenTargets.has(targetData.targetId)) {\n    return;\n  }\n\n  // Mark this as something the client is currently listening for.\n  remoteStoreImpl.listenTargets.set(targetData.targetId, targetData);\n\n  if (shouldStartWatchStream(remoteStoreImpl)) {\n    // The listen will be sent in onWatchStreamOpen\n    startWatchStream(remoteStoreImpl);\n  } else if (ensureWatchStream(remoteStoreImpl).isOpen()) {\n    sendWatchRequest(remoteStoreImpl, targetData);\n  }\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 */\nexport function remoteStoreUnlisten(\n  remoteStore: RemoteStore,\n  targetId: TargetId\n): void {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  const watchStream = ensureWatchStream(remoteStoreImpl);\n\n  debugAssert(\n    remoteStoreImpl.listenTargets.has(targetId),\n    `unlisten called on target no currently watched: ${targetId}`\n  );\n\n  remoteStoreImpl.listenTargets.delete(targetId);\n  if (watchStream.isOpen()) {\n    sendUnwatchRequest(remoteStoreImpl, targetId);\n  }\n\n  if (remoteStoreImpl.listenTargets.size === 0) {\n    if (watchStream.isOpen()) {\n      watchStream.markIdle();\n    } else if (canUseNetwork(remoteStoreImpl)) {\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      remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\n    }\n  }\n}\n\n/**\n * We need to increment 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 */\nfunction sendWatchRequest(\n  remoteStoreImpl: RemoteStoreImpl,\n  targetData: TargetData\n): void {\n  remoteStoreImpl.watchChangeAggregator!.recordPendingTargetRequest(\n    targetData.targetId\n  );\n\n  if (\n    targetData.resumeToken.approximateByteSize() > 0 ||\n    targetData.snapshotVersion.compareTo(SnapshotVersion.min()) > 0\n  ) {\n    const expectedCount = remoteStoreImpl.remoteSyncer.getRemoteKeysForTarget!(\n      targetData.targetId\n    ).size;\n    targetData = targetData.withExpectedCount(expectedCount);\n  }\n\n  ensureWatchStream(remoteStoreImpl).watch(targetData);\n}\n\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 */\nfunction sendUnwatchRequest(\n  remoteStoreImpl: RemoteStoreImpl,\n  targetId: TargetId\n): void {\n  remoteStoreImpl.watchChangeAggregator!.recordPendingTargetRequest(targetId);\n  ensureWatchStream(remoteStoreImpl).unwatch(targetId);\n}\n\nfunction startWatchStream(remoteStoreImpl: RemoteStoreImpl): void {\n  debugAssert(\n    shouldStartWatchStream(remoteStoreImpl),\n    'startWatchStream() called when shouldStartWatchStream() is false.'\n  );\n  debugAssert(\n    !!remoteStoreImpl.remoteSyncer.getRemoteKeysForTarget,\n    'getRemoteKeysForTarget() not set'\n  );\n\n  remoteStoreImpl.watchChangeAggregator = new WatchChangeAggregator({\n    getRemoteKeysForTarget: targetId =>\n      remoteStoreImpl.remoteSyncer.getRemoteKeysForTarget!(targetId),\n    getTargetDataForTarget: targetId =>\n      remoteStoreImpl.listenTargets.get(targetId) || null,\n    getDatabaseId: () => remoteStoreImpl.datastore.serializer.databaseId\n  });\n  ensureWatchStream(remoteStoreImpl).start();\n  remoteStoreImpl.onlineStateTracker.handleWatchStreamStart();\n}\n\n/**\n * Returns whether the watch stream should be started because it's necessary\n * and has not yet been started.\n */\nfunction shouldStartWatchStream(remoteStoreImpl: RemoteStoreImpl): boolean {\n  return (\n    canUseNetwork(remoteStoreImpl) &&\n    !ensureWatchStream(remoteStoreImpl).isStarted() &&\n    remoteStoreImpl.listenTargets.size > 0\n  );\n}\n\nexport function canUseNetwork(remoteStore: RemoteStore): boolean {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  return remoteStoreImpl.offlineCauses.size === 0;\n}\n\nfunction cleanUpWatchStreamState(remoteStoreImpl: RemoteStoreImpl): void {\n  remoteStoreImpl.watchChangeAggregator = undefined;\n}\n\nasync function onWatchStreamConnected(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  // Mark the client as online since we got a \"connected\" notification.\n  remoteStoreImpl.onlineStateTracker.set(OnlineState.Online);\n}\n\nasync function onWatchStreamOpen(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  remoteStoreImpl.listenTargets.forEach((targetData, targetId) => {\n    sendWatchRequest(remoteStoreImpl, targetData);\n  });\n}\n\nasync function onWatchStreamClose(\n  remoteStoreImpl: RemoteStoreImpl,\n  error?: FirestoreError\n): Promise<void> {\n  if (error === undefined) {\n    // Graceful stop (due to stop() or idle timeout). Make sure that's\n    // desirable.\n    debugAssert(\n      !shouldStartWatchStream(remoteStoreImpl),\n      'Watch stream was stopped gracefully while still needed.'\n    );\n  }\n\n  cleanUpWatchStreamState(remoteStoreImpl);\n\n  // If we still need the watch stream, retry the connection.\n  if (shouldStartWatchStream(remoteStoreImpl)) {\n    remoteStoreImpl.onlineStateTracker.handleWatchStreamFailure(error!);\n\n    startWatchStream(remoteStoreImpl);\n  } else {\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    remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\n  }\n}\n\nasync function onWatchStreamChange(\n  remoteStoreImpl: RemoteStoreImpl,\n  watchChange: WatchChange,\n  snapshotVersion: SnapshotVersion\n): Promise<void> {\n  // Mark the client as online since we got a message from the server\n  remoteStoreImpl.onlineStateTracker.set(OnlineState.Online);\n\n  if (\n    watchChange instanceof WatchTargetChange &&\n    watchChange.state === WatchTargetChangeState.Removed &&\n    watchChange.cause\n  ) {\n    // There was an error on a target, don't wait for a consistent snapshot\n    // to raise events\n    try {\n      await handleTargetError(remoteStoreImpl, watchChange);\n    } catch (e) {\n      logDebug(\n        LOG_TAG,\n        'Failed to remove targets %s: %s ',\n        watchChange.targetIds.join(','),\n        e\n      );\n      await disableNetworkUntilRecovery(remoteStoreImpl, e as FirestoreError);\n    }\n    return;\n  }\n\n  if (watchChange instanceof DocumentWatchChange) {\n    remoteStoreImpl.watchChangeAggregator!.handleDocumentChange(watchChange);\n  } else if (watchChange instanceof ExistenceFilterChange) {\n    remoteStoreImpl.watchChangeAggregator!.handleExistenceFilter(watchChange);\n  } else {\n    debugAssert(\n      watchChange instanceof WatchTargetChange,\n      'Expected watchChange to be an instance of WatchTargetChange'\n    );\n    remoteStoreImpl.watchChangeAggregator!.handleTargetChange(watchChange);\n  }\n\n  if (!snapshotVersion.isEqual(SnapshotVersion.min())) {\n    try {\n      const lastRemoteSnapshotVersion =\n        await localStoreGetLastRemoteSnapshotVersion(\n          remoteStoreImpl.localStore\n        );\n      if (snapshotVersion.compareTo(lastRemoteSnapshotVersion) >= 0) {\n        // We have received a target change with a global snapshot if the snapshot\n        // version is not equal to SnapshotVersion.min().\n        await raiseWatchSnapshot(remoteStoreImpl, snapshotVersion);\n      }\n    } catch (e) {\n      logDebug(LOG_TAG, 'Failed to raise snapshot:', e);\n      await disableNetworkUntilRecovery(remoteStoreImpl, e as FirestoreError);\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 */\nasync function disableNetworkUntilRecovery(\n  remoteStoreImpl: RemoteStoreImpl,\n  e: FirestoreError,\n  op?: () => Promise<unknown>\n): Promise<void> {\n  if (isIndexedDbTransactionError(e)) {\n    debugAssert(\n      !remoteStoreImpl.offlineCauses.has(OfflineCause.IndexedDbFailed),\n      'Unexpected network event when IndexedDB was marked failed.'\n    );\n    remoteStoreImpl.offlineCauses.add(OfflineCause.IndexedDbFailed);\n\n    // Disable network and raise offline snapshots\n    await disableNetworkInternal(remoteStoreImpl);\n    remoteStoreImpl.onlineStateTracker.set(OnlineState.Offline);\n\n    if (!op) {\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      op = () =>\n        localStoreGetLastRemoteSnapshotVersion(remoteStoreImpl.localStore);\n    }\n\n    // Probe IndexedDB periodically and re-enable network\n    remoteStoreImpl.asyncQueue.enqueueRetryable(async () => {\n      logDebug(LOG_TAG, 'Retrying IndexedDB access');\n      await op!();\n      remoteStoreImpl.offlineCauses.delete(OfflineCause.IndexedDbFailed);\n      await enableNetworkInternal(remoteStoreImpl);\n    });\n  } else {\n    throw e;\n  }\n}\n\n/**\n * Executes `op`. If `op` fails, takes the network offline until `op`\n * succeeds. Returns after the first attempt.\n */\nfunction executeWithRecovery(\n  remoteStoreImpl: RemoteStoreImpl,\n  op: () => Promise<void>\n): Promise<void> {\n  return op().catch(e => disableNetworkUntilRecovery(remoteStoreImpl, e, op));\n}\n\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 */\nfunction raiseWatchSnapshot(\n  remoteStoreImpl: RemoteStoreImpl,\n  snapshotVersion: SnapshotVersion\n): Promise<void> {\n  debugAssert(\n    !snapshotVersion.isEqual(SnapshotVersion.min()),\n    \"Can't raise event for unknown SnapshotVersion\"\n  );\n  const remoteEvent =\n    remoteStoreImpl.watchChangeAggregator!.createRemoteEvent(snapshotVersion);\n\n  // Update in-memory resume tokens. LocalStore will update the\n  // persistent view of these when applying the completed RemoteEvent.\n  remoteEvent.targetChanges.forEach((change, targetId) => {\n    if (change.resumeToken.approximateByteSize() > 0) {\n      const targetData = remoteStoreImpl.listenTargets.get(targetId);\n      // A watched target might have been removed already.\n      if (targetData) {\n        remoteStoreImpl.listenTargets.set(\n          targetId,\n          targetData.withResumeToken(change.resumeToken, snapshotVersion)\n        );\n      }\n    }\n  });\n\n  // Re-establish listens for the targets that have been invalidated by\n  // existence filter mismatches.\n  remoteEvent.targetMismatches.forEach((targetId, targetPurpose) => {\n    const targetData = remoteStoreImpl.listenTargets.get(targetId);\n    if (!targetData) {\n      // A watched target might have been removed already.\n      return;\n    }\n\n    // Clear the resume token for the target, since we're in a known mismatch\n    // state.\n    remoteStoreImpl.listenTargets.set(\n      targetId,\n      targetData.withResumeToken(\n        ByteString.EMPTY_BYTE_STRING,\n        targetData.snapshotVersion\n      )\n    );\n\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    sendUnwatchRequest(remoteStoreImpl, targetId);\n\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    const requestTargetData = new TargetData(\n      targetData.target,\n      targetId,\n      targetPurpose,\n      targetData.sequenceNumber\n    );\n    sendWatchRequest(remoteStoreImpl, requestTargetData);\n  });\n\n  // Finally raise remote event\n  debugAssert(\n    !!remoteStoreImpl.remoteSyncer.applyRemoteEvent,\n    'applyRemoteEvent() not set'\n  );\n  return remoteStoreImpl.remoteSyncer.applyRemoteEvent(remoteEvent);\n}\n\n/** Handles an error on a target */\nasync function handleTargetError(\n  remoteStoreImpl: RemoteStoreImpl,\n  watchChange: WatchTargetChange\n): Promise<void> {\n  debugAssert(\n    !!remoteStoreImpl.remoteSyncer.rejectListen,\n    'rejectListen() not set'\n  );\n  debugAssert(!!watchChange.cause, 'Handling target error without a cause');\n  const error = watchChange.cause!;\n  for (const targetId of watchChange.targetIds) {\n    // A watched target might have been removed already.\n    if (remoteStoreImpl.listenTargets.has(targetId)) {\n      await remoteStoreImpl.remoteSyncer.rejectListen(targetId, error);\n      remoteStoreImpl.listenTargets.delete(targetId);\n      remoteStoreImpl.watchChangeAggregator!.removeTarget(targetId);\n    }\n  }\n}\n\n/**\n * Attempts to fill our write pipeline with writes from the LocalStore.\n *\n * Called internally to bootstrap or refill the write pipeline and by\n * SyncEngine whenever there are new mutations to process.\n *\n * Starts the write stream if necessary.\n */\nexport async function fillWritePipeline(\n  remoteStore: RemoteStore\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  const writeStream = ensureWriteStream(remoteStoreImpl);\n\n  let lastBatchIdRetrieved =\n    remoteStoreImpl.writePipeline.length > 0\n      ? remoteStoreImpl.writePipeline[remoteStoreImpl.writePipeline.length - 1]\n          .batchId\n      : BATCHID_UNKNOWN;\n\n  while (canAddToWritePipeline(remoteStoreImpl)) {\n    try {\n      const batch = await localStoreGetNextMutationBatch(\n        remoteStoreImpl.localStore,\n        lastBatchIdRetrieved\n      );\n\n      if (batch === null) {\n        if (remoteStoreImpl.writePipeline.length === 0) {\n          writeStream.markIdle();\n        }\n        break;\n      } else {\n        lastBatchIdRetrieved = batch.batchId;\n        addToWritePipeline(remoteStoreImpl, batch);\n      }\n    } catch (e) {\n      await disableNetworkUntilRecovery(remoteStoreImpl, e as FirestoreError);\n    }\n  }\n\n  if (shouldStartWriteStream(remoteStoreImpl)) {\n    startWriteStream(remoteStoreImpl);\n  }\n}\n\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 */\nfunction canAddToWritePipeline(remoteStoreImpl: RemoteStoreImpl): boolean {\n  return (\n    canUseNetwork(remoteStoreImpl) &&\n    remoteStoreImpl.writePipeline.length < MAX_PENDING_WRITES\n  );\n}\n\n// For testing\nexport function outstandingWrites(remoteStore: RemoteStore): number {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  return remoteStoreImpl.writePipeline.length;\n}\n\n/**\n * Queues additional writes to be sent to the write stream, sending them\n * immediately if the write stream is established.\n */\nfunction addToWritePipeline(\n  remoteStoreImpl: RemoteStoreImpl,\n  batch: MutationBatch\n): void {\n  debugAssert(\n    canAddToWritePipeline(remoteStoreImpl),\n    'addToWritePipeline called when pipeline is full'\n  );\n  remoteStoreImpl.writePipeline.push(batch);\n\n  const writeStream = ensureWriteStream(remoteStoreImpl);\n  if (writeStream.isOpen() && writeStream.handshakeComplete) {\n    writeStream.writeMutations(batch.mutations);\n  }\n}\n\nfunction shouldStartWriteStream(remoteStoreImpl: RemoteStoreImpl): boolean {\n  return (\n    canUseNetwork(remoteStoreImpl) &&\n    !ensureWriteStream(remoteStoreImpl).isStarted() &&\n    remoteStoreImpl.writePipeline.length > 0\n  );\n}\n\nfunction startWriteStream(remoteStoreImpl: RemoteStoreImpl): void {\n  debugAssert(\n    shouldStartWriteStream(remoteStoreImpl),\n    'startWriteStream() called when shouldStartWriteStream() is false.'\n  );\n  ensureWriteStream(remoteStoreImpl).start();\n}\n\nasync function onWriteStreamOpen(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  ensureWriteStream(remoteStoreImpl).writeHandshake();\n}\n\nasync function onWriteHandshakeComplete(\n  remoteStoreImpl: RemoteStoreImpl\n): Promise<void> {\n  const writeStream = ensureWriteStream(remoteStoreImpl);\n  // Send the write pipeline now that the stream is established.\n  for (const batch of remoteStoreImpl.writePipeline) {\n    writeStream.writeMutations(batch.mutations);\n  }\n}\n\nasync function onMutationResult(\n  remoteStoreImpl: RemoteStoreImpl,\n  commitVersion: SnapshotVersion,\n  results: MutationResult[]\n): Promise<void> {\n  // This is a response to a write containing mutations and should be\n  // correlated to the first write in our write pipeline.\n  debugAssert(\n    remoteStoreImpl.writePipeline.length > 0,\n    'Got result for empty write pipeline'\n  );\n  const batch = remoteStoreImpl.writePipeline.shift()!;\n  const success = MutationBatchResult.from(batch, commitVersion, results);\n\n  debugAssert(\n    !!remoteStoreImpl.remoteSyncer.applySuccessfulWrite,\n    'applySuccessfulWrite() not set'\n  );\n  await executeWithRecovery(remoteStoreImpl, () =>\n    remoteStoreImpl.remoteSyncer.applySuccessfulWrite!(success)\n  );\n\n  // It's possible that with the completion of this mutation another\n  // slot has freed up.\n  await fillWritePipeline(remoteStoreImpl);\n}\n\nasync function onWriteStreamClose(\n  remoteStoreImpl: RemoteStoreImpl,\n  error?: FirestoreError\n): Promise<void> {\n  if (error === undefined) {\n    // Graceful stop (due to stop() or idle timeout). Make sure that's\n    // desirable.\n    debugAssert(\n      !shouldStartWriteStream(remoteStoreImpl),\n      'Write stream was stopped gracefully while still needed.'\n    );\n  }\n\n  // If the write stream closed after the write handshake completes, a write\n  // operation failed and we fail the pending operation.\n  if (error && ensureWriteStream(remoteStoreImpl).handshakeComplete) {\n    // This error affects the actual write.\n    await handleWriteError(remoteStoreImpl, error!);\n  }\n\n  // The write stream might have been started by refilling the write\n  // pipeline for failed writes\n  if (shouldStartWriteStream(remoteStoreImpl)) {\n    startWriteStream(remoteStoreImpl);\n  }\n}\n\nasync function handleWriteError(\n  remoteStoreImpl: RemoteStoreImpl,\n  error: FirestoreError\n): Promise<void> {\n  // Only handle permanent errors here. If it's transient, just let the retry\n  // logic kick in.\n  if (isPermanentWriteError(error.code)) {\n    // This was a permanent error, the request itself was the problem\n    // so it's not going to succeed if we resend it.\n    const batch = remoteStoreImpl.writePipeline.shift()!;\n\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    ensureWriteStream(remoteStoreImpl).inhibitBackoff();\n\n    debugAssert(\n      !!remoteStoreImpl.remoteSyncer.rejectFailedWrite,\n      'rejectFailedWrite() not set'\n    );\n    await executeWithRecovery(remoteStoreImpl, () =>\n      remoteStoreImpl.remoteSyncer.rejectFailedWrite!(batch.batchId, error)\n    );\n\n    // It's possible that with the completion of this mutation\n    // another slot has freed up.\n    await fillWritePipeline(remoteStoreImpl);\n  } else {\n    // Transient error, just let the retry logic kick in.\n  }\n}\n\nasync function restartNetwork(remoteStore: RemoteStore): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  remoteStoreImpl.offlineCauses.add(OfflineCause.ConnectivityChange);\n  await disableNetworkInternal(remoteStoreImpl);\n  remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\n  remoteStoreImpl.offlineCauses.delete(OfflineCause.ConnectivityChange);\n  await enableNetworkInternal(remoteStoreImpl);\n}\n\nexport async function remoteStoreHandleCredentialChange(\n  remoteStore: RemoteStore,\n  user: User\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  remoteStoreImpl.asyncQueue.verifyOperationInProgress();\n  debugAssert(\n    !!remoteStoreImpl.remoteSyncer.handleCredentialChange,\n    'handleCredentialChange() not set'\n  );\n\n  logDebug(LOG_TAG, 'RemoteStore received new credentials');\n  const usesNetwork = canUseNetwork(remoteStoreImpl);\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  remoteStoreImpl.offlineCauses.add(OfflineCause.CredentialChange);\n  await disableNetworkInternal(remoteStoreImpl);\n  if (usesNetwork) {\n    // Don't set the network status to Unknown if we are offline.\n    remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\n  }\n  await remoteStoreImpl.remoteSyncer.handleCredentialChange(user);\n  remoteStoreImpl.offlineCauses.delete(OfflineCause.CredentialChange);\n  await enableNetworkInternal(remoteStoreImpl);\n}\n\n/**\n * Toggles the network state when the client gains or loses its primary lease.\n */\nexport async function remoteStoreApplyPrimaryState(\n  remoteStore: RemoteStore,\n  isPrimary: boolean\n): Promise<void> {\n  const remoteStoreImpl = debugCast(remoteStore, RemoteStoreImpl);\n  if (isPrimary) {\n    remoteStoreImpl.offlineCauses.delete(OfflineCause.IsSecondary);\n    await enableNetworkInternal(remoteStoreImpl);\n  } else if (!isPrimary) {\n    remoteStoreImpl.offlineCauses.add(OfflineCause.IsSecondary);\n    await disableNetworkInternal(remoteStoreImpl);\n    remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\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 */\nfunction ensureWatchStream(\n  remoteStoreImpl: RemoteStoreImpl\n): PersistentListenStream {\n  if (!remoteStoreImpl.watchStream) {\n    // Create stream (but note that it is not started yet).\n    remoteStoreImpl.watchStream = newPersistentWatchStream(\n      remoteStoreImpl.datastore,\n      remoteStoreImpl.asyncQueue,\n      {\n        onConnected: onWatchStreamConnected.bind(null, remoteStoreImpl),\n        onOpen: onWatchStreamOpen.bind(null, remoteStoreImpl),\n        onClose: onWatchStreamClose.bind(null, remoteStoreImpl),\n        onWatchChange: onWatchStreamChange.bind(null, remoteStoreImpl)\n      }\n    );\n\n    remoteStoreImpl.onNetworkStatusChange.push(async enabled => {\n      if (enabled) {\n        remoteStoreImpl.watchStream!.inhibitBackoff();\n        if (shouldStartWatchStream(remoteStoreImpl)) {\n          startWatchStream(remoteStoreImpl);\n        } else {\n          remoteStoreImpl.onlineStateTracker.set(OnlineState.Unknown);\n        }\n      } else {\n        await remoteStoreImpl.watchStream!.stop();\n        cleanUpWatchStreamState(remoteStoreImpl);\n      }\n    });\n  }\n\n  return remoteStoreImpl.watchStream;\n}\n\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 */\nfunction ensureWriteStream(\n  remoteStoreImpl: RemoteStoreImpl\n): PersistentWriteStream {\n  if (!remoteStoreImpl.writeStream) {\n    debugAssert(\n      remoteStoreImpl.writePipeline.length === 0,\n      'Should not issue writes before WriteStream is enabled'\n    );\n\n    // Create stream (but note that it is not started yet).\n    remoteStoreImpl.writeStream = newPersistentWriteStream(\n      remoteStoreImpl.datastore,\n      remoteStoreImpl.asyncQueue,\n      {\n        onConnected: () => Promise.resolve(),\n        onOpen: onWriteStreamOpen.bind(null, remoteStoreImpl),\n        onClose: onWriteStreamClose.bind(null, remoteStoreImpl),\n        onHandshakeComplete: onWriteHandshakeComplete.bind(\n          null,\n          remoteStoreImpl\n        ),\n        onMutationResult: onMutationResult.bind(null, remoteStoreImpl)\n      }\n    );\n\n    remoteStoreImpl.onNetworkStatusChange.push(async enabled => {\n      if (enabled) {\n        remoteStoreImpl.writeStream!.inhibitBackoff();\n\n        // This will start the write stream if necessary.\n        await fillWritePipeline(remoteStoreImpl);\n      } else {\n        await remoteStoreImpl.writeStream!.stop();\n\n        if (remoteStoreImpl.writePipeline.length > 0) {\n          logDebug(\n            LOG_TAG,\n            `Stopping write stream with ${remoteStoreImpl.writePipeline.length} pending writes`\n          );\n          remoteStoreImpl.writePipeline = [];\n        }\n      }\n    });\n  }\n\n  return remoteStoreImpl.writeStream;\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 { isIndexedDbTransactionError } from '../local/simple_db';\n\nimport { Code, FirestoreError } from './error';\nimport { logError } from './log';\nimport { Deferred } from './promise';\n\nconst LOG_TAG = 'AsyncQueue';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype TimerHandle = any;\n\n/**\n * Wellknown \"timer\" IDs used when scheduling delayed operations on the\n * AsyncQueue. These IDs can then be used from tests to check for the presence\n * of operations or to run them early.\n *\n * The string values are used when encoding these timer IDs in JSON spec tests.\n */\nexport const enum TimerId {\n  /** All can be used with runDelayedOperationsEarly() to run all timers. */\n  All = 'all',\n\n  /**\n   * The following 5 timers are used in persistent_stream.ts for the listen and\n   * write streams. The \"Idle\" timer is used to close the stream due to\n   * inactivity. The \"ConnectionBackoff\" timer is used to restart a stream once\n   * the appropriate backoff delay has elapsed. The health check is used to mark\n   * a stream healthy if it has not received an error during its initial setup.\n   */\n  ListenStreamIdle = 'listen_stream_idle',\n  ListenStreamConnectionBackoff = 'listen_stream_connection_backoff',\n  WriteStreamIdle = 'write_stream_idle',\n  WriteStreamConnectionBackoff = 'write_stream_connection_backoff',\n  HealthCheckTimeout = 'health_check_timeout',\n\n  /**\n   * A timer used in online_state_tracker.ts to transition from\n   * OnlineState.Unknown to Offline after a set timeout, rather than waiting\n   * indefinitely for success or failure.\n   */\n  OnlineStateTimeout = 'online_state_timeout',\n\n  /**\n   * A timer used to update the client metadata in IndexedDb, which is used\n   * to determine the primary leaseholder.\n   */\n  ClientMetadataRefresh = 'client_metadata_refresh',\n\n  /** A timer used to periodically attempt LRU Garbage collection */\n  LruGarbageCollection = 'lru_garbage_collection',\n\n  /**\n   * A timer used to retry transactions. Since there can be multiple concurrent\n   * transactions, multiple of these may be in the queue at a given time.\n   */\n  TransactionRetry = 'transaction_retry',\n\n  /**\n   * A timer used to retry operations scheduled via retryable AsyncQueue\n   * operations.\n   */\n  AsyncQueueRetry = 'async_queue_retry',\n\n  /**\n   *  A timer used to periodically attempt index backfill.\n   */\n  IndexBackfill = 'index_backfill'\n}\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 */\nexport class DelayedOperation<T extends unknown> implements PromiseLike<T> {\n  // handle for use with clearTimeout(), or null if the operation has been\n  // executed or canceled already.\n  private timerHandle: TimerHandle | null;\n\n  private readonly deferred = new Deferred<T>();\n\n  private constructor(\n    private readonly asyncQueue: AsyncQueue,\n    readonly timerId: TimerId,\n    readonly targetTimeMs: number,\n    private readonly op: () => Promise<T>,\n    private readonly removalCallback: (op: DelayedOperation<T>) => void\n  ) {\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.deferred.promise.catch(err => {});\n  }\n\n  get promise(): Promise<T> {\n    return this.deferred.promise;\n  }\n\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  static createAndSchedule<R extends unknown>(\n    asyncQueue: AsyncQueue,\n    timerId: TimerId,\n    delayMs: number,\n    op: () => Promise<R>,\n    removalCallback: (op: DelayedOperation<R>) => void\n  ): DelayedOperation<R> {\n    const targetTime = Date.now() + delayMs;\n    const delayedOp = new DelayedOperation(\n      asyncQueue,\n      timerId,\n      targetTime,\n      op,\n      removalCallback\n    );\n    delayedOp.start(delayMs);\n    return delayedOp;\n  }\n\n  /**\n   * Starts the timer. This is called immediately after construction by\n   * createAndSchedule().\n   */\n  private start(delayMs: number): void {\n    this.timerHandle = setTimeout(() => this.handleDelayElapsed(), delayMs);\n  }\n\n  /**\n   * Queues the operation to run immediately (if it hasn't already been run or\n   * canceled).\n   */\n  skipDelay(): void {\n    return this.handleDelayElapsed();\n  }\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  cancel(reason?: string): void {\n    if (this.timerHandle !== null) {\n      this.clearTimeout();\n      this.deferred.reject(\n        new FirestoreError(\n          Code.CANCELLED,\n          'Operation cancelled' + (reason ? ': ' + reason : '')\n        )\n      );\n    }\n  }\n\n  then = this.deferred.promise.then.bind(this.deferred.promise);\n\n  private handleDelayElapsed(): void {\n    this.asyncQueue.enqueueAndForget(() => {\n      if (this.timerHandle !== null) {\n        this.clearTimeout();\n        return this.op().then(result => {\n          return this.deferred.resolve(result);\n        });\n      } else {\n        return Promise.resolve();\n      }\n    });\n  }\n\n  private clearTimeout(): void {\n    if (this.timerHandle !== null) {\n      this.removalCallback(this);\n      clearTimeout(this.timerHandle);\n      this.timerHandle = null;\n    }\n  }\n}\n\nexport interface AsyncQueue {\n  // Is this AsyncQueue being shut down? If true, this instance will not enqueue\n  // any new operations, Promises from enqueue requests will not resolve.\n  readonly isShuttingDown: boolean;\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  enqueueAndForget<T extends unknown>(op: () => Promise<T>): void;\n\n  /**\n   * Regardless if the queue has initialized shutdown, adds a new operation to the\n   * queue without waiting for it to complete (i.e. we ignore the Promise result).\n   */\n  enqueueAndForgetEvenWhileRestricted<T extends unknown>(\n    op: () => Promise<T>\n  ): void;\n\n  /**\n   * Initialize the shutdown of this queue. Once this method is called, the\n   * only possible way to request running an operation is through\n   * `enqueueEvenWhileRestricted()`.\n   *\n   * @param purgeExistingTasks Whether already enqueued tasked should be\n   * rejected (unless enqueued with `enqueueEvenWhileRestricted()`). Defaults\n   * to false.\n   */\n  enterRestrictedMode(purgeExistingTasks?: boolean): void;\n\n  /**\n   * Adds a new operation to the queue. Returns a promise that will be resolved\n   * when the promise returned by the new operation is (with its value).\n   */\n  enqueue<T extends unknown>(op: () => Promise<T>): Promise<T>;\n\n  /**\n   * Enqueue a retryable operation.\n   *\n   * A retryable operation is rescheduled with backoff if it fails with a\n   * IndexedDbTransactionError (the error type used by SimpleDb). All\n   * retryable operations are executed in order and only run if all prior\n   * operations were retried successfully.\n   */\n  enqueueRetryable(op: () => Promise<void>): void;\n\n  /**\n   * Schedules an operation to be queued on the AsyncQueue once the specified\n   * `delayMs` has elapsed. The returned DelayedOperation can be used to cancel\n   * or fast-forward the operation prior to its running.\n   */\n  enqueueAfterDelay<T extends unknown>(\n    timerId: TimerId,\n    delayMs: number,\n    op: () => Promise<T>\n  ): DelayedOperation<T>;\n\n  /**\n   * Verifies there's an operation currently in-progress on the AsyncQueue.\n   * Unfortunately we can't verify that the running code is in the promise chain\n   * of that operation, so this isn't a foolproof check, but it should be enough\n   * to catch some bugs.\n   */\n  verifyOperationInProgress(): void;\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 */\nexport function wrapInUserErrorIfRecoverable(\n  e: Error,\n  msg: string\n): FirestoreError {\n  logError(LOG_TAG, `${msg}: ${e}`);\n  if (isIndexedDbTransactionError(e)) {\n    return new FirestoreError(Code.UNAVAILABLE, `${msg}: ${e}`);\n  } else {\n    throw 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\nimport { SortedMap } from '../util/sorted_map';\n\nimport { documentMap } from './collections';\nimport { Document } from './document';\nimport { DocumentComparator } from './document_comparator';\nimport { DocumentKey } from './document_key';\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 */\n\nexport class DocumentSet {\n  /**\n   * Returns an empty copy of the existing DocumentSet, using the same\n   * comparator.\n   */\n  static emptySet(oldSet: DocumentSet): DocumentSet {\n    return new DocumentSet(oldSet.comparator);\n  }\n\n  private comparator: DocumentComparator;\n  private keyedMap: SortedMap<DocumentKey, Document>;\n  private sortedSet: SortedMap<Document, null>;\n\n  /** The default ordering is by key if the comparator is omitted */\n  constructor(comp?: DocumentComparator) {\n    // We are adding document key comparator to the end as it's the only\n    // guaranteed unique property of a document.\n    if (comp) {\n      this.comparator = (d1: Document, d2: Document) =>\n        comp(d1, d2) || DocumentKey.comparator(d1.key, d2.key);\n    } else {\n      this.comparator = (d1: Document, d2: Document) =>\n        DocumentKey.comparator(d1.key, d2.key);\n    }\n\n    this.keyedMap = documentMap();\n    this.sortedSet = new SortedMap<Document, null>(this.comparator);\n  }\n\n  has(key: DocumentKey): boolean {\n    return this.keyedMap.get(key) != null;\n  }\n\n  get(key: DocumentKey): Document | null {\n    return this.keyedMap.get(key);\n  }\n\n  first(): Document | null {\n    return this.sortedSet.minKey();\n  }\n\n  last(): Document | null {\n    return this.sortedSet.maxKey();\n  }\n\n  isEmpty(): boolean {\n    return this.sortedSet.isEmpty();\n  }\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  indexOf(key: DocumentKey): number {\n    const doc = this.keyedMap.get(key);\n    return doc ? this.sortedSet.indexOf(doc) : -1;\n  }\n\n  get size(): number {\n    return this.sortedSet.size;\n  }\n\n  /** Iterates documents in order defined by \"comparator\" */\n  forEach(cb: (doc: Document) => void): void {\n    this.sortedSet.inorderTraversal((k, v) => {\n      cb(k);\n      return false;\n    });\n  }\n\n  /** Inserts or updates a document with the same key */\n  add(doc: Document): DocumentSet {\n    // First remove the element if we have it.\n    const set = this.delete(doc.key);\n    return set.copy(\n      set.keyedMap.insert(doc.key, doc),\n      set.sortedSet.insert(doc, null)\n    );\n  }\n\n  /** Deletes a document with a given key */\n  delete(key: DocumentKey): DocumentSet {\n    const doc = this.get(key);\n    if (!doc) {\n      return this;\n    }\n\n    return this.copy(this.keyedMap.remove(key), this.sortedSet.remove(doc));\n  }\n\n  isEqual(other: DocumentSet | null | undefined): boolean {\n    if (!(other instanceof DocumentSet)) {\n      return false;\n    }\n    if (this.size !== other.size) {\n      return false;\n    }\n\n    const thisIt = this.sortedSet.getIterator();\n    const otherIt = other.sortedSet.getIterator();\n    while (thisIt.hasNext()) {\n      const thisDoc = thisIt.getNext().key;\n      const otherDoc = otherIt.getNext().key;\n      if (!thisDoc.isEqual(otherDoc)) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  toString(): string {\n    const docStrings: string[] = [];\n    this.forEach(doc => {\n      docStrings.push(doc.toString());\n    });\n    if (docStrings.length === 0) {\n      return 'DocumentSet ()';\n    } else {\n      return 'DocumentSet (\\n  ' + docStrings.join('  \\n') + '\\n)';\n    }\n  }\n\n  private copy(\n    keyedMap: SortedMap<DocumentKey, Document>,\n    sortedSet: SortedMap<Document, null>\n  ): DocumentSet {\n    const newSet = new DocumentSet();\n    newSet.comparator = this.comparator;\n    newSet.keyedMap = keyedMap;\n    newSet.sortedSet = sortedSet;\n    return newSet;\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 { DocumentKeySet } from '../model/collections';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { DocumentSet } from '../model/document_set';\nimport { fail } from '../util/assert';\nimport { SortedMap } from '../util/sorted_map';\n\nimport { Query, queryEquals } from './query';\n\nexport const enum ChangeType {\n  Added,\n  Removed,\n  Modified,\n  Metadata\n}\n\nexport interface DocumentViewChange {\n  type: ChangeType;\n  doc: Document;\n}\n\nexport const enum SyncState {\n  Local,\n  Synced\n}\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 */\nexport class DocumentChangeSet {\n  private changeMap = new SortedMap<DocumentKey, DocumentViewChange>(\n    DocumentKey.comparator\n  );\n\n  track(change: DocumentViewChange): void {\n    const key = change.doc.key;\n    const oldChange = this.changeMap.get(key);\n    if (!oldChange) {\n      this.changeMap = this.changeMap.insert(key, change);\n      return;\n    }\n\n    // Merge the new change with the existing change.\n    if (\n      change.type !== ChangeType.Added &&\n      oldChange.type === ChangeType.Metadata\n    ) {\n      this.changeMap = this.changeMap.insert(key, change);\n    } else if (\n      change.type === ChangeType.Metadata &&\n      oldChange.type !== ChangeType.Removed\n    ) {\n      this.changeMap = this.changeMap.insert(key, {\n        type: oldChange.type,\n        doc: change.doc\n      });\n    } else if (\n      change.type === ChangeType.Modified &&\n      oldChange.type === ChangeType.Modified\n    ) {\n      this.changeMap = this.changeMap.insert(key, {\n        type: ChangeType.Modified,\n        doc: change.doc\n      });\n    } else if (\n      change.type === ChangeType.Modified &&\n      oldChange.type === ChangeType.Added\n    ) {\n      this.changeMap = this.changeMap.insert(key, {\n        type: ChangeType.Added,\n        doc: change.doc\n      });\n    } else if (\n      change.type === ChangeType.Removed &&\n      oldChange.type === ChangeType.Added\n    ) {\n      this.changeMap = this.changeMap.remove(key);\n    } else if (\n      change.type === ChangeType.Removed &&\n      oldChange.type === ChangeType.Modified\n    ) {\n      this.changeMap = this.changeMap.insert(key, {\n        type: ChangeType.Removed,\n        doc: oldChange.doc\n      });\n    } else if (\n      change.type === ChangeType.Added &&\n      oldChange.type === ChangeType.Removed\n    ) {\n      this.changeMap = this.changeMap.insert(key, {\n        type: ChangeType.Modified,\n        doc: change.doc\n      });\n    } else {\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      fail(\n        'unsupported combination of changes: ' +\n          JSON.stringify(change) +\n          ' after ' +\n          JSON.stringify(oldChange)\n      );\n    }\n  }\n\n  getChanges(): DocumentViewChange[] {\n    const changes: DocumentViewChange[] = [];\n    this.changeMap.inorderTraversal(\n      (key: DocumentKey, change: DocumentViewChange) => {\n        changes.push(change);\n      }\n    );\n    return changes;\n  }\n}\n\nexport class ViewSnapshot {\n  constructor(\n    readonly query: Query,\n    readonly docs: DocumentSet,\n    readonly oldDocs: DocumentSet,\n    readonly docChanges: DocumentViewChange[],\n    readonly mutatedKeys: DocumentKeySet,\n    readonly fromCache: boolean,\n    readonly syncStateChanged: boolean,\n    readonly excludesMetadataChanges: boolean,\n    readonly hasCachedResults: boolean\n  ) {}\n\n  /** Returns a view snapshot as if all documents in the snapshot were added. */\n  static fromInitialDocuments(\n    query: Query,\n    documents: DocumentSet,\n    mutatedKeys: DocumentKeySet,\n    fromCache: boolean,\n    hasCachedResults: boolean\n  ): ViewSnapshot {\n    const changes: DocumentViewChange[] = [];\n    documents.forEach(doc => {\n      changes.push({ type: ChangeType.Added, doc });\n    });\n\n    return new ViewSnapshot(\n      query,\n      documents,\n      DocumentSet.emptySet(documents),\n      changes,\n      mutatedKeys,\n      fromCache,\n      /* syncStateChanged= */ true,\n      /* excludesMetadataChanges= */ false,\n      hasCachedResults\n    );\n  }\n\n  get hasPendingWrites(): boolean {\n    return !this.mutatedKeys.isEmpty();\n  }\n\n  isEqual(other: ViewSnapshot): boolean {\n    if (\n      this.fromCache !== other.fromCache ||\n      this.hasCachedResults !== other.hasCachedResults ||\n      this.syncStateChanged !== other.syncStateChanged ||\n      !this.mutatedKeys.isEqual(other.mutatedKeys) ||\n      !queryEquals(this.query, other.query) ||\n      !this.docs.isEqual(other.docs) ||\n      !this.oldDocs.isEqual(other.oldDocs)\n    ) {\n      return false;\n    }\n    const changes: DocumentViewChange[] = this.docChanges;\n    const otherChanges: DocumentViewChange[] = other.docChanges;\n    if (changes.length !== otherChanges.length) {\n      return false;\n    }\n    for (let i = 0; i < changes.length; i++) {\n      if (\n        changes[i].type !== otherChanges[i].type ||\n        !changes[i].doc.isEqual(otherChanges[i].doc)\n      ) {\n        return false;\n      }\n    }\n    return 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 { debugAssert, debugCast } from '../util/assert';\nimport { wrapInUserErrorIfRecoverable } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\nimport { EventHandler } from '../util/misc';\nimport { ObjectMap } from '../util/obj_map';\n\nimport { canonifyQuery, Query, queryEquals, stringifyQuery } from './query';\nimport { OnlineState } from './types';\nimport { ChangeType, DocumentViewChange, ViewSnapshot } from './view_snapshot';\n\n/**\n * Holds the listeners and the last received ViewSnapshot for a query being\n * tracked by EventManager.\n */\nclass QueryListenersInfo {\n  viewSnap: ViewSnapshot | undefined = undefined;\n  listeners: QueryListener[] = [];\n\n  // Helper methods that checks if the query has listeners that listening to remote store\n  hasRemoteListeners(): boolean {\n    return this.listeners.some(listener => listener.listensToRemoteStore());\n  }\n}\n\n/**\n * Interface for handling events from the EventManager.\n */\nexport interface Observer<T> {\n  next: EventHandler<T>;\n  error: EventHandler<FirestoreError>;\n}\n\n/**\n * EventManager is responsible for mapping queries to query event emitters.\n * It handles \"fan-out\". -- Identical queries will re-use the same watch on the\n * backend.\n *\n * PORTING NOTE: On Web, EventManager `onListen` and `onUnlisten` need to be\n * assigned to SyncEngine's `listen()` and `unlisten()` API before usage. This\n * allows users to tree-shake the Watch logic.\n */\nexport interface EventManager {\n  onListen?: (\n    query: Query,\n    enableRemoteListen: boolean\n  ) => Promise<ViewSnapshot>;\n  onUnlisten?: (query: Query, disableRemoteListen: boolean) => Promise<void>;\n  onFirstRemoteStoreListen?: (query: Query) => Promise<void>;\n  onLastRemoteStoreUnlisten?: (query: Query) => Promise<void>;\n  terminate(): void;\n}\n\nexport function newEventManager(): EventManager {\n  return new EventManagerImpl();\n}\n\nexport class EventManagerImpl implements EventManager {\n  queries: ObjectMap<Query, QueryListenersInfo> = newQueriesObjectMap();\n\n  onlineState: OnlineState = OnlineState.Unknown;\n\n  snapshotsInSyncListeners: Set<Observer<void>> = new Set();\n\n  /** Callback invoked when a Query is first listen to. */\n  onListen?: (\n    query: Query,\n    enableRemoteListen: boolean\n  ) => Promise<ViewSnapshot>;\n  /** Callback invoked once all listeners to a Query are removed. */\n  onUnlisten?: (query: Query, disableRemoteListen: boolean) => Promise<void>;\n\n  /**\n   * Callback invoked when a Query starts listening to the remote store, while\n   * already listening to the cache.\n   */\n  onFirstRemoteStoreListen?: (query: Query) => Promise<void>;\n  /**\n   * Callback invoked when a Query stops listening to the remote store, while\n   * still listening to the cache.\n   */\n  onLastRemoteStoreUnlisten?: (query: Query) => Promise<void>;\n\n  terminate(): void {\n    errorAllTargets(\n      this,\n      new FirestoreError(Code.ABORTED, 'Firestore shutting down')\n    );\n  }\n}\n\nfunction newQueriesObjectMap(): ObjectMap<Query, QueryListenersInfo> {\n  return new ObjectMap<Query, QueryListenersInfo>(\n    q => canonifyQuery(q),\n    queryEquals\n  );\n}\n\nfunction validateEventManager(eventManagerImpl: EventManagerImpl): void {\n  debugAssert(!!eventManagerImpl.onListen, 'onListen not set');\n  debugAssert(\n    !!eventManagerImpl.onFirstRemoteStoreListen,\n    'onFirstRemoteStoreListen not set'\n  );\n  debugAssert(!!eventManagerImpl.onUnlisten, 'onUnlisten not set');\n  debugAssert(\n    !!eventManagerImpl.onLastRemoteStoreUnlisten,\n    'onLastRemoteStoreUnlisten not set'\n  );\n}\n\nconst enum ListenerSetupAction {\n  InitializeLocalListenAndRequireWatchConnection,\n  InitializeLocalListenOnly,\n  RequireWatchConnectionOnly,\n  NoActionRequired\n}\n\nconst enum ListenerRemovalAction {\n  TerminateLocalListenAndRequireWatchDisconnection,\n  TerminateLocalListenOnly,\n  RequireWatchDisconnectionOnly,\n  NoActionRequired\n}\n\nexport async function eventManagerListen(\n  eventManager: EventManager,\n  listener: QueryListener\n): Promise<void> {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n  validateEventManager(eventManagerImpl);\n\n  let listenerAction = ListenerSetupAction.NoActionRequired;\n\n  const query = listener.query;\n\n  let queryInfo = eventManagerImpl.queries.get(query);\n  if (!queryInfo) {\n    queryInfo = new QueryListenersInfo();\n    listenerAction = listener.listensToRemoteStore()\n      ? ListenerSetupAction.InitializeLocalListenAndRequireWatchConnection\n      : ListenerSetupAction.InitializeLocalListenOnly;\n  } else if (\n    !queryInfo.hasRemoteListeners() &&\n    listener.listensToRemoteStore()\n  ) {\n    // Query has been listening to local cache, and tries to add a new listener sourced from watch.\n    listenerAction = ListenerSetupAction.RequireWatchConnectionOnly;\n  }\n\n  try {\n    switch (listenerAction) {\n      case ListenerSetupAction.InitializeLocalListenAndRequireWatchConnection:\n        queryInfo.viewSnap = await eventManagerImpl.onListen!(\n          query,\n          /** enableRemoteListen= */ true\n        );\n        break;\n      case ListenerSetupAction.InitializeLocalListenOnly:\n        queryInfo.viewSnap = await eventManagerImpl.onListen!(\n          query,\n          /** enableRemoteListen= */ false\n        );\n        break;\n      case ListenerSetupAction.RequireWatchConnectionOnly:\n        await eventManagerImpl.onFirstRemoteStoreListen!(query);\n        break;\n      default:\n        break;\n    }\n  } catch (e) {\n    const firestoreError = wrapInUserErrorIfRecoverable(\n      e as Error,\n      `Initialization of query '${stringifyQuery(listener.query)}' failed`\n    );\n    listener.onError(firestoreError);\n    return;\n  }\n\n  eventManagerImpl.queries.set(query, queryInfo);\n  queryInfo.listeners.push(listener);\n\n  // Run global snapshot listeners if a consistent snapshot has been emitted.\n  const raisedEvent = listener.applyOnlineStateChange(\n    eventManagerImpl.onlineState\n  );\n  debugAssert(\n    !raisedEvent,\n    \"applyOnlineStateChange() shouldn't raise an event for brand-new listeners.\"\n  );\n\n  if (queryInfo.viewSnap) {\n    const raisedEvent = listener.onViewSnapshot(queryInfo.viewSnap);\n    if (raisedEvent) {\n      raiseSnapshotsInSyncEvent(eventManagerImpl);\n    }\n  }\n}\n\nexport async function eventManagerUnlisten(\n  eventManager: EventManager,\n  listener: QueryListener\n): Promise<void> {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n  validateEventManager(eventManagerImpl);\n\n  const query = listener.query;\n  let listenerAction = ListenerRemovalAction.NoActionRequired;\n\n  const queryInfo = eventManagerImpl.queries.get(query);\n  if (queryInfo) {\n    const i = queryInfo.listeners.indexOf(listener);\n    if (i >= 0) {\n      queryInfo.listeners.splice(i, 1);\n\n      if (queryInfo.listeners.length === 0) {\n        listenerAction = listener.listensToRemoteStore()\n          ? ListenerRemovalAction.TerminateLocalListenAndRequireWatchDisconnection\n          : ListenerRemovalAction.TerminateLocalListenOnly;\n      } else if (\n        !queryInfo.hasRemoteListeners() &&\n        listener.listensToRemoteStore()\n      ) {\n        // The removed listener is the last one that sourced from watch.\n        listenerAction = ListenerRemovalAction.RequireWatchDisconnectionOnly;\n      }\n    }\n  }\n  switch (listenerAction) {\n    case ListenerRemovalAction.TerminateLocalListenAndRequireWatchDisconnection:\n      eventManagerImpl.queries.delete(query);\n      return eventManagerImpl.onUnlisten!(\n        query,\n        /** disableRemoteListen= */ true\n      );\n    case ListenerRemovalAction.TerminateLocalListenOnly:\n      eventManagerImpl.queries.delete(query);\n      return eventManagerImpl.onUnlisten!(\n        query,\n        /** disableRemoteListen= */ false\n      );\n    case ListenerRemovalAction.RequireWatchDisconnectionOnly:\n      return eventManagerImpl.onLastRemoteStoreUnlisten!(query);\n    default:\n      return;\n  }\n}\n\nexport function eventManagerOnWatchChange(\n  eventManager: EventManager,\n  viewSnaps: ViewSnapshot[]\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n\n  let raisedEvent = false;\n  for (const viewSnap of viewSnaps) {\n    const query = viewSnap.query;\n    const queryInfo = eventManagerImpl.queries.get(query);\n    if (queryInfo) {\n      for (const listener of queryInfo.listeners) {\n        if (listener.onViewSnapshot(viewSnap)) {\n          raisedEvent = true;\n        }\n      }\n      queryInfo.viewSnap = viewSnap;\n    }\n  }\n  if (raisedEvent) {\n    raiseSnapshotsInSyncEvent(eventManagerImpl);\n  }\n}\n\nexport function eventManagerOnWatchError(\n  eventManager: EventManager,\n  query: Query,\n  error: FirestoreError\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n\n  const queryInfo = eventManagerImpl.queries.get(query);\n  if (queryInfo) {\n    for (const listener of queryInfo.listeners) {\n      listener.onError(error);\n    }\n  }\n\n  // Remove all listeners. NOTE: We don't need to call syncEngine.unlisten()\n  // after an error.\n  eventManagerImpl.queries.delete(query);\n}\n\nexport function eventManagerOnOnlineStateChange(\n  eventManager: EventManager,\n  onlineState: OnlineState\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n\n  eventManagerImpl.onlineState = onlineState;\n  let raisedEvent = false;\n  eventManagerImpl.queries.forEach((_, queryInfo) => {\n    for (const listener of queryInfo.listeners) {\n      // Run global snapshot listeners if a consistent snapshot has been emitted.\n      if (listener.applyOnlineStateChange(onlineState)) {\n        raisedEvent = true;\n      }\n    }\n  });\n  if (raisedEvent) {\n    raiseSnapshotsInSyncEvent(eventManagerImpl);\n  }\n}\n\nexport function addSnapshotsInSyncListener(\n  eventManager: EventManager,\n  observer: Observer<void>\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n\n  eventManagerImpl.snapshotsInSyncListeners.add(observer);\n  // Immediately fire an initial event, indicating all existing listeners\n  // are in-sync.\n  observer.next();\n}\n\nexport function removeSnapshotsInSyncListener(\n  eventManager: EventManager,\n  observer: Observer<void>\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n  eventManagerImpl.snapshotsInSyncListeners.delete(observer);\n}\n\nfunction errorAllTargets(\n  eventManager: EventManager,\n  error: FirestoreError\n): void {\n  const eventManagerImpl = debugCast(eventManager, EventManagerImpl);\n  const queries = eventManagerImpl.queries;\n\n  // Prevent further access by clearing ObjectMap.\n  eventManagerImpl.queries = newQueriesObjectMap();\n\n  queries.forEach((_, queryInfo) => {\n    for (const listener of queryInfo.listeners) {\n      listener.onError(error);\n    }\n  });\n}\n\n// Call all global snapshot listeners that have been set.\nfunction raiseSnapshotsInSyncEvent(eventManagerImpl: EventManagerImpl): void {\n  eventManagerImpl.snapshotsInSyncListeners.forEach(observer => {\n    observer.next();\n  });\n}\n\nexport enum ListenerDataSource {\n  /** Listen to both cache and server changes */\n  Default = 'default',\n\n  /** Listen to changes in cache only */\n  Cache = 'cache'\n}\n\nexport interface ListenOptions {\n  /** Raise events even when only the metadata changes */\n  readonly includeMetadataChanges?: boolean;\n\n  /**\n   * Wait for a sync with the server when online, but still raise events while\n   * offline.\n   */\n  readonly waitForSyncWhenOnline?: boolean;\n\n  /** Set the source events raised from. */\n  readonly source?: ListenerDataSource;\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 */\nexport class QueryListener {\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  private raisedInitialEvent = false;\n\n  private options: ListenOptions;\n\n  private snap: ViewSnapshot | null = null;\n\n  private onlineState = OnlineState.Unknown;\n\n  constructor(\n    readonly query: Query,\n    private queryObserver: Observer<ViewSnapshot>,\n    options?: ListenOptions\n  ) {\n    this.options = options || {};\n  }\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  onViewSnapshot(snap: ViewSnapshot): boolean {\n    debugAssert(\n      snap.docChanges.length > 0 || snap.syncStateChanged,\n      'We got a new snapshot with no changes?'\n    );\n\n    if (!this.options.includeMetadataChanges) {\n      // Remove the metadata only changes.\n      const docChanges: DocumentViewChange[] = [];\n      for (const docChange of snap.docChanges) {\n        if (docChange.type !== ChangeType.Metadata) {\n          docChanges.push(docChange);\n        }\n      }\n      snap = new ViewSnapshot(\n        snap.query,\n        snap.docs,\n        snap.oldDocs,\n        docChanges,\n        snap.mutatedKeys,\n        snap.fromCache,\n        snap.syncStateChanged,\n        /* excludesMetadataChanges= */ true,\n        snap.hasCachedResults\n      );\n    }\n    let raisedEvent = false;\n    if (!this.raisedInitialEvent) {\n      if (this.shouldRaiseInitialEvent(snap, this.onlineState)) {\n        this.raiseInitialEvent(snap);\n        raisedEvent = true;\n      }\n    } else if (this.shouldRaiseEvent(snap)) {\n      this.queryObserver.next(snap);\n      raisedEvent = true;\n    }\n\n    this.snap = snap;\n    return raisedEvent;\n  }\n\n  onError(error: FirestoreError): void {\n    this.queryObserver.error(error);\n  }\n\n  /** Returns whether a snapshot was raised. */\n  applyOnlineStateChange(onlineState: OnlineState): boolean {\n    this.onlineState = onlineState;\n    let raisedEvent = false;\n    if (\n      this.snap &&\n      !this.raisedInitialEvent &&\n      this.shouldRaiseInitialEvent(this.snap, onlineState)\n    ) {\n      this.raiseInitialEvent(this.snap);\n      raisedEvent = true;\n    }\n    return raisedEvent;\n  }\n\n  private shouldRaiseInitialEvent(\n    snap: ViewSnapshot,\n    onlineState: OnlineState\n  ): boolean {\n    debugAssert(\n      !this.raisedInitialEvent,\n      'Determining whether to raise first event but already had first event'\n    );\n\n    // Always raise the first event when we're synced\n    if (!snap.fromCache) {\n      return true;\n    }\n\n    // Always raise event if listening to cache\n    if (!this.listensToRemoteStore()) {\n      return true;\n    }\n\n    // NOTE: We consider OnlineState.Unknown as online (it should become Offline\n    // or Online if we wait long enough).\n    const maybeOnline = onlineState !== OnlineState.Offline;\n    // Don't raise the event if we're online, aren't synced yet (checked\n    // above) and are waiting for a sync.\n    if (this.options.waitForSyncWhenOnline && maybeOnline) {\n      debugAssert(\n        snap.fromCache,\n        'Waiting for sync, but snapshot is not from cache'\n      );\n      return false;\n    }\n\n    // Raise data from cache if we have any documents, have cached results before,\n    // or we are offline.\n    return (\n      !snap.docs.isEmpty() ||\n      snap.hasCachedResults ||\n      onlineState === OnlineState.Offline\n    );\n  }\n\n  private shouldRaiseEvent(snap: ViewSnapshot): boolean {\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 (snap.docChanges.length > 0) {\n      return true;\n    }\n\n    const hasPendingWritesChanged =\n      this.snap && this.snap.hasPendingWrites !== snap.hasPendingWrites;\n    if (snap.syncStateChanged || hasPendingWritesChanged) {\n      return this.options.includeMetadataChanges === true;\n    }\n\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    return false;\n  }\n\n  private raiseInitialEvent(snap: ViewSnapshot): void {\n    debugAssert(\n      !this.raisedInitialEvent,\n      'Trying to raise initial events for second time'\n    );\n    snap = ViewSnapshot.fromInitialDocuments(\n      snap.query,\n      snap.docs,\n      snap.mutatedKeys,\n      snap.fromCache,\n      snap.hasCachedResults\n    );\n    this.raisedInitialEvent = true;\n    this.queryObserver.next(snap);\n  }\n\n  listensToRemoteStore(): boolean {\n    return this.options.source !== ListenerDataSource.Cache;\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 { QueryResult } from '../local/local_store_impl';\nimport {\n  documentKeySet,\n  DocumentKeySet,\n  DocumentMap\n} from '../model/collections';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { DocumentSet } from '../model/document_set';\nimport { TargetChange } from '../remote/remote_event';\nimport { debugAssert, fail } from '../util/assert';\n\nimport { LimitType, newQueryComparator, Query, queryMatches } from './query';\nimport { OnlineState } from './types';\nimport {\n  ChangeType,\n  DocumentChangeSet,\n  SyncState,\n  ViewSnapshot\n} from './view_snapshot';\n\nexport type LimboDocumentChange = AddedLimboDocument | RemovedLimboDocument;\nexport class AddedLimboDocument {\n  constructor(public key: DocumentKey) {}\n}\nexport class RemovedLimboDocument {\n  constructor(public key: DocumentKey) {}\n}\n\n/** The result of applying a set of doc changes to a view. */\nexport interface ViewDocumentChanges {\n  /** The new set of docs that should be in the view. */\n  documentSet: DocumentSet;\n  /** The diff of these docs with the previous set of docs. */\n  changeSet: DocumentChangeSet;\n  /**\n   * Whether the set of documents passed in was not sufficient to calculate the\n   * new state of the view and there needs to be another pass based on the\n   * local cache.\n   */\n  needsRefill: boolean;\n\n  mutatedKeys: DocumentKeySet;\n}\n\nexport interface ViewChange {\n  snapshot?: ViewSnapshot;\n  limboChanges: LimboDocumentChange[];\n}\n\n/**\n * View is responsible for computing the final merged truth of what docs are in\n * a query. It gets notified of local and remote changes to docs, and applies\n * the query filters and limits to determine the most correct possible results.\n */\nexport class View {\n  private syncState: SyncState | null = null;\n  private hasCachedResults: boolean = false;\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  private current = false;\n  private documentSet: DocumentSet;\n  /** Documents in the view but not in the remote target */\n  private limboDocuments = documentKeySet();\n  /** Document Keys that have local changes */\n  private mutatedKeys = documentKeySet();\n  /** Query comparator that defines the document order in this view. */\n  private docComparator: (d1: Document, d2: Document) => number;\n\n  constructor(\n    private query: Query,\n    /** Documents included in the remote target */\n    private _syncedDocuments: DocumentKeySet\n  ) {\n    this.docComparator = newQueryComparator(query);\n    this.documentSet = new DocumentSet(this.docComparator);\n  }\n\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 syncedDocuments(): DocumentKeySet {\n    return this._syncedDocuments;\n  }\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  computeDocChanges(\n    docChanges: DocumentMap,\n    previousChanges?: ViewDocumentChanges\n  ): ViewDocumentChanges {\n    const changeSet = previousChanges\n      ? previousChanges.changeSet\n      : new DocumentChangeSet();\n    const oldDocumentSet = previousChanges\n      ? previousChanges.documentSet\n      : this.documentSet;\n    let newMutatedKeys = previousChanges\n      ? previousChanges.mutatedKeys\n      : this.mutatedKeys;\n    let newDocumentSet = oldDocumentSet;\n    let needsRefill = false;\n\n    // Track the last doc in a (full) limit. This is necessary, because some\n    // update (a delete, or an update moving a doc past the old limit) might\n    // mean there is some other document in the local cache that either should\n    // come (1) between the old last limit doc and the new last document, in the\n    // case of updates, or (2) after the new last document, in the case of\n    // deletes. So we keep this doc at the old limit to compare the updates to.\n    //\n    // Note that this should never get used in a refill (when previousChanges is\n    // set), because there will only be adds -- no deletes or updates.\n    const lastDocInLimit =\n      this.query.limitType === LimitType.First &&\n      oldDocumentSet.size === this.query.limit\n        ? oldDocumentSet.last()\n        : null;\n    const firstDocInLimit =\n      this.query.limitType === LimitType.Last &&\n      oldDocumentSet.size === this.query.limit\n        ? oldDocumentSet.first()\n        : null;\n\n    docChanges.inorderTraversal((key, entry) => {\n      const oldDoc = oldDocumentSet.get(key);\n      const newDoc = queryMatches(this.query, entry) ? entry : null;\n\n      const oldDocHadPendingMutations = oldDoc\n        ? this.mutatedKeys.has(oldDoc.key)\n        : false;\n      const newDocHasPendingMutations = newDoc\n        ? newDoc.hasLocalMutations ||\n          // We only consider committed mutations for documents that were\n          // mutated during the lifetime of the view.\n          (this.mutatedKeys.has(newDoc.key) && newDoc.hasCommittedMutations)\n        : false;\n\n      let changeApplied = false;\n\n      // Calculate change\n      if (oldDoc && newDoc) {\n        const docsEqual = oldDoc.data.isEqual(newDoc.data);\n        if (!docsEqual) {\n          if (!this.shouldWaitForSyncedDocument(oldDoc, newDoc)) {\n            changeSet.track({\n              type: ChangeType.Modified,\n              doc: newDoc\n            });\n            changeApplied = true;\n\n            if (\n              (lastDocInLimit &&\n                this.docComparator(newDoc, lastDocInLimit) > 0) ||\n              (firstDocInLimit &&\n                this.docComparator(newDoc, firstDocInLimit) < 0)\n            ) {\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              needsRefill = true;\n            }\n          }\n        } else if (oldDocHadPendingMutations !== newDocHasPendingMutations) {\n          changeSet.track({ type: ChangeType.Metadata, doc: newDoc });\n          changeApplied = true;\n        }\n      } else if (!oldDoc && newDoc) {\n        changeSet.track({ type: ChangeType.Added, doc: newDoc });\n        changeApplied = true;\n      } else if (oldDoc && !newDoc) {\n        changeSet.track({ type: ChangeType.Removed, doc: oldDoc });\n        changeApplied = true;\n\n        if (lastDocInLimit || firstDocInLimit) {\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          needsRefill = true;\n        }\n      }\n\n      if (changeApplied) {\n        if (newDoc) {\n          newDocumentSet = newDocumentSet.add(newDoc);\n          if (newDocHasPendingMutations) {\n            newMutatedKeys = newMutatedKeys.add(key);\n          } else {\n            newMutatedKeys = newMutatedKeys.delete(key);\n          }\n        } else {\n          newDocumentSet = newDocumentSet.delete(key);\n          newMutatedKeys = newMutatedKeys.delete(key);\n        }\n      }\n    });\n\n    // Drop documents out to meet limit/limitToLast requirement.\n    if (this.query.limit !== null) {\n      while (newDocumentSet.size > this.query.limit!) {\n        const oldDoc =\n          this.query.limitType === LimitType.First\n            ? newDocumentSet.last()\n            : newDocumentSet.first();\n        newDocumentSet = newDocumentSet.delete(oldDoc!.key);\n        newMutatedKeys = newMutatedKeys.delete(oldDoc!.key);\n        changeSet.track({ type: ChangeType.Removed, doc: oldDoc! });\n      }\n    }\n\n    debugAssert(\n      !needsRefill || !previousChanges,\n      'View was refilled using docs that themselves needed refilling.'\n    );\n    return {\n      documentSet: newDocumentSet,\n      changeSet,\n      needsRefill,\n      mutatedKeys: newMutatedKeys\n    };\n  }\n\n  private shouldWaitForSyncedDocument(\n    oldDoc: Document,\n    newDoc: Document\n  ): boolean {\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 (\n      oldDoc.hasLocalMutations &&\n      newDoc.hasCommittedMutations &&\n      !newDoc.hasLocalMutations\n    );\n  }\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 limboResolutionEnabled - 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   * @param targetIsPendingReset - Whether the target is pending to reset due to\n   *        existence filter mismatch. If not explicitly specified, it is treated\n   *        equivalently to `false`.\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  applyChanges(\n    docChanges: ViewDocumentChanges,\n    limboResolutionEnabled: boolean,\n    targetChange?: TargetChange,\n    targetIsPendingReset?: boolean\n  ): ViewChange {\n    debugAssert(\n      !docChanges.needsRefill,\n      'Cannot apply changes that need a refill'\n    );\n    const oldDocs = this.documentSet;\n    this.documentSet = docChanges.documentSet;\n    this.mutatedKeys = docChanges.mutatedKeys;\n    // Sort changes based on type and query comparator\n    const changes = docChanges.changeSet.getChanges();\n    changes.sort((c1, c2) => {\n      return (\n        compareChangeType(c1.type, c2.type) ||\n        this.docComparator(c1.doc, c2.doc)\n      );\n    });\n\n    this.applyTargetChange(targetChange);\n\n    targetIsPendingReset = targetIsPendingReset ?? false;\n    const limboChanges =\n      limboResolutionEnabled && !targetIsPendingReset\n        ? this.updateLimboDocuments()\n        : [];\n\n    // We are at synced state if there is no limbo docs are waiting to be resolved, view is current\n    // with the backend, and the query is not pending to reset due to existence filter mismatch.\n    const synced =\n      this.limboDocuments.size === 0 && this.current && !targetIsPendingReset;\n\n    const newSyncState = synced ? SyncState.Synced : SyncState.Local;\n    const syncStateChanged = newSyncState !== this.syncState;\n    this.syncState = newSyncState;\n\n    if (changes.length === 0 && !syncStateChanged) {\n      // no changes\n      return { limboChanges };\n    } else {\n      const snap: ViewSnapshot = new ViewSnapshot(\n        this.query,\n        docChanges.documentSet,\n        oldDocs,\n        changes,\n        docChanges.mutatedKeys,\n        newSyncState === SyncState.Local,\n        syncStateChanged,\n        /* excludesMetadataChanges= */ false,\n        targetChange\n          ? targetChange.resumeToken.approximateByteSize() > 0\n          : false\n      );\n      return {\n        snapshot: snap,\n        limboChanges\n      };\n    }\n  }\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  applyOnlineStateChange(onlineState: OnlineState): ViewChange {\n    if (this.current && onlineState === OnlineState.Offline) {\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.current = false;\n      return this.applyChanges(\n        {\n          documentSet: this.documentSet,\n          changeSet: new DocumentChangeSet(),\n          mutatedKeys: this.mutatedKeys,\n          needsRefill: false\n        },\n        /* limboResolutionEnabled= */ false\n      );\n    } else {\n      // No effect, just return a no-op ViewChange.\n      return { limboChanges: [] };\n    }\n  }\n\n  /**\n   * Returns whether the doc for the given key should be in limbo.\n   */\n  private shouldBeInLimbo(key: DocumentKey): boolean {\n    // If the remote end says it's part of this query, it's not in limbo.\n    if (this._syncedDocuments.has(key)) {\n      return false;\n    }\n    // The local store doesn't think it's a result, so it shouldn't be in limbo.\n    if (!this.documentSet.has(key)) {\n      return false;\n    }\n    // If there are local changes to the doc, they might explain why the server\n    // doesn't know that it's part of the query. So don't put it in limbo.\n    // TODO(klimt): Ideally, we would only consider changes that might actually\n    // affect this specific query.\n    if (this.documentSet.get(key)!.hasLocalMutations) {\n      return false;\n    }\n    // Everything else is in limbo.\n    return true;\n  }\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  private applyTargetChange(targetChange?: TargetChange): void {\n    if (targetChange) {\n      targetChange.addedDocuments.forEach(\n        key => (this._syncedDocuments = this._syncedDocuments.add(key))\n      );\n      targetChange.modifiedDocuments.forEach(key => {\n        debugAssert(\n          this._syncedDocuments.has(key),\n          `Modified document ${key} not found in view.`\n        );\n      });\n      targetChange.removedDocuments.forEach(\n        key => (this._syncedDocuments = this._syncedDocuments.delete(key))\n      );\n      this.current = targetChange.current;\n    }\n  }\n\n  private updateLimboDocuments(): LimboDocumentChange[] {\n    // We can only determine limbo documents when we're in-sync with the server.\n    if (!this.current) {\n      return [];\n    }\n\n    // TODO(klimt): Do this incrementally so that it's not quadratic when\n    // updating many documents.\n    const oldLimboDocuments = this.limboDocuments;\n    this.limboDocuments = documentKeySet();\n    this.documentSet.forEach(doc => {\n      if (this.shouldBeInLimbo(doc.key)) {\n        this.limboDocuments = this.limboDocuments.add(doc.key);\n      }\n    });\n\n    // Diff the new limbo docs with the old limbo docs.\n    const changes: LimboDocumentChange[] = [];\n    oldLimboDocuments.forEach(key => {\n      if (!this.limboDocuments.has(key)) {\n        changes.push(new RemovedLimboDocument(key));\n      }\n    });\n    this.limboDocuments.forEach(key => {\n      if (!oldLimboDocuments.has(key)) {\n        changes.push(new AddedLimboDocument(key));\n      }\n    });\n    return changes;\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  synchronizeWithPersistedState(queryResult: QueryResult): ViewChange {\n    this._syncedDocuments = queryResult.remoteKeys;\n    this.limboDocuments = documentKeySet();\n    const docChanges = this.computeDocChanges(queryResult.documents);\n    return this.applyChanges(docChanges, /* limboResolutionEnabled= */ true);\n  }\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  computeInitialSnapshot(): ViewSnapshot {\n    return ViewSnapshot.fromInitialDocuments(\n      this.query,\n      this.documentSet,\n      this.mutatedKeys,\n      this.syncState === SyncState.Local,\n      this.hasCachedResults\n    );\n  }\n}\n\nfunction compareChangeType(c1: ChangeType, c2: ChangeType): number {\n  const order = (change: ChangeType): 0 | 1 | 2 => {\n    switch (change) {\n      case ChangeType.Added:\n        return 1;\n      case ChangeType.Modified:\n        return 2;\n      case ChangeType.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      case ChangeType.Removed:\n        return 0;\n      default:\n        return fail('Unknown ChangeType: ' + change);\n    }\n  };\n\n  return order(c1) - order(c2);\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 { LoadBundleTask } from '../api/bundle';\nimport { User } from '../auth/user';\nimport { ignoreIfPrimaryLeaseLoss, LocalStore } from '../local/local_store';\nimport {\n  localStoreAcknowledgeBatch,\n  localStoreAllocateTarget,\n  localStoreApplyRemoteEventToLocalCache,\n  localStoreExecuteQuery,\n  localStoreGetActiveClients,\n  localStoreGetCachedTarget,\n  localStoreGetHighestUnacknowledgedBatchId,\n  localStoreGetNewDocumentChanges,\n  localStoreHandleUserChange,\n  localStoreHasNewerBundle,\n  localStoreLookupMutationDocuments,\n  localStoreNotifyLocalViewChanges,\n  localStoreRejectBatch,\n  localStoreReleaseTarget,\n  localStoreRemoveCachedMutationBatchMetadata,\n  localStoreSaveBundle,\n  localStoreWriteLocally\n} from '../local/local_store_impl';\nimport { LocalViewChanges } from '../local/local_view_changes';\nimport { ReferenceSet } from '../local/reference_set';\nimport { ClientId, SharedClientState } from '../local/shared_client_state';\nimport { QueryTargetState } from '../local/shared_client_state_syncer';\nimport { TargetData, TargetPurpose } from '../local/target_data';\nimport {\n  DocumentKeySet,\n  documentKeySet,\n  DocumentMap\n} from '../model/collections';\nimport { MutableDocument } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { Mutation } from '../model/mutation';\nimport { MutationBatchResult } from '../model/mutation_batch';\nimport { ResourcePath } from '../model/path';\nimport { RemoteEvent, TargetChange } from '../remote/remote_event';\nimport {\n  canUseNetwork,\n  fillWritePipeline,\n  RemoteStore,\n  remoteStoreApplyPrimaryState,\n  remoteStoreListen,\n  remoteStoreUnlisten\n} from '../remote/remote_store';\nimport { debugAssert, debugCast, fail, hardAssert } from '../util/assert';\nimport { wrapInUserErrorIfRecoverable } from '../util/async_queue';\nimport { BundleReader } from '../util/bundle_reader';\nimport { ByteString } from '../util/byte_string';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug, logWarn } from '../util/log';\nimport { primitiveComparator } from '../util/misc';\nimport { ObjectMap } from '../util/obj_map';\nimport { Deferred } from '../util/promise';\nimport { SortedMap } from '../util/sorted_map';\nimport { BATCHID_UNKNOWN } from '../util/types';\n\nimport {\n  bundleInitialProgress,\n  BundleLoader,\n  bundleSuccessProgress\n} from './bundle_impl';\nimport {\n  EventManager,\n  eventManagerOnOnlineStateChange,\n  eventManagerOnWatchChange,\n  eventManagerOnWatchError\n} from './event_manager';\nimport { ListenSequence } from './listen_sequence';\nimport {\n  canonifyQuery,\n  LimitType,\n  newQuery,\n  newQueryForPath,\n  Query,\n  queryEquals,\n  queryCollectionGroup,\n  queryToTarget,\n  stringifyQuery\n} from './query';\nimport { SnapshotVersion } from './snapshot_version';\nimport { SyncEngine } from './sync_engine';\nimport { Target } from './target';\nimport { TargetIdGenerator } from './target_id_generator';\nimport {\n  BatchId,\n  MutationBatchState,\n  OnlineState,\n  OnlineStateSource,\n  TargetId\n} from './types';\nimport {\n  AddedLimboDocument,\n  LimboDocumentChange,\n  RemovedLimboDocument,\n  View,\n  ViewChange\n} from './view';\nimport { ViewSnapshot } from './view_snapshot';\n\nconst LOG_TAG = 'SyncEngine';\n\n/**\n * QueryView contains all of the data that SyncEngine needs to keep track of for\n * a particular query.\n */\nclass QueryView {\n  constructor(\n    /**\n     * The query itself.\n     */\n    public query: Query,\n    /**\n     * The target number created by the client that is used in the watch\n     * stream to identify this query.\n     */\n    public targetId: TargetId,\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     */\n    public view: View\n  ) {}\n}\n\n/** Tracks a limbo resolution. */\nclass LimboResolution {\n  constructor(public key: DocumentKey) {}\n\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  receivedDocument: boolean = false;\n}\n\n/**\n * A function that updates a QueryView with a set of document changes (and a\n * remote event if applicable).\n */\ntype ApplyDocChangesHandler = (\n  queryView: QueryView,\n  changes: DocumentMap,\n  remoteEvent?: RemoteEvent\n) => Promise<ViewSnapshot | undefined>;\n\n/**\n * Callbacks implemented by EventManager to handle notifications from\n * SyncEngine.\n */\ninterface SyncEngineListener {\n  /** Handles new view snapshots. */\n  onWatchChange?(snapshots: ViewSnapshot[]): void;\n\n  /** Handles the failure of a query. */\n  onWatchError?(query: Query, error: FirestoreError): void;\n}\n\n/**\n * An implementation of `SyncEngine` coordinating with other parts of SDK.\n *\n * The parts of SyncEngine that act as a callback to RemoteStore need to be\n * registered individually. This is done in `syncEngineWrite()` and\n * `syncEngineListen()` (as well as `applyPrimaryState()`) as these methods\n * serve as entry points to RemoteStore's functionality.\n *\n * Note: some field defined in this class might have public access level, but\n * the class is not exported so they are only accessible from this module.\n * This is useful to implement optional features (like bundles) in free\n * functions, such that they are tree-shakeable.\n */\nclass SyncEngineImpl implements SyncEngine {\n  syncEngineListener: SyncEngineListener = {};\n\n  /**\n   * A callback that updates the QueryView based on the provided change.\n   *\n   * PORTING NOTE: On other platforms, this logic lives in\n   * `emitNewSnapshotsAndNotifyLocalStore()`, but on Web it is extracted to\n   *  ensure that all view logic only exists in bundles that include views.\n   */\n  applyDocChanges?: ApplyDocChangesHandler;\n\n  queryViewsByQuery = new ObjectMap<Query, QueryView>(\n    q => canonifyQuery(q),\n    queryEquals\n  );\n  queriesByTarget = new Map<TargetId, Query[]>();\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  enqueuedLimboResolutions = new Set<string>();\n  /**\n   * Keeps track of the target ID for each document that is in limbo with an\n   * active target.\n   */\n  activeLimboTargetsByKey = new SortedMap<DocumentKey, TargetId>(\n    DocumentKey.comparator\n  );\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  activeLimboResolutionsByTarget = new Map<TargetId, LimboResolution>();\n  limboDocumentRefs = new ReferenceSet();\n  /** Stores user completion handlers, indexed by User and BatchId. */\n  mutationUserCallbacks = {} as {\n    [uidKey: string]: SortedMap<BatchId, Deferred<void>>;\n  };\n  /** Stores user callbacks waiting for all pending writes to be acknowledged. */\n  pendingWritesCallbacks = new Map<BatchId, Array<Deferred<void>>>();\n  limboTargetIdGenerator = TargetIdGenerator.forSyncEngine();\n\n  onlineState = OnlineState.Unknown;\n\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  _isPrimaryClient: undefined | boolean = undefined;\n\n  constructor(\n    readonly localStore: LocalStore,\n    readonly remoteStore: RemoteStore,\n    readonly eventManager: EventManager,\n    // PORTING NOTE: Manages state synchronization in multi-tab environments.\n    readonly sharedClientState: SharedClientState,\n    public currentUser: User,\n    readonly maxConcurrentLimboResolutions: number\n  ) {}\n\n  get isPrimaryClient(): boolean {\n    return this._isPrimaryClient === true;\n  }\n}\n\nexport function newSyncEngine(\n  localStore: LocalStore,\n  remoteStore: RemoteStore,\n  eventManager: EventManager,\n  // PORTING NOTE: Manages state synchronization in multi-tab environments.\n  sharedClientState: SharedClientState,\n  currentUser: User,\n  maxConcurrentLimboResolutions: number,\n  isPrimary: boolean\n): SyncEngine {\n  const syncEngine = new SyncEngineImpl(\n    localStore,\n    remoteStore,\n    eventManager,\n    sharedClientState,\n    currentUser,\n    maxConcurrentLimboResolutions\n  );\n  if (isPrimary) {\n    syncEngine._isPrimaryClient = true;\n  }\n  return syncEngine;\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 */\nexport async function syncEngineListen(\n  syncEngine: SyncEngine,\n  query: Query,\n  shouldListenToRemote: boolean = true\n): Promise<ViewSnapshot> {\n  const syncEngineImpl = ensureWatchCallbacks(syncEngine);\n\n  let viewSnapshot;\n\n  const queryView = syncEngineImpl.queryViewsByQuery.get(query);\n  if (queryView) {\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    syncEngineImpl.sharedClientState.addLocalQueryTarget(queryView.targetId);\n    viewSnapshot = queryView.view.computeInitialSnapshot();\n  } else {\n    viewSnapshot = await allocateTargetAndMaybeListen(\n      syncEngineImpl,\n      query,\n      shouldListenToRemote,\n      /** shouldInitializeView= */ true\n    );\n    debugAssert(!!viewSnapshot, 'viewSnapshot is not initialized');\n  }\n\n  return viewSnapshot;\n}\n\n/** Query has been listening to the cache, and tries to initiate the remote store listen */\nexport async function triggerRemoteStoreListen(\n  syncEngine: SyncEngine,\n  query: Query\n): Promise<void> {\n  const syncEngineImpl = ensureWatchCallbacks(syncEngine);\n  await allocateTargetAndMaybeListen(\n    syncEngineImpl,\n    query,\n    /** shouldListenToRemote= */ true,\n    /** shouldInitializeView= */ false\n  );\n}\n\nasync function allocateTargetAndMaybeListen(\n  syncEngineImpl: SyncEngineImpl,\n  query: Query,\n  shouldListenToRemote: boolean,\n  shouldInitializeView: boolean\n): Promise<ViewSnapshot | undefined> {\n  const targetData = await localStoreAllocateTarget(\n    syncEngineImpl.localStore,\n    queryToTarget(query)\n  );\n\n  const targetId = targetData.targetId;\n\n  // PORTING NOTE: When the query is listening to cache only, we skip sending it over to Watch by\n  // not registering it in shared client state, and directly calculate initial snapshots and\n  // subsequent updates from cache. Otherwise, register the target ID with local Firestore client\n  // as active watch target.\n  const status: QueryTargetState =\n    syncEngineImpl.sharedClientState.addLocalQueryTarget(\n      targetId,\n      /* addToActiveTargetIds= */ shouldListenToRemote\n    );\n\n  let viewSnapshot;\n  if (shouldInitializeView) {\n    viewSnapshot = await initializeViewAndComputeSnapshot(\n      syncEngineImpl,\n      query,\n      targetId,\n      status === 'current',\n      targetData.resumeToken\n    );\n  }\n\n  if (syncEngineImpl.isPrimaryClient && shouldListenToRemote) {\n    remoteStoreListen(syncEngineImpl.remoteStore, targetData);\n  }\n\n  return viewSnapshot;\n}\n\n/**\n * Registers a view for a previously unknown query and computes its initial\n * snapshot.\n */\nasync function initializeViewAndComputeSnapshot(\n  syncEngineImpl: SyncEngineImpl,\n  query: Query,\n  targetId: TargetId,\n  current: boolean,\n  resumeToken: ByteString\n): Promise<ViewSnapshot> {\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  syncEngineImpl.applyDocChanges = (queryView, changes, remoteEvent) =>\n    applyDocChanges(syncEngineImpl, queryView, changes, remoteEvent);\n\n  const queryResult = await localStoreExecuteQuery(\n    syncEngineImpl.localStore,\n    query,\n    /* usePreviousResults= */ true\n  );\n  const view = new View(query, queryResult.remoteKeys);\n  const viewDocChanges = view.computeDocChanges(queryResult.documents);\n  const synthesizedTargetChange =\n    TargetChange.createSynthesizedTargetChangeForCurrentChange(\n      targetId,\n      current && syncEngineImpl.onlineState !== OnlineState.Offline,\n      resumeToken\n    );\n  const viewChange = view.applyChanges(\n    viewDocChanges,\n    /* limboResolutionEnabled= */ syncEngineImpl.isPrimaryClient,\n    synthesizedTargetChange\n  );\n  updateTrackedLimbos(syncEngineImpl, targetId, viewChange.limboChanges);\n\n  debugAssert(\n    !!viewChange.snapshot,\n    'applyChanges for new view should always return a snapshot'\n  );\n\n  const data = new QueryView(query, targetId, view);\n\n  syncEngineImpl.queryViewsByQuery.set(query, data);\n  if (syncEngineImpl.queriesByTarget.has(targetId)) {\n    syncEngineImpl.queriesByTarget.get(targetId)!.push(query);\n  } else {\n    syncEngineImpl.queriesByTarget.set(targetId, [query]);\n  }\n\n  return viewChange.snapshot;\n}\n\n/** Stops listening to the query. */\nexport async function syncEngineUnlisten(\n  syncEngine: SyncEngine,\n  query: Query,\n  shouldUnlistenToRemote: boolean\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const queryView = syncEngineImpl.queryViewsByQuery.get(query)!;\n  debugAssert(\n    !!queryView,\n    'Trying to unlisten on query not found:' + stringifyQuery(query)\n  );\n\n  // Only clean up the query view and target if this is the only query mapped\n  // to the target.\n  const queries = syncEngineImpl.queriesByTarget.get(queryView.targetId)!;\n  if (queries.length > 1) {\n    syncEngineImpl.queriesByTarget.set(\n      queryView.targetId,\n      queries.filter(q => !queryEquals(q, query))\n    );\n    syncEngineImpl.queryViewsByQuery.delete(query);\n    return;\n  }\n\n  // No other queries are mapped to the target, clean up the query and the target.\n  if (syncEngineImpl.isPrimaryClient) {\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    syncEngineImpl.sharedClientState.removeLocalQueryTarget(queryView.targetId);\n    const targetRemainsActive =\n      syncEngineImpl.sharedClientState.isActiveQueryTarget(queryView.targetId);\n\n    if (!targetRemainsActive) {\n      await localStoreReleaseTarget(\n        syncEngineImpl.localStore,\n        queryView.targetId,\n        /*keepPersistedTargetData=*/ false\n      )\n        .then(() => {\n          syncEngineImpl.sharedClientState.clearQueryState(queryView.targetId);\n          if (shouldUnlistenToRemote) {\n            remoteStoreUnlisten(syncEngineImpl.remoteStore, queryView.targetId);\n          }\n          removeAndCleanupTarget(syncEngineImpl, queryView.targetId);\n        })\n        .catch(ignoreIfPrimaryLeaseLoss);\n    }\n  } else {\n    removeAndCleanupTarget(syncEngineImpl, queryView.targetId);\n    await localStoreReleaseTarget(\n      syncEngineImpl.localStore,\n      queryView.targetId,\n      /*keepPersistedTargetData=*/ true\n    );\n  }\n}\n\n/** Unlistens to the remote store while still listening to the cache. */\nexport async function triggerRemoteStoreUnlisten(\n  syncEngine: SyncEngine,\n  query: Query\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const queryView = syncEngineImpl.queryViewsByQuery.get(query)!;\n  debugAssert(\n    !!queryView,\n    'Trying to unlisten on query not found:' + stringifyQuery(query)\n  );\n  const queries = syncEngineImpl.queriesByTarget.get(queryView.targetId)!;\n\n  if (syncEngineImpl.isPrimaryClient && queries.length === 1) {\n    // PORTING NOTE: Unregister the target ID with local Firestore client as\n    // watch target.\n    syncEngineImpl.sharedClientState.removeLocalQueryTarget(queryView.targetId);\n\n    remoteStoreUnlisten(syncEngineImpl.remoteStore, queryView.targetId);\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 */\nexport async function syncEngineWrite(\n  syncEngine: SyncEngine,\n  batch: Mutation[],\n  userCallback: Deferred<void>\n): Promise<void> {\n  const syncEngineImpl = syncEngineEnsureWriteCallbacks(syncEngine);\n\n  try {\n    const result = await localStoreWriteLocally(\n      syncEngineImpl.localStore,\n      batch\n    );\n    syncEngineImpl.sharedClientState.addPendingMutation(result.batchId);\n    addMutationCallback(syncEngineImpl, result.batchId, userCallback);\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(\n      syncEngineImpl,\n      result.changes\n    );\n    await fillWritePipeline(syncEngineImpl.remoteStore);\n  } catch (e) {\n    // If we can't persist the mutation, we reject the user callback and\n    // don't send the mutation. The user can then retry the write.\n    const error = wrapInUserErrorIfRecoverable(\n      e as Error,\n      `Failed to persist write`\n    );\n    userCallback.reject(error);\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 */\nexport async function syncEngineApplyRemoteEvent(\n  syncEngine: SyncEngine,\n  remoteEvent: RemoteEvent\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n\n  try {\n    const changes = await localStoreApplyRemoteEventToLocalCache(\n      syncEngineImpl.localStore,\n      remoteEvent\n    );\n    // Update `receivedDocument` as appropriate for any limbo targets.\n    remoteEvent.targetChanges.forEach((targetChange, targetId) => {\n      const limboResolution =\n        syncEngineImpl.activeLimboResolutionsByTarget.get(targetId);\n      if (limboResolution) {\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        hardAssert(\n          targetChange.addedDocuments.size +\n            targetChange.modifiedDocuments.size +\n            targetChange.removedDocuments.size <=\n            1,\n          'Limbo resolution for single document contains multiple changes.'\n        );\n        if (targetChange.addedDocuments.size > 0) {\n          limboResolution.receivedDocument = true;\n        } else if (targetChange.modifiedDocuments.size > 0) {\n          hardAssert(\n            limboResolution.receivedDocument,\n            'Received change for limbo target document without add.'\n          );\n        } else if (targetChange.removedDocuments.size > 0) {\n          hardAssert(\n            limboResolution.receivedDocument,\n            'Received remove for limbo target document without add.'\n          );\n          limboResolution.receivedDocument = false;\n        } else {\n          // This was probably just a CURRENT targetChange or similar.\n        }\n      }\n    });\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(\n      syncEngineImpl,\n      changes,\n      remoteEvent\n    );\n  } catch (error) {\n    await ignoreIfPrimaryLeaseLoss(error as FirestoreError);\n  }\n}\n\n/**\n * Applies an OnlineState change to the sync engine and notifies any views of\n * the change.\n */\nexport function syncEngineApplyOnlineStateChange(\n  syncEngine: SyncEngine,\n  onlineState: OnlineState,\n  source: OnlineStateSource\n): void {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\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 (\n    (syncEngineImpl.isPrimaryClient &&\n      source === OnlineStateSource.RemoteStore) ||\n    (!syncEngineImpl.isPrimaryClient &&\n      source === OnlineStateSource.SharedClientState)\n  ) {\n    const newViewSnapshots = [] as ViewSnapshot[];\n    syncEngineImpl.queryViewsByQuery.forEach((query, queryView) => {\n      const viewChange = queryView.view.applyOnlineStateChange(onlineState);\n      debugAssert(\n        viewChange.limboChanges.length === 0,\n        'OnlineState should not affect limbo documents.'\n      );\n      if (viewChange.snapshot) {\n        newViewSnapshots.push(viewChange.snapshot);\n      }\n    });\n\n    eventManagerOnOnlineStateChange(syncEngineImpl.eventManager, onlineState);\n\n    if (newViewSnapshots.length) {\n      debugAssert(\n        !!syncEngineImpl.syncEngineListener.onWatchChange,\n        'Active views but EventManager callbacks are not assigned'\n      );\n      syncEngineImpl.syncEngineListener.onWatchChange(newViewSnapshots);\n    }\n\n    syncEngineImpl.onlineState = onlineState;\n    if (syncEngineImpl.isPrimaryClient) {\n      syncEngineImpl.sharedClientState.setOnlineState(onlineState);\n    }\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 */\nexport async function syncEngineRejectListen(\n  syncEngine: SyncEngine,\n  targetId: TargetId,\n  err: FirestoreError\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n\n  // PORTING NOTE: Multi-tab only.\n  syncEngineImpl.sharedClientState.updateQueryState(targetId, 'rejected', err);\n\n  const limboResolution =\n    syncEngineImpl.activeLimboResolutionsByTarget.get(targetId);\n  const limboKey = limboResolution && limboResolution.key;\n  if (limboKey) {\n    // TODO(klimt): We really only should do the following on permission\n    // denied errors, but we don't have the cause code here.\n\n    // It's a limbo doc. Create a synthetic event saying it was deleted.\n    // This is kind of a hack. Ideally, we would have a method in the local\n    // store to purge a document. However, it would be tricky to keep all of\n    // the local store's invariants with another method.\n    let documentUpdates = new SortedMap<DocumentKey, MutableDocument>(\n      DocumentKey.comparator\n    );\n    // TODO(b/217189216): This limbo document should ideally have a read time,\n    // so that it is picked up by any read-time based scans. The backend,\n    // however, does not send a read time for target removals.\n    documentUpdates = documentUpdates.insert(\n      limboKey,\n      MutableDocument.newNoDocument(limboKey, SnapshotVersion.min())\n    );\n    const resolvedLimboDocuments = documentKeySet().add(limboKey);\n    const event = new RemoteEvent(\n      SnapshotVersion.min(),\n      /* targetChanges= */ new Map<TargetId, TargetChange>(),\n      /* targetMismatches= */ new SortedMap<TargetId, TargetPurpose>(\n        primitiveComparator\n      ),\n      documentUpdates,\n      resolvedLimboDocuments\n    );\n\n    await syncEngineApplyRemoteEvent(syncEngineImpl, event);\n\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    syncEngineImpl.activeLimboTargetsByKey =\n      syncEngineImpl.activeLimboTargetsByKey.remove(limboKey);\n    syncEngineImpl.activeLimboResolutionsByTarget.delete(targetId);\n    pumpEnqueuedLimboResolutions(syncEngineImpl);\n  } else {\n    await localStoreReleaseTarget(\n      syncEngineImpl.localStore,\n      targetId,\n      /* keepPersistedTargetData */ false\n    )\n      .then(() => removeAndCleanupTarget(syncEngineImpl, targetId, err))\n      .catch(ignoreIfPrimaryLeaseLoss);\n  }\n}\n\nexport async function syncEngineApplySuccessfulWrite(\n  syncEngine: SyncEngine,\n  mutationBatchResult: MutationBatchResult\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const batchId = mutationBatchResult.batch.batchId;\n\n  try {\n    const changes = await localStoreAcknowledgeBatch(\n      syncEngineImpl.localStore,\n      mutationBatchResult\n    );\n\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    processUserCallback(syncEngineImpl, batchId, /*error=*/ null);\n    triggerPendingWritesCallbacks(syncEngineImpl, batchId);\n\n    syncEngineImpl.sharedClientState.updateMutationState(\n      batchId,\n      'acknowledged'\n    );\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(syncEngineImpl, changes);\n  } catch (error) {\n    await ignoreIfPrimaryLeaseLoss(error as FirestoreError);\n  }\n}\n\nexport async function syncEngineRejectFailedWrite(\n  syncEngine: SyncEngine,\n  batchId: BatchId,\n  error: FirestoreError\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n\n  try {\n    const changes = await localStoreRejectBatch(\n      syncEngineImpl.localStore,\n      batchId\n    );\n\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    processUserCallback(syncEngineImpl, batchId, error);\n    triggerPendingWritesCallbacks(syncEngineImpl, batchId);\n\n    syncEngineImpl.sharedClientState.updateMutationState(\n      batchId,\n      'rejected',\n      error\n    );\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(syncEngineImpl, changes);\n  } catch (error) {\n    await ignoreIfPrimaryLeaseLoss(error as FirestoreError);\n  }\n}\n\n/**\n * Registers a user callback that resolves when all pending mutations at the moment of calling\n * are acknowledged .\n */\nexport async function syncEngineRegisterPendingWritesCallback(\n  syncEngine: SyncEngine,\n  callback: Deferred<void>\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  if (!canUseNetwork(syncEngineImpl.remoteStore)) {\n    logDebug(\n      LOG_TAG,\n      'The network is disabled. The task returned by ' +\n        \"'awaitPendingWrites()' will not complete until the network is enabled.\"\n    );\n  }\n\n  try {\n    const highestBatchId = await localStoreGetHighestUnacknowledgedBatchId(\n      syncEngineImpl.localStore\n    );\n    if (highestBatchId === BATCHID_UNKNOWN) {\n      // Trigger the callback right away if there is no pending writes at the moment.\n      callback.resolve();\n      return;\n    }\n\n    const callbacks =\n      syncEngineImpl.pendingWritesCallbacks.get(highestBatchId) || [];\n    callbacks.push(callback);\n    syncEngineImpl.pendingWritesCallbacks.set(highestBatchId, callbacks);\n  } catch (e) {\n    const firestoreError = wrapInUserErrorIfRecoverable(\n      e as Error,\n      'Initialization of waitForPendingWrites() operation failed'\n    );\n    callback.reject(firestoreError);\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 */\nfunction triggerPendingWritesCallbacks(\n  syncEngineImpl: SyncEngineImpl,\n  batchId: BatchId\n): void {\n  (syncEngineImpl.pendingWritesCallbacks.get(batchId) || []).forEach(\n    callback => {\n      callback.resolve();\n    }\n  );\n\n  syncEngineImpl.pendingWritesCallbacks.delete(batchId);\n}\n\n/** Reject all outstanding callbacks waiting for pending writes to complete. */\nfunction rejectOutstandingPendingWritesCallbacks(\n  syncEngineImpl: SyncEngineImpl,\n  errorMessage: string\n): void {\n  syncEngineImpl.pendingWritesCallbacks.forEach(callbacks => {\n    callbacks.forEach(callback => {\n      callback.reject(new FirestoreError(Code.CANCELLED, errorMessage));\n    });\n  });\n\n  syncEngineImpl.pendingWritesCallbacks.clear();\n}\n\nfunction addMutationCallback(\n  syncEngineImpl: SyncEngineImpl,\n  batchId: BatchId,\n  callback: Deferred<void>\n): void {\n  let newCallbacks =\n    syncEngineImpl.mutationUserCallbacks[syncEngineImpl.currentUser.toKey()];\n  if (!newCallbacks) {\n    newCallbacks = new SortedMap<BatchId, Deferred<void>>(primitiveComparator);\n  }\n  newCallbacks = newCallbacks.insert(batchId, callback);\n  syncEngineImpl.mutationUserCallbacks[syncEngineImpl.currentUser.toKey()] =\n    newCallbacks;\n}\n\n/**\n * Resolves or rejects the user callback for the given batch and then discards\n * it.\n */\nfunction processUserCallback(\n  syncEngine: SyncEngine,\n  batchId: BatchId,\n  error: FirestoreError | null\n): void {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  let newCallbacks =\n    syncEngineImpl.mutationUserCallbacks[syncEngineImpl.currentUser.toKey()];\n\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 (newCallbacks) {\n    const callback = newCallbacks.get(batchId);\n    if (callback) {\n      debugAssert(\n        batchId === newCallbacks.minKey(),\n        'Mutation callbacks processed out-of-order?'\n      );\n      if (error) {\n        callback.reject(error);\n      } else {\n        callback.resolve();\n      }\n      newCallbacks = newCallbacks.remove(batchId);\n    }\n    syncEngineImpl.mutationUserCallbacks[syncEngineImpl.currentUser.toKey()] =\n      newCallbacks;\n  }\n}\n\nfunction removeAndCleanupTarget(\n  syncEngineImpl: SyncEngineImpl,\n  targetId: number,\n  error: FirestoreError | null = null\n): void {\n  syncEngineImpl.sharedClientState.removeLocalQueryTarget(targetId);\n\n  debugAssert(\n    syncEngineImpl.queriesByTarget.has(targetId) &&\n      syncEngineImpl.queriesByTarget.get(targetId)!.length !== 0,\n    `There are no queries mapped to target id ${targetId}`\n  );\n\n  for (const query of syncEngineImpl.queriesByTarget.get(targetId)!) {\n    syncEngineImpl.queryViewsByQuery.delete(query);\n    if (error) {\n      syncEngineImpl.syncEngineListener.onWatchError!(query, error);\n    }\n  }\n\n  syncEngineImpl.queriesByTarget.delete(targetId);\n\n  if (syncEngineImpl.isPrimaryClient) {\n    const limboKeys =\n      syncEngineImpl.limboDocumentRefs.removeReferencesForId(targetId);\n    limboKeys.forEach(limboKey => {\n      const isReferenced =\n        syncEngineImpl.limboDocumentRefs.containsKey(limboKey);\n      if (!isReferenced) {\n        // We removed the last reference for this key\n        removeLimboTarget(syncEngineImpl, limboKey);\n      }\n    });\n  }\n}\n\nfunction removeLimboTarget(\n  syncEngineImpl: SyncEngineImpl,\n  key: DocumentKey\n): void {\n  syncEngineImpl.enqueuedLimboResolutions.delete(key.path.canonicalString());\n\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  const limboTargetId = syncEngineImpl.activeLimboTargetsByKey.get(key);\n  if (limboTargetId === null) {\n    // This target already got removed, because the query failed.\n    return;\n  }\n\n  remoteStoreUnlisten(syncEngineImpl.remoteStore, limboTargetId);\n  syncEngineImpl.activeLimboTargetsByKey =\n    syncEngineImpl.activeLimboTargetsByKey.remove(key);\n  syncEngineImpl.activeLimboResolutionsByTarget.delete(limboTargetId);\n  pumpEnqueuedLimboResolutions(syncEngineImpl);\n}\n\nfunction updateTrackedLimbos(\n  syncEngineImpl: SyncEngineImpl,\n  targetId: TargetId,\n  limboChanges: LimboDocumentChange[]\n): void {\n  for (const limboChange of limboChanges) {\n    if (limboChange instanceof AddedLimboDocument) {\n      syncEngineImpl.limboDocumentRefs.addReference(limboChange.key, targetId);\n      trackLimboChange(syncEngineImpl, limboChange);\n    } else if (limboChange instanceof RemovedLimboDocument) {\n      logDebug(LOG_TAG, 'Document no longer in limbo: ' + limboChange.key);\n      syncEngineImpl.limboDocumentRefs.removeReference(\n        limboChange.key,\n        targetId\n      );\n      const isReferenced = syncEngineImpl.limboDocumentRefs.containsKey(\n        limboChange.key\n      );\n      if (!isReferenced) {\n        // We removed the last reference for this key\n        removeLimboTarget(syncEngineImpl, limboChange.key);\n      }\n    } else {\n      fail('Unknown limbo change: ' + JSON.stringify(limboChange));\n    }\n  }\n}\n\nfunction trackLimboChange(\n  syncEngineImpl: SyncEngineImpl,\n  limboChange: AddedLimboDocument\n): void {\n  const key = limboChange.key;\n  const keyString = key.path.canonicalString();\n  if (\n    !syncEngineImpl.activeLimboTargetsByKey.get(key) &&\n    !syncEngineImpl.enqueuedLimboResolutions.has(keyString)\n  ) {\n    logDebug(LOG_TAG, 'New document in limbo: ' + key);\n    syncEngineImpl.enqueuedLimboResolutions.add(keyString);\n    pumpEnqueuedLimboResolutions(syncEngineImpl);\n  }\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 */\nfunction pumpEnqueuedLimboResolutions(syncEngineImpl: SyncEngineImpl): void {\n  while (\n    syncEngineImpl.enqueuedLimboResolutions.size > 0 &&\n    syncEngineImpl.activeLimboTargetsByKey.size <\n      syncEngineImpl.maxConcurrentLimboResolutions\n  ) {\n    const keyString = syncEngineImpl.enqueuedLimboResolutions\n      .values()\n      .next().value;\n    syncEngineImpl.enqueuedLimboResolutions.delete(keyString);\n    const key = new DocumentKey(ResourcePath.fromString(keyString));\n    const limboTargetId = syncEngineImpl.limboTargetIdGenerator.next();\n    syncEngineImpl.activeLimboResolutionsByTarget.set(\n      limboTargetId,\n      new LimboResolution(key)\n    );\n    syncEngineImpl.activeLimboTargetsByKey =\n      syncEngineImpl.activeLimboTargetsByKey.insert(key, limboTargetId);\n    remoteStoreListen(\n      syncEngineImpl.remoteStore,\n      new TargetData(\n        queryToTarget(newQueryForPath(key.path)),\n        limboTargetId,\n        TargetPurpose.LimboResolution,\n        ListenSequence.INVALID\n      )\n    );\n  }\n}\n\n// Visible for testing\nexport function syncEngineGetActiveLimboDocumentResolutions(\n  syncEngine: SyncEngine\n): SortedMap<DocumentKey, TargetId> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  return syncEngineImpl.activeLimboTargetsByKey;\n}\n\n// Visible for testing\nexport function syncEngineGetEnqueuedLimboDocumentResolutions(\n  syncEngine: SyncEngine\n): Set<string> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  return syncEngineImpl.enqueuedLimboResolutions;\n}\n\nexport async function syncEngineEmitNewSnapsAndNotifyLocalStore(\n  syncEngine: SyncEngine,\n  changes: DocumentMap,\n  remoteEvent?: RemoteEvent\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const newSnaps: ViewSnapshot[] = [];\n  const docChangesInAllViews: LocalViewChanges[] = [];\n  const queriesProcessed: Array<Promise<void>> = [];\n\n  if (syncEngineImpl.queryViewsByQuery.isEmpty()) {\n    // Return early since `onWatchChange()` might not have been assigned yet.\n    return;\n  }\n\n  syncEngineImpl.queryViewsByQuery.forEach((_, queryView) => {\n    debugAssert(\n      !!syncEngineImpl.applyDocChanges,\n      'ApplyDocChangesHandler not set'\n    );\n    queriesProcessed.push(\n      syncEngineImpl\n        .applyDocChanges(queryView, changes, remoteEvent)\n        .then(viewSnapshot => {\n          // If there are changes, or we are handling a global snapshot, notify\n          // secondary clients to update query state.\n          if (viewSnapshot || remoteEvent) {\n            if (syncEngineImpl.isPrimaryClient) {\n              // Query state is set to `current` if:\n              // - There is a view change and it is up-to-date, or,\n              // - There is a global snapshot, the Target is current, and no changes to be resolved\n              const isCurrent = viewSnapshot\n                ? !viewSnapshot.fromCache\n                : remoteEvent?.targetChanges.get(queryView.targetId)?.current;\n\n              syncEngineImpl.sharedClientState.updateQueryState(\n                queryView.targetId,\n                isCurrent ? 'current' : 'not-current'\n              );\n            }\n          }\n\n          // Update views if there are actual changes.\n          if (!!viewSnapshot) {\n            newSnaps.push(viewSnapshot);\n            const docChanges = LocalViewChanges.fromSnapshot(\n              queryView.targetId,\n              viewSnapshot\n            );\n            docChangesInAllViews.push(docChanges);\n          }\n        })\n    );\n  });\n\n  await Promise.all(queriesProcessed);\n  syncEngineImpl.syncEngineListener.onWatchChange!(newSnaps);\n  await localStoreNotifyLocalViewChanges(\n    syncEngineImpl.localStore,\n    docChangesInAllViews\n  );\n}\n\nasync function applyDocChanges(\n  syncEngineImpl: SyncEngineImpl,\n  queryView: QueryView,\n  changes: DocumentMap,\n  remoteEvent?: RemoteEvent\n): Promise<ViewSnapshot | undefined> {\n  let viewDocChanges = queryView.view.computeDocChanges(changes);\n  if (viewDocChanges.needsRefill) {\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    viewDocChanges = await localStoreExecuteQuery(\n      syncEngineImpl.localStore,\n      queryView.query,\n      /* usePreviousResults= */ false\n    ).then(({ documents }) => {\n      return queryView.view.computeDocChanges(documents, viewDocChanges);\n    });\n  }\n\n  const targetChange =\n    remoteEvent && remoteEvent.targetChanges.get(queryView.targetId);\n  const targetIsPendingReset =\n    remoteEvent && remoteEvent.targetMismatches.get(queryView.targetId) != null;\n  const viewChange = queryView.view.applyChanges(\n    viewDocChanges,\n    /* limboResolutionEnabled= */ syncEngineImpl.isPrimaryClient,\n    targetChange,\n    targetIsPendingReset\n  );\n  updateTrackedLimbos(\n    syncEngineImpl,\n    queryView.targetId,\n    viewChange.limboChanges\n  );\n  return viewChange.snapshot;\n}\n\nexport async function syncEngineHandleCredentialChange(\n  syncEngine: SyncEngine,\n  user: User\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const userChanged = !syncEngineImpl.currentUser.isEqual(user);\n\n  if (userChanged) {\n    logDebug(LOG_TAG, 'User change. New user:', user.toKey());\n\n    const result = await localStoreHandleUserChange(\n      syncEngineImpl.localStore,\n      user\n    );\n    syncEngineImpl.currentUser = user;\n\n    // Fails tasks waiting for pending writes requested by previous user.\n    rejectOutstandingPendingWritesCallbacks(\n      syncEngineImpl,\n      \"'waitForPendingWrites' promise is rejected due to a user change.\"\n    );\n    // TODO(b/114226417): Consider calling this only in the primary tab.\n    syncEngineImpl.sharedClientState.handleUserChange(\n      user,\n      result.removedBatchIds,\n      result.addedBatchIds\n    );\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(\n      syncEngineImpl,\n      result.affectedDocuments\n    );\n  }\n}\n\nexport function syncEngineGetRemoteKeysForTarget(\n  syncEngine: SyncEngine,\n  targetId: TargetId\n): DocumentKeySet {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const limboResolution =\n    syncEngineImpl.activeLimboResolutionsByTarget.get(targetId);\n  if (limboResolution && limboResolution.receivedDocument) {\n    return documentKeySet().add(limboResolution.key);\n  } else {\n    let keySet = documentKeySet();\n    const queries = syncEngineImpl.queriesByTarget.get(targetId);\n    if (!queries) {\n      return keySet;\n    }\n    for (const query of queries) {\n      const queryView = syncEngineImpl.queryViewsByQuery.get(query);\n      debugAssert(\n        !!queryView,\n        `No query view found for ${stringifyQuery(query)}`\n      );\n      keySet = keySet.unionWith(queryView.view.syncedDocuments);\n    }\n    return keySet;\n  }\n}\n\n/**\n * Reconcile the list of synced documents in an existing view with those\n * from persistence.\n */\nasync function synchronizeViewAndComputeSnapshot(\n  syncEngine: SyncEngine,\n  queryView: QueryView\n): Promise<ViewChange> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const queryResult = await localStoreExecuteQuery(\n    syncEngineImpl.localStore,\n    queryView.query,\n    /* usePreviousResults= */ true\n  );\n  const viewSnapshot =\n    queryView.view.synchronizeWithPersistedState(queryResult);\n  if (syncEngineImpl.isPrimaryClient) {\n    updateTrackedLimbos(\n      syncEngineImpl,\n      queryView.targetId,\n      viewSnapshot.limboChanges\n    );\n  }\n  return viewSnapshot;\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.\nexport async function syncEngineSynchronizeWithChangedDocuments(\n  syncEngine: SyncEngine,\n  collectionGroup: string\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n\n  return localStoreGetNewDocumentChanges(\n    syncEngineImpl.localStore,\n    collectionGroup\n  ).then(changes =>\n    syncEngineEmitNewSnapsAndNotifyLocalStore(syncEngineImpl, changes)\n  );\n}\n\n/** Applies a mutation state to an existing batch.  */\n// PORTING NOTE: Multi-Tab only.\nexport async function syncEngineApplyBatchState(\n  syncEngine: SyncEngine,\n  batchId: BatchId,\n  batchState: MutationBatchState,\n  error?: FirestoreError\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const documents = await localStoreLookupMutationDocuments(\n    syncEngineImpl.localStore,\n    batchId\n  );\n\n  if (documents === null) {\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    logDebug(LOG_TAG, 'Cannot apply mutation batch with id: ' + batchId);\n    return;\n  }\n\n  if (batchState === 'pending') {\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    await fillWritePipeline(syncEngineImpl.remoteStore);\n  } else if (batchState === 'acknowledged' || batchState === 'rejected') {\n    // NOTE: Both these methods are no-ops for batches that originated from\n    // other clients.\n    processUserCallback(syncEngineImpl, batchId, error ? error : null);\n    triggerPendingWritesCallbacks(syncEngineImpl, batchId);\n    localStoreRemoveCachedMutationBatchMetadata(\n      syncEngineImpl.localStore,\n      batchId\n    );\n  } else {\n    fail(`Unknown batchState: ${batchState}`);\n  }\n\n  await syncEngineEmitNewSnapsAndNotifyLocalStore(syncEngineImpl, documents);\n}\n\n/** Applies a query target change from a different tab. */\n// PORTING NOTE: Multi-Tab only.\nexport async function syncEngineApplyPrimaryState(\n  syncEngine: SyncEngine,\n  isPrimary: boolean\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  ensureWatchCallbacks(syncEngineImpl);\n  syncEngineEnsureWriteCallbacks(syncEngineImpl);\n  if (isPrimary === true && syncEngineImpl._isPrimaryClient !== true) {\n    // Secondary tabs only maintain Views for their local listeners and the\n    // Views internal state may not be 100% populated (in particular\n    // secondary tabs don't track syncedDocuments, the set of documents the\n    // server considers to be in the target). So when a secondary becomes\n    // primary, we need to need to make sure that all views for all targets\n    // match the state on disk.\n    const activeTargets =\n      syncEngineImpl.sharedClientState.getAllActiveQueryTargets();\n    const activeQueries = await synchronizeQueryViewsAndRaiseSnapshots(\n      syncEngineImpl,\n      activeTargets.toArray(),\n      /*transitionToPrimary=*/ true\n    );\n    syncEngineImpl._isPrimaryClient = true;\n    await remoteStoreApplyPrimaryState(syncEngineImpl.remoteStore, true);\n    for (const targetData of activeQueries) {\n      remoteStoreListen(syncEngineImpl.remoteStore, targetData);\n    }\n  } else if (isPrimary === false && syncEngineImpl._isPrimaryClient !== false) {\n    const activeTargets: TargetId[] = [];\n\n    let p = Promise.resolve();\n    syncEngineImpl.queriesByTarget.forEach((_, targetId) => {\n      if (syncEngineImpl.sharedClientState.isLocalQueryTarget(targetId)) {\n        activeTargets.push(targetId);\n      } else {\n        p = p.then(() => {\n          removeAndCleanupTarget(syncEngineImpl, targetId);\n          return localStoreReleaseTarget(\n            syncEngineImpl.localStore,\n            targetId,\n            /*keepPersistedTargetData=*/ true\n          );\n        });\n      }\n      remoteStoreUnlisten(syncEngineImpl.remoteStore, targetId);\n    });\n    await p;\n\n    await synchronizeQueryViewsAndRaiseSnapshots(\n      syncEngineImpl,\n      activeTargets,\n      /*transitionToPrimary=*/ false\n    );\n    resetLimboDocuments(syncEngineImpl);\n    syncEngineImpl._isPrimaryClient = false;\n    await remoteStoreApplyPrimaryState(syncEngineImpl.remoteStore, false);\n  }\n}\n\n// PORTING NOTE: Multi-Tab only.\nfunction resetLimboDocuments(syncEngine: SyncEngine): void {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  syncEngineImpl.activeLimboResolutionsByTarget.forEach((_, targetId) => {\n    remoteStoreUnlisten(syncEngineImpl.remoteStore, targetId);\n  });\n  syncEngineImpl.limboDocumentRefs.removeAllReferences();\n  syncEngineImpl.activeLimboResolutionsByTarget = new Map<\n    TargetId,\n    LimboResolution\n  >();\n  syncEngineImpl.activeLimboTargetsByKey = new SortedMap<DocumentKey, TargetId>(\n    DocumentKey.comparator\n  );\n}\n\n/**\n * Reconcile the query views of the provided query targets with the state from\n * persistence. Raises snapshots for any changes that affect the local\n * client and returns the updated state of all target's query data.\n *\n * @param syncEngine - The sync engine implementation\n * @param targets - the list of targets with views that need to be recomputed\n * @param transitionToPrimary - `true` iff the tab transitions from a secondary\n * tab to a primary tab\n */\n// PORTING NOTE: Multi-Tab only.\nasync function synchronizeQueryViewsAndRaiseSnapshots(\n  syncEngine: SyncEngine,\n  targets: TargetId[],\n  transitionToPrimary: boolean\n): Promise<TargetData[]> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  const activeQueries: TargetData[] = [];\n  const newViewSnapshots: ViewSnapshot[] = [];\n  for (const targetId of targets) {\n    let targetData: TargetData;\n    const queries = syncEngineImpl.queriesByTarget.get(targetId);\n\n    if (queries && queries.length !== 0) {\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      targetData = await localStoreAllocateTarget(\n        syncEngineImpl.localStore,\n        queryToTarget(queries[0])\n      );\n\n      for (const query of queries) {\n        const queryView = syncEngineImpl.queryViewsByQuery.get(query);\n        debugAssert(\n          !!queryView,\n          `No query view found for ${stringifyQuery(query)}`\n        );\n\n        const viewChange = await synchronizeViewAndComputeSnapshot(\n          syncEngineImpl,\n          queryView\n        );\n        if (viewChange.snapshot) {\n          newViewSnapshots.push(viewChange.snapshot);\n        }\n      }\n    } else {\n      debugAssert(\n        transitionToPrimary,\n        'A secondary tab should never have an active view without an active target.'\n      );\n      // For queries that never executed on this client, we need to\n      // allocate the target in LocalStore and initialize a new View.\n      const target = await localStoreGetCachedTarget(\n        syncEngineImpl.localStore,\n        targetId\n      );\n      debugAssert(!!target, `Target for id ${targetId} not found`);\n      targetData = await localStoreAllocateTarget(\n        syncEngineImpl.localStore,\n        target\n      );\n      await initializeViewAndComputeSnapshot(\n        syncEngineImpl,\n        synthesizeTargetToQuery(target!),\n        targetId,\n        /*current=*/ false,\n        targetData.resumeToken\n      );\n    }\n\n    activeQueries.push(targetData!);\n  }\n\n  syncEngineImpl.syncEngineListener.onWatchChange!(newViewSnapshots);\n  return activeQueries;\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 synthesizeTargetToQuery(target: Target): Query {\n  return newQuery(\n    target.path,\n    target.collectionGroup,\n    target.orderBy,\n    target.filters,\n    target.limit,\n    LimitType.First,\n    target.startAt,\n    target.endAt\n  );\n}\n\n/** Returns the IDs of the clients that are currently active. */\n// PORTING NOTE: Multi-Tab only.\nexport function syncEngineGetActiveClients(\n  syncEngine: SyncEngine\n): Promise<ClientId[]> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  return localStoreGetActiveClients(syncEngineImpl.localStore);\n}\n\n/** Applies a query target change from a different tab. */\n// PORTING NOTE: Multi-Tab only.\nexport async function syncEngineApplyTargetState(\n  syncEngine: SyncEngine,\n  targetId: TargetId,\n  state: QueryTargetState,\n  error?: FirestoreError\n): Promise<void> {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  if (syncEngineImpl._isPrimaryClient) {\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    logDebug(LOG_TAG, 'Ignoring unexpected query state notification.');\n    return;\n  }\n\n  const query = syncEngineImpl.queriesByTarget.get(targetId);\n  if (query && query.length > 0) {\n    switch (state) {\n      case 'current':\n      case 'not-current': {\n        const changes = await localStoreGetNewDocumentChanges(\n          syncEngineImpl.localStore,\n          queryCollectionGroup(query[0])\n        );\n        const synthesizedRemoteEvent =\n          RemoteEvent.createSynthesizedRemoteEventForCurrentChange(\n            targetId,\n            state === 'current',\n            ByteString.EMPTY_BYTE_STRING\n          );\n        await syncEngineEmitNewSnapsAndNotifyLocalStore(\n          syncEngineImpl,\n          changes,\n          synthesizedRemoteEvent\n        );\n        break;\n      }\n      case 'rejected': {\n        await localStoreReleaseTarget(\n          syncEngineImpl.localStore,\n          targetId,\n          /* keepPersistedTargetData */ true\n        );\n        removeAndCleanupTarget(syncEngineImpl, targetId, error);\n        break;\n      }\n      default:\n        fail('Unexpected target state: ' + state);\n    }\n  }\n}\n\n/** Adds or removes Watch targets for queries from different tabs. */\nexport async function syncEngineApplyActiveTargetsChange(\n  syncEngine: SyncEngine,\n  added: TargetId[],\n  removed: TargetId[]\n): Promise<void> {\n  const syncEngineImpl = ensureWatchCallbacks(syncEngine);\n  if (!syncEngineImpl._isPrimaryClient) {\n    return;\n  }\n\n  for (const targetId of added) {\n    // A target is already listening to remote store if it is already registered to\n    // sharedClientState.\n    const targetAlreadyListeningToRemoteStore =\n      syncEngineImpl.queriesByTarget.has(targetId) &&\n      syncEngineImpl.sharedClientState.isActiveQueryTarget(targetId);\n    if (targetAlreadyListeningToRemoteStore) {\n      logDebug(LOG_TAG, 'Adding an already active target ' + targetId);\n      continue;\n    }\n\n    const target = await localStoreGetCachedTarget(\n      syncEngineImpl.localStore,\n      targetId\n    );\n    debugAssert(!!target, `Query data for active target ${targetId} not found`);\n    const targetData = await localStoreAllocateTarget(\n      syncEngineImpl.localStore,\n      target\n    );\n    await initializeViewAndComputeSnapshot(\n      syncEngineImpl,\n      synthesizeTargetToQuery(target),\n      targetData.targetId,\n      /*current=*/ false,\n      targetData.resumeToken\n    );\n    remoteStoreListen(syncEngineImpl.remoteStore, targetData);\n  }\n\n  for (const targetId of removed) {\n    // Check that the target is still active since the target might have been\n    // removed if it has been rejected by the backend.\n    if (!syncEngineImpl.queriesByTarget.has(targetId)) {\n      continue;\n    }\n\n    // Release queries that are still active.\n    await localStoreReleaseTarget(\n      syncEngineImpl.localStore,\n      targetId,\n      /* keepPersistedTargetData */ false\n    )\n      .then(() => {\n        remoteStoreUnlisten(syncEngineImpl.remoteStore, targetId);\n        removeAndCleanupTarget(syncEngineImpl, targetId);\n      })\n      .catch(ignoreIfPrimaryLeaseLoss);\n  }\n}\n\nfunction ensureWatchCallbacks(syncEngine: SyncEngine): SyncEngineImpl {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  syncEngineImpl.remoteStore.remoteSyncer.applyRemoteEvent =\n    syncEngineApplyRemoteEvent.bind(null, syncEngineImpl);\n  syncEngineImpl.remoteStore.remoteSyncer.getRemoteKeysForTarget =\n    syncEngineGetRemoteKeysForTarget.bind(null, syncEngineImpl);\n  syncEngineImpl.remoteStore.remoteSyncer.rejectListen =\n    syncEngineRejectListen.bind(null, syncEngineImpl);\n  syncEngineImpl.syncEngineListener.onWatchChange =\n    eventManagerOnWatchChange.bind(null, syncEngineImpl.eventManager);\n  syncEngineImpl.syncEngineListener.onWatchError =\n    eventManagerOnWatchError.bind(null, syncEngineImpl.eventManager);\n  return syncEngineImpl;\n}\n\nexport function syncEngineEnsureWriteCallbacks(\n  syncEngine: SyncEngine\n): SyncEngineImpl {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n  syncEngineImpl.remoteStore.remoteSyncer.applySuccessfulWrite =\n    syncEngineApplySuccessfulWrite.bind(null, syncEngineImpl);\n  syncEngineImpl.remoteStore.remoteSyncer.rejectFailedWrite =\n    syncEngineRejectFailedWrite.bind(null, syncEngineImpl);\n  return syncEngineImpl;\n}\n\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 */\nexport function syncEngineLoadBundle(\n  syncEngine: SyncEngine,\n  bundleReader: BundleReader,\n  task: LoadBundleTask\n): void {\n  const syncEngineImpl = debugCast(syncEngine, SyncEngineImpl);\n\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  loadBundleImpl(syncEngineImpl, bundleReader, task).then(collectionGroups => {\n    syncEngineImpl.sharedClientState.notifyBundleLoaded(collectionGroups);\n  });\n}\n\n/** Loads a bundle and returns the list of affected collection groups. */\nasync function loadBundleImpl(\n  syncEngine: SyncEngineImpl,\n  reader: BundleReader,\n  task: LoadBundleTask\n): Promise<Set<string>> {\n  try {\n    const metadata = await reader.getMetadata();\n    const skip = await localStoreHasNewerBundle(\n      syncEngine.localStore,\n      metadata\n    );\n    if (skip) {\n      await reader.close();\n      task._completeWith(bundleSuccessProgress(metadata));\n      return Promise.resolve(new Set<string>());\n    }\n\n    task._updateProgress(bundleInitialProgress(metadata));\n\n    const loader = new BundleLoader(\n      metadata,\n      syncEngine.localStore,\n      reader.serializer\n    );\n    let element = await reader.nextElement();\n    while (element) {\n      debugAssert(\n        !element.payload.metadata,\n        'Unexpected BundleMetadata element.'\n      );\n      const progress = await loader.addSizedElement(element);\n      if (progress) {\n        task._updateProgress(progress);\n      }\n\n      element = await reader.nextElement();\n    }\n\n    const result = await loader.complete();\n    await syncEngineEmitNewSnapsAndNotifyLocalStore(\n      syncEngine,\n      result.changedDocs,\n      /* remoteEvent */ undefined\n    );\n\n    // Save metadata, so loading the same bundle will skip.\n    await localStoreSaveBundle(syncEngine.localStore, metadata);\n    task._completeWith(result.progress);\n    return Promise.resolve(result.changedCollectionGroups);\n  } catch (e) {\n    logWarn(LOG_TAG, `Loading bundle failed with ${e}`);\n    task._failWith(e as FirestoreError);\n    return Promise.resolve(new Set<string>());\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 { CredentialsProvider } from '../api/credentials';\nimport { User } from '../auth/user';\nimport {\n  IndexBackfiller,\n  IndexBackfillerScheduler\n} from '../local/index_backfiller';\nimport {\n  indexedDbStoragePrefix,\n  IndexedDbPersistence\n} from '../local/indexeddb_persistence';\nimport { LocalStore } from '../local/local_store';\nimport { newLocalStore } from '../local/local_store_impl';\nimport { LruParams } from '../local/lru_garbage_collector';\nimport { LruScheduler } from '../local/lru_garbage_collector_impl';\nimport {\n  MemoryEagerDelegate,\n  MemoryLruDelegate,\n  MemoryPersistence\n} from '../local/memory_persistence';\nimport { Scheduler, Persistence } from '../local/persistence';\nimport { QueryEngine } from '../local/query_engine';\nimport {\n  ClientId,\n  MemorySharedClientState,\n  SharedClientState,\n  WebStorageSharedClientState\n} from '../local/shared_client_state';\nimport { newConnection, newConnectivityMonitor } from '../platform/connection';\nimport { getDocument, getWindow } from '../platform/dom';\nimport { newSerializer } from '../platform/serializer';\nimport { Datastore, newDatastore } from '../remote/datastore';\nimport {\n  fillWritePipeline,\n  newRemoteStore,\n  RemoteStore,\n  remoteStoreApplyPrimaryState,\n  remoteStoreShutdown\n} from '../remote/remote_store';\nimport { JsonProtoSerializer } from '../remote/serializer';\nimport { hardAssert } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { Code, FirestoreError } from '../util/error';\n\nimport { DatabaseInfo } from './database_info';\nimport { EventManager, newEventManager } from './event_manager';\nimport { SyncEngine } from './sync_engine';\nimport {\n  newSyncEngine,\n  syncEngineApplyActiveTargetsChange,\n  syncEngineApplyBatchState,\n  syncEngineApplyOnlineStateChange,\n  syncEngineApplyPrimaryState,\n  syncEngineApplyTargetState,\n  syncEngineEnsureWriteCallbacks,\n  syncEngineGetActiveClients,\n  syncEngineHandleCredentialChange,\n  syncEngineSynchronizeWithChangedDocuments\n} from './sync_engine_impl';\nimport { OnlineStateSource } from './types';\n\ntype Kind = 'memory' | 'persistent';\n\nexport interface ComponentConfiguration {\n  asyncQueue: AsyncQueue;\n  databaseInfo: DatabaseInfo;\n  authCredentials: CredentialsProvider<User>;\n  appCheckCredentials: CredentialsProvider<string>;\n  clientId: ClientId;\n  initialUser: User;\n  maxConcurrentLimboResolutions: number;\n}\n\nexport interface OfflineComponentProviderFactory {\n  build(onlineComponents: OnlineComponentProvider): OfflineComponentProvider;\n}\n\n/**\n * Initializes and wires components that are needed to interface with the local\n * cache. Implementations override `initialize()` to provide all components.\n */\nexport interface OfflineComponentProvider {\n  readonly kind: Kind;\n  persistence: Persistence;\n  sharedClientState: SharedClientState;\n  localStore: LocalStore;\n  gcScheduler: Scheduler | null;\n  indexBackfillerScheduler: Scheduler | null;\n  synchronizeTabs: boolean;\n\n  initialize(cfg: ComponentConfiguration): Promise<void>;\n\n  terminate(): Promise<void>;\n}\n\n/**\n * Provides all components needed for Firestore with in-memory persistence.\n * Uses EagerGC garbage collection.\n */\nexport class MemoryOfflineComponentProvider\n  implements OfflineComponentProvider\n{\n  kind: Kind = 'memory';\n\n  static readonly provider: OfflineComponentProviderFactory = {\n    build: () => new MemoryOfflineComponentProvider()\n  };\n\n  persistence!: Persistence;\n  sharedClientState!: SharedClientState;\n  localStore!: LocalStore;\n  gcScheduler!: Scheduler | null;\n  indexBackfillerScheduler!: Scheduler | null;\n  synchronizeTabs = false;\n\n  serializer!: JsonProtoSerializer;\n\n  async initialize(cfg: ComponentConfiguration): Promise<void> {\n    this.serializer = newSerializer(cfg.databaseInfo.databaseId);\n    this.sharedClientState = this.createSharedClientState(cfg);\n    this.persistence = this.createPersistence(cfg);\n    await this.persistence.start();\n    this.localStore = this.createLocalStore(cfg);\n    this.gcScheduler = this.createGarbageCollectionScheduler(\n      cfg,\n      this.localStore\n    );\n    this.indexBackfillerScheduler = this.createIndexBackfillerScheduler(\n      cfg,\n      this.localStore\n    );\n  }\n\n  createGarbageCollectionScheduler(\n    cfg: ComponentConfiguration,\n    localStore: LocalStore\n  ): Scheduler | null {\n    return null;\n  }\n\n  createIndexBackfillerScheduler(\n    cfg: ComponentConfiguration,\n    localStore: LocalStore\n  ): Scheduler | null {\n    return null;\n  }\n\n  createLocalStore(cfg: ComponentConfiguration): LocalStore {\n    return newLocalStore(\n      this.persistence,\n      new QueryEngine(),\n      cfg.initialUser,\n      this.serializer\n    );\n  }\n\n  createPersistence(cfg: ComponentConfiguration): Persistence {\n    return new MemoryPersistence(MemoryEagerDelegate.factory, this.serializer);\n  }\n\n  createSharedClientState(cfg: ComponentConfiguration): SharedClientState {\n    return new MemorySharedClientState();\n  }\n\n  async terminate(): Promise<void> {\n    this.gcScheduler?.stop();\n    this.indexBackfillerScheduler?.stop();\n    this.sharedClientState.shutdown();\n    await this.persistence.shutdown();\n  }\n}\n\nexport class LruGcMemoryOfflineComponentProvider extends MemoryOfflineComponentProvider {\n  constructor(protected readonly cacheSizeBytes: number | undefined) {\n    super();\n  }\n\n  createGarbageCollectionScheduler(\n    cfg: ComponentConfiguration,\n    localStore: LocalStore\n  ): Scheduler | null {\n    hardAssert(\n      this.persistence.referenceDelegate instanceof MemoryLruDelegate,\n      'referenceDelegate is expected to be an instance of MemoryLruDelegate.'\n    );\n\n    const garbageCollector =\n      this.persistence.referenceDelegate.garbageCollector;\n    return new LruScheduler(garbageCollector, cfg.asyncQueue, localStore);\n  }\n\n  createPersistence(cfg: ComponentConfiguration): Persistence {\n    const lruParams =\n      this.cacheSizeBytes !== undefined\n        ? LruParams.withCacheSize(this.cacheSizeBytes)\n        : LruParams.DEFAULT;\n    return new MemoryPersistence(\n      p => MemoryLruDelegate.factory(p, lruParams),\n      this.serializer\n    );\n  }\n}\n\n/**\n * Provides all components needed for Firestore with IndexedDB persistence.\n */\nexport class IndexedDbOfflineComponentProvider extends MemoryOfflineComponentProvider {\n  kind: Kind = 'persistent';\n  persistence!: IndexedDbPersistence;\n  sharedClientState!: SharedClientState;\n  localStore!: LocalStore;\n  gcScheduler!: Scheduler | null;\n  indexBackfillerScheduler!: Scheduler | null;\n  synchronizeTabs = false;\n\n  constructor(\n    protected readonly onlineComponentProvider: OnlineComponentProvider,\n    protected readonly cacheSizeBytes: number | undefined,\n    protected readonly forceOwnership: boolean | undefined\n  ) {\n    super();\n  }\n\n  async initialize(cfg: ComponentConfiguration): Promise<void> {\n    await super.initialize(cfg);\n\n    await this.onlineComponentProvider.initialize(this, cfg);\n\n    // Enqueue writes from a previous session\n    await syncEngineEnsureWriteCallbacks(\n      this.onlineComponentProvider.syncEngine\n    );\n    await fillWritePipeline(this.onlineComponentProvider.remoteStore);\n\n    // NOTE: This will immediately call the listener, so we make sure to\n    // set it after localStore / remoteStore are started.\n    await this.persistence.setPrimaryStateListener(() => {\n      if (this.gcScheduler && !this.gcScheduler.started) {\n        this.gcScheduler.start();\n      }\n      if (\n        this.indexBackfillerScheduler &&\n        !this.indexBackfillerScheduler.started\n      ) {\n        this.indexBackfillerScheduler.start();\n      }\n      return Promise.resolve();\n    });\n  }\n\n  createLocalStore(cfg: ComponentConfiguration): LocalStore {\n    return newLocalStore(\n      this.persistence,\n      new QueryEngine(),\n      cfg.initialUser,\n      this.serializer\n    );\n  }\n\n  createGarbageCollectionScheduler(\n    cfg: ComponentConfiguration,\n    localStore: LocalStore\n  ): Scheduler | null {\n    const garbageCollector =\n      this.persistence.referenceDelegate.garbageCollector;\n    return new LruScheduler(garbageCollector, cfg.asyncQueue, localStore);\n  }\n\n  createIndexBackfillerScheduler(\n    cfg: ComponentConfiguration,\n    localStore: LocalStore\n  ): Scheduler | null {\n    const indexBackfiller = new IndexBackfiller(localStore, this.persistence);\n    return new IndexBackfillerScheduler(cfg.asyncQueue, indexBackfiller);\n  }\n\n  createPersistence(cfg: ComponentConfiguration): IndexedDbPersistence {\n    const persistenceKey = indexedDbStoragePrefix(\n      cfg.databaseInfo.databaseId,\n      cfg.databaseInfo.persistenceKey\n    );\n    const lruParams =\n      this.cacheSizeBytes !== undefined\n        ? LruParams.withCacheSize(this.cacheSizeBytes)\n        : LruParams.DEFAULT;\n\n    return new IndexedDbPersistence(\n      this.synchronizeTabs,\n      persistenceKey,\n      cfg.clientId,\n      lruParams,\n      cfg.asyncQueue,\n      getWindow(),\n      getDocument(),\n      this.serializer,\n      this.sharedClientState,\n      !!this.forceOwnership\n    );\n  }\n\n  createSharedClientState(cfg: ComponentConfiguration): SharedClientState {\n    return new MemorySharedClientState();\n  }\n}\n\n/**\n * Provides all components needed for Firestore with multi-tab IndexedDB\n * persistence.\n *\n * In the legacy client, this provider is used to provide both multi-tab and\n * non-multi-tab persistence since we cannot tell at build time whether\n * `synchronizeTabs` will be enabled.\n */\nexport class MultiTabOfflineComponentProvider extends IndexedDbOfflineComponentProvider {\n  synchronizeTabs = true;\n\n  constructor(\n    protected readonly onlineComponentProvider: OnlineComponentProvider,\n    protected readonly cacheSizeBytes: number | undefined\n  ) {\n    super(onlineComponentProvider, cacheSizeBytes, /* forceOwnership= */ false);\n  }\n\n  async initialize(cfg: ComponentConfiguration): Promise<void> {\n    await super.initialize(cfg);\n\n    const syncEngine = this.onlineComponentProvider.syncEngine;\n\n    if (this.sharedClientState instanceof WebStorageSharedClientState) {\n      this.sharedClientState.syncEngine = {\n        applyBatchState: syncEngineApplyBatchState.bind(null, syncEngine),\n        applyTargetState: syncEngineApplyTargetState.bind(null, syncEngine),\n        applyActiveTargetsChange: syncEngineApplyActiveTargetsChange.bind(\n          null,\n          syncEngine\n        ),\n        getActiveClients: syncEngineGetActiveClients.bind(null, syncEngine),\n        synchronizeWithChangedDocuments:\n          syncEngineSynchronizeWithChangedDocuments.bind(null, syncEngine)\n      };\n      await this.sharedClientState.start();\n    }\n\n    // NOTE: This will immediately call the listener, so we make sure to\n    // set it after localStore / remoteStore are started.\n    await this.persistence.setPrimaryStateListener(async isPrimary => {\n      await syncEngineApplyPrimaryState(\n        this.onlineComponentProvider.syncEngine,\n        isPrimary\n      );\n      if (this.gcScheduler) {\n        if (isPrimary && !this.gcScheduler.started) {\n          this.gcScheduler.start();\n        } else if (!isPrimary) {\n          this.gcScheduler.stop();\n        }\n      }\n      if (this.indexBackfillerScheduler) {\n        if (isPrimary && !this.indexBackfillerScheduler.started) {\n          this.indexBackfillerScheduler.start();\n        } else if (!isPrimary) {\n          this.indexBackfillerScheduler.stop();\n        }\n      }\n    });\n  }\n\n  createSharedClientState(cfg: ComponentConfiguration): SharedClientState {\n    const window = getWindow();\n    if (!WebStorageSharedClientState.isAvailable(window)) {\n      throw new FirestoreError(\n        Code.UNIMPLEMENTED,\n        'IndexedDB persistence is only available on platforms that support LocalStorage.'\n      );\n    }\n    const persistenceKey = indexedDbStoragePrefix(\n      cfg.databaseInfo.databaseId,\n      cfg.databaseInfo.persistenceKey\n    );\n    return new WebStorageSharedClientState(\n      window,\n      cfg.asyncQueue,\n      persistenceKey,\n      cfg.clientId,\n      cfg.initialUser\n    );\n  }\n}\n\nexport interface OnlineComponentProviderFactory {\n  build(): OnlineComponentProvider;\n}\n\n/**\n * Initializes and wires the components that are needed to interface with the\n * network.\n */\nexport class OnlineComponentProvider {\n  static readonly provider: OnlineComponentProviderFactory = {\n    build: () => new OnlineComponentProvider()\n  };\n\n  protected localStore!: LocalStore;\n  protected sharedClientState!: SharedClientState;\n  datastore!: Datastore;\n  eventManager!: EventManager;\n  remoteStore!: RemoteStore;\n  syncEngine!: SyncEngine;\n\n  async initialize(\n    offlineComponentProvider: OfflineComponentProvider,\n    cfg: ComponentConfiguration\n  ): Promise<void> {\n    if (this.localStore) {\n      // OnlineComponentProvider may get initialized multiple times if\n      // multi-tab persistence is used.\n      return;\n    }\n\n    this.localStore = offlineComponentProvider.localStore;\n    this.sharedClientState = offlineComponentProvider.sharedClientState;\n    this.datastore = this.createDatastore(cfg);\n    this.remoteStore = this.createRemoteStore(cfg);\n    this.eventManager = this.createEventManager(cfg);\n    this.syncEngine = this.createSyncEngine(\n      cfg,\n      /* startAsPrimary=*/ !offlineComponentProvider.synchronizeTabs\n    );\n\n    this.sharedClientState.onlineStateHandler = onlineState =>\n      syncEngineApplyOnlineStateChange(\n        this.syncEngine,\n        onlineState,\n        OnlineStateSource.SharedClientState\n      );\n\n    this.remoteStore.remoteSyncer.handleCredentialChange =\n      syncEngineHandleCredentialChange.bind(null, this.syncEngine);\n\n    await remoteStoreApplyPrimaryState(\n      this.remoteStore,\n      this.syncEngine.isPrimaryClient\n    );\n  }\n\n  createEventManager(cfg: ComponentConfiguration): EventManager {\n    return newEventManager();\n  }\n\n  createDatastore(cfg: ComponentConfiguration): Datastore {\n    const serializer = newSerializer(cfg.databaseInfo.databaseId);\n    const connection = newConnection(cfg.databaseInfo);\n    return newDatastore(\n      cfg.authCredentials,\n      cfg.appCheckCredentials,\n      connection,\n      serializer\n    );\n  }\n\n  createRemoteStore(cfg: ComponentConfiguration): RemoteStore {\n    return newRemoteStore(\n      this.localStore,\n      this.datastore,\n      cfg.asyncQueue,\n      onlineState =>\n        syncEngineApplyOnlineStateChange(\n          this.syncEngine,\n          onlineState,\n          OnlineStateSource.RemoteStore\n        ),\n      newConnectivityMonitor()\n    );\n  }\n\n  createSyncEngine(\n    cfg: ComponentConfiguration,\n    startAsPrimary: boolean\n  ): SyncEngine {\n    return newSyncEngine(\n      this.localStore,\n      this.remoteStore,\n      this.eventManager,\n      this.sharedClientState,\n      cfg.initialUser,\n      cfg.maxConcurrentLimboResolutions,\n      startAsPrimary\n    );\n  }\n\n  async terminate(): Promise<void> {\n    await remoteStoreShutdown(this.remoteStore);\n    this.datastore?.terminate();\n    this.eventManager?.terminate();\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 { DatabaseInfo } from '../../core/database_info';\nimport { Connection } from '../../remote/connection';\nimport { ConnectivityMonitor } from '../../remote/connectivity_monitor';\nimport { NoopConnectivityMonitor } from '../../remote/connectivity_monitor_noop';\n\nimport { BrowserConnectivityMonitor } from './connectivity_monitor';\nimport { WebChannelConnection } from './webchannel_connection';\n\n/** Initializes the WebChannelConnection for the browser. */\nexport function newConnection(databaseInfo: DatabaseInfo): Connection {\n  return new WebChannelConnection(databaseInfo);\n}\n\n/** Return the Platform-specific connectivity monitor. */\nexport function newConnectivityMonitor(): ConnectivityMonitor {\n  if (BrowserConnectivityMonitor.isAvailable()) {\n    return new BrowserConnectivityMonitor();\n  } else {\n    return new NoopConnectivityMonitor();\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 { Observer } from '../core/event_manager';\n\nimport { FirestoreError } from './error';\nimport { logError } from './log';\nimport { EventHandler } from './misc';\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 */\nexport class AsyncObserver<T> implements Observer<T> {\n  /**\n   * When set to true, will not raise future events. Necessary to deal with\n   * async detachment of listener.\n   */\n  private muted = false;\n\n  constructor(private observer: Partial<Observer<T>>) {}\n\n  next(value: T): void {\n    if (this.muted) {\n      return;\n    }\n    if (this.observer.next) {\n      this.scheduleEvent(this.observer.next, value);\n    }\n  }\n\n  error(error: FirestoreError): void {\n    if (this.muted) {\n      return;\n    }\n    if (this.observer.error) {\n      this.scheduleEvent(this.observer.error, error);\n    } else {\n      logError('Uncaught Error in snapshot listener:', error.toString());\n    }\n  }\n\n  mute(): void {\n    this.muted = true;\n  }\n\n  private scheduleEvent<E>(eventHandler: EventHandler<E>, event: E): void {\n    setTimeout(() => {\n      if (!this.muted) {\n        eventHandler(event);\n      }\n    }, 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\nimport { GetOptions } from '@firebase/firestore-types';\n\nimport { LoadBundleTask } from '../api/bundle';\nimport {\n  CredentialChangeListener,\n  CredentialsProvider\n} from '../api/credentials';\nimport { User } from '../auth/user';\nimport { LocalStore } from '../local/local_store';\nimport {\n  localStoreConfigureFieldIndexes,\n  localStoreDeleteAllFieldIndexes,\n  localStoreExecuteQuery,\n  localStoreGetNamedQuery,\n  localStoreHandleUserChange,\n  localStoreReadDocument,\n  localStoreSetIndexAutoCreationEnabled\n} from '../local/local_store_impl';\nimport { Persistence } from '../local/persistence';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldIndex } from '../model/field_index';\nimport { Mutation } from '../model/mutation';\nimport { toByteStreamReader } from '../platform/byte_stream_reader';\nimport { newSerializer } from '../platform/serializer';\nimport { newTextEncoder } from '../platform/text_serializer';\nimport { ApiClientObjectMap, Value } from '../protos/firestore_proto_api';\nimport { Datastore, invokeRunAggregationQueryRpc } from '../remote/datastore';\nimport {\n  RemoteStore,\n  remoteStoreDisableNetwork,\n  remoteStoreEnableNetwork,\n  remoteStoreHandleCredentialChange\n} from '../remote/remote_store';\nimport { JsonProtoSerializer } from '../remote/serializer';\nimport { debugAssert } from '../util/assert';\nimport { AsyncObserver } from '../util/async_observer';\nimport { AsyncQueue, wrapInUserErrorIfRecoverable } from '../util/async_queue';\nimport { BundleReader } from '../util/bundle_reader';\nimport { newBundleReader } from '../util/bundle_reader_impl';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug, logWarn } from '../util/log';\nimport { AutoId } from '../util/misc';\nimport { Deferred } from '../util/promise';\n\nimport { Aggregate } from './aggregate';\nimport { NamedQuery } from './bundle';\nimport {\n  ComponentConfiguration,\n  LruGcMemoryOfflineComponentProvider,\n  MemoryOfflineComponentProvider,\n  OfflineComponentProvider,\n  OnlineComponentProvider\n} from './component_provider';\nimport { DatabaseId, DatabaseInfo } from './database_info';\nimport {\n  addSnapshotsInSyncListener,\n  EventManager,\n  eventManagerListen,\n  eventManagerUnlisten,\n  ListenOptions,\n  Observer,\n  QueryListener,\n  removeSnapshotsInSyncListener\n} from './event_manager';\nimport { newQueryForPath, Query } from './query';\nimport { SyncEngine } from './sync_engine';\nimport {\n  syncEngineListen,\n  syncEngineLoadBundle,\n  syncEngineRegisterPendingWritesCallback,\n  syncEngineUnlisten,\n  syncEngineWrite,\n  triggerRemoteStoreListen,\n  triggerRemoteStoreUnlisten\n} from './sync_engine_impl';\nimport { Transaction } from './transaction';\nimport { TransactionOptions } from './transaction_options';\nimport { TransactionRunner } from './transaction_runner';\nimport { View } from './view';\nimport { ViewSnapshot } from './view_snapshot';\n\nconst LOG_TAG = 'FirestoreClient';\nexport const MAX_CONCURRENT_LIMBO_RESOLUTIONS = 100;\n\n/** DOMException error code constants. */\nconst DOM_EXCEPTION_INVALID_STATE = 11;\nconst DOM_EXCEPTION_ABORTED = 20;\nconst DOM_EXCEPTION_QUOTA_EXCEEDED = 22;\n\n/**\n * FirestoreClient is a top-level class that constructs and owns all of the //\n * pieces of the client SDK architecture. It is responsible for creating the //\n * async queue that is shared by all of the other components in the system. //\n */\nexport class FirestoreClient {\n  private user = User.UNAUTHENTICATED;\n  private readonly clientId = AutoId.newId();\n  private authCredentialListener: CredentialChangeListener<User> = () =>\n    Promise.resolve();\n  private appCheckCredentialListener: (\n    appCheckToken: string,\n    user: User\n  ) => Promise<void> = () => Promise.resolve();\n  _uninitializedComponentsProvider?: {\n    _offline: OfflineComponentProvider;\n    _online: OnlineComponentProvider;\n  };\n\n  _offlineComponents?: OfflineComponentProvider;\n  _onlineComponents?: OnlineComponentProvider;\n\n  constructor(\n    private authCredentials: CredentialsProvider<User>,\n    private appCheckCredentials: CredentialsProvider<string>,\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    public asyncQueue: AsyncQueue,\n    private databaseInfo: DatabaseInfo,\n    componentProvider?: {\n      _offline: OfflineComponentProvider;\n      _online: OnlineComponentProvider;\n    }\n  ) {\n    this._uninitializedComponentsProvider = componentProvider;\n    this.authCredentials.start(asyncQueue, async user => {\n      logDebug(LOG_TAG, 'Received user=', user.uid);\n      await this.authCredentialListener(user);\n      this.user = user;\n    });\n    this.appCheckCredentials.start(asyncQueue, newAppCheckToken => {\n      logDebug(LOG_TAG, 'Received new app check token=', newAppCheckToken);\n      return this.appCheckCredentialListener(newAppCheckToken, this.user);\n    });\n  }\n\n  get configuration(): ComponentConfiguration {\n    return {\n      asyncQueue: this.asyncQueue,\n      databaseInfo: this.databaseInfo,\n      clientId: this.clientId,\n      authCredentials: this.authCredentials,\n      appCheckCredentials: this.appCheckCredentials,\n      initialUser: this.user,\n      maxConcurrentLimboResolutions: MAX_CONCURRENT_LIMBO_RESOLUTIONS\n    };\n  }\n\n  setCredentialChangeListener(listener: (user: User) => Promise<void>): void {\n    this.authCredentialListener = listener;\n  }\n\n  setAppCheckTokenChangeListener(\n    listener: (appCheckToken: string, user: User) => Promise<void>\n  ): void {\n    this.appCheckCredentialListener = listener;\n  }\n\n  terminate(): Promise<void> {\n    this.asyncQueue.enterRestrictedMode();\n    const deferred = new Deferred();\n    this.asyncQueue.enqueueAndForgetEvenWhileRestricted(async () => {\n      try {\n        if (this._onlineComponents) {\n          await this._onlineComponents.terminate();\n        }\n        if (this._offlineComponents) {\n          await this._offlineComponents.terminate();\n        }\n\n        // The credentials provider must be terminated after shutting down the\n        // RemoteStore as it will prevent the RemoteStore from retrieving auth\n        // tokens.\n        this.authCredentials.shutdown();\n        this.appCheckCredentials.shutdown();\n        deferred.resolve();\n      } catch (e) {\n        const firestoreError = wrapInUserErrorIfRecoverable(\n          e as Error,\n          `Failed to shutdown persistence`\n        );\n        deferred.reject(firestoreError);\n      }\n    });\n    return deferred.promise;\n  }\n}\n\nexport async function setOfflineComponentProvider(\n  client: FirestoreClient,\n  offlineComponentProvider: OfflineComponentProvider\n): Promise<void> {\n  client.asyncQueue.verifyOperationInProgress();\n\n  logDebug(LOG_TAG, 'Initializing OfflineComponentProvider');\n  const configuration = client.configuration;\n  await offlineComponentProvider.initialize(configuration);\n\n  let currentUser = configuration.initialUser;\n  client.setCredentialChangeListener(async user => {\n    if (!currentUser.isEqual(user)) {\n      await localStoreHandleUserChange(\n        offlineComponentProvider.localStore,\n        user\n      );\n      currentUser = user;\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  offlineComponentProvider.persistence.setDatabaseDeletedListener(() =>\n    client.terminate()\n  );\n\n  client._offlineComponents = offlineComponentProvider;\n}\n\nexport async function setOnlineComponentProvider(\n  client: FirestoreClient,\n  onlineComponentProvider: OnlineComponentProvider\n): Promise<void> {\n  client.asyncQueue.verifyOperationInProgress();\n\n  const offlineComponents = await ensureOfflineComponents(client);\n\n  logDebug(LOG_TAG, 'Initializing OnlineComponentProvider');\n  await onlineComponentProvider.initialize(\n    offlineComponents,\n    client.configuration\n  );\n  // The CredentialChangeListener of the online component provider takes\n  // precedence over the offline component provider.\n  client.setCredentialChangeListener(user =>\n    remoteStoreHandleCredentialChange(onlineComponentProvider.remoteStore, user)\n  );\n  client.setAppCheckTokenChangeListener((_, user) =>\n    remoteStoreHandleCredentialChange(onlineComponentProvider.remoteStore, user)\n  );\n  client._onlineComponents = onlineComponentProvider;\n}\n\n/**\n * Decides whether the provided error allows us to gracefully disable\n * persistence (as opposed to crashing the client).\n */\nexport function canFallbackFromIndexedDbError(\n  error: FirestoreError | DOMException\n): boolean {\n  if (error.name === 'FirebaseError') {\n    return (\n      error.code === Code.FAILED_PRECONDITION ||\n      error.code === Code.UNIMPLEMENTED\n    );\n  } else if (\n    typeof DOMException !== 'undefined' &&\n    error instanceof DOMException\n  ) {\n    // There are a few known circumstances where we can open IndexedDb but\n    // trying to read/write will fail (e.g. quota exceeded). For\n    // well-understood cases, we attempt to detect these and then gracefully\n    // fall back to memory persistence.\n    // NOTE: Rather than continue to add to this list, we could decide to\n    // always fall back, with the risk that we might accidentally hide errors\n    // representing actual SDK bugs.\n    return (\n      // When the browser is out of quota we could get either quota exceeded\n      // or an aborted error depending on whether the error happened during\n      // schema migration.\n      error.code === DOM_EXCEPTION_QUOTA_EXCEEDED ||\n      error.code === DOM_EXCEPTION_ABORTED ||\n      // Firefox Private Browsing mode disables IndexedDb and returns\n      // INVALID_STATE for any usage.\n      error.code === DOM_EXCEPTION_INVALID_STATE\n    );\n  }\n\n  return true;\n}\n\nasync function ensureOfflineComponents(\n  client: FirestoreClient\n): Promise<OfflineComponentProvider> {\n  if (!client._offlineComponents) {\n    if (client._uninitializedComponentsProvider) {\n      logDebug(LOG_TAG, 'Using user provided OfflineComponentProvider');\n      try {\n        await setOfflineComponentProvider(\n          client,\n          client._uninitializedComponentsProvider._offline\n        );\n      } catch (e) {\n        const error = e as FirestoreError | DOMException;\n        if (!canFallbackFromIndexedDbError(error)) {\n          throw error;\n        }\n        logWarn(\n          'Error using user provided cache. Falling back to ' +\n            'memory cache: ' +\n            error\n        );\n        await setOfflineComponentProvider(\n          client,\n          new MemoryOfflineComponentProvider()\n        );\n      }\n    } else {\n      logDebug(LOG_TAG, 'Using default OfflineComponentProvider');\n      await setOfflineComponentProvider(\n        client,\n        new LruGcMemoryOfflineComponentProvider(undefined)\n      );\n    }\n  }\n\n  return client._offlineComponents!;\n}\n\nasync function ensureOnlineComponents(\n  client: FirestoreClient\n): Promise<OnlineComponentProvider> {\n  if (!client._onlineComponents) {\n    if (client._uninitializedComponentsProvider) {\n      logDebug(LOG_TAG, 'Using user provided OnlineComponentProvider');\n      await setOnlineComponentProvider(\n        client,\n        client._uninitializedComponentsProvider._online\n      );\n    } else {\n      logDebug(LOG_TAG, 'Using default OnlineComponentProvider');\n      await setOnlineComponentProvider(client, new OnlineComponentProvider());\n    }\n  }\n\n  return client._onlineComponents!;\n}\n\nfunction getPersistence(client: FirestoreClient): Promise<Persistence> {\n  return ensureOfflineComponents(client).then(c => c.persistence);\n}\n\nexport function getLocalStore(client: FirestoreClient): Promise<LocalStore> {\n  return ensureOfflineComponents(client).then(c => c.localStore);\n}\n\nfunction getRemoteStore(client: FirestoreClient): Promise<RemoteStore> {\n  return ensureOnlineComponents(client).then(c => c.remoteStore);\n}\n\nexport function getSyncEngine(client: FirestoreClient): Promise<SyncEngine> {\n  return ensureOnlineComponents(client).then(c => c.syncEngine);\n}\n\nfunction getDatastore(client: FirestoreClient): Promise<Datastore> {\n  return ensureOnlineComponents(client).then(c => c.datastore);\n}\n\nexport async function getEventManager(\n  client: FirestoreClient\n): Promise<EventManager> {\n  const onlineComponentProvider = await ensureOnlineComponents(client);\n  const eventManager = onlineComponentProvider.eventManager;\n  eventManager.onListen = syncEngineListen.bind(\n    null,\n    onlineComponentProvider.syncEngine\n  );\n  eventManager.onUnlisten = syncEngineUnlisten.bind(\n    null,\n    onlineComponentProvider.syncEngine\n  );\n  eventManager.onFirstRemoteStoreListen = triggerRemoteStoreListen.bind(\n    null,\n    onlineComponentProvider.syncEngine\n  );\n  eventManager.onLastRemoteStoreUnlisten = triggerRemoteStoreUnlisten.bind(\n    null,\n    onlineComponentProvider.syncEngine\n  );\n  return eventManager;\n}\n\n/** Enables the network connection and re-enqueues all pending operations. */\nexport function firestoreClientEnableNetwork(\n  client: FirestoreClient\n): Promise<void> {\n  return client.asyncQueue.enqueue(async () => {\n    const persistence = await getPersistence(client);\n    const remoteStore = await getRemoteStore(client);\n    persistence.setNetworkEnabled(true);\n    return remoteStoreEnableNetwork(remoteStore);\n  });\n}\n\n/** Disables the network connection. Pending operations will not complete. */\nexport function firestoreClientDisableNetwork(\n  client: FirestoreClient\n): Promise<void> {\n  return client.asyncQueue.enqueue(async () => {\n    const persistence = await getPersistence(client);\n    const remoteStore = await getRemoteStore(client);\n    persistence.setNetworkEnabled(false);\n    return remoteStoreDisableNetwork(remoteStore);\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 */\nexport function firestoreClientWaitForPendingWrites(\n  client: FirestoreClient\n): Promise<void> {\n  const deferred = new Deferred<void>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const syncEngine = await getSyncEngine(client);\n    return syncEngineRegisterPendingWritesCallback(syncEngine, deferred);\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientListen(\n  client: FirestoreClient,\n  query: Query,\n  options: ListenOptions,\n  observer: Partial<Observer<ViewSnapshot>>\n): () => void {\n  const wrappedObserver = new AsyncObserver(observer);\n  const listener = new QueryListener(query, wrappedObserver, options);\n  client.asyncQueue.enqueueAndForget(async () => {\n    const eventManager = await getEventManager(client);\n    return eventManagerListen(eventManager, listener);\n  });\n  return () => {\n    wrappedObserver.mute();\n    client.asyncQueue.enqueueAndForget(async () => {\n      const eventManager = await getEventManager(client);\n      return eventManagerUnlisten(eventManager, listener);\n    });\n  };\n}\n\nexport function firestoreClientGetDocumentFromLocalCache(\n  client: FirestoreClient,\n  docKey: DocumentKey\n): Promise<Document | null> {\n  const deferred = new Deferred<Document | null>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const localStore = await getLocalStore(client);\n    return readDocumentFromCache(localStore, docKey, deferred);\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientGetDocumentViaSnapshotListener(\n  client: FirestoreClient,\n  key: DocumentKey,\n  options: GetOptions = {}\n): Promise<ViewSnapshot> {\n  const deferred = new Deferred<ViewSnapshot>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const eventManager = await getEventManager(client);\n    return readDocumentViaSnapshotListener(\n      eventManager,\n      client.asyncQueue,\n      key,\n      options,\n      deferred\n    );\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientGetDocumentsFromLocalCache(\n  client: FirestoreClient,\n  query: Query\n): Promise<ViewSnapshot> {\n  const deferred = new Deferred<ViewSnapshot>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const localStore = await getLocalStore(client);\n    return executeQueryFromCache(localStore, query, deferred);\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientGetDocumentsViaSnapshotListener(\n  client: FirestoreClient,\n  query: Query,\n  options: GetOptions = {}\n): Promise<ViewSnapshot> {\n  const deferred = new Deferred<ViewSnapshot>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const eventManager = await getEventManager(client);\n    return executeQueryViaSnapshotListener(\n      eventManager,\n      client.asyncQueue,\n      query,\n      options,\n      deferred\n    );\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientRunAggregateQuery(\n  client: FirestoreClient,\n  query: Query,\n  aggregates: Aggregate[]\n): Promise<ApiClientObjectMap<Value>> {\n  const deferred = new Deferred<ApiClientObjectMap<Value>>();\n\n  client.asyncQueue.enqueueAndForget(async () => {\n    // Implement and call executeAggregateQueryViaSnapshotListener, similar\n    // to the implementation in firestoreClientGetDocumentsViaSnapshotListener\n    // above\n    try {\n      // TODO(b/277628384): check `canUseNetwork()` and handle multi-tab.\n      const datastore = await getDatastore(client);\n      deferred.resolve(\n        invokeRunAggregationQueryRpc(datastore, query, aggregates)\n      );\n    } catch (e) {\n      deferred.reject(e as Error);\n    }\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientWrite(\n  client: FirestoreClient,\n  mutations: Mutation[]\n): Promise<void> {\n  const deferred = new Deferred<void>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const syncEngine = await getSyncEngine(client);\n    return syncEngineWrite(syncEngine, mutations, deferred);\n  });\n  return deferred.promise;\n}\n\nexport function firestoreClientAddSnapshotsInSyncListener(\n  client: FirestoreClient,\n  observer: Partial<Observer<void>>\n): () => void {\n  const wrappedObserver = new AsyncObserver(observer);\n  client.asyncQueue.enqueueAndForget(async () => {\n    const eventManager = await getEventManager(client);\n    return addSnapshotsInSyncListener(eventManager, wrappedObserver);\n  });\n  return () => {\n    wrappedObserver.mute();\n    client.asyncQueue.enqueueAndForget(async () => {\n      const eventManager = await getEventManager(client);\n      return removeSnapshotsInSyncListener(eventManager, wrappedObserver);\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 */\nexport function firestoreClientTransaction<T>(\n  client: FirestoreClient,\n  updateFunction: (transaction: Transaction) => Promise<T>,\n  options: TransactionOptions\n): Promise<T> {\n  const deferred = new Deferred<T>();\n  client.asyncQueue.enqueueAndForget(async () => {\n    const datastore = await getDatastore(client);\n    new TransactionRunner<T>(\n      client.asyncQueue,\n      datastore,\n      options,\n      updateFunction,\n      deferred\n    ).run();\n  });\n  return deferred.promise;\n}\n\nasync function readDocumentFromCache(\n  localStore: LocalStore,\n  docKey: DocumentKey,\n  result: Deferred<Document | null>\n): Promise<void> {\n  try {\n    const document = await localStoreReadDocument(localStore, docKey);\n    if (document.isFoundDocument()) {\n      result.resolve(document);\n    } else if (document.isNoDocument()) {\n      result.resolve(null);\n    } else {\n      result.reject(\n        new FirestoreError(\n          Code.UNAVAILABLE,\n          'Failed to get document from cache. (However, this document may ' +\n            \"exist on the server. Run again without setting 'source' in \" +\n            'the GetOptions to attempt to retrieve the document from the ' +\n            'server.)'\n        )\n      );\n    }\n  } catch (e) {\n    const firestoreError = wrapInUserErrorIfRecoverable(\n      e as Error,\n      `Failed to get document '${docKey} from cache`\n    );\n    result.reject(firestoreError);\n  }\n}\n\n/**\n * Retrieves a latency-compensated document from the backend via a\n * SnapshotListener.\n */\nfunction readDocumentViaSnapshotListener(\n  eventManager: EventManager,\n  asyncQueue: AsyncQueue,\n  key: DocumentKey,\n  options: GetOptions,\n  result: Deferred<ViewSnapshot>\n): Promise<void> {\n  const wrappedObserver = new AsyncObserver({\n    next: (snap: ViewSnapshot) => {\n      // Mute and remove query first before passing event to user to avoid\n      // user actions affecting the now stale query.\n      wrappedObserver.mute();\n      asyncQueue.enqueueAndForget(() =>\n        eventManagerUnlisten(eventManager, listener)\n      );\n\n      const exists = snap.docs.has(key);\n      if (!exists && snap.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        result.reject(\n          new FirestoreError(\n            Code.UNAVAILABLE,\n            'Failed to get document because the client is offline.'\n          )\n        );\n      } else if (\n        exists &&\n        snap.fromCache &&\n        options &&\n        options.source === 'server'\n      ) {\n        result.reject(\n          new FirestoreError(\n            Code.UNAVAILABLE,\n            'Failed to get document from server. (However, this ' +\n              'document does exist in the local cache. Run again ' +\n              'without setting source to \"server\" to ' +\n              'retrieve the cached document.)'\n          )\n        );\n      } else {\n        debugAssert(\n          snap.docs.size <= 1,\n          'Expected zero or a single result on a document-only query'\n        );\n        result.resolve(snap);\n      }\n    },\n    error: e => result.reject(e)\n  });\n\n  const listener = new QueryListener(\n    newQueryForPath(key.path),\n    wrappedObserver,\n    {\n      includeMetadataChanges: true,\n      waitForSyncWhenOnline: true\n    }\n  );\n  return eventManagerListen(eventManager, listener);\n}\n\nasync function executeQueryFromCache(\n  localStore: LocalStore,\n  query: Query,\n  result: Deferred<ViewSnapshot>\n): Promise<void> {\n  try {\n    const queryResult = await localStoreExecuteQuery(\n      localStore,\n      query,\n      /* usePreviousResults= */ true\n    );\n    const view = new View(query, queryResult.remoteKeys);\n    const viewDocChanges = view.computeDocChanges(queryResult.documents);\n    const viewChange = view.applyChanges(\n      viewDocChanges,\n      /* limboResolutionEnabled= */ false\n    );\n    result.resolve(viewChange.snapshot!);\n  } catch (e) {\n    const firestoreError = wrapInUserErrorIfRecoverable(\n      e as Error,\n      `Failed to execute query '${query} against cache`\n    );\n    result.reject(firestoreError);\n  }\n}\n\n/**\n * Retrieves a latency-compensated query snapshot from the backend via a\n * SnapshotListener.\n */\nfunction executeQueryViaSnapshotListener(\n  eventManager: EventManager,\n  asyncQueue: AsyncQueue,\n  query: Query,\n  options: GetOptions,\n  result: Deferred<ViewSnapshot>\n): Promise<void> {\n  const wrappedObserver = new AsyncObserver<ViewSnapshot>({\n    next: snapshot => {\n      // Mute and remove query first before passing event to user to avoid\n      // user actions affecting the now stale query.\n      wrappedObserver.mute();\n      asyncQueue.enqueueAndForget(() =>\n        eventManagerUnlisten(eventManager, listener)\n      );\n\n      if (snapshot.fromCache && options.source === 'server') {\n        result.reject(\n          new FirestoreError(\n            Code.UNAVAILABLE,\n            'Failed to get documents from server. (However, these ' +\n              'documents may exist in the local cache. Run again ' +\n              'without setting source to \"server\" to ' +\n              'retrieve the cached documents.)'\n          )\n        );\n      } else {\n        result.resolve(snapshot);\n      }\n    },\n    error: e => result.reject(e)\n  });\n\n  const listener = new QueryListener(query, wrappedObserver, {\n    includeMetadataChanges: true,\n    waitForSyncWhenOnline: true\n  });\n  return eventManagerListen(eventManager, listener);\n}\n\nexport function firestoreClientLoadBundle(\n  client: FirestoreClient,\n  databaseId: DatabaseId,\n  data: ReadableStream<Uint8Array> | ArrayBuffer | string,\n  resultTask: LoadBundleTask\n): void {\n  const reader = createBundleReader(data, newSerializer(databaseId));\n  client.asyncQueue.enqueueAndForget(async () => {\n    syncEngineLoadBundle(await getSyncEngine(client), reader, resultTask);\n  });\n}\n\nexport function firestoreClientGetNamedQuery(\n  client: FirestoreClient,\n  queryName: string\n): Promise<NamedQuery | undefined> {\n  return client.asyncQueue.enqueue(async () =>\n    localStoreGetNamedQuery(await getLocalStore(client), queryName)\n  );\n}\n\nfunction createBundleReader(\n  data: ReadableStream<Uint8Array> | ArrayBuffer | string,\n  serializer: JsonProtoSerializer\n): BundleReader {\n  let content: ReadableStream<Uint8Array> | ArrayBuffer;\n  if (typeof data === 'string') {\n    content = newTextEncoder().encode(data);\n  } else {\n    content = data;\n  }\n  return newBundleReader(toByteStreamReader(content), serializer);\n}\n\nexport function firestoreClientSetIndexConfiguration(\n  client: FirestoreClient,\n  indexes: FieldIndex[]\n): Promise<void> {\n  return client.asyncQueue.enqueue(async () => {\n    return localStoreConfigureFieldIndexes(\n      await getLocalStore(client),\n      indexes\n    );\n  });\n}\n\nexport function firestoreClientSetPersistentCacheIndexAutoCreationEnabled(\n  client: FirestoreClient,\n  isEnabled: boolean\n): Promise<void> {\n  return client.asyncQueue.enqueue(async () => {\n    return localStoreSetIndexAutoCreationEnabled(\n      await getLocalStore(client),\n      isEnabled\n    );\n  });\n}\n\nexport function firestoreClientDeleteAllFieldIndexes(\n  client: FirestoreClient\n): Promise<void> {\n  return client.asyncQueue.enqueue(async () => {\n    return localStoreDeleteAllFieldIndexes(await getLocalStore(client));\n  });\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * Options that configure the SDK’s underlying network transport (WebChannel)\n * when long-polling is used.\n *\n * Note: This interface is \"experimental\" and is subject to change.\n *\n * See `FirestoreSettings.experimentalAutoDetectLongPolling`,\n * `FirestoreSettings.experimentalForceLongPolling`, and\n * `FirestoreSettings.experimentalLongPollingOptions`.\n */\nexport interface ExperimentalLongPollingOptions {\n  /**\n   * The desired maximum timeout interval, in seconds, to complete a\n   * long-polling GET response. Valid values are between 5 and 30, inclusive.\n   * Floating point values are allowed and will be rounded to the nearest\n   * millisecond.\n   *\n   * By default, when long-polling is used the \"hanging GET\" request sent by\n   * the client times out after 30 seconds. To request a different timeout\n   * from the server, set this setting with the desired timeout.\n   *\n   * Changing the default timeout may be useful, for example, if the buffering\n   * proxy that necessitated enabling long-polling in the first place has a\n   * shorter timeout for hanging GET requests, in which case setting the\n   * long-polling timeout to a shorter value, such as 25 seconds, may fix\n   * prematurely-closed hanging GET requests.\n   * For example, see https://github.com/firebase/firebase-js-sdk/issues/6987.\n   */\n  timeoutSeconds?: number;\n}\n\n/**\n * Compares two `ExperimentalLongPollingOptions` objects for equality.\n */\nexport function longPollingOptionsEqual(\n  options1: ExperimentalLongPollingOptions,\n  options2: ExperimentalLongPollingOptions\n): boolean {\n  return options1.timeoutSeconds === options2.timeoutSeconds;\n}\n\n/**\n * Creates and returns a new `ExperimentalLongPollingOptions` with the same\n * option values as the given instance.\n */\nexport function cloneLongPollingOptions(\n  options: ExperimentalLongPollingOptions\n): ExperimentalLongPollingOptions {\n  const clone: ExperimentalLongPollingOptions = {};\n\n  if (options.timeoutSeconds !== undefined) {\n    clone.timeoutSeconds = options.timeoutSeconds;\n  }\n\n  return clone;\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// eslint-disable-next-line import/no-extraneous-dependencies\nimport { _FirebaseService } from '@firebase/app';\n\nimport { CredentialsProvider } from '../api/credentials';\nimport { cloneLongPollingOptions } from '../api/long_polling_options';\nimport { User } from '../auth/user';\nimport { DatabaseId, DatabaseInfo } from '../core/database_info';\nimport { newConnection } from '../platform/connection';\nimport { newSerializer } from '../platform/serializer';\nimport { Datastore, newDatastore } from '../remote/datastore';\nimport { Code, FirestoreError } from '../util/error';\nimport { logDebug } from '../util/log';\n\nimport { FirestoreSettingsImpl } from './settings';\n\nexport const LOG_TAG = 'ComponentProvider';\n\n// The components module manages the lifetime of dependencies of the Firestore\n// client. Dependencies can be lazily constructed and only one exists per\n// Firestore instance.\n\n/**\n * An interface implemented by FirebaseFirestore that provides compatibility\n * with the usage in this file.\n *\n * This interface mainly exists to remove a cyclic dependency.\n */\nexport interface FirestoreService extends _FirebaseService {\n  _authCredentials: CredentialsProvider<User>;\n  _appCheckCredentials: CredentialsProvider<string>;\n  _persistenceKey: string;\n  _databaseId: DatabaseId;\n  _terminated: boolean;\n\n  _freezeSettings(): FirestoreSettingsImpl;\n}\n/**\n * An instance map that ensures only one Datastore exists per Firestore\n * instance.\n */\nconst datastoreInstances = new Map<FirestoreService, Datastore>();\n\n/**\n * Returns an initialized and started Datastore for the given Firestore\n * instance. Callers must invoke removeComponents() when the Firestore\n * instance is terminated.\n */\nexport function getDatastore(firestore: FirestoreService): Datastore {\n  if (firestore._terminated) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'The client has already been terminated.'\n    );\n  }\n  if (!datastoreInstances.has(firestore)) {\n    logDebug(LOG_TAG, 'Initializing Datastore');\n    const databaseInfo = makeDatabaseInfo(\n      firestore._databaseId,\n      firestore.app.options.appId || '',\n      firestore._persistenceKey,\n      firestore._freezeSettings()\n    );\n    const connection = newConnection(databaseInfo);\n    const serializer = newSerializer(firestore._databaseId);\n    const datastore = newDatastore(\n      firestore._authCredentials,\n      firestore._appCheckCredentials,\n      connection,\n      serializer\n    );\n\n    datastoreInstances.set(firestore, datastore);\n  }\n  return datastoreInstances.get(firestore)!;\n}\n\n/**\n * Removes all components associated with the provided instance. Must be called\n * when the `Firestore` instance is terminated.\n */\nexport function removeComponents(firestore: FirestoreService): void {\n  const datastore = datastoreInstances.get(firestore);\n  if (datastore) {\n    logDebug(LOG_TAG, 'Removing Datastore');\n    datastoreInstances.delete(firestore);\n    datastore.terminate();\n  }\n}\n\nexport function makeDatabaseInfo(\n  databaseId: DatabaseId,\n  appId: string,\n  persistenceKey: string,\n  settings: FirestoreSettingsImpl\n): DatabaseInfo {\n  return new DatabaseInfo(\n    databaseId,\n    appId,\n    persistenceKey,\n    settings.host,\n    settings.ssl,\n    settings.experimentalForceLongPolling,\n    settings.experimentalAutoDetectLongPolling,\n    cloneLongPollingOptions(settings.experimentalLongPollingOptions),\n    settings.useFetchStreams\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 { DocumentKey } from '../model/document_key';\nimport { ResourcePath } from '../model/path';\n\nimport { fail } from './assert';\nimport { Code, FirestoreError } from './error';\n\n/** Types accepted by validateType() and related methods for validation. */\nexport type ValidationType =\n  | 'undefined'\n  | 'object'\n  | 'function'\n  | 'boolean'\n  | 'number'\n  | 'string'\n  | 'non-empty string';\n\nexport function validateNonEmptyArgument(\n  functionName: string,\n  argumentName: string,\n  argument?: string\n): asserts argument is string {\n  if (!argument) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Function ${functionName}() cannot be called with an empty ${argumentName}.`\n    );\n  }\n}\n\n/**\n * Validates that two boolean options are not set at the same time.\n * @internal\n */\nexport function validateIsNotUsedTogether(\n  optionName1: string,\n  argument1: boolean | undefined,\n  optionName2: string,\n  argument2: boolean | undefined\n): void {\n  if (argument1 === true && argument2 === true) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `${optionName1} and ${optionName2} cannot be used together.`\n    );\n  }\n}\n\n/**\n * Validates that `path` refers to a document (indicated by the fact it contains\n * an even numbers of segments).\n */\nexport function validateDocumentPath(path: ResourcePath): void {\n  if (!DocumentKey.isDocumentKey(path)) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Invalid document reference. Document references must have an even number of segments, but ${path} has ${path.length}.`\n    );\n  }\n}\n\n/**\n * Validates that `path` refers to a collection (indicated by the fact it\n * contains an odd numbers of segments).\n */\nexport function validateCollectionPath(path: ResourcePath): void {\n  if (DocumentKey.isDocumentKey(path)) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Invalid collection reference. Collection references must have an odd number of segments, but ${path} has ${path.length}.`\n    );\n  }\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 */\nexport function isPlainObject(input: unknown): boolean {\n  return (\n    typeof input === 'object' &&\n    input !== null &&\n    (Object.getPrototypeOf(input) === Object.prototype ||\n      Object.getPrototypeOf(input) === null)\n  );\n}\n\n/** Returns a string describing the type / value of the provided input. */\nexport function valueDescription(input: unknown): string {\n  if (input === undefined) {\n    return 'undefined';\n  } else if (input === null) {\n    return 'null';\n  } else if (typeof input === 'string') {\n    if (input.length > 20) {\n      input = `${input.substring(0, 20)}...`;\n    }\n    return JSON.stringify(input);\n  } else if (typeof input === 'number' || typeof input === 'boolean') {\n    return '' + input;\n  } else if (typeof input === 'object') {\n    if (input instanceof Array) {\n      return 'an array';\n    } else {\n      const customObjectName = tryGetCustomObjectType(input!);\n      if (customObjectName) {\n        return `a custom ${customObjectName} object`;\n      } else {\n        return 'an object';\n      }\n    }\n  } else if (typeof input === 'function') {\n    return 'a function';\n  } else {\n    return fail('Unknown wrong type: ' + typeof input);\n  }\n}\n\n/** try to get the constructor name for an object. */\nexport function tryGetCustomObjectType(input: object): string | null {\n  if (input.constructor) {\n    return input.constructor.name;\n  }\n  return null;\n}\n\n/**\n * Casts `obj` to `T`, optionally unwrapping Compat types to expose the\n * underlying instance. Throws if  `obj` is not an instance of `T`.\n *\n * This cast is used in the Lite and Full SDK to verify instance types for\n * arguments passed to the public API.\n * @internal\n */\nexport function cast<T>(\n  obj: object,\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  constructor: { new (...args: any[]): T }\n): T | never {\n  if ('_delegate' in obj) {\n    // Unwrap Compat types\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    obj = (obj as any)._delegate;\n  }\n\n  if (!(obj instanceof constructor)) {\n    if (constructor.name === obj.constructor.name) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Type does not match the expected instance. Did you pass a ' +\n          `reference from a different Firestore SDK?`\n      );\n    } else {\n      const description = valueDescription(obj);\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `Expected type '${constructor.name}', but it was: ${description}`\n      );\n    }\n  }\n  return obj as T;\n}\n\nexport function validatePositiveNumber(functionName: string, n: number): void {\n  if (n <= 0) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Function ${functionName}() requires a positive number, but it was: ${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\nimport { FirestoreLocalCache } from '../api/cache_config';\nimport { CredentialsSettings } from '../api/credentials';\nimport {\n  ExperimentalLongPollingOptions,\n  cloneLongPollingOptions,\n  longPollingOptionsEqual\n} from '../api/long_polling_options';\nimport {\n  LRU_COLLECTION_DISABLED,\n  LRU_DEFAULT_CACHE_SIZE_BYTES\n} from '../local/lru_garbage_collector';\nimport { LRU_MINIMUM_CACHE_SIZE_BYTES } from '../local/lru_garbage_collector_impl';\nimport { Code, FirestoreError } from '../util/error';\nimport { validateIsNotUsedTogether } from '../util/input_validation';\n\n// settings() defaults:\nexport const DEFAULT_HOST = 'firestore.googleapis.com';\nexport const DEFAULT_SSL = true;\n\n// The minimum long-polling timeout is hardcoded on the server. The value here\n// should be kept in sync with the value used by the server, as the server will\n// silently ignore a value below the minimum and fall back to the default.\n// Googlers see b/266868871 for relevant discussion.\nconst MIN_LONG_POLLING_TIMEOUT_SECONDS = 5;\n\n// No maximum long-polling timeout is configured in the server, and defaults to\n// 30 seconds, which is what Watch appears to use.\n// Googlers see b/266868871 for relevant discussion.\nconst MAX_LONG_POLLING_TIMEOUT_SECONDS = 30;\n\n// Whether long-polling auto-detected is enabled by default.\nconst DEFAULT_AUTO_DETECT_LONG_POLLING = true;\n\n/**\n * Specifies custom configurations for your Cloud Firestore instance.\n * You must set these before invoking any other methods.\n */\nexport interface FirestoreSettings {\n  /** The hostname to connect to. */\n  host?: string;\n\n  /** Whether to use SSL when connecting. */\n  ssl?: boolean;\n\n  /**\n   * Whether to skip nested properties that are set to `undefined` during\n   * object serialization. If set to `true`, these properties are skipped\n   * and not written to Firestore. If set to `false` or omitted, the SDK\n   * throws an exception when it encounters properties of type `undefined`.\n   */\n  ignoreUndefinedProperties?: boolean;\n}\n\n/**\n * @internal\n * Undocumented, private additional settings not exposed in our public API.\n */\nexport interface PrivateSettings extends FirestoreSettings {\n  // Can be a google-auth-library or gapi client.\n  credentials?: CredentialsSettings;\n  cacheSizeBytes?: number;\n  experimentalForceLongPolling?: boolean;\n  experimentalAutoDetectLongPolling?: boolean;\n  experimentalLongPollingOptions?: ExperimentalLongPollingOptions;\n  useFetchStreams?: boolean;\n\n  localCache?: FirestoreLocalCache;\n}\n\n/**\n * A concrete type describing all the values that can be applied via a\n * user-supplied `FirestoreSettings` object. This is a separate type so that\n * defaults can be supplied and the value can be checked for equality.\n */\nexport class FirestoreSettingsImpl {\n  /** The hostname to connect to. */\n  readonly host: string;\n\n  /** Whether to use SSL when connecting. */\n  readonly ssl: boolean;\n\n  readonly cacheSizeBytes: number;\n\n  readonly experimentalForceLongPolling: boolean;\n\n  readonly experimentalAutoDetectLongPolling: boolean;\n\n  readonly experimentalLongPollingOptions: ExperimentalLongPollingOptions;\n\n  readonly ignoreUndefinedProperties: boolean;\n\n  readonly useFetchStreams: boolean;\n  readonly localCache?: FirestoreLocalCache;\n\n  // Can be a google-auth-library or gapi client.\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  credentials?: any;\n\n  constructor(settings: PrivateSettings) {\n    if (settings.host === undefined) {\n      if (settings.ssl !== undefined) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          \"Can't provide ssl option if host option is not set\"\n        );\n      }\n      this.host = DEFAULT_HOST;\n      this.ssl = DEFAULT_SSL;\n    } else {\n      this.host = settings.host;\n      this.ssl = settings.ssl ?? DEFAULT_SSL;\n    }\n\n    this.credentials = settings.credentials;\n    this.ignoreUndefinedProperties = !!settings.ignoreUndefinedProperties;\n    this.localCache = settings.localCache;\n\n    if (settings.cacheSizeBytes === undefined) {\n      this.cacheSizeBytes = LRU_DEFAULT_CACHE_SIZE_BYTES;\n    } else {\n      if (\n        settings.cacheSizeBytes !== LRU_COLLECTION_DISABLED &&\n        settings.cacheSizeBytes < LRU_MINIMUM_CACHE_SIZE_BYTES\n      ) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `cacheSizeBytes must be at least ${LRU_MINIMUM_CACHE_SIZE_BYTES}`\n        );\n      } else {\n        this.cacheSizeBytes = settings.cacheSizeBytes;\n      }\n    }\n\n    validateIsNotUsedTogether(\n      'experimentalForceLongPolling',\n      settings.experimentalForceLongPolling,\n      'experimentalAutoDetectLongPolling',\n      settings.experimentalAutoDetectLongPolling\n    );\n\n    this.experimentalForceLongPolling = !!settings.experimentalForceLongPolling;\n\n    if (this.experimentalForceLongPolling) {\n      this.experimentalAutoDetectLongPolling = false;\n    } else if (settings.experimentalAutoDetectLongPolling === undefined) {\n      this.experimentalAutoDetectLongPolling = DEFAULT_AUTO_DETECT_LONG_POLLING;\n    } else {\n      // For backwards compatibility, coerce the value to boolean even though\n      // the TypeScript compiler has narrowed the type to boolean already.\n      // noinspection PointlessBooleanExpressionJS\n      this.experimentalAutoDetectLongPolling =\n        !!settings.experimentalAutoDetectLongPolling;\n    }\n\n    this.experimentalLongPollingOptions = cloneLongPollingOptions(\n      settings.experimentalLongPollingOptions ?? {}\n    );\n    validateLongPollingOptions(this.experimentalLongPollingOptions);\n\n    this.useFetchStreams = !!settings.useFetchStreams;\n  }\n\n  isEqual(other: FirestoreSettingsImpl): boolean {\n    return (\n      this.host === other.host &&\n      this.ssl === other.ssl &&\n      this.credentials === other.credentials &&\n      this.cacheSizeBytes === other.cacheSizeBytes &&\n      this.experimentalForceLongPolling ===\n        other.experimentalForceLongPolling &&\n      this.experimentalAutoDetectLongPolling ===\n        other.experimentalAutoDetectLongPolling &&\n      longPollingOptionsEqual(\n        this.experimentalLongPollingOptions,\n        other.experimentalLongPollingOptions\n      ) &&\n      this.ignoreUndefinedProperties === other.ignoreUndefinedProperties &&\n      this.useFetchStreams === other.useFetchStreams\n    );\n  }\n}\n\nfunction validateLongPollingOptions(\n  options: ExperimentalLongPollingOptions\n): void {\n  if (options.timeoutSeconds !== undefined) {\n    if (isNaN(options.timeoutSeconds)) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `invalid long polling timeout: ` +\n          `${options.timeoutSeconds} (must not be NaN)`\n      );\n    }\n    if (options.timeoutSeconds < MIN_LONG_POLLING_TIMEOUT_SECONDS) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `invalid long polling timeout: ${options.timeoutSeconds} ` +\n          `(minimum allowed value is ${MIN_LONG_POLLING_TIMEOUT_SECONDS})`\n      );\n    }\n    if (options.timeoutSeconds > MAX_LONG_POLLING_TIMEOUT_SECONDS) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `invalid long polling timeout: ${options.timeoutSeconds} ` +\n          `(maximum allowed value is ${MAX_LONG_POLLING_TIMEOUT_SECONDS})`\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// eslint-disable-next-line import/no-extraneous-dependencies\nimport {\n  _getProvider,\n  _removeServiceInstance,\n  FirebaseApp,\n  getApp\n} from '@firebase/app';\nimport {\n  createMockUserToken,\n  EmulatorMockTokenOptions,\n  getDefaultEmulatorHostnameAndPort\n} from '@firebase/util';\n\nimport {\n  CredentialsProvider,\n  EmulatorAuthCredentialsProvider,\n  makeAuthCredentialsProvider,\n  OAuthToken\n} from '../api/credentials';\nimport { User } from '../auth/user';\nimport { DatabaseId, DEFAULT_DATABASE_NAME } from '../core/database_info';\nimport { Code, FirestoreError } from '../util/error';\nimport { cast } from '../util/input_validation';\nimport { logWarn } from '../util/log';\n\nimport { FirestoreService, removeComponents } from './components';\nimport {\n  DEFAULT_HOST,\n  FirestoreSettingsImpl,\n  PrivateSettings,\n  FirestoreSettings\n} from './settings';\n\nexport { EmulatorMockTokenOptions } from '@firebase/util';\n\ndeclare module '@firebase/component' {\n  interface NameServiceMapping {\n    'firestore/lite': Firestore;\n  }\n}\n\n/**\n * The Cloud Firestore service interface.\n *\n * Do not call this constructor directly. Instead, use {@link (getFirestore:1)}.\n */\nexport class Firestore implements FirestoreService {\n  /**\n   * Whether it's a Firestore or Firestore Lite instance.\n   */\n  type: 'firestore-lite' | 'firestore' = 'firestore-lite';\n\n  readonly _persistenceKey: string = '(lite)';\n\n  private _settings = new FirestoreSettingsImpl({});\n  private _settingsFrozen = false;\n\n  // A task that is assigned when the terminate() is invoked and resolved when\n  // all components have shut down. Otherwise, Firestore is not terminated,\n  // which can mean either the FirestoreClient is in the process of starting,\n  // or restarting.\n  private _terminateTask: Promise<void> | 'notTerminated' = 'notTerminated';\n\n  /** @hideconstructor */\n  constructor(\n    public _authCredentials: CredentialsProvider<User>,\n    public _appCheckCredentials: CredentialsProvider<string>,\n    readonly _databaseId: DatabaseId,\n    readonly _app?: FirebaseApp\n  ) {}\n\n  /**\n   * The {@link @firebase/app#FirebaseApp} associated with this `Firestore` service\n   * instance.\n   */\n  get app(): FirebaseApp {\n    if (!this._app) {\n      throw new FirestoreError(\n        Code.FAILED_PRECONDITION,\n        \"Firestore was not initialized using the Firebase SDK. 'app' is \" +\n          'not available'\n      );\n    }\n    return this._app;\n  }\n\n  get _initialized(): boolean {\n    return this._settingsFrozen;\n  }\n\n  get _terminated(): boolean {\n    return this._terminateTask !== 'notTerminated';\n  }\n\n  _setSettings(settings: PrivateSettings): void {\n    if (this._settingsFrozen) {\n      throw new FirestoreError(\n        Code.FAILED_PRECONDITION,\n        'Firestore has already been started and its settings can no longer ' +\n          'be changed. You can only modify settings before calling any other ' +\n          'methods on a Firestore object.'\n      );\n    }\n    this._settings = new FirestoreSettingsImpl(settings);\n    if (settings.credentials !== undefined) {\n      this._authCredentials = makeAuthCredentialsProvider(settings.credentials);\n    }\n  }\n\n  _getSettings(): FirestoreSettingsImpl {\n    return this._settings;\n  }\n\n  _freezeSettings(): FirestoreSettingsImpl {\n    this._settingsFrozen = true;\n    return this._settings;\n  }\n\n  _delete(): Promise<void> {\n    // The `_terminateTask` must be assigned future that completes when\n    // terminate is complete. The existence of this future puts SDK in state\n    // that will not accept further API interaction.\n    if (this._terminateTask === 'notTerminated') {\n      this._terminateTask = this._terminate();\n    }\n    return this._terminateTask;\n  }\n\n  async _restart(): Promise<void> {\n    // The `_terminateTask` must equal 'notTerminated' after restart to\n    // signal that client is in a state that accepts API calls.\n    if (this._terminateTask === 'notTerminated') {\n      await this._terminate();\n    } else {\n      this._terminateTask = 'notTerminated';\n    }\n  }\n\n  /** Returns a JSON-serializable representation of this `Firestore` instance. */\n  toJSON(): object {\n    return {\n      app: this._app,\n      databaseId: this._databaseId,\n      settings: this._settings\n    };\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  protected _terminate(): Promise<void> {\n    removeComponents(this);\n    return Promise.resolve();\n  }\n}\n\n/**\n * Initializes a new instance of Cloud Firestore with the provided settings.\n * Can only be called before any other functions, including\n * {@link (getFirestore:1)}. If the custom settings are empty, this function is\n * equivalent to calling {@link (getFirestore:1)}.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} with which the `Firestore` instance will\n * be associated.\n * @param settings - A settings object to configure the `Firestore` instance.\n * @returns A newly initialized `Firestore` instance.\n */\nexport function initializeFirestore(\n  app: FirebaseApp,\n  settings: FirestoreSettings\n): Firestore;\n/**\n * Initializes a new instance of Cloud Firestore with the provided settings.\n * Can only be called before any other functions, including\n * {@link (getFirestore:1)}. If the custom settings are empty, this function is\n * equivalent to calling {@link (getFirestore:1)}.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} with which the `Firestore` instance will\n * be associated.\n * @param settings - A settings object to configure the `Firestore` instance.\n * @param databaseId - The name of the database.\n * @returns A newly initialized `Firestore` instance.\n * @beta\n */\nexport function initializeFirestore(\n  app: FirebaseApp,\n  settings: FirestoreSettings,\n  databaseId?: string\n): Firestore;\nexport function initializeFirestore(\n  app: FirebaseApp,\n  settings: FirestoreSettings,\n  databaseId?: string\n): Firestore {\n  if (!databaseId) {\n    databaseId = DEFAULT_DATABASE_NAME;\n  }\n  const provider = _getProvider(app, 'firestore/lite');\n\n  if (provider.isInitialized(databaseId)) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'Firestore can only be initialized once per app.'\n    );\n  }\n\n  return provider.initialize({\n    options: settings,\n    instanceIdentifier: databaseId\n  });\n}\n\n/**\n * Returns the existing default {@link Firestore} instance that is associated with the\n * default {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @returns The {@link Firestore} instance of the provided app.\n */\nexport function getFirestore(): Firestore;\n/**\n * Returns the existing default {@link Firestore} instance that is associated with the\n * provided {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} instance that the returned {@link Firestore}\n * instance is associated with.\n * @returns The {@link Firestore} instance of the provided app.\n */\nexport function getFirestore(app: FirebaseApp): Firestore;\n/**\n * Returns the existing {@link Firestore} instance that is associated with the\n * default {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param databaseId - The name of the database.\n * @returns The {@link Firestore} instance of the provided app.\n * @beta\n */\nexport function getFirestore(databaseId: string): Firestore;\n/**\n * Returns the existing {@link Firestore} instance that is associated with the\n * provided {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} instance that the returned {@link Firestore}\n * instance is associated with.\n * @param databaseId - The name of the database.\n * @returns The {@link Firestore} instance of the provided app.\n * @beta\n */\nexport function getFirestore(app: FirebaseApp, databaseId: string): Firestore;\nexport function getFirestore(\n  appOrDatabaseId?: FirebaseApp | string,\n  optionalDatabaseId?: string\n): Firestore {\n  const app: FirebaseApp =\n    typeof appOrDatabaseId === 'object' ? appOrDatabaseId : getApp();\n  const databaseId =\n    typeof appOrDatabaseId === 'string'\n      ? appOrDatabaseId\n      : optionalDatabaseId || '(default)';\n  const db = _getProvider(app, 'firestore/lite').getImmediate({\n    identifier: databaseId\n  }) as Firestore;\n  if (!db._initialized) {\n    const emulator = getDefaultEmulatorHostnameAndPort('firestore');\n    if (emulator) {\n      connectFirestoreEmulator(db, ...emulator);\n    }\n  }\n  return db;\n}\n\n/**\n * Modify this instance to communicate with the Cloud Firestore emulator.\n *\n * Note: This must be called before this instance has been used to do any\n * operations.\n *\n * @param firestore - The `Firestore` instance to configure to connect to the\n * emulator.\n * @param host - the emulator host (ex: localhost).\n * @param port - the emulator port (ex: 9000).\n * @param options.mockUserToken - the mock auth token to use for unit testing\n * Security Rules.\n */\nexport function connectFirestoreEmulator(\n  firestore: Firestore,\n  host: string,\n  port: number,\n  options: {\n    mockUserToken?: EmulatorMockTokenOptions | string;\n  } = {}\n): void {\n  firestore = cast(firestore, Firestore);\n  const settings = firestore._getSettings();\n  const newHostSetting = `${host}:${port}`;\n\n  if (settings.host !== DEFAULT_HOST && settings.host !== newHostSetting) {\n    logWarn(\n      'Host has been set in both settings() and connectFirestoreEmulator(), emulator host ' +\n        'will be used.'\n    );\n  }\n\n  firestore._setSettings({\n    ...settings,\n    host: newHostSetting,\n    ssl: false\n  });\n\n  if (options.mockUserToken) {\n    let token: string;\n    let user: User;\n    if (typeof options.mockUserToken === 'string') {\n      token = options.mockUserToken;\n      user = User.MOCK_USER;\n    } else {\n      // Let createMockUserToken validate first (catches common mistakes like\n      // invalid field \"uid\" and missing field \"sub\" / \"user_id\".)\n      token = createMockUserToken(\n        options.mockUserToken,\n        firestore._app?.options.projectId\n      );\n      const uid = options.mockUserToken.sub || options.mockUserToken.user_id;\n      if (!uid) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          \"mockUserToken must contain 'sub' or 'user_id' field!\"\n        );\n      }\n      user = new User(uid);\n    }\n\n    firestore._authCredentials = new EmulatorAuthCredentialsProvider(\n      new OAuthToken(token, user)\n    );\n  }\n}\n\n/**\n * Terminates the provided `Firestore` instance.\n *\n * After calling `terminate()` only the `clearIndexedDbPersistence()` functions\n * may be used. Any other function will throw a `FirestoreError`. Termination\n * does not cancel any pending writes, and any promises that are awaiting a\n * response from the server will not be resolved.\n *\n * To restart after termination, create a new instance of `Firestore` with\n * {@link (getFirestore:1)}.\n *\n * Note: Under normal circumstances, calling `terminate()` is not required. This\n * function is useful only when you want to force this instance to release all of\n * its resources or in combination with {@link clearIndexedDbPersistence} to\n * ensure that all local state is destroyed between test runs.\n *\n * @param firestore - The `Firestore` instance to terminate.\n * @returns A `Promise` that is resolved when the instance has been successfully\n * terminated.\n */\nexport function terminate(firestore: Firestore): Promise<void> {\n  firestore = cast(firestore, Firestore);\n  _removeServiceInstance(firestore.app, 'firestore/lite');\n  return firestore._delete();\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 { getModularInstance } from '@firebase/util';\n\nimport {\n  newQueryForCollectionGroup,\n  newQueryForPath,\n  Query as InternalQuery,\n  queryEquals\n} from '../core/query';\nimport { DocumentKey } from '../model/document_key';\nimport { ResourcePath } from '../model/path';\nimport { Code, FirestoreError } from '../util/error';\nimport {\n  cast,\n  validateCollectionPath,\n  validateDocumentPath,\n  validateNonEmptyArgument\n} from '../util/input_validation';\nimport { AutoId } from '../util/misc';\n\nimport { Firestore } from './database';\nimport { FieldPath } from './field_path';\nimport { FieldValue } from './field_value';\nimport { FirestoreDataConverter } from './snapshot';\nimport { NestedUpdateFields, Primitive } from './types';\n\n/**\n * Document data (for use with {@link @firebase/firestore/lite#(setDoc:1)}) consists of fields mapped to\n * values.\n */\nexport interface DocumentData {\n  /** A mapping between a field and its value. */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  [field: string]: any;\n}\n\n/**\n * Similar to TypeScript's `Partial<T>`, but allows nested fields to be\n * omitted and FieldValues to be passed in as property values.\n */\nexport type PartialWithFieldValue<T> =\n  | Partial<T>\n  | (T extends Primitive\n      ? T\n      : T extends {}\n      ? { [K in keyof T]?: PartialWithFieldValue<T[K]> | FieldValue }\n      : never);\n\n/**\n * Allows FieldValues to be passed in as a property value while maintaining\n * type safety.\n */\nexport type WithFieldValue<T> =\n  | T\n  | (T extends Primitive\n      ? T\n      : T extends {}\n      ? { [K in keyof T]: WithFieldValue<T[K]> | FieldValue }\n      : never);\n\n/**\n * Update data (for use with {@link (updateDoc:1)}) that consists of field paths\n * (e.g. 'foo' or 'foo.baz') mapped to values. Fields that contain dots\n * reference nested fields within the document. FieldValues can be passed in\n * as property values.\n */\nexport type UpdateData<T> = T extends Primitive\n  ? T\n  : T extends {}\n  ? { [K in keyof T]?: UpdateData<T[K]> | FieldValue } & NestedUpdateFields<T>\n  : Partial<T>;\n/**\n * An options object that configures the behavior of {@link @firebase/firestore/lite#(setDoc:1)}, {@link\n * @firebase/firestore/lite#(WriteBatch.set:1)} and {@link @firebase/firestore/lite#(Transaction.set:1)} calls. These calls can be\n * configured to perform granular merges instead of overwriting the target\n * documents in their entirety by providing a `SetOptions` with `merge: true`.\n *\n * @param merge - Changes the behavior of a `setDoc()` call to only replace the\n * values specified in its data argument. Fields omitted from the `setDoc()`\n * call remain untouched. If your input sets any field to an empty map, all\n * nested fields are overwritten.\n * @param mergeFields - Changes the behavior of `setDoc()` calls to only replace\n * the specified field paths. Any field path that is not specified is ignored\n * and remains untouched. If your input sets any field to an empty map, all\n * nested fields are overwritten.\n */\nexport type SetOptions =\n  | {\n      readonly merge?: boolean;\n    }\n  | {\n      readonly mergeFields?: Array<string | FieldPath>;\n    };\n\n/**\n * A `Query` refers to a query which you can read or listen to. You can also\n * construct refined `Query` objects by adding filters and ordering.\n */\nexport class Query<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /** The type of this Firestore reference. */\n  readonly type: 'query' | 'collection' = 'query';\n\n  /**\n   * The `Firestore` instance for the Firestore database (useful for performing\n   * transactions, etc.).\n   */\n  readonly firestore: Firestore;\n\n  // This is the lite version of the Query class in the main SDK.\n\n  /** @hideconstructor protected */\n  constructor(\n    firestore: Firestore,\n    /**\n     * If provided, the `FirestoreDataConverter` associated with this instance.\n     */\n    readonly converter: FirestoreDataConverter<\n      AppModelType,\n      DbModelType\n    > | null,\n    readonly _query: InternalQuery\n  ) {\n    this.firestore = firestore;\n  }\n\n  /**\n   * Removes the current converter.\n   *\n   * @param converter - `null` removes the current converter.\n   * @returns A `Query<DocumentData, DocumentData>` that does not use a\n   * converter.\n   */\n  withConverter(converter: null): Query<DocumentData, DocumentData>;\n  /**\n   * Applies a custom data converter to this query, allowing you to use your own\n   * custom model objects with Firestore. When you call {@link getDocs} with\n   * the returned query, the provided converter will convert between Firestore\n   * data of type `NewDbModelType` and your custom type `NewAppModelType`.\n   *\n   * @param converter - Converts objects to and from Firestore.\n   * @returns A `Query` that uses the provided converter.\n   */\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType>\n  ): Query<NewAppModelType, NewDbModelType>;\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType> | null\n  ): Query<NewAppModelType, NewDbModelType> {\n    return new Query<NewAppModelType, NewDbModelType>(\n      this.firestore,\n      converter,\n      this._query\n    );\n  }\n}\n\n/**\n * A `DocumentReference` refers to a document location in a Firestore database\n * and can be used to write, read, or listen to the location. The document at\n * the referenced location may or may not exist.\n */\nexport class DocumentReference<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /** The type of this Firestore reference. */\n  readonly type = 'document';\n\n  /**\n   * The {@link Firestore} instance the document is in.\n   * This is useful for performing transactions, for example.\n   */\n  readonly firestore: Firestore;\n\n  /** @hideconstructor */\n  constructor(\n    firestore: Firestore,\n    /**\n     * If provided, the `FirestoreDataConverter` associated with this instance.\n     */\n    readonly converter: FirestoreDataConverter<\n      AppModelType,\n      DbModelType\n    > | null,\n    readonly _key: DocumentKey\n  ) {\n    this.firestore = firestore;\n  }\n\n  get _path(): ResourcePath {\n    return this._key.path;\n  }\n\n  /**\n   * The document's identifier within its collection.\n   */\n  get id(): string {\n    return this._key.path.lastSegment();\n  }\n\n  /**\n   * A string representing the path of the referenced document (relative\n   * to the root of the database).\n   */\n  get path(): string {\n    return this._key.path.canonicalString();\n  }\n\n  /**\n   * The collection this `DocumentReference` belongs to.\n   */\n  get parent(): CollectionReference<AppModelType, DbModelType> {\n    return new CollectionReference<AppModelType, DbModelType>(\n      this.firestore,\n      this.converter,\n      this._key.path.popLast()\n    );\n  }\n\n  /**\n   * Applies a custom data converter to this `DocumentReference`, allowing you\n   * to use your own custom model objects with Firestore. When you call {@link\n   * @firebase/firestore/lite#(setDoc:1)}, {@link @firebase/firestore/lite#getDoc}, etc. with the returned `DocumentReference`\n   * instance, the provided converter will convert between Firestore data of\n   * type `NewDbModelType` and your custom type `NewAppModelType`.\n   *\n   * @param converter - Converts objects to and from Firestore.\n   * @returns A `DocumentReference` that uses the provided converter.\n   */\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType>\n  ): DocumentReference<NewAppModelType, NewDbModelType>;\n  /**\n   * Removes the current converter.\n   *\n   * @param converter - `null` removes the current converter.\n   * @returns A `DocumentReference<DocumentData, DocumentData>` that does not\n   * use a converter.\n   */\n  withConverter(converter: null): DocumentReference<DocumentData, DocumentData>;\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType> | null\n  ): DocumentReference<NewAppModelType, NewDbModelType> {\n    return new DocumentReference<NewAppModelType, NewDbModelType>(\n      this.firestore,\n      converter,\n      this._key\n    );\n  }\n}\n\n/**\n * A `CollectionReference` object can be used for adding documents, getting\n * document references, and querying for documents (using {@link (query:1)}).\n */\nexport class CollectionReference<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> extends Query<AppModelType, DbModelType> {\n  /** The type of this Firestore reference. */\n  readonly type = 'collection';\n\n  /** @hideconstructor */\n  constructor(\n    firestore: Firestore,\n    converter: FirestoreDataConverter<AppModelType, DbModelType> | null,\n    readonly _path: ResourcePath\n  ) {\n    super(firestore, converter, newQueryForPath(_path));\n  }\n\n  /** The collection's identifier. */\n  get id(): string {\n    return this._query.path.lastSegment();\n  }\n\n  /**\n   * A string representing the path of the referenced collection (relative\n   * to the root of the database).\n   */\n  get path(): string {\n    return this._query.path.canonicalString();\n  }\n\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 parent(): DocumentReference<DocumentData, DocumentData> | null {\n    const parentPath = this._path.popLast();\n    if (parentPath.isEmpty()) {\n      return null;\n    } else {\n      return new DocumentReference(\n        this.firestore,\n        /* converter= */ null,\n        new DocumentKey(parentPath)\n      );\n    }\n  }\n\n  /**\n   * Applies a custom data converter to this `CollectionReference`, allowing you\n   * to use your own custom model objects with Firestore. When you call {@link\n   * addDoc} with the returned `CollectionReference` instance, the provided\n   * converter will convert between Firestore data of type `NewDbModelType` and\n   * your custom type `NewAppModelType`.\n   *\n   * @param converter - Converts objects to and from Firestore.\n   * @returns A `CollectionReference` that uses the provided converter.\n   */\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType>\n  ): CollectionReference<NewAppModelType, NewDbModelType>;\n  /**\n   * Removes the current converter.\n   *\n   * @param converter - `null` removes the current converter.\n   * @returns A `CollectionReference<DocumentData, DocumentData>` that does not\n   * use a converter.\n   */\n  withConverter(\n    converter: null\n  ): CollectionReference<DocumentData, DocumentData>;\n  withConverter<\n    NewAppModelType,\n    NewDbModelType extends DocumentData = DocumentData\n  >(\n    converter: FirestoreDataConverter<NewAppModelType, NewDbModelType> | null\n  ): CollectionReference<NewAppModelType, NewDbModelType> {\n    return new CollectionReference<NewAppModelType, NewDbModelType>(\n      this.firestore,\n      converter,\n      this._path\n    );\n  }\n}\n\n/**\n * Gets a `CollectionReference` instance that refers to the collection at\n * the specified absolute path.\n *\n * @param firestore - A reference to the root `Firestore` instance.\n * @param path - A slash-separated path to a collection.\n * @param pathSegments - Additional path segments to apply relative to the first\n * argument.\n * @throws If the final path has an even number of segments and does not point\n * to a collection.\n * @returns The `CollectionReference` instance.\n */\nexport function collection(\n  firestore: Firestore,\n  path: string,\n  ...pathSegments: string[]\n): CollectionReference<DocumentData, DocumentData>;\n/**\n * Gets a `CollectionReference` instance that refers to a subcollection of\n * `reference` at the specified relative path.\n *\n * @param reference - A reference to a collection.\n * @param path - A slash-separated path to a collection.\n * @param pathSegments - Additional path segments to apply relative to the first\n * argument.\n * @throws If the final path has an even number of segments and does not point\n * to a collection.\n * @returns The `CollectionReference` instance.\n */\nexport function collection<AppModelType, DbModelType extends DocumentData>(\n  reference: CollectionReference<AppModelType, DbModelType>,\n  path: string,\n  ...pathSegments: string[]\n): CollectionReference<DocumentData, DocumentData>;\n/**\n * Gets a `CollectionReference` instance that refers to a subcollection of\n * `reference` at the specified relative path.\n *\n * @param reference - A reference to a Firestore document.\n * @param path - A slash-separated path to a collection.\n * @param pathSegments - Additional path segments that will be applied relative\n * to the first argument.\n * @throws If the final path has an even number of segments and does not point\n * to a collection.\n * @returns The `CollectionReference` instance.\n */\nexport function collection<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  path: string,\n  ...pathSegments: string[]\n): CollectionReference<DocumentData, DocumentData>;\nexport function collection<AppModelType, DbModelType extends DocumentData>(\n  parent:\n    | Firestore\n    | DocumentReference<AppModelType, DbModelType>\n    | CollectionReference<AppModelType, DbModelType>,\n  path: string,\n  ...pathSegments: string[]\n): CollectionReference<DocumentData, DocumentData> {\n  parent = getModularInstance(parent);\n\n  validateNonEmptyArgument('collection', 'path', path);\n  if (parent instanceof Firestore) {\n    const absolutePath = ResourcePath.fromString(path, ...pathSegments);\n    validateCollectionPath(absolutePath);\n    return new CollectionReference(parent, /* converter= */ null, absolutePath);\n  } else {\n    if (\n      !(parent instanceof DocumentReference) &&\n      !(parent instanceof CollectionReference)\n    ) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Expected first argument to collection() to be a CollectionReference, ' +\n          'a DocumentReference or FirebaseFirestore'\n      );\n    }\n    const absolutePath = parent._path.child(\n      ResourcePath.fromString(path, ...pathSegments)\n    );\n    validateCollectionPath(absolutePath);\n    return new CollectionReference(\n      parent.firestore,\n      /* converter= */ null,\n      absolutePath\n    );\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/**\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 */\nexport function collectionGroup(\n  firestore: Firestore,\n  collectionId: string\n): Query<DocumentData, DocumentData> {\n  firestore = cast(firestore, Firestore);\n\n  validateNonEmptyArgument('collectionGroup', 'collection id', collectionId);\n  if (collectionId.indexOf('/') >= 0) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Invalid collection ID '${collectionId}' passed to function ` +\n        `collectionGroup(). Collection IDs must not contain '/'.`\n    );\n  }\n\n  return new Query(\n    firestore,\n    /* converter= */ null,\n    newQueryForCollectionGroup(collectionId)\n  );\n}\n\n/**\n * Gets a `DocumentReference` instance that refers to the document at the\n * specified absolute path.\n *\n * @param firestore - A reference to the root `Firestore` instance.\n * @param path - A slash-separated path to a document.\n * @param pathSegments - Additional path segments that will be applied relative\n * to the first argument.\n * @throws If the final path has an odd number of segments and does not point to\n * a document.\n * @returns The `DocumentReference` instance.\n */\nexport function doc(\n  firestore: Firestore,\n  path: string,\n  ...pathSegments: string[]\n): DocumentReference<DocumentData, DocumentData>;\n/**\n * Gets a `DocumentReference` instance that refers to a document within\n * `reference` at the specified relative path. If no path is specified, an\n * automatically-generated unique ID will be used for the returned\n * `DocumentReference`.\n *\n * @param reference - A reference to a collection.\n * @param path - A slash-separated path to a document. Has to be omitted to use\n * auto-generated IDs.\n * @param pathSegments - Additional path segments that will be applied relative\n * to the first argument.\n * @throws If the final path has an odd number of segments and does not point to\n * a document.\n * @returns The `DocumentReference` instance.\n */\nexport function doc<AppModelType, DbModelType extends DocumentData>(\n  reference: CollectionReference<AppModelType, DbModelType>,\n  path?: string,\n  ...pathSegments: string[]\n): DocumentReference<AppModelType, DbModelType>;\n/**\n * Gets a `DocumentReference` instance that refers to a document within\n * `reference` at the specified relative path.\n *\n * @param reference - A reference to a Firestore document.\n * @param path - A slash-separated path to a document.\n * @param pathSegments - Additional path segments that will be applied relative\n * to the first argument.\n * @throws If the final path has an odd number of segments and does not point to\n * a document.\n * @returns The `DocumentReference` instance.\n */\nexport function doc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  path: string,\n  ...pathSegments: string[]\n): DocumentReference<DocumentData, DocumentData>;\nexport function doc<AppModelType, DbModelType extends DocumentData>(\n  parent:\n    | Firestore\n    | CollectionReference<AppModelType, DbModelType>\n    | DocumentReference<AppModelType, DbModelType>,\n  path?: string,\n  ...pathSegments: string[]\n): DocumentReference<AppModelType, DbModelType> {\n  parent = getModularInstance(parent);\n\n  // We allow omission of 'pathString' but explicitly prohibit passing in both\n  // 'undefined' and 'null'.\n  if (arguments.length === 1) {\n    path = AutoId.newId();\n  }\n  validateNonEmptyArgument('doc', 'path', path);\n\n  if (parent instanceof Firestore) {\n    const absolutePath = ResourcePath.fromString(path, ...pathSegments);\n    validateDocumentPath(absolutePath);\n    return new DocumentReference(\n      parent,\n      /* converter= */ null,\n      new DocumentKey(absolutePath)\n    );\n  } else {\n    if (\n      !(parent instanceof DocumentReference) &&\n      !(parent instanceof CollectionReference)\n    ) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Expected first argument to collection() to be a CollectionReference, ' +\n          'a DocumentReference or FirebaseFirestore'\n      );\n    }\n    const absolutePath = parent._path.child(\n      ResourcePath.fromString(path, ...pathSegments)\n    );\n    validateDocumentPath(absolutePath);\n    return new DocumentReference<AppModelType, DbModelType>(\n      parent.firestore,\n      parent instanceof CollectionReference ? parent.converter : null,\n      new DocumentKey(absolutePath)\n    );\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 */\nexport function refEqual<AppModelType, DbModelType extends DocumentData>(\n  left:\n    | DocumentReference<AppModelType, DbModelType>\n    | CollectionReference<AppModelType, DbModelType>,\n  right:\n    | DocumentReference<AppModelType, DbModelType>\n    | CollectionReference<AppModelType, DbModelType>\n): boolean {\n  left = getModularInstance(left);\n  right = getModularInstance(right);\n\n  if (\n    (left instanceof DocumentReference ||\n      left instanceof CollectionReference) &&\n    (right instanceof DocumentReference || right instanceof CollectionReference)\n  ) {\n    return (\n      left.firestore === right.firestore &&\n      left.path === right.path &&\n      left.converter === right.converter\n    );\n  }\n  return false;\n}\n\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 */\nexport function queryEqual<AppModelType, DbModelType extends DocumentData>(\n  left: Query<AppModelType, DbModelType>,\n  right: Query<AppModelType, DbModelType>\n): boolean {\n  left = getModularInstance(left);\n  right = getModularInstance(right);\n\n  if (left instanceof Query && right instanceof Query) {\n    return (\n      left.firestore === right.firestore &&\n      queryEquals(left._query, right._query) &&\n      left.converter === right.converter\n    );\n  }\n  return false;\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 { isIndexedDbTransactionError } from '../local/simple_db';\nimport { getDocument } from '../platform/dom';\nimport { ExponentialBackoff } from '../remote/backoff';\n\nimport { debugAssert, fail } from './assert';\nimport { AsyncQueue, DelayedOperation, TimerId } from './async_queue';\nimport { FirestoreError } from './error';\nimport { logDebug, logError } from './log';\nimport { Deferred } from './promise';\n\nconst LOG_TAG = 'AsyncQueue';\n\nexport class AsyncQueueImpl implements AsyncQueue {\n  // The last promise in the queue.\n  private tail: Promise<unknown>;\n\n  // A list of retryable operations. Retryable operations are run in order and\n  // retried with backoff.\n  private retryableOps: Array<() => Promise<void>> = [];\n\n  // Is this AsyncQueue being shut down? Once it is set to true, it will not\n  // be changed again.\n  private _isShuttingDown: boolean = false;\n\n  // Operations scheduled to be queued in the future. Operations are\n  // automatically removed after they are run or canceled.\n  private delayedOperations: Array<DelayedOperation<unknown>> = [];\n\n  // visible for testing\n  failure: FirestoreError | null = null;\n\n  // Flag set while there's an outstanding AsyncQueue operation, used for\n  // assertion sanity-checks.\n  private operationInProgress = false;\n\n  // Enabled during shutdown on Safari to prevent future access to IndexedDB.\n  private skipNonRestrictedTasks = false;\n\n  // List of TimerIds to fast-forward delays for.\n  private timerIdsToSkip: TimerId[] = [];\n\n  // Backoff timer used to schedule retries for retryable operations\n  private backoff = new ExponentialBackoff(this, TimerId.AsyncQueueRetry);\n\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  private visibilityHandler: () => void = () => {\n    const document = getDocument();\n    if (document) {\n      logDebug(\n        LOG_TAG,\n        'Visibility state changed to ' + document.visibilityState\n      );\n    }\n    this.backoff.skipBackoff();\n  };\n\n  constructor(tail: Promise<unknown> = Promise.resolve()) {\n    this.tail = tail;\n    const document = getDocument();\n    if (document && typeof document.addEventListener === 'function') {\n      document.addEventListener('visibilitychange', this.visibilityHandler);\n    }\n  }\n\n  get isShuttingDown(): boolean {\n    return this._isShuttingDown;\n  }\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  enqueueAndForget<T extends unknown>(op: () => Promise<T>): void {\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.enqueue(op);\n  }\n\n  enqueueAndForgetEvenWhileRestricted<T extends unknown>(\n    op: () => Promise<T>\n  ): void {\n    this.verifyNotFailed();\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.enqueueInternal(op);\n  }\n\n  enterRestrictedMode(purgeExistingTasks?: boolean): void {\n    if (!this._isShuttingDown) {\n      this._isShuttingDown = true;\n      this.skipNonRestrictedTasks = purgeExistingTasks || false;\n      const document = getDocument();\n      if (document && typeof document.removeEventListener === 'function') {\n        document.removeEventListener(\n          'visibilitychange',\n          this.visibilityHandler\n        );\n      }\n    }\n  }\n\n  enqueue<T extends unknown>(op: () => Promise<T>): Promise<T> {\n    this.verifyNotFailed();\n    if (this._isShuttingDown) {\n      // Return a Promise which never resolves.\n      return new Promise<T>(() => {});\n    }\n\n    // Create a deferred Promise that we can return to the callee. This\n    // allows us to return a \"hanging Promise\" only to the callee and still\n    // advance the queue even when the operation is not run.\n    const task = new Deferred<T>();\n    return this.enqueueInternal<unknown>(() => {\n      if (this._isShuttingDown && this.skipNonRestrictedTasks) {\n        // We do not resolve 'task'\n        return Promise.resolve();\n      }\n\n      op().then(task.resolve, task.reject);\n      return task.promise;\n    }).then(() => task.promise);\n  }\n\n  enqueueRetryable(op: () => Promise<void>): void {\n    this.enqueueAndForget(() => {\n      this.retryableOps.push(op);\n      return this.retryNextOp();\n    });\n  }\n\n  /**\n   * Runs the next operation from the retryable queue. If the operation fails,\n   * reschedules with backoff.\n   */\n  private async retryNextOp(): Promise<void> {\n    if (this.retryableOps.length === 0) {\n      return;\n    }\n\n    try {\n      await this.retryableOps[0]();\n      this.retryableOps.shift();\n      this.backoff.reset();\n    } catch (e) {\n      if (isIndexedDbTransactionError(e as Error)) {\n        logDebug(LOG_TAG, 'Operation failed with retryable error: ' + e);\n      } else {\n        throw e; // Failure will be handled by AsyncQueue\n      }\n    }\n\n    if (this.retryableOps.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.backoff.backoffAndRun(() => this.retryNextOp());\n    }\n  }\n\n  private enqueueInternal<T extends unknown>(op: () => Promise<T>): Promise<T> {\n    const newTail = this.tail.then(() => {\n      this.operationInProgress = true;\n      return op()\n        .catch((error: FirestoreError) => {\n          this.failure = error;\n          this.operationInProgress = false;\n          const message = getMessageOrStack(error);\n          logError('INTERNAL UNHANDLED ERROR: ', message);\n\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 error;\n        })\n        .then(result => {\n          this.operationInProgress = false;\n          return result;\n        });\n    });\n    this.tail = newTail;\n    return newTail;\n  }\n\n  enqueueAfterDelay<T extends unknown>(\n    timerId: TimerId,\n    delayMs: number,\n    op: () => Promise<T>\n  ): DelayedOperation<T> {\n    this.verifyNotFailed();\n\n    debugAssert(\n      delayMs >= 0,\n      `Attempted to schedule an operation with a negative delay of ${delayMs}`\n    );\n\n    // Fast-forward delays for timerIds that have been overridden.\n    if (this.timerIdsToSkip.indexOf(timerId) > -1) {\n      delayMs = 0;\n    }\n\n    const delayedOp = DelayedOperation.createAndSchedule<T>(\n      this,\n      timerId,\n      delayMs,\n      op,\n      removedOp =>\n        this.removeDelayedOperation(removedOp as DelayedOperation<unknown>)\n    );\n    this.delayedOperations.push(delayedOp as DelayedOperation<unknown>);\n    return delayedOp;\n  }\n\n  private verifyNotFailed(): void {\n    if (this.failure) {\n      fail('AsyncQueue is already failed: ' + getMessageOrStack(this.failure));\n    }\n  }\n\n  verifyOperationInProgress(): void {\n    debugAssert(\n      this.operationInProgress,\n      'verifyOpInProgress() called when no op in progress on this queue.'\n    );\n  }\n\n  /**\n   * Waits until all currently queued tasks are finished executing. Delayed\n   * operations are not run.\n   */\n  async drain(): Promise<void> {\n    // Operations in the queue prior to draining may have enqueued additional\n    // operations. Keep draining the queue until the tail is no longer advanced,\n    // which indicates that no more new operations were enqueued and that all\n    // operations were executed.\n    let currentTail: Promise<unknown>;\n    do {\n      currentTail = this.tail;\n      await currentTail;\n    } while (currentTail !== this.tail);\n  }\n\n  /**\n   * For Tests: Determine if a delayed operation with a particular TimerId\n   * exists.\n   */\n  containsDelayedOperation(timerId: TimerId): boolean {\n    for (const op of this.delayedOperations) {\n      if (op.timerId === timerId) {\n        return true;\n      }\n    }\n    return false;\n  }\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  runAllDelayedOperationsUntil(lastTimerId: TimerId): Promise<void> {\n    // Note that draining may generate more delayed ops, so we do that first.\n    return this.drain().then(() => {\n      // Run ops in the same order they'd run if they ran naturally.\n      /* eslint-disable-next-line @typescript-eslint/no-floating-promises */\n      this.delayedOperations.sort((a, b) => a.targetTimeMs - b.targetTimeMs);\n\n      for (const op of this.delayedOperations) {\n        op.skipDelay();\n        if (lastTimerId !== TimerId.All && op.timerId === lastTimerId) {\n          break;\n        }\n      }\n\n      return this.drain();\n    });\n  }\n\n  /**\n   * For Tests: Skip all subsequent delays for a timer id.\n   */\n  skipDelaysForTimerId(timerId: TimerId): void {\n    this.timerIdsToSkip.push(timerId);\n  }\n\n  /** Called once a DelayedOperation is run or canceled. */\n  private removeDelayedOperation(op: DelayedOperation<unknown>): void {\n    // NOTE: indexOf / slice are O(n), but delayedOperations is expected to be small.\n    const index = this.delayedOperations.indexOf(op);\n    debugAssert(index >= 0, 'Delayed operation not found.');\n    /* eslint-disable-next-line @typescript-eslint/no-floating-promises */\n    this.delayedOperations.splice(index, 1);\n  }\n}\n\nexport function newAsyncQueue(): AsyncQueue {\n  return new AsyncQueueImpl();\n}\n\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 */\nfunction getMessageOrStack(error: Error): string {\n  let message = error.message || '';\n  if (error.stack) {\n    if (error.stack.includes(error.message)) {\n      message = error.stack;\n    } else {\n      message = error.message + '\\n' + error.stack;\n    }\n  }\n  return message;\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  _getProvider,\n  _removeServiceInstance,\n  FirebaseApp,\n  getApp\n} from '@firebase/app';\nimport { deepEqual, getDefaultEmulatorHostnameAndPort } from '@firebase/util';\n\nimport { User } from '../auth/user';\nimport {\n  IndexedDbOfflineComponentProvider,\n  MultiTabOfflineComponentProvider,\n  OfflineComponentProvider,\n  OfflineComponentProviderFactory,\n  OnlineComponentProvider,\n  OnlineComponentProviderFactory\n} from '../core/component_provider';\nimport { DatabaseId, DEFAULT_DATABASE_NAME } from '../core/database_info';\nimport {\n  FirestoreClient,\n  firestoreClientDisableNetwork,\n  firestoreClientEnableNetwork,\n  firestoreClientGetNamedQuery,\n  firestoreClientLoadBundle,\n  firestoreClientWaitForPendingWrites\n} from '../core/firestore_client';\nimport { makeDatabaseInfo } from '../lite-api/components';\nimport {\n  connectFirestoreEmulator,\n  Firestore as LiteFirestore\n} from '../lite-api/database';\nimport { Query } from '../lite-api/reference';\nimport {\n  indexedDbClearPersistence,\n  indexedDbStoragePrefix\n} from '../local/indexeddb_persistence';\nimport { LRU_COLLECTION_DISABLED } from '../local/lru_garbage_collector';\nimport { LRU_MINIMUM_CACHE_SIZE_BYTES } from '../local/lru_garbage_collector_impl';\nimport { debugAssert } from '../util/assert';\nimport { AsyncQueue } from '../util/async_queue';\nimport { AsyncQueueImpl } from '../util/async_queue_impl';\nimport { Code, FirestoreError } from '../util/error';\nimport { cast } from '../util/input_validation';\nimport { logWarn } from '../util/log';\nimport { Deferred } from '../util/promise';\n\nimport { LoadBundleTask } from './bundle';\nimport { CredentialsProvider } from './credentials';\nimport { FirestoreSettings, PersistenceSettings } from './settings';\n\nexport {\n  connectFirestoreEmulator,\n  EmulatorMockTokenOptions\n} from '../lite-api/database';\n\ndeclare module '@firebase/component' {\n  interface NameServiceMapping {\n    'firestore': Firestore;\n  }\n}\n\n/**\n * Constant used to indicate the LRU garbage collection should be disabled.\n * Set this value as the `cacheSizeBytes` on the settings passed to the\n * {@link Firestore} instance.\n */\nexport const CACHE_SIZE_UNLIMITED = LRU_COLLECTION_DISABLED;\n\n/**\n * The Cloud Firestore service interface.\n *\n * Do not call this constructor directly. Instead, use {@link (getFirestore:1)}.\n */\nexport class Firestore extends LiteFirestore {\n  /**\n   * Whether it's a {@link Firestore} or Firestore Lite instance.\n   */\n  type: 'firestore-lite' | 'firestore' = 'firestore';\n\n  _queue: AsyncQueue = new AsyncQueueImpl();\n  readonly _persistenceKey: string;\n\n  _firestoreClient: FirestoreClient | undefined;\n\n  _componentsProvider?: {\n    _offline: OfflineComponentProviderFactory;\n    _online: OnlineComponentProviderFactory;\n  };\n\n  /** @hideconstructor */\n  constructor(\n    authCredentialsProvider: CredentialsProvider<User>,\n    appCheckCredentialsProvider: CredentialsProvider<string>,\n    databaseId: DatabaseId,\n    app?: FirebaseApp\n  ) {\n    super(\n      authCredentialsProvider,\n      appCheckCredentialsProvider,\n      databaseId,\n      app\n    );\n    this._persistenceKey = app?.name || '[DEFAULT]';\n  }\n\n  protected async _terminate(): Promise<void> {\n    if (this._firestoreClient) {\n      const terminate = this._firestoreClient.terminate();\n      this._queue = new AsyncQueueImpl(terminate);\n      this._firestoreClient = undefined;\n      await terminate;\n    }\n  }\n}\n\n/**\n * Initializes a new instance of {@link Firestore} with the provided settings.\n * Can only be called before any other function, including\n * {@link (getFirestore:1)}. If the custom settings are empty, this function is\n * equivalent to calling {@link (getFirestore:1)}.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} with which the {@link Firestore} instance will\n * be associated.\n * @param settings - A settings object to configure the {@link Firestore} instance.\n * @param databaseId - The name of the database.\n * @returns A newly initialized {@link Firestore} instance.\n */\nexport function initializeFirestore(\n  app: FirebaseApp,\n  settings: FirestoreSettings,\n  databaseId?: string\n): Firestore {\n  if (!databaseId) {\n    databaseId = DEFAULT_DATABASE_NAME;\n  }\n  const provider = _getProvider(app, 'firestore');\n\n  if (provider.isInitialized(databaseId)) {\n    const existingInstance = provider.getImmediate({\n      identifier: databaseId\n    });\n    const initialSettings = provider.getOptions(\n      databaseId\n    ) as FirestoreSettings;\n    if (deepEqual(initialSettings, settings)) {\n      return existingInstance;\n    } else {\n      throw new FirestoreError(\n        Code.FAILED_PRECONDITION,\n        'initializeFirestore() has already been called with ' +\n          'different options. To avoid this error, call initializeFirestore() with the ' +\n          'same options as when it was originally called, or call getFirestore() to return the' +\n          ' already initialized instance.'\n      );\n    }\n  }\n\n  if (\n    settings.cacheSizeBytes !== undefined &&\n    settings.localCache !== undefined\n  ) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `cache and cacheSizeBytes cannot be specified at the same time as cacheSizeBytes will` +\n        `be deprecated. Instead, specify the cache size in the cache object`\n    );\n  }\n\n  if (\n    settings.cacheSizeBytes !== undefined &&\n    settings.cacheSizeBytes !== CACHE_SIZE_UNLIMITED &&\n    settings.cacheSizeBytes < LRU_MINIMUM_CACHE_SIZE_BYTES\n  ) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `cacheSizeBytes must be at least ${LRU_MINIMUM_CACHE_SIZE_BYTES}`\n    );\n  }\n\n  return provider.initialize({\n    options: settings,\n    instanceIdentifier: databaseId\n  });\n}\n\n/**\n * Returns the existing default {@link Firestore} instance that is associated with the\n * default {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @returns The default {@link Firestore} instance of the default app.\n */\nexport function getFirestore(): Firestore;\n/**\n * Returns the existing default {@link Firestore} instance that is associated with the\n * provided {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} instance that the returned {@link Firestore}\n * instance is associated with.\n * @returns The default {@link Firestore} instance of the provided app.\n */\nexport function getFirestore(app: FirebaseApp): Firestore;\n/**\n * Returns the existing named {@link Firestore} instance that is associated with the\n * default {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param databaseId - The name of the database.\n * @returns The named {@link Firestore} instance of the default app.\n * @beta\n */\nexport function getFirestore(databaseId: string): Firestore;\n/**\n * Returns the existing named {@link Firestore} instance that is associated with the\n * provided {@link @firebase/app#FirebaseApp}. If no instance exists, initializes a new\n * instance with default settings.\n *\n * @param app - The {@link @firebase/app#FirebaseApp} instance that the returned {@link Firestore}\n * instance is associated with.\n * @param databaseId - The name of the database.\n * @returns The named {@link Firestore} instance of the provided app.\n * @beta\n */\nexport function getFirestore(app: FirebaseApp, databaseId: string): Firestore;\nexport function getFirestore(\n  appOrDatabaseId?: FirebaseApp | string,\n  optionalDatabaseId?: string\n): Firestore {\n  const app: FirebaseApp =\n    typeof appOrDatabaseId === 'object' ? appOrDatabaseId : getApp();\n  const databaseId =\n    typeof appOrDatabaseId === 'string'\n      ? appOrDatabaseId\n      : optionalDatabaseId || DEFAULT_DATABASE_NAME;\n  const db = _getProvider(app, 'firestore').getImmediate({\n    identifier: databaseId\n  }) as Firestore;\n  if (!db._initialized) {\n    const emulator = getDefaultEmulatorHostnameAndPort('firestore');\n    if (emulator) {\n      connectFirestoreEmulator(db, ...emulator);\n    }\n  }\n  return db;\n}\n\n/**\n * @internal\n */\nexport function ensureFirestoreConfigured(\n  firestore: Firestore\n): FirestoreClient {\n  if (firestore._terminated) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'The client has already been terminated.'\n    );\n  }\n  if (!firestore._firestoreClient) {\n    configureFirestore(firestore);\n  }\n  return firestore._firestoreClient as FirestoreClient;\n}\n\nexport function configureFirestore(firestore: Firestore): void {\n  const settings = firestore._freezeSettings();\n  debugAssert(!!settings.host, 'FirestoreSettings.host is not set');\n  debugAssert(\n    !firestore._firestoreClient,\n    'configureFirestore() called multiple times'\n  );\n\n  const databaseInfo = makeDatabaseInfo(\n    firestore._databaseId,\n    firestore._app?.options.appId || '',\n    firestore._persistenceKey,\n    settings\n  );\n  if (!firestore._componentsProvider) {\n    if (\n      settings.localCache?._offlineComponentProvider &&\n      settings.localCache?._onlineComponentProvider\n    ) {\n      firestore._componentsProvider = {\n        _offline: settings.localCache._offlineComponentProvider,\n        _online: settings.localCache._onlineComponentProvider\n      };\n    }\n  }\n  firestore._firestoreClient = new FirestoreClient(\n    firestore._authCredentials,\n    firestore._appCheckCredentials,\n    firestore._queue,\n    databaseInfo,\n    firestore._componentsProvider &&\n      buildComponentProvider(firestore._componentsProvider)\n  );\n}\n\nfunction buildComponentProvider(componentsProvider: {\n  _offline: OfflineComponentProviderFactory;\n  _online: OnlineComponentProviderFactory;\n}): {\n  _offline: OfflineComponentProvider;\n  _online: OnlineComponentProvider;\n} {\n  const online = componentsProvider?._online.build();\n  return {\n    _offline: componentsProvider?._offline.build(online),\n    _online: online\n  };\n}\n\n/**\n * Attempts to enable persistent storage, if possible.\n *\n * On failure, `enableIndexedDbPersistence()` will reject the promise or\n * throw an exception. There are several reasons why this can fail, which can be\n * identified by 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 persistence\n *     implementation.\n *\n * Note that even after a failure, the {@link Firestore} instance will remain\n * usable, however offline persistence will be disabled.\n *\n * Note: `enableIndexedDbPersistence()` must be called before any other functions\n * (other than {@link initializeFirestore}, {@link (getFirestore:1)} or\n * {@link clearIndexedDbPersistence}.\n *\n * Persistence cannot be used in a Node.js environment.\n *\n * @param firestore - The {@link 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 * @deprecated This function will be removed in a future major release. Instead, set\n * `FirestoreSettings.localCache` to an instance of `PersistentLocalCache` to\n * turn on IndexedDb cache. Calling this function when `FirestoreSettings.localCache`\n * is already specified will throw an exception.\n */\nexport function enableIndexedDbPersistence(\n  firestore: Firestore,\n  persistenceSettings?: PersistenceSettings\n): Promise<void> {\n  logWarn(\n    'enableIndexedDbPersistence() will be deprecated in the future, ' +\n      'you can use `FirestoreSettings.cache` instead.'\n  );\n  const settings = firestore._freezeSettings();\n\n  setPersistenceProviders(firestore, OnlineComponentProvider.provider, {\n    build: (onlineComponents: OnlineComponentProvider) =>\n      new IndexedDbOfflineComponentProvider(\n        onlineComponents,\n        settings.cacheSizeBytes,\n        persistenceSettings?.forceOwnership\n      )\n  });\n  return Promise.resolve();\n}\n\n/**\n * Attempts to enable multi-tab persistent storage, if possible. If enabled\n * across all tabs, all operations share access to local persistence, including\n * shared execution of queries and latency-compensated local document updates\n * across all connected instances.\n *\n * On failure, `enableMultiTabIndexedDbPersistence()` will reject the promise or\n * throw an exception. There are several reasons why this can fail, which can be\n * identified by the `code` on the error.\n *\n *   * failed-precondition: The app is already open in another browser tab and\n *     multi-tab is not enabled.\n *   * unimplemented: The browser is incompatible with the offline persistence\n *     implementation.\n *\n * Note that even after a failure, the {@link Firestore} instance will remain\n * usable, however offline persistence will be disabled.\n *\n * @param firestore - The {@link Firestore} instance to enable persistence for.\n * @returns A `Promise` that represents successfully enabling persistent\n * storage.\n * @deprecated This function will be removed in a future major release. Instead, set\n * `FirestoreSettings.localCache` to an instance of `PersistentLocalCache` to\n * turn on indexeddb cache. Calling this function when `FirestoreSettings.localCache`\n * is already specified will throw an exception.\n */\nexport async function enableMultiTabIndexedDbPersistence(\n  firestore: Firestore\n): Promise<void> {\n  logWarn(\n    'enableMultiTabIndexedDbPersistence() will be deprecated in the future, ' +\n      'you can use `FirestoreSettings.cache` instead.'\n  );\n  const settings = firestore._freezeSettings();\n\n  setPersistenceProviders(firestore, OnlineComponentProvider.provider, {\n    build: (onlineComponents: OnlineComponentProvider) =>\n      new MultiTabOfflineComponentProvider(\n        onlineComponents,\n        settings.cacheSizeBytes\n      )\n  });\n}\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 */\nfunction setPersistenceProviders(\n  firestore: Firestore,\n  onlineComponentProvider: OnlineComponentProviderFactory,\n  offlineComponentProvider: OfflineComponentProviderFactory\n): void {\n  firestore = cast(firestore, Firestore);\n  if (firestore._firestoreClient || firestore._terminated) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'Firestore has already been started and persistence can no longer be ' +\n        'enabled. You can only enable persistence before calling any other ' +\n        'methods on a Firestore object.'\n    );\n  }\n\n  if (firestore._componentsProvider || firestore._getSettings().localCache) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'SDK cache is already specified.'\n    );\n  }\n\n  firestore._componentsProvider = {\n    _online: onlineComponentProvider,\n    _offline: offlineComponentProvider\n  };\n\n  configureFirestore(firestore);\n}\n\n/**\n * Clears the persistent storage. This includes pending writes and cached\n * documents.\n *\n * Must be called while the {@link Firestore} instance is not started (after the app is\n * terminated or when the app is first initialized). On startup, this function\n * must be called before other functions (other than {@link\n * initializeFirestore} or {@link (getFirestore:1)})). If the {@link Firestore}\n * instance is still running, the promise will be rejected with the error code\n * of `failed-precondition`.\n *\n * Note: `clearIndexedDbPersistence()` is primarily intended to help write\n * reliable tests that use Cloud Firestore. It uses an efficient mechanism for\n * dropping existing data but does not attempt to securely overwrite or\n * otherwise make cached data unrecoverable. For applications that are sensitive\n * to the disclosure of cached data in between user sessions, we strongly\n * recommend not enabling persistence at all.\n *\n * @param firestore - The {@link Firestore} instance to clear persistence for.\n * @returns A `Promise` that is resolved when the persistent storage is\n * cleared. Otherwise, the promise is rejected with an error.\n */\nexport function clearIndexedDbPersistence(firestore: Firestore): Promise<void> {\n  if (firestore._initialized && !firestore._terminated) {\n    throw new FirestoreError(\n      Code.FAILED_PRECONDITION,\n      'Persistence can only be cleared before a Firestore instance is ' +\n        'initialized or after it is terminated.'\n    );\n  }\n\n  const deferred = new Deferred<void>();\n  firestore._queue.enqueueAndForgetEvenWhileRestricted(async () => {\n    try {\n      await indexedDbClearPersistence(\n        indexedDbStoragePrefix(firestore._databaseId, firestore._persistenceKey)\n      );\n      deferred.resolve();\n    } catch (e) {\n      deferred.reject(e as Error | undefined);\n    }\n  });\n  return deferred.promise;\n}\n\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 */\nexport function waitForPendingWrites(firestore: Firestore): Promise<void> {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientWaitForPendingWrites(client);\n}\n\n/**\n * Re-enables use of the network for this {@link 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 */\nexport function enableNetwork(firestore: Firestore): Promise<void> {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientEnableNetwork(client);\n}\n\n/**\n * Disables network usage for this instance. It can be re-enabled via {@link\n * enableNetwork}. While the network is disabled, any snapshot listeners,\n * `getDoc()` or `getDocs()` calls will return results from cache, and any write\n * operations will be queued until the network is restored.\n *\n * @returns A `Promise` that is resolved once the network has been disabled.\n */\nexport function disableNetwork(firestore: Firestore): Promise<void> {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientDisableNetwork(client);\n}\n\n/**\n * Terminates the provided {@link Firestore} instance.\n *\n * After calling `terminate()` only the `clearIndexedDbPersistence()` function\n * may be used. Any other function will throw a `FirestoreError`.\n *\n * To restart after termination, create a new instance of FirebaseFirestore with\n * {@link (getFirestore:1)}.\n *\n * Termination does not cancel any pending writes, and any promises that are\n * awaiting a response from the server will not be resolved. If you have\n * persistence enabled, the next time you start this instance, it will resume\n * sending these writes to the server.\n *\n * Note: Under normal circumstances, calling `terminate()` is not required. This\n * function is useful only when you want to force this instance to release all\n * of its resources or in combination with `clearIndexedDbPersistence()` to\n * ensure that all local state is destroyed between test runs.\n *\n * @returns A `Promise` that is resolved when the instance has been successfully\n * terminated.\n */\nexport function terminate(firestore: Firestore): Promise<void> {\n  _removeServiceInstance(\n    firestore.app,\n    'firestore',\n    firestore._databaseId.database\n  );\n  return firestore._delete();\n}\n\n/**\n * Loads a Firestore bundle into the local cache.\n *\n * @param firestore - The {@link Firestore} instance to load bundles for.\n * @param bundleData - An object representing the bundle to be loaded. Valid\n * objects are `ArrayBuffer`, `ReadableStream<Uint8Array>` or `string`.\n *\n * @returns A `LoadBundleTask` object, which notifies callers with progress\n * updates, and completion or error events. It can be used as a\n * `Promise<LoadBundleTaskProgress>`.\n */\nexport function loadBundle(\n  firestore: Firestore,\n  bundleData: ReadableStream<Uint8Array> | ArrayBuffer | string\n): LoadBundleTask {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const resultTask = new LoadBundleTask();\n  firestoreClientLoadBundle(\n    client,\n    firestore._databaseId,\n    bundleData,\n    resultTask\n  );\n  return resultTask;\n}\n\n/**\n * Reads a Firestore {@link Query} from local cache, identified by the given\n * name.\n *\n * The named queries are packaged  into bundles on the server side (along\n * with resulting documents), and loaded to local cache using `loadBundle`. Once\n * in local cache, use this method to extract a {@link Query} by name.\n *\n * @param firestore - The {@link Firestore} instance to read the query from.\n * @param name - The name of the query.\n * @returns A `Promise` that is resolved with the Query or `null`.\n */\nexport function namedQuery(\n  firestore: Firestore,\n  name: string\n): Promise<Query | null> {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientGetNamedQuery(client, name).then(namedQuery => {\n    if (!namedQuery) {\n      return null;\n    }\n\n    return new Query(firestore, null, namedQuery.query);\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 { ByteString } from '../util/byte_string';\nimport { Code, FirestoreError } from '../util/error';\n\n/**\n * An immutable object representing an array of bytes.\n */\nexport class Bytes {\n  _byteString: ByteString;\n\n  /** @hideconstructor */\n  constructor(byteString: ByteString) {\n    this._byteString = byteString;\n  }\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   */\n  static fromBase64String(base64: string): Bytes {\n    try {\n      return new Bytes(ByteString.fromBase64String(base64));\n    } catch (e) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Failed to construct data from Base64 string: ' + e\n      );\n    }\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  static fromUint8Array(array: Uint8Array): Bytes {\n    return new Bytes(ByteString.fromUint8Array(array));\n  }\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  toBase64(): string {\n    return this._byteString.toBase64();\n  }\n\n  /**\n   * Returns the underlying bytes in a new `Uint8Array`.\n   *\n   * @returns The Uint8Array created from the `Bytes` object.\n   */\n  toUint8Array(): Uint8Array {\n    return this._byteString.toUint8Array();\n  }\n\n  /**\n   * Returns a string representation of the `Bytes` object.\n   *\n   * @returns A string representation of the `Bytes` object.\n   */\n  toString(): string {\n    return 'Bytes(base64: ' + this.toBase64() + ')';\n  }\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  isEqual(other: Bytes): boolean {\n    return this._byteString.isEqual(other._byteString);\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  DOCUMENT_KEY_NAME,\n  FieldPath as InternalFieldPath\n} from '../model/path';\nimport { Code, FirestoreError } from '../util/error';\n\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\n * list of field names (referring to a nested field in the document).\n *\n * Create a `FieldPath` by providing field names. If more than one field\n * name is provided, the path will point to a nested field in a document.\n */\nexport class FieldPath {\n  /** Internal representation of a Firestore field path. */\n  readonly _internalPath: InternalFieldPath;\n\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  constructor(...fieldNames: string[]) {\n    for (let i = 0; i < fieldNames.length; ++i) {\n      if (fieldNames[i].length === 0) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid field name at argument $(i + 1). ` +\n            'Field names must not be empty.'\n        );\n      }\n    }\n\n    this._internalPath = new InternalFieldPath(fieldNames);\n  }\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   */\n  isEqual(other: FieldPath): boolean {\n    return this._internalPath.isEqual(other._internalPath);\n  }\n}\n\n/**\n * Returns a special sentinel `FieldPath` to refer to the ID of a document.\n * It can be used in queries to sort or filter by the document ID.\n */\nexport function documentId(): FieldPath {\n  return new FieldPath(DOCUMENT_KEY_NAME);\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 { ParseContext } from '../api/parse_context';\nimport { FieldTransform } from '../model/mutation';\n\n/**\n * Sentinel values that can be used when writing document fields with `set()`\n * or `update()`.\n */\nexport abstract class FieldValue {\n  /**\n   * @param _methodName - The public API endpoint that returns this class.\n   * @hideconstructor\n   */\n  constructor(public _methodName: string) {}\n\n  /** Compares `FieldValue`s for equality. */\n  abstract isEqual(other: FieldValue): boolean;\n  abstract _toFieldTransform(context: ParseContext): FieldTransform | 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 { Code, FirestoreError } from '../util/error';\nimport { primitiveComparator } from '../util/misc';\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 */\nexport class GeoPoint {\n  // Prefix with underscore to signal this is a private variable in JS and\n  // prevent it showing up for autocompletion when typing latitude or longitude.\n  private _lat: number;\n  private _long: number;\n\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  constructor(latitude: number, longitude: number) {\n    if (!isFinite(latitude) || latitude < -90 || latitude > 90) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Latitude must be a number between -90 and 90, but was: ' + latitude\n      );\n    }\n    if (!isFinite(longitude) || longitude < -180 || longitude > 180) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Longitude must be a number between -180 and 180, but was: ' + longitude\n      );\n    }\n\n    this._lat = latitude;\n    this._long = longitude;\n  }\n\n  /**\n   * The latitude of this `GeoPoint` instance.\n   */\n  get latitude(): number {\n    return this._lat;\n  }\n\n  /**\n   * The longitude of this `GeoPoint` instance.\n   */\n  get longitude(): number {\n    return this._long;\n  }\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  isEqual(other: GeoPoint): boolean {\n    return this._lat === other._lat && this._long === other._long;\n  }\n\n  /** Returns a JSON-serializable representation of this GeoPoint. */\n  toJSON(): { latitude: number; longitude: number } {\n    return { latitude: this._lat, longitude: this._long };\n  }\n\n  /**\n   * Actually private to JS consumers of our API, so this function is prefixed\n   * with an underscore.\n   */\n  _compareTo(other: GeoPoint): number {\n    return (\n      primitiveComparator(this._lat, other._lat) ||\n      primitiveComparator(this._long, other._long)\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2024 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { isPrimitiveArrayEqual } from '../util/array';\n\n/**\n * Represents a vector type in Firestore documents.\n * Create an instance with {@link FieldValue.vector}.\n *\n * @class VectorValue\n */\nexport class VectorValue {\n  private readonly _values: number[];\n\n  /**\n   * @private\n   * @internal\n   */\n  constructor(values: number[] | undefined) {\n    // Making a copy of the parameter.\n    this._values = (values || []).map(n => n);\n  }\n\n  /**\n   * Returns a copy of the raw number array form of the vector.\n   */\n  toArray(): number[] {\n    return this._values.map(n => n);\n  }\n\n  /**\n   * Returns `true` if the two VectorValue has the same raw number arrays, returns `false` otherwise.\n   */\n  isEqual(other: VectorValue): boolean {\n    return isPrimitiveArrayEqual(this._values, other._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\n/**\n * Returns true iff the array contains the value using strong equality.\n */\nexport function includes<T>(array: T[], value: T): boolean {\n  for (let i = 0; i < array.length; i++) {\n    if (array[i] === value) {\n      return true;\n    }\n  }\n  return false;\n}\n\n/**\n * Returns true iff the array contains any value matching the predicate\n */\nexport function some<T>(array: T[], predicate: (t: T) => boolean): boolean {\n  for (let i = 0; i < array.length; i++) {\n    if (predicate(array[i])) {\n      return true;\n    }\n  }\n  return false;\n}\n\n/**\n * Calls predicate function for each item in the array until the predicate\n * returns true, at which point the index of that item is returned.  If the\n * predicate does not return true for any item, null is returned.\n */\nexport function findIndex<A>(\n  array: A[],\n  predicate: (value: A) => boolean\n): number | null {\n  for (let i = 0; i < array.length; i++) {\n    if (predicate(array[i])) {\n      return i;\n    }\n  }\n  return null;\n}\n\n/**\n * Compares two array for equality using comparator. The method computes the\n * intersection and invokes `onAdd` for every element that is in `after` but not\n * `before`. `onRemove` is invoked for every element in `before` but missing\n * from `after`.\n *\n * The method creates a copy of both `before` and `after` and runs in O(n log\n * n), where n is the size of the two lists.\n *\n * @param before - The elements that exist in the original array.\n * @param after - The elements to diff against the original array.\n * @param comparator - The comparator for the elements in before and after.\n * @param onAdd - A function to invoke for every element that is part of `\n * after` but not `before`.\n * @param onRemove - A function to invoke for every element that is part of\n * `before` but not `after`.\n */\nexport function diffArrays<T>(\n  before: T[],\n  after: T[],\n  comparator: (l: T, r: T) => number,\n  onAdd: (entry: T) => void,\n  onRemove: (entry: T) => void\n): void {\n  before = [...before];\n  after = [...after];\n  before.sort(comparator);\n  after.sort(comparator);\n\n  const bLen = before.length;\n  const aLen = after.length;\n  let a = 0;\n  let b = 0;\n  while (a < aLen && b < bLen) {\n    const cmp = comparator(before[b], after[a]);\n    if (cmp < 0) {\n      // The element was removed if the next element in our ordered\n      // walkthrough is only in `before`.\n      onRemove(before[b++]);\n    } else if (cmp > 0) {\n      // The element was added if the next element in our ordered walkthrough\n      // is only in `after`.\n      onAdd(after[a++]);\n    } else {\n      a++;\n      b++;\n    }\n  }\n  while (a < aLen) {\n    onAdd(after[a++]);\n  }\n  while (b < bLen) {\n    onRemove(before[b++]);\n  }\n}\n\n/**\n * Verifies equality for an array of objects using the `isEqual` interface.\n *\n * @private\n * @internal\n * @param left Array of objects supporting `isEqual`.\n * @param right Array of objects supporting `isEqual`.\n * @return True if arrays are equal.\n */\nexport function isArrayEqual<T extends { isEqual: (t: T) => boolean }>(\n  left: T[],\n  right: T[]\n): boolean {\n  if (left.length !== right.length) {\n    return false;\n  }\n\n  for (let i = 0; i < left.length; ++i) {\n    if (!left[i].isEqual(right[i])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Verifies equality for an array of primitives.\n *\n * @private\n * @internal\n * @param left Array of primitives.\n * @param right Array of primitives.\n * @return True if arrays are equal.\n */\nexport function isPrimitiveArrayEqual<T extends number | string>(\n  left: T[],\n  right: T[]\n): boolean {\n  if (left.length !== right.length) {\n    return false;\n  }\n\n  for (let i = 0; i < left.length; ++i) {\n    if (left[i] !== right[i]) {\n      return false;\n    }\n  }\n\n  return 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 {\n  DocumentData,\n  FieldPath as PublicFieldPath,\n  SetOptions\n} from '@firebase/firestore-types';\nimport { Compat, deepEqual, getModularInstance } from '@firebase/util';\n\nimport { ParseContext } from '../api/parse_context';\nimport { DatabaseId } from '../core/database_info';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldMask } from '../model/field_mask';\nimport {\n  FieldTransform,\n  Mutation,\n  PatchMutation,\n  Precondition,\n  SetMutation\n} from '../model/mutation';\nimport { ObjectValue } from '../model/object_value';\nimport { FieldPath as InternalFieldPath } from '../model/path';\nimport {\n  ArrayRemoveTransformOperation,\n  ArrayUnionTransformOperation,\n  NumericIncrementTransformOperation,\n  ServerTimestampTransform\n} from '../model/transform_operation';\nimport {\n  TYPE_KEY,\n  VECTOR_MAP_VECTORS_KEY,\n  VECTOR_VALUE_SENTINEL\n} from '../model/values';\nimport { newSerializer } from '../platform/serializer';\nimport {\n  MapValue as ProtoMapValue,\n  Value as ProtoValue\n} from '../protos/firestore_proto_api';\nimport { toDouble, toNumber } from '../remote/number_serializer';\nimport {\n  JsonProtoSerializer,\n  toBytes,\n  toResourceName,\n  toTimestamp\n} from '../remote/serializer';\nimport { debugAssert, fail } from '../util/assert';\nimport { Code, FirestoreError } from '../util/error';\nimport { isPlainObject, valueDescription } from '../util/input_validation';\nimport { Dict, forEach, isEmpty } from '../util/obj';\n\nimport { Bytes } from './bytes';\nimport { Firestore } from './database';\nimport { FieldPath } from './field_path';\nimport { FieldValue } from './field_value';\nimport { GeoPoint } from './geo_point';\nimport {\n  DocumentReference,\n  PartialWithFieldValue,\n  WithFieldValue\n} from './reference';\nimport { Timestamp } from './timestamp';\nimport { VectorValue } from './vector_value';\n\nconst RESERVED_FIELD_REGEX = /^__.*__$/;\n\n/**\n * An untyped Firestore Data Converter interface that is shared between the\n * lite, firestore-exp and classic SDK.\n */\nexport interface UntypedFirestoreDataConverter<\n  AppModelType,\n  DbModelType extends DocumentData = DocumentData\n> {\n  toFirestore(\n    modelObject: WithFieldValue<AppModelType>\n  ): WithFieldValue<DbModelType>;\n  toFirestore(\n    modelObject: PartialWithFieldValue<AppModelType>,\n    options: SetOptions\n  ): PartialWithFieldValue<DbModelType>;\n  fromFirestore(snapshot: unknown, options?: unknown): AppModelType;\n}\n\n/** The result of parsing document data (e.g. for a setData call). */\nexport class ParsedSetData {\n  constructor(\n    readonly data: ObjectValue,\n    readonly fieldMask: FieldMask | null,\n    readonly fieldTransforms: FieldTransform[]\n  ) {}\n\n  toMutation(key: DocumentKey, precondition: Precondition): Mutation {\n    if (this.fieldMask !== null) {\n      return new PatchMutation(\n        key,\n        this.data,\n        this.fieldMask,\n        precondition,\n        this.fieldTransforms\n      );\n    } else {\n      return new SetMutation(\n        key,\n        this.data,\n        precondition,\n        this.fieldTransforms\n      );\n    }\n  }\n}\n\n/** The result of parsing \"update\" data (i.e. for an updateData call). */\nexport class ParsedUpdateData {\n  constructor(\n    readonly data: ObjectValue,\n    // The fieldMask does not include document transforms.\n    readonly fieldMask: FieldMask,\n    readonly fieldTransforms: FieldTransform[]\n  ) {}\n\n  toMutation(key: DocumentKey, precondition: Precondition): Mutation {\n    return new PatchMutation(\n      key,\n      this.data,\n      this.fieldMask,\n      precondition,\n      this.fieldTransforms\n    );\n  }\n}\n\n/*\n * Represents what type of API method provided the data being parsed; useful\n * for determining which error conditions apply during parsing and providing\n * better error messages.\n */\nexport const enum UserDataSource {\n  Set,\n  Update,\n  MergeSet,\n  /**\n   * Indicates the source is a where clause, cursor bound, arrayUnion()\n   * element, etc. Of note, isWrite(source) will return false.\n   */\n  Argument,\n  /**\n   * Indicates that the source is an Argument that may directly contain nested\n   * arrays (e.g. the operand of an `in` query).\n   */\n  ArrayArgument\n}\n\nfunction isWrite(dataSource: UserDataSource): boolean {\n  switch (dataSource) {\n    case UserDataSource.Set: // fall through\n    case UserDataSource.MergeSet: // fall through\n    case UserDataSource.Update:\n      return true;\n    case UserDataSource.Argument:\n    case UserDataSource.ArrayArgument:\n      return false;\n    default:\n      throw fail(`Unexpected case for UserDataSource: ${dataSource}`);\n  }\n}\n\n/** Contains the settings that are mutated as we parse user data. */\ninterface ContextSettings {\n  /** Indicates what kind of API method this data came from. */\n  readonly dataSource: UserDataSource;\n  /** The name of the method the user called to create the ParseContext. */\n  readonly methodName: string;\n  /** The document the user is attempting to modify, if that applies. */\n  readonly targetDoc?: DocumentKey;\n  /**\n   * A path within the object being parsed. This could be an empty path (in\n   * which case the context represents the root of the data being parsed), or a\n   * nonempty path (indicating the context represents a nested location within\n   * the data).\n   */\n  readonly path?: InternalFieldPath;\n  /**\n   * Whether or not this context corresponds to an element of an array.\n   * If not set, elements are treated as if they were outside of arrays.\n   */\n  readonly arrayElement?: boolean;\n  /**\n   * Whether or not a converter was specified in this context. If true, error\n   * messages will reference the converter when invalid data is provided.\n   */\n  readonly hasConverter?: boolean;\n}\n\n/** A \"context\" object passed around while parsing user data. */\nclass ParseContextImpl implements ParseContext {\n  readonly fieldTransforms: FieldTransform[];\n  readonly fieldMask: InternalFieldPath[];\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  constructor(\n    readonly settings: ContextSettings,\n    readonly databaseId: DatabaseId,\n    readonly serializer: JsonProtoSerializer,\n    readonly ignoreUndefinedProperties: boolean,\n    fieldTransforms?: FieldTransform[],\n    fieldMask?: InternalFieldPath[]\n  ) {\n    // Minor hack: If fieldTransforms is undefined, we assume this is an\n    // external call and we need to validate the entire path.\n    if (fieldTransforms === undefined) {\n      this.validatePath();\n    }\n    this.fieldTransforms = fieldTransforms || [];\n    this.fieldMask = fieldMask || [];\n  }\n\n  get path(): InternalFieldPath | undefined {\n    return this.settings.path;\n  }\n\n  get dataSource(): UserDataSource {\n    return this.settings.dataSource;\n  }\n\n  /** Returns a new context with the specified settings overwritten. */\n  contextWith(configuration: Partial<ContextSettings>): ParseContextImpl {\n    return new ParseContextImpl(\n      { ...this.settings, ...configuration },\n      this.databaseId,\n      this.serializer,\n      this.ignoreUndefinedProperties,\n      this.fieldTransforms,\n      this.fieldMask\n    );\n  }\n\n  childContextForField(field: string): ParseContextImpl {\n    const childPath = this.path?.child(field);\n    const context = this.contextWith({ path: childPath, arrayElement: false });\n    context.validatePathSegment(field);\n    return context;\n  }\n\n  childContextForFieldPath(field: InternalFieldPath): ParseContextImpl {\n    const childPath = this.path?.child(field);\n    const context = this.contextWith({ path: childPath, arrayElement: false });\n    context.validatePath();\n    return context;\n  }\n\n  childContextForArray(index: number): ParseContextImpl {\n    // TODO(b/34871131): We don't support array paths right now; so make path\n    // undefined.\n    return this.contextWith({ path: undefined, arrayElement: true });\n  }\n\n  createError(reason: string): FirestoreError {\n    return createError(\n      reason,\n      this.settings.methodName,\n      this.settings.hasConverter || false,\n      this.path,\n      this.settings.targetDoc\n    );\n  }\n\n  /** Returns 'true' if 'fieldPath' was traversed when creating this context. */\n  contains(fieldPath: InternalFieldPath): boolean {\n    return (\n      this.fieldMask.find(field => fieldPath.isPrefixOf(field)) !== undefined ||\n      this.fieldTransforms.find(transform =>\n        fieldPath.isPrefixOf(transform.field)\n      ) !== undefined\n    );\n  }\n\n  private validatePath(): void {\n    // TODO(b/34871131): Remove null check once we have proper paths for fields\n    // within arrays.\n    if (!this.path) {\n      return;\n    }\n    for (let i = 0; i < this.path.length; i++) {\n      this.validatePathSegment(this.path.get(i));\n    }\n  }\n\n  private validatePathSegment(segment: string): void {\n    if (segment.length === 0) {\n      throw this.createError('Document fields must not be empty');\n    }\n    if (isWrite(this.dataSource) && RESERVED_FIELD_REGEX.test(segment)) {\n      throw this.createError('Document fields cannot begin and end with \"__\"');\n    }\n  }\n}\n\n/**\n * Helper for parsing raw user input (provided via the API) into internal model\n * classes.\n */\nexport class UserDataReader {\n  private readonly serializer: JsonProtoSerializer;\n\n  constructor(\n    private readonly databaseId: DatabaseId,\n    private readonly ignoreUndefinedProperties: boolean,\n    serializer?: JsonProtoSerializer\n  ) {\n    this.serializer = serializer || newSerializer(databaseId);\n  }\n\n  /** Creates a new top-level parse context. */\n  createContext(\n    dataSource: UserDataSource,\n    methodName: string,\n    targetDoc?: DocumentKey,\n    hasConverter = false\n  ): ParseContextImpl {\n    return new ParseContextImpl(\n      {\n        dataSource,\n        methodName,\n        targetDoc,\n        path: InternalFieldPath.emptyPath(),\n        arrayElement: false,\n        hasConverter\n      },\n      this.databaseId,\n      this.serializer,\n      this.ignoreUndefinedProperties\n    );\n  }\n}\n\nexport function newUserDataReader(firestore: Firestore): UserDataReader {\n  const settings = firestore._freezeSettings();\n  const serializer = newSerializer(firestore._databaseId);\n  return new UserDataReader(\n    firestore._databaseId,\n    !!settings.ignoreUndefinedProperties,\n    serializer\n  );\n}\n\n/** Parse document data from a set() call. */\nexport function parseSetData(\n  userDataReader: UserDataReader,\n  methodName: string,\n  targetDoc: DocumentKey,\n  input: unknown,\n  hasConverter: boolean,\n  options: SetOptions = {}\n): ParsedSetData {\n  const context = userDataReader.createContext(\n    options.merge || options.mergeFields\n      ? UserDataSource.MergeSet\n      : UserDataSource.Set,\n    methodName,\n    targetDoc,\n    hasConverter\n  );\n  validatePlainObject('Data must be an object, but it was:', context, input);\n  const updateData = parseObject(input, context)!;\n\n  let fieldMask: FieldMask | null;\n  let fieldTransforms: FieldTransform[];\n\n  if (options.merge) {\n    fieldMask = new FieldMask(context.fieldMask);\n    fieldTransforms = context.fieldTransforms;\n  } else if (options.mergeFields) {\n    const validatedFieldPaths: InternalFieldPath[] = [];\n\n    for (const stringOrFieldPath of options.mergeFields) {\n      const fieldPath = fieldPathFromArgument(\n        methodName,\n        stringOrFieldPath,\n        targetDoc\n      );\n      if (!context.contains(fieldPath)) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Field '${fieldPath}' is specified in your field mask but missing from your input data.`\n        );\n      }\n\n      if (!fieldMaskContains(validatedFieldPaths, fieldPath)) {\n        validatedFieldPaths.push(fieldPath);\n      }\n    }\n\n    fieldMask = new FieldMask(validatedFieldPaths);\n    fieldTransforms = context.fieldTransforms.filter(transform =>\n      fieldMask!.covers(transform.field)\n    );\n  } else {\n    fieldMask = null;\n    fieldTransforms = context.fieldTransforms;\n  }\n\n  return new ParsedSetData(\n    new ObjectValue(updateData),\n    fieldMask,\n    fieldTransforms\n  );\n}\n\nexport class DeleteFieldValueImpl extends FieldValue {\n  _toFieldTransform(context: ParseContextImpl): null {\n    if (context.dataSource === UserDataSource.MergeSet) {\n      // No transform to add for a delete, but we need to add it to our\n      // fieldMask so it gets deleted.\n      context.fieldMask.push(context.path!);\n    } else if (context.dataSource === UserDataSource.Update) {\n      debugAssert(\n        context.path!.length > 0,\n        `${this._methodName}() at the top level should have already ` +\n          'been handled.'\n      );\n      throw context.createError(\n        `${this._methodName}() can only appear at the top level ` +\n          'of your update data'\n      );\n    } else {\n      // We shouldn't encounter delete sentinels for queries or non-merge set() calls.\n      throw context.createError(\n        `${this._methodName}() cannot be used with set() unless you pass ` +\n          '{merge:true}'\n      );\n    }\n    return null;\n  }\n\n  isEqual(other: FieldValue): boolean {\n    return other instanceof DeleteFieldValueImpl;\n  }\n}\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 */\nfunction createSentinelChildContext(\n  fieldValue: FieldValue,\n  context: ParseContextImpl,\n  arrayElement: boolean\n): ParseContextImpl {\n  return new ParseContextImpl(\n    {\n      dataSource: UserDataSource.Argument,\n      targetDoc: context.settings.targetDoc,\n      methodName: fieldValue._methodName,\n      arrayElement\n    },\n    context.databaseId,\n    context.serializer,\n    context.ignoreUndefinedProperties\n  );\n}\n\nexport class ServerTimestampFieldValueImpl extends FieldValue {\n  _toFieldTransform(context: ParseContextImpl): FieldTransform {\n    return new FieldTransform(context.path!, new ServerTimestampTransform());\n  }\n\n  isEqual(other: FieldValue): boolean {\n    return other instanceof ServerTimestampFieldValueImpl;\n  }\n}\n\nexport class ArrayUnionFieldValueImpl extends FieldValue {\n  constructor(methodName: string, private readonly _elements: unknown[]) {\n    super(methodName);\n  }\n\n  _toFieldTransform(context: ParseContextImpl): FieldTransform {\n    const parseContext = createSentinelChildContext(\n      this,\n      context,\n      /*array=*/ true\n    );\n    const parsedElements = this._elements.map(\n      element => parseData(element, parseContext)!\n    );\n    const arrayUnion = new ArrayUnionTransformOperation(parsedElements);\n    return new FieldTransform(context.path!, arrayUnion);\n  }\n\n  isEqual(other: FieldValue): boolean {\n    return (\n      other instanceof ArrayUnionFieldValueImpl &&\n      deepEqual(this._elements, other._elements)\n    );\n  }\n}\n\nexport class ArrayRemoveFieldValueImpl extends FieldValue {\n  constructor(methodName: string, private readonly _elements: unknown[]) {\n    super(methodName);\n  }\n\n  _toFieldTransform(context: ParseContextImpl): FieldTransform {\n    const parseContext = createSentinelChildContext(\n      this,\n      context,\n      /*array=*/ true\n    );\n    const parsedElements = this._elements.map(\n      element => parseData(element, parseContext)!\n    );\n    const arrayUnion = new ArrayRemoveTransformOperation(parsedElements);\n    return new FieldTransform(context.path!, arrayUnion);\n  }\n\n  isEqual(other: FieldValue): boolean {\n    return (\n      other instanceof ArrayRemoveFieldValueImpl &&\n      deepEqual(this._elements, other._elements)\n    );\n  }\n}\n\nexport class NumericIncrementFieldValueImpl extends FieldValue {\n  constructor(methodName: string, private readonly _operand: number) {\n    super(methodName);\n  }\n\n  _toFieldTransform(context: ParseContextImpl): FieldTransform {\n    const numericIncrement = new NumericIncrementTransformOperation(\n      context.serializer,\n      toNumber(context.serializer, this._operand)\n    );\n    return new FieldTransform(context.path!, numericIncrement);\n  }\n\n  isEqual(other: FieldValue): boolean {\n    return (\n      other instanceof NumericIncrementFieldValueImpl &&\n      this._operand === other._operand\n    );\n  }\n}\n\n/** Parse update data from an update() call. */\nexport function parseUpdateData(\n  userDataReader: UserDataReader,\n  methodName: string,\n  targetDoc: DocumentKey,\n  input: unknown\n): ParsedUpdateData {\n  const context = userDataReader.createContext(\n    UserDataSource.Update,\n    methodName,\n    targetDoc\n  );\n  validatePlainObject('Data must be an object, but it was:', context, input);\n\n  const fieldMaskPaths: InternalFieldPath[] = [];\n  const updateData = ObjectValue.empty();\n  forEach(input as Dict<unknown>, (key, value) => {\n    const path = fieldPathFromDotSeparatedString(methodName, key, targetDoc);\n\n    // For Compat types, we have to \"extract\" the underlying types before\n    // performing validation.\n    value = getModularInstance(value);\n\n    const childContext = context.childContextForFieldPath(path);\n    if (value instanceof DeleteFieldValueImpl) {\n      // Add it to the field mask, but don't add anything to updateData.\n      fieldMaskPaths.push(path);\n    } else {\n      const parsedValue = parseData(value, childContext);\n      if (parsedValue != null) {\n        fieldMaskPaths.push(path);\n        updateData.set(path, parsedValue);\n      }\n    }\n  });\n\n  const mask = new FieldMask(fieldMaskPaths);\n  return new ParsedUpdateData(updateData, mask, context.fieldTransforms);\n}\n\n/** Parse update data from a list of field/value arguments. */\nexport function parseUpdateVarargs(\n  userDataReader: UserDataReader,\n  methodName: string,\n  targetDoc: DocumentKey,\n  field: string | PublicFieldPath | Compat<PublicFieldPath>,\n  value: unknown,\n  moreFieldsAndValues: unknown[]\n): ParsedUpdateData {\n  const context = userDataReader.createContext(\n    UserDataSource.Update,\n    methodName,\n    targetDoc\n  );\n  const keys = [fieldPathFromArgument(methodName, field, targetDoc)];\n  const values = [value];\n\n  if (moreFieldsAndValues.length % 2 !== 0) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Function ${methodName}() needs to be called with an even number ` +\n        'of arguments that alternate between field names and values.'\n    );\n  }\n\n  for (let i = 0; i < moreFieldsAndValues.length; i += 2) {\n    keys.push(\n      fieldPathFromArgument(\n        methodName,\n        moreFieldsAndValues[i] as string | PublicFieldPath\n      )\n    );\n    values.push(moreFieldsAndValues[i + 1]);\n  }\n\n  const fieldMaskPaths: InternalFieldPath[] = [];\n  const updateData = ObjectValue.empty();\n\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 (let i = keys.length - 1; i >= 0; --i) {\n    if (!fieldMaskContains(fieldMaskPaths, keys[i])) {\n      const path = keys[i];\n      let value = values[i];\n\n      // For Compat types, we have to \"extract\" the underlying types before\n      // performing validation.\n      value = getModularInstance(value);\n\n      const childContext = context.childContextForFieldPath(path);\n      if (value instanceof DeleteFieldValueImpl) {\n        // Add it to the field mask, but don't add anything to updateData.\n        fieldMaskPaths.push(path);\n      } else {\n        const parsedValue = parseData(value, childContext);\n        if (parsedValue != null) {\n          fieldMaskPaths.push(path);\n          updateData.set(path, parsedValue);\n        }\n      }\n    }\n  }\n\n  const mask = new FieldMask(fieldMaskPaths);\n  return new ParsedUpdateData(updateData, mask, context.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 */\nexport function parseQueryValue(\n  userDataReader: UserDataReader,\n  methodName: string,\n  input: unknown,\n  allowArrays = false\n): ProtoValue {\n  const context = userDataReader.createContext(\n    allowArrays ? UserDataSource.ArrayArgument : UserDataSource.Argument,\n    methodName\n  );\n  const parsed = parseData(input, context);\n  debugAssert(parsed != null, 'Parsed data should not be null.');\n  debugAssert(\n    context.fieldTransforms.length === 0,\n    'Field transforms should have been disallowed.'\n  );\n  return parsed;\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 */\nexport function parseData(\n  input: unknown,\n  context: ParseContextImpl\n): ProtoValue | null {\n  // Unwrap the API type from the Compat SDK. This will return the API type\n  // from firestore-exp.\n  input = getModularInstance(input);\n\n  if (looksLikeJsonObject(input)) {\n    validatePlainObject('Unsupported field value:', context, input);\n    return parseObject(input, context);\n  } else if (input instanceof FieldValue) {\n    // FieldValues usually parse into transforms (except deleteField())\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    parseSentinelFieldValue(input, context);\n    return null;\n  } else if (input === undefined && context.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  } else {\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    if (context.path) {\n      context.fieldMask.push(context.path);\n    }\n\n    if (input 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 (\n        context.settings.arrayElement &&\n        context.dataSource !== UserDataSource.ArrayArgument\n      ) {\n        throw context.createError('Nested arrays are not supported');\n      }\n      return parseArray(input as unknown[], context);\n    } else {\n      return parseScalarValue(input, context);\n    }\n  }\n}\n\nfunction parseObject(\n  obj: Dict<unknown>,\n  context: ParseContextImpl\n): { mapValue: ProtoMapValue } {\n  const fields: Dict<ProtoValue> = {};\n\n  if (isEmpty(obj)) {\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    if (context.path && context.path.length > 0) {\n      context.fieldMask.push(context.path);\n    }\n  } else {\n    forEach(obj, (key: string, val: unknown) => {\n      const parsedValue = parseData(val, context.childContextForField(key));\n      if (parsedValue != null) {\n        fields[key] = parsedValue;\n      }\n    });\n  }\n\n  return { mapValue: { fields } };\n}\n\nfunction parseArray(array: unknown[], context: ParseContextImpl): ProtoValue {\n  const values: ProtoValue[] = [];\n  let entryIndex = 0;\n  for (const entry of array) {\n    let parsedEntry = parseData(\n      entry,\n      context.childContextForArray(entryIndex)\n    );\n    if (parsedEntry == null) {\n      // Just include nulls in the array for fields being replaced with a\n      // sentinel.\n      parsedEntry = { nullValue: 'NULL_VALUE' };\n    }\n    values.push(parsedEntry);\n    entryIndex++;\n  }\n  return { arrayValue: { values } };\n}\n\n/**\n * \"Parses\" the provided FieldValueImpl, adding any necessary transforms to\n * context.fieldTransforms.\n */\nfunction parseSentinelFieldValue(\n  value: FieldValue,\n  context: ParseContextImpl\n): void {\n  // Sentinels are only supported with writes, and not within arrays.\n  if (!isWrite(context.dataSource)) {\n    throw context.createError(\n      `${value._methodName}() can only be used with update() and set()`\n    );\n  }\n  if (!context.path) {\n    throw context.createError(\n      `${value._methodName}() is not currently supported inside arrays`\n    );\n  }\n\n  const fieldTransform = value._toFieldTransform(context);\n  if (fieldTransform) {\n    context.fieldTransforms.push(fieldTransform);\n  }\n}\n\n/**\n * Helper to parse a scalar value (i.e. not an Object, Array, or FieldValue)\n *\n * @returns The parsed value\n */\nfunction parseScalarValue(\n  value: unknown,\n  context: ParseContextImpl\n): ProtoValue | null {\n  value = getModularInstance(value);\n\n  if (value === null) {\n    return { nullValue: 'NULL_VALUE' };\n  } else if (typeof value === 'number') {\n    return toNumber(context.serializer, value);\n  } else if (typeof value === 'boolean') {\n    return { booleanValue: value };\n  } else if (typeof value === 'string') {\n    return { stringValue: value };\n  } else if (value instanceof Date) {\n    const timestamp = Timestamp.fromDate(value);\n    return {\n      timestampValue: toTimestamp(context.serializer, timestamp)\n    };\n  } else if (value instanceof Timestamp) {\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    const timestamp = new Timestamp(\n      value.seconds,\n      Math.floor(value.nanoseconds / 1000) * 1000\n    );\n    return {\n      timestampValue: toTimestamp(context.serializer, timestamp)\n    };\n  } else if (value instanceof GeoPoint) {\n    return {\n      geoPointValue: {\n        latitude: value.latitude,\n        longitude: value.longitude\n      }\n    };\n  } else if (value instanceof Bytes) {\n    return { bytesValue: toBytes(context.serializer, value._byteString) };\n  } else if (value instanceof DocumentReference) {\n    const thisDb = context.databaseId;\n    const otherDb = value.firestore._databaseId;\n    if (!otherDb.isEqual(thisDb)) {\n      throw context.createError(\n        'Document reference is for database ' +\n          `${otherDb.projectId}/${otherDb.database} but should be ` +\n          `for database ${thisDb.projectId}/${thisDb.database}`\n      );\n    }\n    return {\n      referenceValue: toResourceName(\n        value.firestore._databaseId || context.databaseId,\n        value._key.path\n      )\n    };\n  } else if (value instanceof VectorValue) {\n    return parseVectorValue(value, context);\n  } else {\n    throw context.createError(\n      `Unsupported field value: ${valueDescription(value)}`\n    );\n  }\n}\n\n/**\n * Creates a new VectorValue proto value (using the internal format).\n */\nexport function parseVectorValue(\n  value: VectorValue,\n  context: ParseContextImpl\n): ProtoValue {\n  const mapValue: ProtoMapValue = {\n    fields: {\n      [TYPE_KEY]: {\n        stringValue: VECTOR_VALUE_SENTINEL\n      },\n      [VECTOR_MAP_VECTORS_KEY]: {\n        arrayValue: {\n          values: value.toArray().map(value => {\n            if (typeof value !== 'number') {\n              throw context.createError(\n                'VectorValues must only contain numeric values.'\n              );\n            }\n\n            return toDouble(context.serializer, value);\n          })\n        }\n      }\n    }\n  };\n\n  return { mapValue };\n}\n\n/**\n * Checks whether an object looks like a JSON object that should be converted\n * into a struct. Normal class/prototype instances are considered to look like\n * JSON objects since they should be converted to a struct value. Arrays, Dates,\n * GeoPoints, etc. are not considered to look like JSON objects since they map\n * to specific FieldValue types other than ObjectValue.\n */\nfunction looksLikeJsonObject(input: unknown): boolean {\n  return (\n    typeof input === 'object' &&\n    input !== null &&\n    !(input instanceof Array) &&\n    !(input instanceof Date) &&\n    !(input instanceof Timestamp) &&\n    !(input instanceof GeoPoint) &&\n    !(input instanceof Bytes) &&\n    !(input instanceof DocumentReference) &&\n    !(input instanceof FieldValue) &&\n    !(input instanceof VectorValue)\n  );\n}\n\nfunction validatePlainObject(\n  message: string,\n  context: ParseContextImpl,\n  input: unknown\n): asserts input is Dict<unknown> {\n  if (!looksLikeJsonObject(input) || !isPlainObject(input)) {\n    const description = valueDescription(input);\n    if (description === 'an object') {\n      // Massage the error if it was an object.\n      throw context.createError(message + ' a custom object');\n    } else {\n      throw context.createError(message + ' ' + description);\n    }\n  }\n}\n\n/**\n * Helper that calls fromDotSeparatedString() but wraps any error thrown.\n */\nexport function fieldPathFromArgument(\n  methodName: string,\n  path: string | PublicFieldPath | Compat<PublicFieldPath>,\n  targetDoc?: DocumentKey\n): InternalFieldPath {\n  // If required, replace the FieldPath Compat class with the firestore-exp\n  // FieldPath.\n  path = getModularInstance(path);\n\n  if (path instanceof FieldPath) {\n    return path._internalPath;\n  } else if (typeof path === 'string') {\n    return fieldPathFromDotSeparatedString(methodName, path);\n  } else {\n    const message = 'Field path arguments must be of type string or ';\n    throw createError(\n      message,\n      methodName,\n      /* hasConverter= */ false,\n      /* path= */ undefined,\n      targetDoc\n    );\n  }\n}\n\n/**\n * Matches any characters in a field path string that are reserved.\n */\nconst FIELD_PATH_RESERVED = 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 */\nexport function fieldPathFromDotSeparatedString(\n  methodName: string,\n  path: string,\n  targetDoc?: DocumentKey\n): InternalFieldPath {\n  const found = path.search(FIELD_PATH_RESERVED);\n  if (found >= 0) {\n    throw createError(\n      `Invalid field path (${path}). Paths must not contain ` +\n        `'~', '*', '/', '[', or ']'`,\n      methodName,\n      /* hasConverter= */ false,\n      /* path= */ undefined,\n      targetDoc\n    );\n  }\n\n  try {\n    return new FieldPath(...path.split('.'))._internalPath;\n  } catch (e) {\n    throw createError(\n      `Invalid field path (${path}). Paths must not be empty, ` +\n        `begin with '.', end with '.', or contain '..'`,\n      methodName,\n      /* hasConverter= */ false,\n      /* path= */ undefined,\n      targetDoc\n    );\n  }\n}\n\nfunction createError(\n  reason: string,\n  methodName: string,\n  hasConverter: boolean,\n  path?: InternalFieldPath,\n  targetDoc?: DocumentKey\n): FirestoreError {\n  const hasPath = path && !path.isEmpty();\n  const hasDocument = targetDoc !== undefined;\n  let message = `Function ${methodName}() called with invalid data`;\n  if (hasConverter) {\n    message += ' (via `toFirestore()`)';\n  }\n  message += '. ';\n\n  let description = '';\n  if (hasPath || hasDocument) {\n    description += ' (found';\n\n    if (hasPath) {\n      description += ` in field ${path}`;\n    }\n    if (hasDocument) {\n      description += ` in document ${targetDoc}`;\n    }\n    description += ')';\n  }\n\n  return new FirestoreError(\n    Code.INVALID_ARGUMENT,\n    message + reason + description\n  );\n}\n\n/** Checks `haystack` if FieldPath `needle` is present. Runs in O(n). */\nfunction fieldMaskContains(\n  haystack: InternalFieldPath[],\n  needle: InternalFieldPath\n): boolean {\n  return haystack.some(v => v.isEqual(needle));\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 { Compat, getModularInstance } from '@firebase/util';\n\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldPath as InternalFieldPath } from '../model/path';\nimport { arrayEquals } from '../util/misc';\n\nimport { Firestore } from './database';\nimport { FieldPath } from './field_path';\nimport {\n  DocumentData,\n  DocumentReference,\n  PartialWithFieldValue,\n  Query,\n  queryEqual,\n  SetOptions,\n  WithFieldValue\n} from './reference';\nimport {\n  fieldPathFromDotSeparatedString,\n  UntypedFirestoreDataConverter\n} from './user_data_reader';\nimport { AbstractUserDataWriter } from './user_data_writer';\n\n/**\n * Converter used by `withConverter()` to transform user objects of type\n * `AppModelType` into Firestore data of type `DbModelType`.\n *\n * Using the converter allows you to specify generic type arguments when\n * storing and retrieving objects from Firestore.\n *\n * In this context, an \"AppModel\" is a class that is used in an application to\n * package together related information and functionality. Such a class could,\n * for example, have properties with complex, nested data types, properties used\n * for memoization, properties of types not supported by Firestore (such as\n * `symbol` and `bigint`), and helper functions that perform compound\n * operations. Such classes are not suitable and/or possible to store into a\n * Firestore database. Instead, instances of such classes need to be converted\n * to \"plain old JavaScript objects\" (POJOs) with exclusively primitive\n * properties, potentially nested inside other POJOs or arrays of POJOs. In this\n * context, this type is referred to as the \"DbModel\" and would be an object\n * suitable for persisting into Firestore. For convenience, applications can\n * implement `FirestoreDataConverter` and register the converter with Firestore\n * objects, such as `DocumentReference` or `Query`, to automatically convert\n * `AppModel` to `DbModel` when storing into Firestore, and convert `DbModel`\n * to `AppModel` when retrieving from Firestore.\n *\n * @example\n *\n * Simple Example\n *\n * ```typescript\n * const numberConverter = {\n *     toFirestore(value: WithFieldValue<number>) {\n *         return { value };\n *     },\n *     fromFirestore(snapshot: QueryDocumentSnapshot, options: SnapshotOptions) {\n *         return snapshot.data(options).value as number;\n *     }\n * };\n *\n * async function simpleDemo(db: Firestore): Promise<void> {\n *     const documentRef = doc(db, 'values/value123').withConverter(numberConverter);\n *\n *     // converters are used with `setDoc`, `addDoc`, and `getDoc`\n *     await setDoc(documentRef, 42);\n *     const snapshot1 = await getDoc(documentRef);\n *     assertEqual(snapshot1.data(), 42);\n *\n *     // converters are not used when writing data with `updateDoc`\n *     await updateDoc(documentRef, { value: 999 });\n *     const snapshot2 = await getDoc(documentRef);\n *     assertEqual(snapshot2.data(), 999);\n * }\n * ```\n *\n * Advanced Example\n *\n * ```typescript\n * // The Post class is a model that is used by our application.\n * // This class may have properties and methods that are specific\n * // to our application execution, which do not need to be persisted\n * // to Firestore.\n * class Post {\n *     constructor(\n *         readonly title: string,\n *         readonly author: string,\n *         readonly lastUpdatedMillis: number\n *     ) {}\n *     toString(): string {\n *         return `${this.title} by ${this.author}`;\n *     }\n * }\n *\n * // The PostDbModel represents how we want our posts to be stored\n * // in Firestore. This DbModel has different properties (`ttl`,\n * // `aut`, and `lut`) from the Post class we use in our application.\n * interface PostDbModel {\n *     ttl: string;\n *     aut: { firstName: string; lastName: string };\n *     lut: Timestamp;\n * }\n *\n * // The `PostConverter` implements `FirestoreDataConverter` and specifies\n * // how the Firestore SDK can convert `Post` objects to `PostDbModel`\n * // objects and vice versa.\n * class PostConverter implements FirestoreDataConverter<Post, PostDbModel> {\n *     toFirestore(post: WithFieldValue<Post>): WithFieldValue<PostDbModel> {\n *         return {\n *             ttl: post.title,\n *             aut: this._autFromAuthor(post.author),\n *             lut: this._lutFromLastUpdatedMillis(post.lastUpdatedMillis)\n *         };\n *     }\n *\n *     fromFirestore(snapshot: QueryDocumentSnapshot, options: SnapshotOptions): Post {\n *         const data = snapshot.data(options) as PostDbModel;\n *         const author = `${data.aut.firstName} ${data.aut.lastName}`;\n *         return new Post(data.ttl, author, data.lut.toMillis());\n *     }\n *\n *     _autFromAuthor(\n *         author: string | FieldValue\n *     ): { firstName: string; lastName: string } | FieldValue {\n *         if (typeof author !== 'string') {\n *             // `author` is a FieldValue, so just return it.\n *             return author;\n *         }\n *         const [firstName, lastName] = author.split(' ');\n *         return {firstName, lastName};\n *     }\n *\n *     _lutFromLastUpdatedMillis(\n *         lastUpdatedMillis: number | FieldValue\n *     ): Timestamp | FieldValue {\n *         if (typeof lastUpdatedMillis !== 'number') {\n *             // `lastUpdatedMillis` must be a FieldValue, so just return it.\n *             return lastUpdatedMillis;\n *         }\n *         return Timestamp.fromMillis(lastUpdatedMillis);\n *     }\n * }\n *\n * async function advancedDemo(db: Firestore): Promise<void> {\n *     // Create a `DocumentReference` with a `FirestoreDataConverter`.\n *     const documentRef = doc(db, 'posts/post123').withConverter(new PostConverter());\n *\n *     // The `data` argument specified to `setDoc()` is type checked by the\n *     // TypeScript compiler to be compatible with `Post`. Since the `data`\n *     // argument is typed as `WithFieldValue<Post>` rather than just `Post`,\n *     // this allows properties of the `data` argument to also be special\n *     // Firestore values that perform server-side mutations, such as\n *     // `arrayRemove()`, `deleteField()`, and `serverTimestamp()`.\n *     await setDoc(documentRef, {\n *         title: 'My Life',\n *         author: 'Foo Bar',\n *         lastUpdatedMillis: serverTimestamp()\n *     });\n *\n *     // The TypeScript compiler will fail to compile if the `data` argument to\n *     // `setDoc()` is _not_ compatible with `WithFieldValue<Post>`. This\n *     // type checking prevents the caller from specifying objects with incorrect\n *     // properties or property values.\n *     // @ts-expect-error \"Argument of type { ttl: string; } is not assignable\n *     // to parameter of type WithFieldValue<Post>\"\n *     await setDoc(documentRef, { ttl: 'The Title' });\n *\n *     // When retrieving a document with `getDoc()` the `DocumentSnapshot`\n *     // object's `data()` method returns a `Post`, rather than a generic object,\n *     // which would have been returned if the `DocumentReference` did _not_ have a\n *     // `FirestoreDataConverter` attached to it.\n *     const snapshot1: DocumentSnapshot<Post> = await getDoc(documentRef);\n *     const post1: Post = snapshot1.data()!;\n *     if (post1) {\n *         assertEqual(post1.title, 'My Life');\n *         assertEqual(post1.author, 'Foo Bar');\n *     }\n *\n *     // The `data` argument specified to `updateDoc()` is type checked by the\n *     // TypeScript compiler to be compatible with `PostDbModel`. Note that\n *     // unlike `setDoc()`, whose `data` argument must be compatible with `Post`,\n *     // the `data` argument to `updateDoc()` must be compatible with\n *     // `PostDbModel`. Similar to `setDoc()`, since the `data` argument is typed\n *     // as `WithFieldValue<PostDbModel>` rather than just `PostDbModel`, this\n *     // allows properties of the `data` argument to also be those special\n *     // Firestore values, like `arrayRemove()`, `deleteField()`, and\n *     // `serverTimestamp()`.\n *     await updateDoc(documentRef, {\n *         'aut.firstName': 'NewFirstName',\n *         lut: serverTimestamp()\n *     });\n *\n *     // The TypeScript compiler will fail to compile if the `data` argument to\n *     // `updateDoc()` is _not_ compatible with `WithFieldValue<PostDbModel>`.\n *     // This type checking prevents the caller from specifying objects with\n *     // incorrect properties or property values.\n *     // @ts-expect-error \"Argument of type { title: string; } is not assignable\n *     // to parameter of type WithFieldValue<PostDbModel>\"\n *     await updateDoc(documentRef, { title: 'New Title' });\n *     const snapshot2: DocumentSnapshot<Post> = await getDoc(documentRef);\n *     const post2: Post = snapshot2.data()!;\n *     if (post2) {\n *         assertEqual(post2.title, 'My Life');\n *         assertEqual(post2.author, 'NewFirstName Bar');\n *     }\n * }\n * ```\n */\nexport interface FirestoreDataConverter<\n  AppModelType,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /**\n   * Called by the Firestore SDK to convert a custom model object of type\n   * `AppModelType` into a plain JavaScript object (suitable for writing\n   * directly to the Firestore database) of type `DbModelType`. Used with\n   * {@link @firebase/firestore/lite#(setDoc:1)},\n   * {@link @firebase/firestore/lite#(WriteBatch.set:1)} and\n   * {@link @firebase/firestore/lite#(Transaction.set:1)}.\n   *\n   * The `WithFieldValue<T>` type extends `T` to also allow FieldValues such as\n   * {@link (deleteField:1)} to be used as property values.\n   */\n  toFirestore(\n    modelObject: WithFieldValue<AppModelType>\n  ): WithFieldValue<DbModelType>;\n\n  /**\n   * Called by the Firestore SDK to convert a custom model object of type\n   * `AppModelType` into a plain JavaScript object (suitable for writing\n   * directly to the Firestore database) of type `DbModelType`. Used with\n   * {@link @firebase/firestore/lite#(setDoc:1)},\n   * {@link @firebase/firestore/lite#(WriteBatch.set:1)} and\n   * {@link @firebase/firestore/lite#(Transaction.set:1)} with `merge:true`\n   * or `mergeFields`.\n   *\n   * The `PartialWithFieldValue<T>` type extends `Partial<T>` to allow\n   * FieldValues such as {@link (arrayUnion:1)} to be used as property values.\n   * It also supports nested `Partial` by allowing nested fields to be\n   * omitted.\n   */\n  toFirestore(\n    modelObject: PartialWithFieldValue<AppModelType>,\n    options: SetOptions\n  ): PartialWithFieldValue<DbModelType>;\n\n  /**\n   * Called by the Firestore SDK to convert Firestore data into an object of\n   * type `AppModelType`. You can access your data by calling:\n   * `snapshot.data()`.\n   *\n   *\n   * Generally, the data returned from `snapshot.data()` can be cast to\n   * `DbModelType`; however, this is not guaranteed because Firestore does not\n   * enforce a schema on the database. For example, writes from a previous\n   * version of the application or writes from another client that did not use a\n   * type converter could have written data with different properties and/or\n   * property types. The implementation will need to choose whether to\n   * gracefully recover from non-conforming data or throw an error.\n   *\n   * @param snapshot - A `QueryDocumentSnapshot` containing your data and\n   * metadata.\n   */\n  fromFirestore(\n    snapshot: QueryDocumentSnapshot<DocumentData, DocumentData>\n  ): AppModelType;\n}\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 */\nexport class DocumentSnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\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\n  /** @hideconstructor protected */\n  constructor(\n    public _firestore: Firestore,\n    public _userDataWriter: AbstractUserDataWriter,\n    public _key: DocumentKey,\n    public _document: Document | null,\n    public _converter: UntypedFirestoreDataConverter<\n      AppModelType,\n      DbModelType\n    > | null\n  ) {}\n\n  /** Property of the `DocumentSnapshot` that provides the document's ID. */\n  get id(): string {\n    return this._key.path.lastSegment();\n  }\n\n  /**\n   * The `DocumentReference` for the document included in the `DocumentSnapshot`.\n   */\n  get ref(): DocumentReference<AppModelType, DbModelType> {\n    return new DocumentReference<AppModelType, DbModelType>(\n      this._firestore,\n      this._converter,\n      this._key\n    );\n  }\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  exists(): this is QueryDocumentSnapshot<AppModelType, DbModelType> {\n    return this._document !== null;\n  }\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  data(): AppModelType | undefined {\n    if (!this._document) {\n      return undefined;\n    } else if (this._converter) {\n      // We only want to use the converter and create a new DocumentSnapshot\n      // if a converter has been provided.\n      const snapshot = new QueryDocumentSnapshot(\n        this._firestore,\n        this._userDataWriter,\n        this._key,\n        this._document,\n        /* converter= */ null\n      );\n      return this._converter.fromFirestore(snapshot);\n    } else {\n      return this._userDataWriter.convertValue(\n        this._document.data.value\n      ) as AppModelType;\n    }\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  get(fieldPath: string | FieldPath): any {\n    if (this._document) {\n      const value = this._document.data.field(\n        fieldPathFromArgument('DocumentSnapshot.get', fieldPath)\n      );\n      if (value !== null) {\n        return this._userDataWriter.convertValue(value);\n      }\n    }\n    return undefined;\n  }\n}\n\n/**\n * A `QueryDocumentSnapshot` contains data read from a document in your\n * Firestore database as part of a query. The document is guaranteed to exist\n * and its data can be extracted with `.data()` or `.get(<field>)` to get a\n * specific field.\n *\n * A `QueryDocumentSnapshot` offers the same API surface as a\n * `DocumentSnapshot`. Since query results contain only existing documents, the\n * `exists` property will always be true and `data()` will never return\n * 'undefined'.\n */\nexport class QueryDocumentSnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> extends DocumentSnapshot<AppModelType, DbModelType> {\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   */\n  data(): AppModelType {\n    return super.data() as AppModelType;\n  }\n}\n\n/**\n * A `QuerySnapshot` contains zero or more `DocumentSnapshot` objects\n * representing the results of a query. The documents can be accessed as an\n * array via the `docs` property or enumerated using the `forEach` method. The\n * number of documents can be determined via the `empty` and `size`\n * properties.\n */\nexport class QuerySnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /**\n   * The query on which you called {@link getDocs} in order to get this\n   * `QuerySnapshot`.\n   */\n  readonly query: Query<AppModelType, DbModelType>;\n\n  /** @hideconstructor */\n  constructor(\n    _query: Query<AppModelType, DbModelType>,\n    readonly _docs: Array<QueryDocumentSnapshot<AppModelType, DbModelType>>\n  ) {\n    this.query = _query;\n  }\n\n  /** An array of all the documents in the `QuerySnapshot`. */\n  get docs(): Array<QueryDocumentSnapshot<AppModelType, DbModelType>> {\n    return [...this._docs];\n  }\n\n  /** The number of documents in the `QuerySnapshot`. */\n  get size(): number {\n    return this.docs.length;\n  }\n\n  /** True if there are no documents in the `QuerySnapshot`. */\n  get empty(): boolean {\n    return this.docs.length === 0;\n  }\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  forEach(\n    callback: (\n      result: QueryDocumentSnapshot<AppModelType, DbModelType>\n    ) => void,\n    thisArg?: unknown\n  ): void {\n    this._docs.forEach(callback, thisArg);\n  }\n}\n\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 */\nexport function snapshotEqual<AppModelType, DbModelType extends DocumentData>(\n  left:\n    | DocumentSnapshot<AppModelType, DbModelType>\n    | QuerySnapshot<AppModelType, DbModelType>,\n  right:\n    | DocumentSnapshot<AppModelType, DbModelType>\n    | QuerySnapshot<AppModelType, DbModelType>\n): boolean {\n  left = getModularInstance(left);\n  right = getModularInstance(right);\n\n  if (left instanceof DocumentSnapshot && right instanceof DocumentSnapshot) {\n    return (\n      left._firestore === right._firestore &&\n      left._key.isEqual(right._key) &&\n      (left._document === null\n        ? right._document === null\n        : left._document.isEqual(right._document)) &&\n      left._converter === right._converter\n    );\n  } else if (left instanceof QuerySnapshot && right instanceof QuerySnapshot) {\n    return (\n      queryEqual(left.query, right.query) &&\n      arrayEquals(left.docs, right.docs, snapshotEqual)\n    );\n  }\n\n  return false;\n}\n\n/**\n * Helper that calls `fromDotSeparatedString()` but wraps any error thrown.\n */\nexport function fieldPathFromArgument(\n  methodName: string,\n  arg: string | FieldPath | Compat<FieldPath>\n): InternalFieldPath {\n  if (typeof arg === 'string') {\n    return fieldPathFromDotSeparatedString(methodName, arg);\n  } else if (arg instanceof FieldPath) {\n    return arg._internalPath;\n  } else {\n    return arg._delegate._internalPath;\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 { getModularInstance } from '@firebase/util';\n\nimport { Bound } from '../core/bound';\nimport { DatabaseId } from '../core/database_info';\nimport {\n  CompositeFilter,\n  CompositeOperator,\n  FieldFilter,\n  Filter,\n  Operator\n} from '../core/filter';\nimport { Direction, OrderBy } from '../core/order_by';\nimport {\n  isCollectionGroupQuery,\n  LimitType,\n  Query as InternalQuery,\n  queryNormalizedOrderBy,\n  queryWithAddedFilter,\n  queryWithAddedOrderBy,\n  queryWithEndAt,\n  queryWithLimit,\n  queryWithStartAt\n} from '../core/query';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { FieldPath as InternalFieldPath, ResourcePath } from '../model/path';\nimport { isServerTimestamp } from '../model/server_timestamps';\nimport { refValue } from '../model/values';\nimport { Value as ProtoValue } from '../protos/firestore_proto_api';\nimport { Code, FirestoreError } from '../util/error';\nimport {\n  validatePositiveNumber,\n  valueDescription\n} from '../util/input_validation';\n\nimport { FieldPath } from './field_path';\nimport { DocumentData, DocumentReference, Query } from './reference';\nimport { DocumentSnapshot, fieldPathFromArgument } from './snapshot';\nimport {\n  newUserDataReader,\n  parseQueryValue,\n  UserDataReader\n} from './user_data_reader';\n\nexport function validateHasExplicitOrderByForLimitToLast(\n  query: InternalQuery\n): void {\n  if (\n    query.limitType === LimitType.Last &&\n    query.explicitOrderBy.length === 0\n  ) {\n    throw new FirestoreError(\n      Code.UNIMPLEMENTED,\n      'limitToLast() queries require specifying at least one orderBy() clause'\n    );\n  }\n}\n\n/** Describes the different query constraints available in this SDK. */\nexport type QueryConstraintType =\n  | 'where'\n  | 'orderBy'\n  | 'limit'\n  | 'limitToLast'\n  | 'startAt'\n  | 'startAfter'\n  | 'endAt'\n  | 'endBefore';\n\n/**\n * An `AppliableConstraint` is an abstraction of a constraint that can be applied\n * to a Firestore query.\n */\nexport abstract class AppliableConstraint {\n  /**\n   * Takes the provided {@link Query} and returns a copy of the {@link Query} with this\n   * {@link AppliableConstraint} applied.\n   */\n  abstract _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType>;\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:1)}, {@link (startAfter:1)}, {@link\n * (endBefore:1)}, {@link (endAt:1)}, {@link limit}, {@link limitToLast} and\n * can then be passed to {@link (query:1)} to create a new query instance that\n * also contains this `QueryConstraint`.\n */\nexport abstract class QueryConstraint extends AppliableConstraint {\n  /** The type of this query constraint */\n  abstract readonly type: QueryConstraintType;\n\n  /**\n   * Takes the provided {@link Query} and returns a copy of the {@link Query} with this\n   * {@link AppliableConstraint} applied.\n   */\n  abstract _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType>;\n}\n\n/**\n * Creates a new immutable instance of {@link Query} that is extended to also\n * include additional query constraints.\n *\n * @param query - The {@link Query} instance to use as a base for the new\n * constraints.\n * @param compositeFilter - The {@link QueryCompositeFilterConstraint} to\n * apply. Create {@link QueryCompositeFilterConstraint} using {@link and} or\n * {@link or}.\n * @param queryConstraints - Additional {@link QueryNonFilterConstraint}s to\n * apply (e.g. {@link orderBy}, {@link limit}).\n * @throws if any of the provided query constraints cannot be combined with the\n * existing or new constraints.\n */\nexport function query<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  compositeFilter: QueryCompositeFilterConstraint,\n  ...queryConstraints: QueryNonFilterConstraint[]\n): Query<AppModelType, DbModelType>;\n\n/**\n * Creates a new immutable instance of {@link Query} that is extended to also\n * include additional query constraints.\n *\n * @param query - The {@link Query} instance to use as a base for the new\n * constraints.\n * @param queryConstraints - The list of {@link QueryConstraint}s to apply.\n * @throws if any of the provided query constraints cannot be combined with the\n * existing or new constraints.\n */\nexport function query<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  ...queryConstraints: QueryConstraint[]\n): Query<AppModelType, DbModelType>;\n\nexport function query<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  queryConstraint: QueryCompositeFilterConstraint | QueryConstraint | undefined,\n  ...additionalQueryConstraints: Array<\n    QueryConstraint | QueryNonFilterConstraint\n  >\n): Query<AppModelType, DbModelType> {\n  let queryConstraints: AppliableConstraint[] = [];\n\n  if (queryConstraint instanceof AppliableConstraint) {\n    queryConstraints.push(queryConstraint);\n  }\n\n  queryConstraints = queryConstraints.concat(additionalQueryConstraints);\n\n  validateQueryConstraintArray(queryConstraints);\n\n  for (const constraint of queryConstraints) {\n    query = constraint._apply(query);\n  }\n  return query;\n}\n\n/**\n * A `QueryFieldFilterConstraint` is used to narrow the set of documents returned by\n * a Firestore query by filtering on one or more document fields.\n * `QueryFieldFilterConstraint`s are created by invoking {@link where} and can then\n * be passed to {@link (query:1)} to create a new query instance that also contains\n * this `QueryFieldFilterConstraint`.\n */\nexport class QueryFieldFilterConstraint extends QueryConstraint {\n  /** The type of this query constraint */\n  readonly type = 'where';\n\n  /**\n   * @internal\n   */\n  protected constructor(\n    private readonly _field: InternalFieldPath,\n    private _op: Operator,\n    private _value: unknown\n  ) {\n    super();\n  }\n\n  static _create(\n    _field: InternalFieldPath,\n    _op: Operator,\n    _value: unknown\n  ): QueryFieldFilterConstraint {\n    return new QueryFieldFilterConstraint(_field, _op, _value);\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    const filter = this._parse(query);\n    validateNewFieldFilter(query._query, filter);\n    return new Query(\n      query.firestore,\n      query.converter,\n      queryWithAddedFilter(query._query, filter)\n    );\n  }\n\n  _parse<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): FieldFilter {\n    const reader = newUserDataReader(query.firestore);\n    const filter = newQueryFilter(\n      query._query,\n      'where',\n      reader,\n      query.firestore._databaseId,\n      this._field,\n      this._op,\n      this._value\n    );\n    return filter;\n  }\n}\n\n/**\n * Filter conditions in a {@link where} clause are specified using the\n * strings '&lt;', '&lt;=', '==', '!=', '&gt;=', '&gt;', 'array-contains', 'in',\n * 'array-contains-any', and 'not-in'.\n */\nexport type WhereFilterOp =\n  | '<'\n  | '<='\n  | '=='\n  | '!='\n  | '>='\n  | '>'\n  | 'array-contains'\n  | 'in'\n  | 'array-contains-any'\n  | 'not-in';\n\n/**\n * Creates a {@link QueryFieldFilterConstraint} that enforces that documents\n * must contain the specified field and that the value should satisfy the\n * relation constraint 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 {@link QueryFieldFilterConstraint}.\n */\nexport function where(\n  fieldPath: string | FieldPath,\n  opStr: WhereFilterOp,\n  value: unknown\n): QueryFieldFilterConstraint {\n  const op = opStr as Operator;\n  const field = fieldPathFromArgument('where', fieldPath);\n  return QueryFieldFilterConstraint._create(field, op, value);\n}\n\n/**\n * A `QueryCompositeFilterConstraint` is used to narrow the set of documents\n * returned by a Firestore query by performing the logical OR or AND of multiple\n * {@link QueryFieldFilterConstraint}s or {@link QueryCompositeFilterConstraint}s.\n * `QueryCompositeFilterConstraint`s are created by invoking {@link or} or\n * {@link and} and can then be passed to {@link (query:1)} to create a new query\n * instance that also contains the `QueryCompositeFilterConstraint`.\n */\nexport class QueryCompositeFilterConstraint extends AppliableConstraint {\n  /**\n   * @internal\n   */\n  protected constructor(\n    /** The type of this query constraint */\n    readonly type: 'or' | 'and',\n    private readonly _queryConstraints: QueryFilterConstraint[]\n  ) {\n    super();\n  }\n\n  static _create(\n    type: 'or' | 'and',\n    _queryConstraints: QueryFilterConstraint[]\n  ): QueryCompositeFilterConstraint {\n    return new QueryCompositeFilterConstraint(type, _queryConstraints);\n  }\n\n  _parse<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Filter {\n    const parsedFilters = this._queryConstraints\n      .map(queryConstraint => {\n        return queryConstraint._parse(query);\n      })\n      .filter(parsedFilter => parsedFilter.getFilters().length > 0);\n\n    if (parsedFilters.length === 1) {\n      return parsedFilters[0];\n    }\n\n    return CompositeFilter.create(parsedFilters, this._getOperator());\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    const parsedFilter = this._parse(query);\n    if (parsedFilter.getFilters().length === 0) {\n      // Return the existing query if not adding any more filters (e.g. an empty\n      // composite filter).\n      return query;\n    }\n    validateNewFilter(query._query, parsedFilter);\n\n    return new Query(\n      query.firestore,\n      query.converter,\n      queryWithAddedFilter(query._query, parsedFilter)\n    );\n  }\n\n  _getQueryConstraints(): readonly AppliableConstraint[] {\n    return this._queryConstraints;\n  }\n\n  _getOperator(): CompositeOperator {\n    return this.type === 'and' ? CompositeOperator.AND : CompositeOperator.OR;\n  }\n}\n\n/**\n * `QueryNonFilterConstraint` is a helper union type that represents\n * QueryConstraints which are used to narrow or order the set of documents,\n * but that do not explicitly filter on a document field.\n * `QueryNonFilterConstraint`s are created by invoking {@link orderBy},\n * {@link (startAt:1)}, {@link (startAfter:1)}, {@link (endBefore:1)}, {@link (endAt:1)},\n * {@link limit} or {@link limitToLast} and can then be passed to {@link (query:1)}\n * to create a new query instance that also contains the `QueryConstraint`.\n */\nexport type QueryNonFilterConstraint =\n  | QueryOrderByConstraint\n  | QueryLimitConstraint\n  | QueryStartAtConstraint\n  | QueryEndAtConstraint;\n\n/**\n * `QueryFilterConstraint` is a helper union type that represents\n * {@link QueryFieldFilterConstraint} and {@link QueryCompositeFilterConstraint}.\n */\nexport type QueryFilterConstraint =\n  | QueryFieldFilterConstraint\n  | QueryCompositeFilterConstraint;\n\n/**\n * Creates a new {@link QueryCompositeFilterConstraint} that is a disjunction of\n * the given filter constraints. A disjunction filter includes a document if it\n * satisfies any of the given filters.\n *\n * @param queryConstraints - Optional. The list of\n * {@link QueryFilterConstraint}s to perform a disjunction for. These must be\n * created with calls to {@link where}, {@link or}, or {@link and}.\n * @returns The newly created {@link QueryCompositeFilterConstraint}.\n */\nexport function or(\n  ...queryConstraints: QueryFilterConstraint[]\n): QueryCompositeFilterConstraint {\n  // Only support QueryFilterConstraints\n  queryConstraints.forEach(queryConstraint =>\n    validateQueryFilterConstraint('or', queryConstraint)\n  );\n\n  return QueryCompositeFilterConstraint._create(\n    CompositeOperator.OR,\n    queryConstraints as QueryFilterConstraint[]\n  );\n}\n\n/**\n * Creates a new {@link QueryCompositeFilterConstraint} that is a conjunction of\n * the given filter constraints. A conjunction filter includes a document if it\n * satisfies all of the given filters.\n *\n * @param queryConstraints - Optional. The list of\n * {@link QueryFilterConstraint}s to perform a conjunction for. These must be\n * created with calls to {@link where}, {@link or}, or {@link and}.\n * @returns The newly created {@link QueryCompositeFilterConstraint}.\n */\nexport function and(\n  ...queryConstraints: QueryFilterConstraint[]\n): QueryCompositeFilterConstraint {\n  // Only support QueryFilterConstraints\n  queryConstraints.forEach(queryConstraint =>\n    validateQueryFilterConstraint('and', queryConstraint)\n  );\n\n  return QueryCompositeFilterConstraint._create(\n    CompositeOperator.AND,\n    queryConstraints as QueryFilterConstraint[]\n  );\n}\n\n/**\n * A `QueryOrderByConstraint` is used to sort the set of documents returned by a\n * Firestore query. `QueryOrderByConstraint`s are created by invoking\n * {@link orderBy} and can then be passed to {@link (query:1)} to create a new query\n * instance that also contains this `QueryOrderByConstraint`.\n *\n * Note: Documents that do not contain the orderBy field will not be present in\n * the query result.\n */\nexport class QueryOrderByConstraint extends QueryConstraint {\n  /** The type of this query constraint */\n  readonly type = 'orderBy';\n\n  /**\n   * @internal\n   */\n  protected constructor(\n    private readonly _field: InternalFieldPath,\n    private _direction: Direction\n  ) {\n    super();\n  }\n\n  static _create(\n    _field: InternalFieldPath,\n    _direction: Direction\n  ): QueryOrderByConstraint {\n    return new QueryOrderByConstraint(_field, _direction);\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    const orderBy = newQueryOrderBy(query._query, this._field, this._direction);\n    return new Query(\n      query.firestore,\n      query.converter,\n      queryWithAddedOrderBy(query._query, orderBy)\n    );\n  }\n}\n\n/**\n * The direction of a {@link orderBy} clause is specified as 'desc' or 'asc'\n * (descending or ascending).\n */\nexport type OrderByDirection = 'desc' | 'asc';\n\n/**\n * Creates a {@link QueryOrderByConstraint} that sorts the query result by the\n * specified field, optionally in descending order instead of ascending.\n *\n * Note: Documents that do not contain the specified field will not be present\n * in the query result.\n *\n * @param fieldPath - The field to sort by.\n * @param directionStr - Optional direction to sort by ('asc' or 'desc'). If\n * not specified, order will be ascending.\n * @returns The created {@link QueryOrderByConstraint}.\n */\nexport function orderBy(\n  fieldPath: string | FieldPath,\n  directionStr: OrderByDirection = 'asc'\n): QueryOrderByConstraint {\n  const direction = directionStr as Direction;\n  const path = fieldPathFromArgument('orderBy', fieldPath);\n  return QueryOrderByConstraint._create(path, direction);\n}\n\n/**\n * A `QueryLimitConstraint` is used to limit the number of documents returned by\n * a Firestore query.\n * `QueryLimitConstraint`s are created by invoking {@link limit} or\n * {@link limitToLast} and can then be passed to {@link (query:1)} to create a new\n * query instance that also contains this `QueryLimitConstraint`.\n */\nexport class QueryLimitConstraint extends QueryConstraint {\n  /**\n   * @internal\n   */\n  protected constructor(\n    /** The type of this query constraint */\n    readonly type: 'limit' | 'limitToLast',\n    private readonly _limit: number,\n    private readonly _limitType: LimitType\n  ) {\n    super();\n  }\n\n  static _create(\n    type: 'limit' | 'limitToLast',\n    _limit: number,\n    _limitType: LimitType\n  ): QueryLimitConstraint {\n    return new QueryLimitConstraint(type, _limit, _limitType);\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    return new Query(\n      query.firestore,\n      query.converter,\n      queryWithLimit(query._query, this._limit, this._limitType)\n    );\n  }\n}\n\n/**\n * Creates a {@link QueryLimitConstraint} that only returns the first matching\n * documents.\n *\n * @param limit - The maximum number of items to return.\n * @returns The created {@link QueryLimitConstraint}.\n */\nexport function limit(limit: number): QueryLimitConstraint {\n  validatePositiveNumber('limit', limit);\n  return QueryLimitConstraint._create('limit', limit, LimitType.First);\n}\n\n/**\n * Creates a {@link QueryLimitConstraint} that only returns the last matching\n * documents.\n *\n * You must specify at least one `orderBy` clause for `limitToLast` queries,\n * otherwise an exception will be thrown during execution.\n *\n * @param limit - The maximum number of items to return.\n * @returns The created {@link QueryLimitConstraint}.\n */\nexport function limitToLast(limit: number): QueryLimitConstraint {\n  validatePositiveNumber('limitToLast', limit);\n  return QueryLimitConstraint._create('limitToLast', limit, LimitType.Last);\n}\n\n/**\n * A `QueryStartAtConstraint` is used to exclude documents from the start of a\n * result set returned by a Firestore query.\n * `QueryStartAtConstraint`s are created by invoking {@link (startAt:1)} or\n * {@link (startAfter:1)} and can then be passed to {@link (query:1)} to create a\n * new query instance that also contains this `QueryStartAtConstraint`.\n */\nexport class QueryStartAtConstraint extends QueryConstraint {\n  /**\n   * @internal\n   */\n  protected constructor(\n    /** The type of this query constraint */\n    readonly type: 'startAt' | 'startAfter',\n    private readonly _docOrFields: Array<unknown | DocumentSnapshot<unknown>>,\n    private readonly _inclusive: boolean\n  ) {\n    super();\n  }\n\n  static _create(\n    type: 'startAt' | 'startAfter',\n    _docOrFields: Array<unknown | DocumentSnapshot<unknown>>,\n    _inclusive: boolean\n  ): QueryStartAtConstraint {\n    return new QueryStartAtConstraint(type, _docOrFields, _inclusive);\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    const bound = newQueryBoundFromDocOrFields(\n      query,\n      this.type,\n      this._docOrFields,\n      this._inclusive\n    );\n    return new Query<AppModelType, DbModelType>(\n      query.firestore,\n      query.converter,\n      queryWithStartAt(query._query, bound)\n    );\n  }\n}\n\n/**\n * Creates a {@link QueryStartAtConstraint} that modifies the result set to\n * start at the provided document (inclusive). The starting position is relative\n * to the order of the query. The document must contain all of the fields\n * provided in the `orderBy` of this query.\n *\n * @param snapshot - The snapshot of the document to start at.\n * @returns A {@link QueryStartAtConstraint} to pass to `query()`.\n */\nexport function startAt<AppModelType, DbModelType extends DocumentData>(\n  snapshot: DocumentSnapshot<AppModelType, DbModelType>\n): QueryStartAtConstraint;\n/**\n * Creates a {@link QueryStartAtConstraint} that modifies the result set to\n * start at the provided fields relative to the order of the query. The order of\n * the field values must match the order of the order by clauses of the query.\n *\n * @param fieldValues - The field values to start this query at, in order\n * of the query's order by.\n * @returns A {@link QueryStartAtConstraint} to pass to `query()`.\n */\nexport function startAt(...fieldValues: unknown[]): QueryStartAtConstraint;\nexport function startAt<AppModelType, DbModelType extends DocumentData>(\n  ...docOrFields: Array<unknown | DocumentSnapshot<AppModelType, DbModelType>>\n): QueryStartAtConstraint {\n  return QueryStartAtConstraint._create(\n    'startAt',\n    docOrFields,\n    /*inclusive=*/ true\n  );\n}\n\n/**\n * Creates a {@link QueryStartAtConstraint} that modifies the result set to\n * start after the provided document (exclusive). The starting position is\n * relative to the order of the query. The document must contain all of the\n * fields provided in the orderBy of the query.\n *\n * @param snapshot - The snapshot of the document to start after.\n * @returns A {@link QueryStartAtConstraint} to pass to `query()`\n */\nexport function startAfter<AppModelType, DbModelType extends DocumentData>(\n  snapshot: DocumentSnapshot<AppModelType, DbModelType>\n): QueryStartAtConstraint;\n/**\n * Creates a {@link QueryStartAtConstraint} that modifies the result set to\n * start after the provided fields relative to the order of the query. The order\n * of the field values must match the order of the order by clauses of the query.\n *\n * @param fieldValues - The field values to start this query after, in order\n * of the query's order by.\n * @returns A {@link QueryStartAtConstraint} to pass to `query()`\n */\nexport function startAfter(...fieldValues: unknown[]): QueryStartAtConstraint;\nexport function startAfter<AppModelType, DbModelType extends DocumentData>(\n  ...docOrFields: Array<unknown | DocumentSnapshot<AppModelType, DbModelType>>\n): QueryStartAtConstraint {\n  return QueryStartAtConstraint._create(\n    'startAfter',\n    docOrFields,\n    /*inclusive=*/ false\n  );\n}\n\n/**\n * A `QueryEndAtConstraint` is used to exclude documents from the end of a\n * result set returned by a Firestore query.\n * `QueryEndAtConstraint`s are created by invoking {@link (endAt:1)} or\n * {@link (endBefore:1)} and can then be passed to {@link (query:1)} to create a new\n * query instance that also contains this `QueryEndAtConstraint`.\n */\nexport class QueryEndAtConstraint extends QueryConstraint {\n  /**\n   * @internal\n   */\n  protected constructor(\n    /** The type of this query constraint */\n    readonly type: 'endBefore' | 'endAt',\n    private readonly _docOrFields: Array<unknown | DocumentSnapshot<unknown>>,\n    private readonly _inclusive: boolean\n  ) {\n    super();\n  }\n\n  static _create(\n    type: 'endBefore' | 'endAt',\n    _docOrFields: Array<unknown | DocumentSnapshot<unknown>>,\n    _inclusive: boolean\n  ): QueryEndAtConstraint {\n    return new QueryEndAtConstraint(type, _docOrFields, _inclusive);\n  }\n\n  _apply<AppModelType, DbModelType extends DocumentData>(\n    query: Query<AppModelType, DbModelType>\n  ): Query<AppModelType, DbModelType> {\n    const bound = newQueryBoundFromDocOrFields(\n      query,\n      this.type,\n      this._docOrFields,\n      this._inclusive\n    );\n    return new Query(\n      query.firestore,\n      query.converter,\n      queryWithEndAt(query._query, bound)\n    );\n  }\n}\n\n/**\n * Creates a {@link QueryEndAtConstraint} that modifies the result set to end\n * before the provided document (exclusive). The end position is relative to the\n * order of the query. The document must contain all of the fields provided in\n * the orderBy of the query.\n *\n * @param snapshot - The snapshot of the document to end before.\n * @returns A {@link QueryEndAtConstraint} to pass to `query()`\n */\nexport function endBefore<AppModelType, DbModelType extends DocumentData>(\n  snapshot: DocumentSnapshot<AppModelType, DbModelType>\n): QueryEndAtConstraint;\n/**\n * Creates a {@link QueryEndAtConstraint} that modifies the result set to end\n * before the provided fields relative to the order of the query. The order of\n * the field values must match the order of the order by clauses of the query.\n *\n * @param fieldValues - The field values to end this query before, in order\n * of the query's order by.\n * @returns A {@link QueryEndAtConstraint} to pass to `query()`\n */\nexport function endBefore(...fieldValues: unknown[]): QueryEndAtConstraint;\nexport function endBefore<AppModelType, DbModelType extends DocumentData>(\n  ...docOrFields: Array<unknown | DocumentSnapshot<AppModelType, DbModelType>>\n): QueryEndAtConstraint {\n  return QueryEndAtConstraint._create(\n    'endBefore',\n    docOrFields,\n    /*inclusive=*/ false\n  );\n}\n\n/**\n * Creates a {@link QueryEndAtConstraint} that modifies the result set to end at\n * the provided document (inclusive). The end position is relative to the order\n * of the query. The document must contain all of the fields provided in the\n * orderBy of the query.\n *\n * @param snapshot - The snapshot of the document to end at.\n * @returns A {@link QueryEndAtConstraint} to pass to `query()`\n */\nexport function endAt<AppModelType, DbModelType extends DocumentData>(\n  snapshot: DocumentSnapshot<AppModelType, DbModelType>\n): QueryEndAtConstraint;\n/**\n * Creates a {@link QueryEndAtConstraint} that modifies the result set to end at\n * the provided fields relative to the order of the query. The order of the field\n * values must match the order of the order by clauses of the query.\n *\n * @param fieldValues - The field values to end this query at, in order\n * of the query's order by.\n * @returns A {@link QueryEndAtConstraint} to pass to `query()`\n */\nexport function endAt(...fieldValues: unknown[]): QueryEndAtConstraint;\nexport function endAt<AppModelType, DbModelType extends DocumentData>(\n  ...docOrFields: Array<unknown | DocumentSnapshot<AppModelType, DbModelType>>\n): QueryEndAtConstraint {\n  return QueryEndAtConstraint._create(\n    'endAt',\n    docOrFields,\n    /*inclusive=*/ true\n  );\n}\n\n/** Helper function to create a bound from a document or fields */\nfunction newQueryBoundFromDocOrFields<\n  AppModelType,\n  DbModelType extends DocumentData\n>(\n  query: Query<AppModelType, DbModelType>,\n  methodName: string,\n  docOrFields: Array<unknown | DocumentSnapshot<AppModelType, DbModelType>>,\n  inclusive: boolean\n): Bound {\n  docOrFields[0] = getModularInstance(docOrFields[0]);\n\n  if (docOrFields[0] instanceof DocumentSnapshot) {\n    return newQueryBoundFromDocument(\n      query._query,\n      query.firestore._databaseId,\n      methodName,\n      docOrFields[0]._document,\n      inclusive\n    );\n  } else {\n    const reader = newUserDataReader(query.firestore);\n    return newQueryBoundFromFields(\n      query._query,\n      query.firestore._databaseId,\n      reader,\n      methodName,\n      docOrFields,\n      inclusive\n    );\n  }\n}\n\nexport function newQueryFilter(\n  query: InternalQuery,\n  methodName: string,\n  dataReader: UserDataReader,\n  databaseId: DatabaseId,\n  fieldPath: InternalFieldPath,\n  op: Operator,\n  value: unknown\n): FieldFilter {\n  let fieldValue: ProtoValue;\n  if (fieldPath.isKeyField()) {\n    if (op === Operator.ARRAY_CONTAINS || op === Operator.ARRAY_CONTAINS_ANY) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `Invalid Query. You can't perform '${op}' queries on documentId().`\n      );\n    } else if (op === Operator.IN || op === Operator.NOT_IN) {\n      validateDisjunctiveFilterElements(value, op);\n      const referenceList: ProtoValue[] = [];\n      for (const arrayValue of value as ProtoValue[]) {\n        referenceList.push(parseDocumentIdValue(databaseId, query, arrayValue));\n      }\n      fieldValue = { arrayValue: { values: referenceList } };\n    } else {\n      fieldValue = parseDocumentIdValue(databaseId, query, value);\n    }\n  } else {\n    if (\n      op === Operator.IN ||\n      op === Operator.NOT_IN ||\n      op === Operator.ARRAY_CONTAINS_ANY\n    ) {\n      validateDisjunctiveFilterElements(value, op);\n    }\n    fieldValue = parseQueryValue(\n      dataReader,\n      methodName,\n      value,\n      /* allowArrays= */ op === Operator.IN || op === Operator.NOT_IN\n    );\n  }\n  const filter = FieldFilter.create(fieldPath, op, fieldValue);\n  return filter;\n}\n\nexport function newQueryOrderBy(\n  query: InternalQuery,\n  fieldPath: InternalFieldPath,\n  direction: Direction\n): OrderBy {\n  if (query.startAt !== null) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'Invalid query. You must not call startAt() or startAfter() before ' +\n        'calling orderBy().'\n    );\n  }\n  if (query.endAt !== null) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'Invalid query. You must not call endAt() or endBefore() before ' +\n        'calling orderBy().'\n    );\n  }\n  const orderBy = new OrderBy(fieldPath, direction);\n  return orderBy;\n}\n\n/**\n * Create a `Bound` from a query and a document.\n *\n * Note that the `Bound` will always include the key of the document\n * and so only the provided document will compare equal to the returned\n * position.\n *\n * Will throw if the document does not contain all fields of the order by\n * of the query or if any of the fields in the order by are an uncommitted\n * server timestamp.\n */\nexport function newQueryBoundFromDocument(\n  query: InternalQuery,\n  databaseId: DatabaseId,\n  methodName: string,\n  doc: Document | null,\n  inclusive: boolean\n): Bound {\n  if (!doc) {\n    throw new FirestoreError(\n      Code.NOT_FOUND,\n      `Can't use a DocumentSnapshot that doesn't exist for ` +\n        `${methodName}().`\n    );\n  }\n\n  const components: ProtoValue[] = [];\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 (const orderBy of queryNormalizedOrderBy(query)) {\n    if (orderBy.field.isKeyField()) {\n      components.push(refValue(databaseId, doc.key));\n    } else {\n      const value = doc.data.field(orderBy.field);\n      if (isServerTimestamp(value)) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          'Invalid query. You are trying to start or end a query using a ' +\n            'document for which the field \"' +\n            orderBy.field +\n            '\" is an uncommitted server timestamp. (Since the value of ' +\n            'this field is unknown, you cannot start/end a query with it.)'\n        );\n      } else if (value !== null) {\n        components.push(value);\n      } else {\n        const field = orderBy.field.canonicalString();\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid query. You are trying to start or end a query using a ` +\n            `document for which the field '${field}' (used as the ` +\n            `orderBy) does not exist.`\n        );\n      }\n    }\n  }\n  return new Bound(components, inclusive);\n}\n\n/**\n * Converts a list of field values to a `Bound` for the given query.\n */\nexport function newQueryBoundFromFields(\n  query: InternalQuery,\n  databaseId: DatabaseId,\n  dataReader: UserDataReader,\n  methodName: string,\n  values: unknown[],\n  inclusive: boolean\n): Bound {\n  // Use explicit order by's because it has to match the query the user made\n  const orderBy = query.explicitOrderBy;\n  if (values.length > orderBy.length) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Too many arguments provided to ${methodName}(). ` +\n        `The number of arguments must be less than or equal to the ` +\n        `number of orderBy() clauses`\n    );\n  }\n\n  const components: ProtoValue[] = [];\n  for (let i = 0; i < values.length; i++) {\n    const rawValue = values[i];\n    const orderByComponent = orderBy[i];\n    if (orderByComponent.field.isKeyField()) {\n      if (typeof rawValue !== 'string') {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid query. Expected a string for document ID in ` +\n            `${methodName}(), but got a ${typeof rawValue}`\n        );\n      }\n      if (!isCollectionGroupQuery(query) && rawValue.indexOf('/') !== -1) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid query. When querying a collection and ordering by documentId(), ` +\n            `the value passed to ${methodName}() must be a plain document ID, but ` +\n            `'${rawValue}' contains a slash.`\n        );\n      }\n      const path = query.path.child(ResourcePath.fromString(rawValue));\n      if (!DocumentKey.isDocumentKey(path)) {\n        throw new FirestoreError(\n          Code.INVALID_ARGUMENT,\n          `Invalid query. When querying a collection group and ordering by ` +\n            `documentId(), the value passed to ${methodName}() must result in a ` +\n            `valid document path, but '${path}' is not because it contains an odd number ` +\n            `of segments.`\n        );\n      }\n      const key = new DocumentKey(path);\n      components.push(refValue(databaseId, key));\n    } else {\n      const wrapped = parseQueryValue(dataReader, methodName, rawValue);\n      components.push(wrapped);\n    }\n  }\n\n  return new Bound(components, inclusive);\n}\n\n/**\n * Parses the given `documentIdValue` into a `ReferenceValue`, throwing\n * appropriate errors if the value is anything other than a `DocumentReference`\n * or `string`, or if the string is malformed.\n */\nfunction parseDocumentIdValue(\n  databaseId: DatabaseId,\n  query: InternalQuery,\n  documentIdValue: unknown\n): ProtoValue {\n  documentIdValue = getModularInstance(documentIdValue);\n\n  if (typeof documentIdValue === 'string') {\n    if (documentIdValue === '') {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Invalid query. When querying with documentId(), you ' +\n          'must provide a valid document ID, but it was an empty string.'\n      );\n    }\n    if (!isCollectionGroupQuery(query) && documentIdValue.indexOf('/') !== -1) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `Invalid query. When querying a collection by ` +\n          `documentId(), you must provide a plain document ID, but ` +\n          `'${documentIdValue}' contains a '/' character.`\n      );\n    }\n    const path = query.path.child(ResourcePath.fromString(documentIdValue));\n    if (!DocumentKey.isDocumentKey(path)) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `Invalid query. When querying a collection group by ` +\n          `documentId(), the value provided must result in a valid document path, ` +\n          `but '${path}' is not because it has an odd number of segments (${path.length}).`\n      );\n    }\n    return refValue(databaseId, new DocumentKey(path));\n  } else if (documentIdValue instanceof DocumentReference) {\n    return refValue(databaseId, documentIdValue._key);\n  } else {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Invalid query. When querying with documentId(), you must provide a valid ` +\n        `string or a DocumentReference, but it was: ` +\n        `${valueDescription(documentIdValue)}.`\n    );\n  }\n}\n\n/**\n * Validates that the value passed into a disjunctive filter satisfies all\n * array requirements.\n */\nfunction validateDisjunctiveFilterElements(\n  value: unknown,\n  operator: Operator\n): void {\n  if (!Array.isArray(value) || value.length === 0) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'Invalid Query. A non-empty array is required for ' +\n        `'${operator.toString()}' filters.`\n    );\n  }\n}\n\n/**\n * Given an operator, returns the set of operators that cannot be used with it.\n *\n * This is not a comprehensive check, and this function should be removed in the\n * long term. Validations should occur in the Firestore backend.\n *\n * Operators in a query must adhere to the following set of rules:\n * 1. Only one inequality per query.\n * 2. `NOT_IN` cannot be used with array, disjunctive, or `NOT_EQUAL` operators.\n */\nfunction conflictingOps(op: Operator): Operator[] {\n  switch (op) {\n    case Operator.NOT_EQUAL:\n      return [Operator.NOT_EQUAL, Operator.NOT_IN];\n    case Operator.ARRAY_CONTAINS_ANY:\n    case Operator.IN:\n      return [Operator.NOT_IN];\n    case Operator.NOT_IN:\n      return [\n        Operator.ARRAY_CONTAINS_ANY,\n        Operator.IN,\n        Operator.NOT_IN,\n        Operator.NOT_EQUAL\n      ];\n    default:\n      return [];\n  }\n}\n\nfunction validateNewFieldFilter(\n  query: InternalQuery,\n  fieldFilter: FieldFilter\n): void {\n  const conflictingOp = findOpInsideFilters(\n    query.filters,\n    conflictingOps(fieldFilter.op)\n  );\n  if (conflictingOp !== null) {\n    // Special case when it's a duplicate op to give a slightly clearer error message.\n    if (conflictingOp === fieldFilter.op) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'Invalid query. You cannot use more than one ' +\n          `'${fieldFilter.op.toString()}' filter.`\n      );\n    } else {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        `Invalid query. You cannot use '${fieldFilter.op.toString()}' filters ` +\n          `with '${conflictingOp.toString()}' filters.`\n      );\n    }\n  }\n}\n\nfunction validateNewFilter(query: InternalQuery, filter: Filter): void {\n  let testQuery = query;\n  const subFilters = filter.getFlattenedFilters();\n  for (const subFilter of subFilters) {\n    validateNewFieldFilter(testQuery, subFilter);\n    testQuery = queryWithAddedFilter(testQuery, subFilter);\n  }\n}\n\n// Checks if any of the provided filter operators are included in the given list of filters and\n// returns the first one that is, or null if none are.\nfunction findOpInsideFilters(\n  filters: Filter[],\n  operators: Operator[]\n): Operator | null {\n  for (const filter of filters) {\n    for (const fieldFilter of filter.getFlattenedFilters()) {\n      if (operators.indexOf(fieldFilter.op) >= 0) {\n        return fieldFilter.op;\n      }\n    }\n  }\n  return null;\n}\n\nexport function validateQueryFilterConstraint(\n  functionName: string,\n  queryConstraint: AppliableConstraint\n): void {\n  if (\n    !(queryConstraint instanceof QueryFieldFilterConstraint) &&\n    !(queryConstraint instanceof QueryCompositeFilterConstraint)\n  ) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      `Function ${functionName}() requires AppliableConstraints created with a call to 'where(...)', 'or(...)', or 'and(...)'.`\n    );\n  }\n}\n\nfunction validateQueryConstraintArray(\n  queryConstraint: AppliableConstraint[]\n): void {\n  const compositeFilterCount = queryConstraint.filter(\n    filter => filter instanceof QueryCompositeFilterConstraint\n  ).length;\n  const fieldFilterCount = queryConstraint.filter(\n    filter => filter instanceof QueryFieldFilterConstraint\n  ).length;\n\n  if (\n    compositeFilterCount > 1 ||\n    (compositeFilterCount > 0 && fieldFilterCount > 0)\n  ) {\n    throw new FirestoreError(\n      Code.INVALID_ARGUMENT,\n      'InvalidQuery. When using composite filters, you cannot use ' +\n        'more than one filter at the top level. Consider nesting the multiple ' +\n        'filters within an `and(...)` statement. For example: ' +\n        'change `query(query, where(...), or(...))` to ' +\n        '`query(query, and(where(...), or(...)))`.'\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 { DocumentData } from '@firebase/firestore-types';\n\nimport { DatabaseId } from '../core/database_info';\nimport { DocumentKey } from '../model/document_key';\nimport {\n  normalizeByteString,\n  normalizeNumber,\n  normalizeTimestamp\n} from '../model/normalize';\nimport { ResourcePath } from '../model/path';\nimport {\n  getLocalWriteTime,\n  getPreviousValue\n} from '../model/server_timestamps';\nimport { TypeOrder } from '../model/type_order';\nimport { VECTOR_MAP_VECTORS_KEY, typeOrder } from '../model/values';\nimport {\n  ApiClientObjectMap,\n  ArrayValue as ProtoArrayValue,\n  LatLng as ProtoLatLng,\n  MapValue as ProtoMapValue,\n  Timestamp as ProtoTimestamp,\n  Value,\n  Value as ProtoValue\n} from '../protos/firestore_proto_api';\nimport { isValidResourceName } from '../remote/serializer';\nimport { fail, hardAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\nimport { logError } from '../util/log';\nimport { forEach } from '../util/obj';\n\nimport { GeoPoint } from './geo_point';\nimport { Timestamp } from './timestamp';\nimport { VectorValue } from './vector_value';\n\nexport type ServerTimestampBehavior = 'estimate' | 'previous' | 'none';\n\n/**\n * Converts Firestore's internal types to the JavaScript types that we expose\n * to the user.\n *\n * @internal\n */\nexport abstract class AbstractUserDataWriter {\n  convertValue(\n    value: ProtoValue,\n    serverTimestampBehavior: ServerTimestampBehavior = 'none'\n  ): unknown {\n    switch (typeOrder(value)) {\n      case TypeOrder.NullValue:\n        return null;\n      case TypeOrder.BooleanValue:\n        return value.booleanValue!;\n      case TypeOrder.NumberValue:\n        return normalizeNumber(value.integerValue || value.doubleValue);\n      case TypeOrder.TimestampValue:\n        return this.convertTimestamp(value.timestampValue!);\n      case TypeOrder.ServerTimestampValue:\n        return this.convertServerTimestamp(value, serverTimestampBehavior);\n      case TypeOrder.StringValue:\n        return value.stringValue!;\n      case TypeOrder.BlobValue:\n        return this.convertBytes(normalizeByteString(value.bytesValue!));\n      case TypeOrder.RefValue:\n        return this.convertReference(value.referenceValue!);\n      case TypeOrder.GeoPointValue:\n        return this.convertGeoPoint(value.geoPointValue!);\n      case TypeOrder.ArrayValue:\n        return this.convertArray(value.arrayValue!, serverTimestampBehavior);\n      case TypeOrder.ObjectValue:\n        return this.convertObject(value.mapValue!, serverTimestampBehavior);\n      case TypeOrder.VectorValue:\n        return this.convertVectorValue(value.mapValue!);\n      default:\n        throw fail('Invalid value type: ' + JSON.stringify(value));\n    }\n  }\n\n  private convertObject(\n    mapValue: ProtoMapValue,\n    serverTimestampBehavior: ServerTimestampBehavior\n  ): DocumentData {\n    return this.convertObjectMap(mapValue.fields, serverTimestampBehavior);\n  }\n\n  /**\n   * @internal\n   */\n  convertObjectMap(\n    fields: ApiClientObjectMap<Value> | undefined,\n    serverTimestampBehavior: ServerTimestampBehavior = 'none'\n  ): DocumentData {\n    const result: DocumentData = {};\n    forEach(fields, (key, value) => {\n      result[key] = this.convertValue(value, serverTimestampBehavior);\n    });\n    return result;\n  }\n\n  /**\n   * @internal\n   */\n  convertVectorValue(mapValue: ProtoMapValue): VectorValue {\n    const values = mapValue.fields?.[\n      VECTOR_MAP_VECTORS_KEY\n    ].arrayValue?.values?.map(value => {\n      return normalizeNumber(value.doubleValue);\n    });\n\n    return new VectorValue(values);\n  }\n\n  private convertGeoPoint(value: ProtoLatLng): GeoPoint {\n    return new GeoPoint(\n      normalizeNumber(value.latitude),\n      normalizeNumber(value.longitude)\n    );\n  }\n\n  private convertArray(\n    arrayValue: ProtoArrayValue,\n    serverTimestampBehavior: ServerTimestampBehavior\n  ): unknown[] {\n    return (arrayValue.values || []).map(value =>\n      this.convertValue(value, serverTimestampBehavior)\n    );\n  }\n\n  private convertServerTimestamp(\n    value: ProtoValue,\n    serverTimestampBehavior: ServerTimestampBehavior\n  ): unknown {\n    switch (serverTimestampBehavior) {\n      case 'previous':\n        const previousValue = getPreviousValue(value);\n        if (previousValue == null) {\n          return null;\n        }\n        return this.convertValue(previousValue, serverTimestampBehavior);\n      case 'estimate':\n        return this.convertTimestamp(getLocalWriteTime(value));\n      default:\n        return null;\n    }\n  }\n\n  private convertTimestamp(value: ProtoTimestamp): Timestamp {\n    const normalizedValue = normalizeTimestamp(value);\n    return new Timestamp(normalizedValue.seconds, normalizedValue.nanos);\n  }\n\n  protected convertDocumentKey(\n    name: string,\n    expectedDatabaseId: DatabaseId\n  ): DocumentKey {\n    const resourcePath = ResourcePath.fromString(name);\n    hardAssert(\n      isValidResourceName(resourcePath),\n      'ReferenceValue is not valid ' + name\n    );\n    const databaseId = new DatabaseId(resourcePath.get(1), resourcePath.get(3));\n    const key = new DocumentKey(resourcePath.popFirst(5));\n\n    if (!databaseId.isEqual(expectedDatabaseId)) {\n      // TODO(b/64130202): Somehow support foreign references.\n      logError(\n        `Document ${key} contains a document ` +\n          `reference within a different database (` +\n          `${databaseId.projectId}/${databaseId.database}) which is not ` +\n          `supported. It will be treated as a reference in the current ` +\n          `database (${expectedDatabaseId.projectId}/${expectedDatabaseId.database}) ` +\n          `instead.`\n      );\n    }\n    return key;\n  }\n\n  protected abstract convertReference(name: string): unknown;\n\n  protected abstract convertBytes(bytes: ByteString): unknown;\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  DocumentData as PublicDocumentData,\n  SetOptions as PublicSetOptions\n} from '@firebase/firestore-types';\nimport { getModularInstance } from '@firebase/util';\n\nimport { LimitType } from '../core/query';\nimport { DeleteMutation, Precondition } from '../model/mutation';\nimport {\n  invokeBatchGetDocumentsRpc,\n  invokeCommitRpc,\n  invokeRunQueryRpc\n} from '../remote/datastore';\nimport { hardAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\nimport { cast } from '../util/input_validation';\n\nimport { Bytes } from './bytes';\nimport { getDatastore } from './components';\nimport { Firestore } from './database';\nimport { FieldPath } from './field_path';\nimport { validateHasExplicitOrderByForLimitToLast } from './query';\nimport {\n  CollectionReference,\n  doc,\n  DocumentData,\n  DocumentReference,\n  PartialWithFieldValue,\n  Query,\n  SetOptions,\n  UpdateData,\n  WithFieldValue\n} from './reference';\nimport {\n  DocumentSnapshot,\n  QueryDocumentSnapshot,\n  QuerySnapshot\n} from './snapshot';\nimport {\n  newUserDataReader,\n  ParsedUpdateData,\n  parseSetData,\n  parseUpdateData,\n  parseUpdateVarargs,\n  UntypedFirestoreDataConverter\n} from './user_data_reader';\nimport { AbstractUserDataWriter } from './user_data_writer';\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 */\nexport function applyFirestoreDataConverter<T>(\n  converter: UntypedFirestoreDataConverter<T> | null,\n  value: WithFieldValue<T> | PartialWithFieldValue<T>,\n  options?: PublicSetOptions\n): PublicDocumentData {\n  let convertedValue;\n  if (converter) {\n    if (options && (options.merge || options.mergeFields)) {\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      convertedValue = (converter as any).toFirestore(value, options);\n    } else {\n      convertedValue = converter.toFirestore(value as WithFieldValue<T>);\n    }\n  } else {\n    convertedValue = value as PublicDocumentData;\n  }\n  return convertedValue;\n}\n\nexport class LiteUserDataWriter extends AbstractUserDataWriter {\n  constructor(protected firestore: Firestore) {\n    super();\n  }\n\n  protected convertBytes(bytes: ByteString): Bytes {\n    return new Bytes(bytes);\n  }\n\n  protected convertReference(name: string): DocumentReference {\n    const key = this.convertDocumentKey(name, this.firestore._databaseId);\n    return new DocumentReference(this.firestore, /* converter= */ null, key);\n  }\n}\n\n/**\n * Reads the document referred to by the specified document reference.\n *\n * All documents are directly fetched from the server, even if the document was\n * previously read or modified. Recent modifications are only reflected in the\n * retrieved `DocumentSnapshot` if they have already been applied by the\n * backend. If the client is offline, the read fails. If you like to use\n * caching or see local modifications, please use the full Firestore SDK.\n *\n * @param reference - The reference of the document to fetch.\n * @returns A Promise resolved with a `DocumentSnapshot` containing the current\n * document contents.\n */\nexport function getDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<DocumentSnapshot<AppModelType, DbModelType>> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const datastore = getDatastore(reference.firestore);\n  const userDataWriter = new LiteUserDataWriter(reference.firestore);\n\n  return invokeBatchGetDocumentsRpc(datastore, [reference._key]).then(\n    result => {\n      hardAssert(result.length === 1, 'Expected a single document result');\n      const document = result[0];\n      return new DocumentSnapshot<AppModelType, DbModelType>(\n        reference.firestore,\n        userDataWriter,\n        reference._key,\n        document.isFoundDocument() ? document : null,\n        reference.converter\n      );\n    }\n  );\n}\n\n/**\n * Executes the query and returns the results as a {@link QuerySnapshot}.\n *\n * All queries are executed directly by the server, even if the query was\n * previously executed. Recent modifications are only reflected in the retrieved\n * results if they have already been applied by the backend. If the client is\n * offline, the operation fails. To see previously cached result and local\n * modifications, use the full Firestore SDK.\n *\n * @param query - The `Query` to execute.\n * @returns A Promise that will be resolved with the results of the query.\n */\nexport function getDocs<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>\n): Promise<QuerySnapshot<AppModelType, DbModelType>> {\n  query = cast<Query<AppModelType, DbModelType>>(query, Query);\n  validateHasExplicitOrderByForLimitToLast(query._query);\n\n  const datastore = getDatastore(query.firestore);\n  const userDataWriter = new LiteUserDataWriter(query.firestore);\n  return invokeRunQueryRpc(datastore, query._query).then(result => {\n    const docs = result.map(\n      doc =>\n        new QueryDocumentSnapshot<AppModelType, DbModelType>(\n          query.firestore,\n          userDataWriter,\n          doc.key,\n          doc,\n          query.converter\n        )\n    );\n\n    if (query._query.limitType === LimitType.Last) {\n      // Limit to last queries reverse the orderBy constraint that was\n      // specified by the user. As such, we need to reverse the order of the\n      // results to return the documents in the expected order.\n      docs.reverse();\n    }\n\n    return new QuerySnapshot<AppModelType, DbModelType>(query, docs);\n  });\n}\n\n/**\n * Writes to the document referred to by the specified `DocumentReference`. If\n * the document does not yet exist, it will be created.\n *\n * The result of this write will only be reflected in document reads that occur\n * 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 * @param reference - A reference to the document to write.\n * @param data - A map of the fields and values for the document.\n * @throws Error - If the provided input is not a valid Firestore document.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend.\n */\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: WithFieldValue<AppModelType>\n): Promise<void>;\n/**\n * Writes to the document referred to by the specified `DocumentReference`. If\n * the document does not yet exist, it will be created. If you provide `merge`\n * or `mergeFields`, the provided data can be merged into an existing document.\n *\n * The result of this write will only be reflected in document reads that occur\n * 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 * @param reference - A reference to the document to write.\n * @param data - A map of the fields and values for the document.\n * @param options - An object to configure the set behavior.\n * @throws Error - If the provided input is not a valid Firestore document.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend.\n */\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: PartialWithFieldValue<AppModelType>,\n  options: SetOptions\n): Promise<void>;\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: PartialWithFieldValue<AppModelType>,\n  options?: SetOptions\n): Promise<void> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const convertedValue = applyFirestoreDataConverter(\n    reference.converter,\n    data,\n    options\n  );\n  const dataReader = newUserDataReader(reference.firestore);\n  const parsed = parseSetData(\n    dataReader,\n    'setDoc',\n    reference._key,\n    convertedValue,\n    reference.converter !== null,\n    options\n  );\n\n  const datastore = getDatastore(reference.firestore);\n  return invokeCommitRpc(datastore, [\n    parsed.toMutation(reference._key, Precondition.none())\n  ]);\n}\n\n/**\n * Updates fields in the document referred to by the specified\n * `DocumentReference`. The update will fail if applied to a document that does\n * not exist.\n *\n * The result of this update will only be reflected in document reads that occur\n * after the returned promise resolves. If the client is offline, the\n * update 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 * @param reference - A reference to the document to update.\n * @param data - An object containing the fields and values with which to\n * update the document. Fields can contain dots to reference nested fields\n * within the document.\n * @throws Error - If the provided input is not valid Firestore data.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend.\n */\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: UpdateData<DbModelType>\n): Promise<void>;\n/**\n * Updates fields in the document referred to by the specified\n * `DocumentReference` The update will fail if applied to a document that does\n * not exist.\n *\n * Nested fields can be updated by providing dot-separated field path\n * strings or by providing `FieldPath` objects.\n *\n * The result of this update will only be reflected in document reads that occur\n * after the returned promise resolves. If the client is offline, the\n * update 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 * @param reference - A reference to the document to update.\n * @param field - The first field to update.\n * @param value - The first value.\n * @param moreFieldsAndValues - Additional key value pairs.\n * @throws Error - If the provided input is not valid Firestore data.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend.\n */\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  field: string | FieldPath,\n  value: unknown,\n  ...moreFieldsAndValues: unknown[]\n): Promise<void>;\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  fieldOrUpdateData: string | FieldPath | UpdateData<DbModelType>,\n  value?: unknown,\n  ...moreFieldsAndValues: unknown[]\n): Promise<void> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const dataReader = newUserDataReader(reference.firestore);\n\n  // For Compat types, we have to \"extract\" the underlying types before\n  // performing validation.\n  fieldOrUpdateData = getModularInstance(fieldOrUpdateData);\n\n  let parsed: ParsedUpdateData;\n  if (\n    typeof fieldOrUpdateData === 'string' ||\n    fieldOrUpdateData instanceof FieldPath\n  ) {\n    parsed = parseUpdateVarargs(\n      dataReader,\n      'updateDoc',\n      reference._key,\n      fieldOrUpdateData,\n      value,\n      moreFieldsAndValues\n    );\n  } else {\n    parsed = parseUpdateData(\n      dataReader,\n      'updateDoc',\n      reference._key,\n      fieldOrUpdateData\n    );\n  }\n\n  const datastore = getDatastore(reference.firestore);\n  return invokeCommitRpc(datastore, [\n    parsed.toMutation(reference._key, Precondition.exists(true))\n  ]);\n}\n\n/**\n * Deletes the document referred to by the specified `DocumentReference`.\n *\n * The deletion will only be reflected in document reads that occur after the\n * returned promise resolves. If the client is offline, the\n * delete 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 * @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.\n */\nexport function deleteDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<void> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const datastore = getDatastore(reference.firestore);\n  return invokeCommitRpc(datastore, [\n    new DeleteMutation(reference._key, Precondition.none())\n  ]);\n}\n\n/**\n * Add a new document to specified `CollectionReference` with the given data,\n * assigning it a document ID automatically.\n *\n * The result of this write will only be reflected in document reads that occur\n * 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 * @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 * @throws Error - If the provided input is not a valid Firestore document.\n * @returns A `Promise` resolved with a `DocumentReference` pointing to the\n * newly created document after it has been written to the backend.\n */\nexport function addDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: CollectionReference<AppModelType, DbModelType>,\n  data: WithFieldValue<AppModelType>\n): Promise<DocumentReference<AppModelType, DbModelType>> {\n  reference = cast<CollectionReference<AppModelType, DbModelType>>(\n    reference,\n    CollectionReference\n  );\n  const docRef = doc(reference);\n\n  const convertedValue = applyFirestoreDataConverter(\n    reference.converter,\n    data as PartialWithFieldValue<AppModelType>\n  );\n\n  const dataReader = newUserDataReader(reference.firestore);\n  const parsed = parseSetData(\n    dataReader,\n    'addDoc',\n    docRef._key,\n    convertedValue,\n    docRef.converter !== null,\n    {}\n  );\n\n  const datastore = getDatastore(reference.firestore);\n  return invokeCommitRpc(datastore, [\n    parsed.toMutation(docRef._key, Precondition.exists(false))\n  ]).then(() => docRef);\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 { newQueryComparator } from '../core/query';\nimport { ChangeType, ViewSnapshot } from '../core/view_snapshot';\nimport { FieldPath } from '../lite-api/field_path';\nimport {\n  DocumentData,\n  PartialWithFieldValue,\n  Query,\n  queryEqual,\n  SetOptions,\n  WithFieldValue\n} from '../lite-api/reference';\nimport {\n  DocumentSnapshot as LiteDocumentSnapshot,\n  fieldPathFromArgument,\n  FirestoreDataConverter as LiteFirestoreDataConverter\n} from '../lite-api/snapshot';\nimport { UntypedFirestoreDataConverter } from '../lite-api/user_data_reader';\nimport { AbstractUserDataWriter } from '../lite-api/user_data_writer';\nimport { Document } from '../model/document';\nimport { DocumentKey } from '../model/document_key';\nimport { debugAssert, fail } from '../util/assert';\nimport { Code, FirestoreError } from '../util/error';\n\nimport { Firestore } from './database';\nimport { SnapshotListenOptions } from './reference_impl';\n\n/**\n * Converter used by `withConverter()` to transform user objects of type\n * `AppModelType` into Firestore data of type `DbModelType`.\n *\n * Using the converter allows you to specify generic type arguments when\n * storing and retrieving objects from Firestore.\n *\n * In this context, an \"AppModel\" is a class that is used in an application to\n * package together related information and functionality. Such a class could,\n * for example, have properties with complex, nested data types, properties used\n * for memoization, properties of types not supported by Firestore (such as\n * `symbol` and `bigint`), and helper functions that perform compound\n * operations. Such classes are not suitable and/or possible to store into a\n * Firestore database. Instead, instances of such classes need to be converted\n * to \"plain old JavaScript objects\" (POJOs) with exclusively primitive\n * properties, potentially nested inside other POJOs or arrays of POJOs. In this\n * context, this type is referred to as the \"DbModel\" and would be an object\n * suitable for persisting into Firestore. For convenience, applications can\n * implement `FirestoreDataConverter` and register the converter with Firestore\n * objects, such as `DocumentReference` or `Query`, to automatically convert\n * `AppModel` to `DbModel` when storing into Firestore, and convert `DbModel`\n * to `AppModel` when retrieving from Firestore.\n *\n * @example\n *\n * Simple Example\n *\n * ```typescript\n * const numberConverter = {\n *     toFirestore(value: WithFieldValue<number>) {\n *         return { value };\n *     },\n *     fromFirestore(snapshot: QueryDocumentSnapshot, options: SnapshotOptions) {\n *         return snapshot.data(options).value as number;\n *     }\n * };\n *\n * async function simpleDemo(db: Firestore): Promise<void> {\n *     const documentRef = doc(db, 'values/value123').withConverter(numberConverter);\n *\n *     // converters are used with `setDoc`, `addDoc`, and `getDoc`\n *     await setDoc(documentRef, 42);\n *     const snapshot1 = await getDoc(documentRef);\n *     assertEqual(snapshot1.data(), 42);\n *\n *     // converters are not used when writing data with `updateDoc`\n *     await updateDoc(documentRef, { value: 999 });\n *     const snapshot2 = await getDoc(documentRef);\n *     assertEqual(snapshot2.data(), 999);\n * }\n * ```\n *\n * Advanced Example\n *\n * ```typescript\n * // The Post class is a model that is used by our application.\n * // This class may have properties and methods that are specific\n * // to our application execution, which do not need to be persisted\n * // to Firestore.\n * class Post {\n *     constructor(\n *         readonly title: string,\n *         readonly author: string,\n *         readonly lastUpdatedMillis: number\n *     ) {}\n *     toString(): string {\n *         return `${this.title} by ${this.author}`;\n *     }\n * }\n *\n * // The PostDbModel represents how we want our posts to be stored\n * // in Firestore. This DbModel has different properties (`ttl`,\n * // `aut`, and `lut`) from the Post class we use in our application.\n * interface PostDbModel {\n *     ttl: string;\n *     aut: { firstName: string; lastName: string };\n *     lut: Timestamp;\n * }\n *\n * // The `PostConverter` implements `FirestoreDataConverter` and specifies\n * // how the Firestore SDK can convert `Post` objects to `PostDbModel`\n * // objects and vice versa.\n * class PostConverter implements FirestoreDataConverter<Post, PostDbModel> {\n *     toFirestore(post: WithFieldValue<Post>): WithFieldValue<PostDbModel> {\n *         return {\n *             ttl: post.title,\n *             aut: this._autFromAuthor(post.author),\n *             lut: this._lutFromLastUpdatedMillis(post.lastUpdatedMillis)\n *         };\n *     }\n *\n *     fromFirestore(snapshot: QueryDocumentSnapshot, options: SnapshotOptions): Post {\n *         const data = snapshot.data(options) as PostDbModel;\n *         const author = `${data.aut.firstName} ${data.aut.lastName}`;\n *         return new Post(data.ttl, author, data.lut.toMillis());\n *     }\n *\n *     _autFromAuthor(\n *         author: string | FieldValue\n *     ): { firstName: string; lastName: string } | FieldValue {\n *         if (typeof author !== 'string') {\n *             // `author` is a FieldValue, so just return it.\n *             return author;\n *         }\n *         const [firstName, lastName] = author.split(' ');\n *         return {firstName, lastName};\n *     }\n *\n *     _lutFromLastUpdatedMillis(\n *         lastUpdatedMillis: number | FieldValue\n *     ): Timestamp | FieldValue {\n *         if (typeof lastUpdatedMillis !== 'number') {\n *             // `lastUpdatedMillis` must be a FieldValue, so just return it.\n *             return lastUpdatedMillis;\n *         }\n *         return Timestamp.fromMillis(lastUpdatedMillis);\n *     }\n * }\n *\n * async function advancedDemo(db: Firestore): Promise<void> {\n *     // Create a `DocumentReference` with a `FirestoreDataConverter`.\n *     const documentRef = doc(db, 'posts/post123').withConverter(new PostConverter());\n *\n *     // The `data` argument specified to `setDoc()` is type checked by the\n *     // TypeScript compiler to be compatible with `Post`. Since the `data`\n *     // argument is typed as `WithFieldValue<Post>` rather than just `Post`,\n *     // this allows properties of the `data` argument to also be special\n *     // Firestore values that perform server-side mutations, such as\n *     // `arrayRemove()`, `deleteField()`, and `serverTimestamp()`.\n *     await setDoc(documentRef, {\n *         title: 'My Life',\n *         author: 'Foo Bar',\n *         lastUpdatedMillis: serverTimestamp()\n *     });\n *\n *     // The TypeScript compiler will fail to compile if the `data` argument to\n *     // `setDoc()` is _not_ compatible with `WithFieldValue<Post>`. This\n *     // type checking prevents the caller from specifying objects with incorrect\n *     // properties or property values.\n *     // @ts-expect-error \"Argument of type { ttl: string; } is not assignable\n *     // to parameter of type WithFieldValue<Post>\"\n *     await setDoc(documentRef, { ttl: 'The Title' });\n *\n *     // When retrieving a document with `getDoc()` the `DocumentSnapshot`\n *     // object's `data()` method returns a `Post`, rather than a generic object,\n *     // which would have been returned if the `DocumentReference` did _not_ have a\n *     // `FirestoreDataConverter` attached to it.\n *     const snapshot1: DocumentSnapshot<Post> = await getDoc(documentRef);\n *     const post1: Post = snapshot1.data()!;\n *     if (post1) {\n *         assertEqual(post1.title, 'My Life');\n *         assertEqual(post1.author, 'Foo Bar');\n *     }\n *\n *     // The `data` argument specified to `updateDoc()` is type checked by the\n *     // TypeScript compiler to be compatible with `PostDbModel`. Note that\n *     // unlike `setDoc()`, whose `data` argument must be compatible with `Post`,\n *     // the `data` argument to `updateDoc()` must be compatible with\n *     // `PostDbModel`. Similar to `setDoc()`, since the `data` argument is typed\n *     // as `WithFieldValue<PostDbModel>` rather than just `PostDbModel`, this\n *     // allows properties of the `data` argument to also be those special\n *     // Firestore values, like `arrayRemove()`, `deleteField()`, and\n *     // `serverTimestamp()`.\n *     await updateDoc(documentRef, {\n *         'aut.firstName': 'NewFirstName',\n *         lut: serverTimestamp()\n *     });\n *\n *     // The TypeScript compiler will fail to compile if the `data` argument to\n *     // `updateDoc()` is _not_ compatible with `WithFieldValue<PostDbModel>`.\n *     // This type checking prevents the caller from specifying objects with\n *     // incorrect properties or property values.\n *     // @ts-expect-error \"Argument of type { title: string; } is not assignable\n *     // to parameter of type WithFieldValue<PostDbModel>\"\n *     await updateDoc(documentRef, { title: 'New Title' });\n *     const snapshot2: DocumentSnapshot<Post> = await getDoc(documentRef);\n *     const post2: Post = snapshot2.data()!;\n *     if (post2) {\n *         assertEqual(post2.title, 'My Life');\n *         assertEqual(post2.author, 'NewFirstName Bar');\n *     }\n * }\n * ```\n */\nexport interface FirestoreDataConverter<\n  AppModelType,\n  DbModelType extends DocumentData = DocumentData\n> extends LiteFirestoreDataConverter<AppModelType, DbModelType> {\n  /**\n   * Called by the Firestore SDK to convert a custom model object of type\n   * `AppModelType` into a plain JavaScript object (suitable for writing\n   * directly to the Firestore database) of type `DbModelType`. To use `set()`\n   * with `merge` and `mergeFields`, `toFirestore()` must be defined with\n   * `PartialWithFieldValue<AppModelType>`.\n   *\n   * The `WithFieldValue<T>` type extends `T` to also allow FieldValues such as\n   * {@link (deleteField:1)} to be used as property values.\n   */\n  toFirestore(\n    modelObject: WithFieldValue<AppModelType>\n  ): WithFieldValue<DbModelType>;\n\n  /**\n   * Called by the Firestore SDK to convert a custom model object of type\n   * `AppModelType` into a plain JavaScript object (suitable for writing\n   * directly to the Firestore database) of type `DbModelType`. Used with\n   * {@link (setDoc:1)}, {@link (WriteBatch.set:1)} and\n   * {@link (Transaction.set:1)} with `merge:true` or `mergeFields`.\n   *\n   * The `PartialWithFieldValue<T>` type extends `Partial<T>` to allow\n   * FieldValues such as {@link (arrayUnion:1)} to be used as property values.\n   * It also supports nested `Partial` by allowing nested fields to be\n   * omitted.\n   */\n  toFirestore(\n    modelObject: PartialWithFieldValue<AppModelType>,\n    options: SetOptions\n  ): PartialWithFieldValue<DbModelType>;\n\n  /**\n   * Called by the Firestore SDK to convert Firestore data into an object of\n   * type `AppModelType`. You can access your data by calling:\n   * `snapshot.data(options)`.\n   *\n   * Generally, the data returned from `snapshot.data()` can be cast to\n   * `DbModelType`; however, this is not guaranteed because Firestore does not\n   * enforce a schema on the database. For example, writes from a previous\n   * version of the application or writes from another client that did not use a\n   * type converter could have written data with different properties and/or\n   * property types. The implementation will need to choose whether to\n   * gracefully recover from non-conforming data or throw an error.\n   *\n   * To override this method, see {@link (FirestoreDataConverter.fromFirestore:1)}.\n   *\n   * @param snapshot - A `QueryDocumentSnapshot` containing your data and metadata.\n   * @param options - The `SnapshotOptions` from the initial call to `data()`.\n   */\n  fromFirestore(\n    snapshot: QueryDocumentSnapshot<DocumentData, DocumentData>,\n    options?: SnapshotOptions\n  ): AppModelType;\n}\n\n/**\n * Options that configure how data is retrieved from a `DocumentSnapshot` (for\n * example the desired behavior for server timestamps that have not yet been set\n * to their final value).\n */\nexport interface SnapshotOptions {\n  /**\n   * If set, controls the return value for server timestamps that have not yet\n   * been set to their final value.\n   *\n   * By specifying 'estimate', pending server timestamps return an estimate\n   * based on the local clock. This estimate will differ from the final value\n   * and cause these values to change once the server result becomes available.\n   *\n   * By specifying 'previous', pending timestamps will be ignored and return\n   * their previous value instead.\n   *\n   * If omitted or set to 'none', `null` will be returned by default until the\n   * server value becomes available.\n   */\n  readonly serverTimestamps?: 'estimate' | 'previous' | 'none';\n}\n\n/**\n * Metadata about a snapshot, describing the state of the snapshot.\n */\nexport class SnapshotMetadata {\n  /**\n   * True if the snapshot contains the result of local writes (for example\n   * `set()` or `update()` calls) that have not yet been committed to the\n   * backend. If your listener has opted into metadata updates (via\n   * `SnapshotListenOptions`) you will receive another snapshot with\n   * `hasPendingWrites` equal to false once the writes have been committed to\n   * the backend.\n   */\n  readonly hasPendingWrites: boolean;\n\n  /**\n   * True if the snapshot was created from cached data rather than guaranteed\n   * up-to-date server data. If your listener has opted into metadata updates\n   * (via `SnapshotListenOptions`) you will receive another snapshot with\n   * `fromCache` set to false once the client has received up-to-date data from\n   * the backend.\n   */\n  readonly fromCache: boolean;\n\n  /** @hideconstructor */\n  constructor(hasPendingWrites: boolean, fromCache: boolean) {\n    this.hasPendingWrites = hasPendingWrites;\n    this.fromCache = fromCache;\n  }\n\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  isEqual(other: SnapshotMetadata): boolean {\n    return (\n      this.hasPendingWrites === other.hasPendingWrites &&\n      this.fromCache === other.fromCache\n    );\n  }\n}\n\n/**\n * The type of a `DocumentChange` may be 'added', 'removed', or 'modified'.\n */\nexport type DocumentChangeType = 'added' | 'removed' | 'modified';\n\n/**\n * A `DocumentChange` represents a change to the documents matching a query.\n * It contains the document affected and the type of change that occurred.\n */\nexport interface DocumentChange<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /** The type of change ('added', 'modified', or 'removed'). */\n  readonly type: DocumentChangeType;\n\n  /** The document affected by this change. */\n  readonly doc: QueryDocumentSnapshot<AppModelType, DbModelType>;\n\n  /**\n   * The index of the changed document in the result set immediately prior to\n   * this `DocumentChange` (i.e. supposing that all prior `DocumentChange` objects\n   * have been applied). Is `-1` for 'added' events.\n   */\n  readonly oldIndex: number;\n\n  /**\n   * The index of the changed document in the result set immediately after\n   * this `DocumentChange` (i.e. supposing that all prior `DocumentChange`\n   * objects and the current `DocumentChange` object have been applied).\n   * Is -1 for 'removed' events.\n   */\n  readonly newIndex: number;\n}\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 */\nexport class DocumentSnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> extends LiteDocumentSnapshot<AppModelType, DbModelType> {\n  private readonly _firestoreImpl: Firestore;\n\n  /**\n   *  Metadata about the `DocumentSnapshot`, including information about its\n   *  source and local modifications.\n   */\n  readonly metadata: SnapshotMetadata;\n\n  /** @hideconstructor protected */\n  constructor(\n    readonly _firestore: Firestore,\n    userDataWriter: AbstractUserDataWriter,\n    key: DocumentKey,\n    document: Document | null,\n    metadata: SnapshotMetadata,\n    converter: UntypedFirestoreDataConverter<AppModelType, DbModelType> | null\n  ) {\n    super(_firestore, userDataWriter, key, document, converter);\n    this._firestoreImpl = _firestore;\n    this.metadata = metadata;\n  }\n\n  /**\n   * Returns whether or not the data exists. True if the document exists.\n   */\n  exists(): this is QueryDocumentSnapshot<AppModelType, DbModelType> {\n    return super.exists();\n  }\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, `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  data(options: SnapshotOptions = {}): AppModelType | undefined {\n    if (!this._document) {\n      return undefined;\n    } else if (this._converter) {\n      // We only want to use the converter and create a new DocumentSnapshot\n      // if a converter has been provided.\n      const snapshot = new QueryDocumentSnapshot(\n        this._firestore,\n        this._userDataWriter,\n        this._key,\n        this._document,\n        this.metadata,\n        /* converter= */ null\n      );\n      return this._converter.fromFirestore(snapshot, options);\n    } else {\n      return this._userDataWriter.convertValue(\n        this._document.data.value,\n        options.serverTimestamps\n      ) as AppModelType;\n    }\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 `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  get(fieldPath: string | FieldPath, options: SnapshotOptions = {}): any {\n    if (this._document) {\n      const value = this._document.data.field(\n        fieldPathFromArgument('DocumentSnapshot.get', fieldPath)\n      );\n      if (value !== null) {\n        return this._userDataWriter.convertValue(\n          value,\n          options.serverTimestamps\n        );\n      }\n    }\n    return undefined;\n  }\n}\n\n/**\n * A `QueryDocumentSnapshot` contains data read from a document in your\n * Firestore database as part of a query. The document is guaranteed to exist\n * and its data can be extracted with `.data()` or `.get(<field>)` to get a\n * specific field.\n *\n * A `QueryDocumentSnapshot` offers the same API surface as a\n * `DocumentSnapshot`. Since query results contain only existing documents, the\n * `exists` property will always be true and `data()` will never return\n * 'undefined'.\n */\nexport class QueryDocumentSnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> extends DocumentSnapshot<AppModelType, DbModelType> {\n  /**\n   * Retrieves all fields in the document as an `Object`.\n   *\n   * By default, `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   */\n  data(options: SnapshotOptions = {}): AppModelType {\n    return super.data(options) as AppModelType;\n  }\n}\n\n/**\n * A `QuerySnapshot` contains zero or more `DocumentSnapshot` objects\n * representing the results of a query. The documents can be accessed as an\n * array via the `docs` property or enumerated using the `forEach` method. The\n * number of documents can be determined via the `empty` and `size`\n * properties.\n */\nexport class QuerySnapshot<\n  AppModelType = DocumentData,\n  DbModelType extends DocumentData = DocumentData\n> {\n  /**\n   * Metadata about this snapshot, concerning its source and if it has local\n   * modifications.\n   */\n  readonly metadata: SnapshotMetadata;\n\n  /**\n   * The query on which you called `get` or `onSnapshot` in order to get this\n   * `QuerySnapshot`.\n   */\n  readonly query: Query<AppModelType, DbModelType>;\n\n  private _cachedChanges?: Array<DocumentChange<AppModelType, DbModelType>>;\n  private _cachedChangesIncludeMetadataChanges?: boolean;\n\n  /** @hideconstructor */\n  constructor(\n    readonly _firestore: Firestore,\n    readonly _userDataWriter: AbstractUserDataWriter,\n    query: Query<AppModelType, DbModelType>,\n    readonly _snapshot: ViewSnapshot\n  ) {\n    this.metadata = new SnapshotMetadata(\n      _snapshot.hasPendingWrites,\n      _snapshot.fromCache\n    );\n    this.query = query;\n  }\n\n  /** An array of all the documents in the `QuerySnapshot`. */\n  get docs(): Array<QueryDocumentSnapshot<AppModelType, DbModelType>> {\n    const result: Array<QueryDocumentSnapshot<AppModelType, DbModelType>> = [];\n    this.forEach(doc => result.push(doc));\n    return result;\n  }\n\n  /** The number of documents in the `QuerySnapshot`. */\n  get size(): number {\n    return this._snapshot.docs.size;\n  }\n\n  /** True if there are no documents in the `QuerySnapshot`. */\n  get empty(): boolean {\n    return this.size === 0;\n  }\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  forEach(\n    callback: (\n      result: QueryDocumentSnapshot<AppModelType, DbModelType>\n    ) => void,\n    thisArg?: unknown\n  ): void {\n    this._snapshot.docs.forEach(doc => {\n      callback.call(\n        thisArg,\n        new QueryDocumentSnapshot<AppModelType, DbModelType>(\n          this._firestore,\n          this._userDataWriter,\n          doc.key,\n          doc,\n          new SnapshotMetadata(\n            this._snapshot.mutatedKeys.has(doc.key),\n            this._snapshot.fromCache\n          ),\n          this.query.converter\n        )\n      );\n    });\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  docChanges(\n    options: SnapshotListenOptions = {}\n  ): Array<DocumentChange<AppModelType, DbModelType>> {\n    const includeMetadataChanges = !!options.includeMetadataChanges;\n\n    if (includeMetadataChanges && this._snapshot.excludesMetadataChanges) {\n      throw new FirestoreError(\n        Code.INVALID_ARGUMENT,\n        'To include metadata changes with your document changes, you must ' +\n          'also pass { includeMetadataChanges:true } to onSnapshot().'\n      );\n    }\n\n    if (\n      !this._cachedChanges ||\n      this._cachedChangesIncludeMetadataChanges !== includeMetadataChanges\n    ) {\n      this._cachedChanges = changesFromSnapshot(this, includeMetadataChanges);\n      this._cachedChangesIncludeMetadataChanges = includeMetadataChanges;\n    }\n\n    return this._cachedChanges;\n  }\n}\n\n/** Calculates the array of `DocumentChange`s for a given `ViewSnapshot`. */\nexport function changesFromSnapshot<\n  AppModelType,\n  DbModelType extends DocumentData\n>(\n  querySnapshot: QuerySnapshot<AppModelType, DbModelType>,\n  includeMetadataChanges: boolean\n): Array<DocumentChange<AppModelType, DbModelType>> {\n  if (querySnapshot._snapshot.oldDocs.isEmpty()) {\n    // Special case the first snapshot because index calculation is easy and\n    // fast\n    let lastDoc: Document;\n    let index = 0;\n    return querySnapshot._snapshot.docChanges.map(change => {\n      debugAssert(\n        change.type === ChangeType.Added,\n        'Invalid event type for first snapshot'\n      );\n      debugAssert(\n        !lastDoc ||\n          newQueryComparator(querySnapshot._snapshot.query)(\n            lastDoc,\n            change.doc\n          ) < 0,\n        'Got added events in wrong order'\n      );\n      const doc = new QueryDocumentSnapshot<AppModelType, DbModelType>(\n        querySnapshot._firestore,\n        querySnapshot._userDataWriter,\n        change.doc.key,\n        change.doc,\n        new SnapshotMetadata(\n          querySnapshot._snapshot.mutatedKeys.has(change.doc.key),\n          querySnapshot._snapshot.fromCache\n        ),\n        querySnapshot.query.converter\n      );\n      lastDoc = change.doc;\n      return {\n        type: 'added' as DocumentChangeType,\n        doc,\n        oldIndex: -1,\n        newIndex: index++\n      };\n    });\n  } else {\n    // A `DocumentSet` that is updated incrementally as changes are applied to use\n    // to lookup the index of a document.\n    let indexTracker = querySnapshot._snapshot.oldDocs;\n    return querySnapshot._snapshot.docChanges\n      .filter(\n        change => includeMetadataChanges || change.type !== ChangeType.Metadata\n      )\n      .map(change => {\n        const doc = new QueryDocumentSnapshot<AppModelType, DbModelType>(\n          querySnapshot._firestore,\n          querySnapshot._userDataWriter,\n          change.doc.key,\n          change.doc,\n          new SnapshotMetadata(\n            querySnapshot._snapshot.mutatedKeys.has(change.doc.key),\n            querySnapshot._snapshot.fromCache\n          ),\n          querySnapshot.query.converter\n        );\n        let oldIndex = -1;\n        let newIndex = -1;\n        if (change.type !== ChangeType.Added) {\n          oldIndex = indexTracker.indexOf(change.doc.key);\n          debugAssert(oldIndex >= 0, 'Index for document not found');\n          indexTracker = indexTracker.delete(change.doc.key);\n        }\n        if (change.type !== ChangeType.Removed) {\n          indexTracker = indexTracker.add(change.doc);\n          newIndex = indexTracker.indexOf(change.doc.key);\n        }\n        return {\n          type: resultChangeType(change.type),\n          doc,\n          oldIndex,\n          newIndex\n        };\n      });\n  }\n}\n\nexport function resultChangeType(type: ChangeType): DocumentChangeType {\n  switch (type) {\n    case ChangeType.Added:\n      return 'added';\n    case ChangeType.Modified:\n    case ChangeType.Metadata:\n      return 'modified';\n    case ChangeType.Removed:\n      return 'removed';\n    default:\n      return fail('Unknown change type: ' + type);\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 */\nexport function snapshotEqual<AppModelType, DbModelType extends DocumentData>(\n  left:\n    | DocumentSnapshot<AppModelType, DbModelType>\n    | QuerySnapshot<AppModelType, DbModelType>,\n  right:\n    | DocumentSnapshot<AppModelType, DbModelType>\n    | QuerySnapshot<AppModelType, DbModelType>\n): boolean {\n  if (left instanceof DocumentSnapshot && right instanceof DocumentSnapshot) {\n    return (\n      left._firestore === right._firestore &&\n      left._key.isEqual(right._key) &&\n      (left._document === null\n        ? right._document === null\n        : left._document.isEqual(right._document)) &&\n      left._converter === right._converter\n    );\n  } else if (left instanceof QuerySnapshot && right instanceof QuerySnapshot) {\n    return (\n      left._firestore === right._firestore &&\n      queryEqual(left.query, right.query) &&\n      left.metadata.isEqual(right.metadata) &&\n      left._snapshot.isEqual(right._snapshot)\n    );\n  }\n\n  return false;\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 { getModularInstance } from '@firebase/util';\n\nimport {\n  CompleteFn,\n  ErrorFn,\n  isPartialObserver,\n  NextFn,\n  PartialObserver\n} from '../api/observer';\nimport { ListenerDataSource } from '../core/event_manager';\nimport {\n  firestoreClientAddSnapshotsInSyncListener,\n  firestoreClientGetDocumentFromLocalCache,\n  firestoreClientGetDocumentsFromLocalCache,\n  firestoreClientGetDocumentsViaSnapshotListener,\n  firestoreClientGetDocumentViaSnapshotListener,\n  firestoreClientListen,\n  firestoreClientWrite\n} from '../core/firestore_client';\nimport { newQueryForPath, Query as InternalQuery } from '../core/query';\nimport { ViewSnapshot } from '../core/view_snapshot';\nimport { Bytes } from '../lite-api/bytes';\nimport { FieldPath } from '../lite-api/field_path';\nimport { validateHasExplicitOrderByForLimitToLast } from '../lite-api/query';\nimport {\n  CollectionReference,\n  doc,\n  DocumentData,\n  DocumentReference,\n  PartialWithFieldValue,\n  Query,\n  SetOptions,\n  UpdateData,\n  WithFieldValue\n} from '../lite-api/reference';\nimport { applyFirestoreDataConverter } from '../lite-api/reference_impl';\nimport {\n  newUserDataReader,\n  ParsedUpdateData,\n  parseSetData,\n  parseUpdateData,\n  parseUpdateVarargs\n} from '../lite-api/user_data_reader';\nimport { AbstractUserDataWriter } from '../lite-api/user_data_writer';\nimport { DeleteMutation, Mutation, Precondition } from '../model/mutation';\nimport { debugAssert } from '../util/assert';\nimport { ByteString } from '../util/byte_string';\nimport { FirestoreError } from '../util/error';\nimport { cast } from '../util/input_validation';\n\nimport { ensureFirestoreConfigured, Firestore } from './database';\nimport { DocumentSnapshot, QuerySnapshot, SnapshotMetadata } from './snapshot';\n\n/**\n * An options object that can be passed to {@link (onSnapshot:1)} and {@link\n * QuerySnapshot.docChanges} to control which types of changes to include in the\n * result set.\n */\nexport interface SnapshotListenOptions {\n  /**\n   * Include a change even if only the metadata of the query or of a document\n   * changed. Default is false.\n   */\n  readonly includeMetadataChanges?: boolean;\n\n  /**\n   * Set the source the query listens to. Default to \"default\", which\n   * listens to both cache and server.\n   */\n  readonly source?: ListenSource;\n}\n\n/**\n * Describe the source a query listens to.\n *\n * Set to `default` to listen to both cache and server changes. Set to `cache`\n * to listen to changes in cache only.\n */\nexport type ListenSource = 'default' | 'cache';\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 */\nexport function getDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<DocumentSnapshot<AppModelType, DbModelType>> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const firestore = cast(reference.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n\n  return firestoreClientGetDocumentViaSnapshotListener(\n    client,\n    reference._key\n  ).then(snapshot => convertToDocSnapshot(firestore, reference, snapshot));\n}\n\nexport class ExpUserDataWriter extends AbstractUserDataWriter {\n  constructor(protected firestore: Firestore) {\n    super();\n  }\n\n  protected convertBytes(bytes: ByteString): Bytes {\n    return new Bytes(bytes);\n  }\n\n  protected convertReference(name: string): DocumentReference {\n    const key = this.convertDocumentKey(name, this.firestore._databaseId);\n    return new DocumentReference(this.firestore, /* converter= */ null, key);\n  }\n}\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 */\nexport function getDocFromCache<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<DocumentSnapshot<AppModelType, DbModelType>> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const firestore = cast(reference.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const userDataWriter = new ExpUserDataWriter(firestore);\n\n  return firestoreClientGetDocumentFromLocalCache(client, reference._key).then(\n    doc =>\n      new DocumentSnapshot<AppModelType, DbModelType>(\n        firestore,\n        userDataWriter,\n        reference._key,\n        doc,\n        new SnapshotMetadata(\n          doc !== null && doc.hasLocalMutations,\n          /* fromCache= */ true\n        ),\n        reference.converter\n      )\n  );\n}\n\n/**\n * Reads the document referred to by this `DocumentReference` from the server.\n * Returns an error if the network is not available.\n *\n * @returns A `Promise` resolved with a `DocumentSnapshot` containing the\n * current document contents.\n */\nexport function getDocFromServer<\n  AppModelType,\n  DbModelType extends DocumentData\n>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<DocumentSnapshot<AppModelType, DbModelType>> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const firestore = cast(reference.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n\n  return firestoreClientGetDocumentViaSnapshotListener(client, reference._key, {\n    source: 'server'\n  }).then(snapshot => convertToDocSnapshot(firestore, reference, snapshot));\n}\n\n/**\n * Executes the query and returns the results as a `QuerySnapshot`.\n *\n * Note: `getDocs()` attempts to provide up-to-date data when possible by\n * waiting for data from the server, but it may return cached data or fail if\n * you are offline and the server cannot be reached. To specify this behavior,\n * invoke {@link getDocsFromCache} or {@link getDocsFromServer}.\n *\n * @returns A `Promise` that will be resolved with the results of the query.\n */\nexport function getDocs<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>\n): Promise<QuerySnapshot<AppModelType, DbModelType>> {\n  query = cast<Query<AppModelType, DbModelType>>(query, Query);\n  const firestore = cast(query.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const userDataWriter = new ExpUserDataWriter(firestore);\n\n  validateHasExplicitOrderByForLimitToLast(query._query);\n  return firestoreClientGetDocumentsViaSnapshotListener(\n    client,\n    query._query\n  ).then(\n    snapshot =>\n      new QuerySnapshot<AppModelType, DbModelType>(\n        firestore,\n        userDataWriter,\n        query,\n        snapshot\n      )\n  );\n}\n\n/**\n * Executes the query and returns the results as a `QuerySnapshot` from cache.\n * Returns an empty result set if no documents matching the query are currently\n * cached.\n *\n * @returns A `Promise` that will be resolved with the results of the query.\n */\nexport function getDocsFromCache<\n  AppModelType,\n  DbModelType extends DocumentData\n>(\n  query: Query<AppModelType, DbModelType>\n): Promise<QuerySnapshot<AppModelType, DbModelType>> {\n  query = cast<Query<AppModelType, DbModelType>>(query, Query);\n  const firestore = cast(query.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const userDataWriter = new ExpUserDataWriter(firestore);\n\n  return firestoreClientGetDocumentsFromLocalCache(client, query._query).then(\n    snapshot =>\n      new QuerySnapshot<AppModelType, DbModelType>(\n        firestore,\n        userDataWriter,\n        query,\n        snapshot\n      )\n  );\n}\n\n/**\n * Executes the query and returns the results as a `QuerySnapshot` from the\n * server. Returns an error if the network is not available.\n *\n * @returns A `Promise` that will be resolved with the results of the query.\n */\nexport function getDocsFromServer<\n  AppModelType,\n  DbModelType extends DocumentData\n>(\n  query: Query<AppModelType, DbModelType>\n): Promise<QuerySnapshot<AppModelType, DbModelType>> {\n  query = cast<Query<AppModelType, DbModelType>>(query, Query);\n  const firestore = cast(query.firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const userDataWriter = new ExpUserDataWriter(firestore);\n\n  return firestoreClientGetDocumentsViaSnapshotListener(client, query._query, {\n    source: 'server'\n  }).then(\n    snapshot => new QuerySnapshot(firestore, userDataWriter, query, snapshot)\n  );\n}\n\n/**\n * Writes to the document referred to by this `DocumentReference`. If the\n * document does not yet exist, it will be created.\n *\n * @param reference - A reference to the document to write.\n * @param data - A map of the fields and values for the document.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend (note that it won't resolve while you're offline).\n */\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: WithFieldValue<AppModelType>\n): Promise<void>;\n/**\n * Writes to the document referred to by the specified `DocumentReference`. If\n * the document does not yet exist, it will be created. If you provide `merge`\n * or `mergeFields`, the provided data can be merged into an existing document.\n *\n * @param reference - A reference to the document to write.\n * @param data - A map of the fields and values for the document.\n * @param options - An object to configure the set behavior.\n * @returns A Promise resolved once the data has been successfully written\n * to the backend (note that it won't resolve while you're offline).\n */\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: PartialWithFieldValue<AppModelType>,\n  options: SetOptions\n): Promise<void>;\nexport function setDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: PartialWithFieldValue<AppModelType>,\n  options?: SetOptions\n): Promise<void> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const firestore = cast(reference.firestore, Firestore);\n\n  const convertedValue = applyFirestoreDataConverter(\n    reference.converter,\n    data as WithFieldValue<AppModelType>,\n    options\n  );\n  const dataReader = newUserDataReader(firestore);\n  const parsed = parseSetData(\n    dataReader,\n    'setDoc',\n    reference._key,\n    convertedValue,\n    reference.converter !== null,\n    options\n  );\n\n  const mutation = parsed.toMutation(reference._key, Precondition.none());\n  return executeWrite(firestore, [mutation]);\n}\n\n/**\n * Updates fields in the document referred to by the specified\n * `DocumentReference`. The update will fail if applied to a document that does\n * not exist.\n *\n * @param reference - A reference to the document to update.\n * @param data - An object containing the fields and values with which to\n * update the document. Fields can contain dots to reference nested fields\n * within the document.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend (note that it won't resolve while you're offline).\n */\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  data: UpdateData<DbModelType>\n): Promise<void>;\n/**\n * Updates fields in the document referred to by the specified\n * `DocumentReference` The update will fail if applied to a document that does\n * not exist.\n *\n * Nested fields can be updated by providing dot-separated field path\n * strings or by providing `FieldPath` objects.\n *\n * @param reference - A reference to the document to update.\n * @param field - The first field to update.\n * @param value - The first value.\n * @param moreFieldsAndValues - Additional key value pairs.\n * @returns A `Promise` resolved once the data has been successfully written\n * to the backend (note that it won't resolve while you're offline).\n */\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  field: string | FieldPath,\n  value: unknown,\n  ...moreFieldsAndValues: unknown[]\n): Promise<void>;\nexport function updateDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<unknown>,\n  fieldOrUpdateData: string | FieldPath | UpdateData<DbModelType>,\n  value?: unknown,\n  ...moreFieldsAndValues: unknown[]\n): Promise<void> {\n  reference = cast<DocumentReference<AppModelType, DbModelType>>(\n    reference,\n    DocumentReference\n  );\n  const firestore = cast(reference.firestore, Firestore);\n\n  const dataReader = newUserDataReader(firestore);\n\n  // For Compat types, we have to \"extract\" the underlying types before\n  // performing validation.\n  fieldOrUpdateData = getModularInstance(fieldOrUpdateData);\n\n  let parsed: ParsedUpdateData;\n  if (\n    typeof fieldOrUpdateData === 'string' ||\n    fieldOrUpdateData instanceof FieldPath\n  ) {\n    parsed = parseUpdateVarargs(\n      dataReader,\n      'updateDoc',\n      reference._key,\n      fieldOrUpdateData,\n      value,\n      moreFieldsAndValues\n    );\n  } else {\n    parsed = parseUpdateData(\n      dataReader,\n      'updateDoc',\n      reference._key,\n      fieldOrUpdateData\n    );\n  }\n\n  const mutation = parsed.toMutation(reference._key, Precondition.exists(true));\n  return executeWrite(firestore, [mutation]);\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 */\nexport function deleteDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>\n): Promise<void> {\n  const firestore = cast(reference.firestore, Firestore);\n  const mutations = [new DeleteMutation(reference._key, Precondition.none())];\n  return executeWrite(firestore, mutations);\n}\n\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 */\nexport function addDoc<AppModelType, DbModelType extends DocumentData>(\n  reference: CollectionReference<AppModelType, DbModelType>,\n  data: WithFieldValue<AppModelType>\n): Promise<DocumentReference<AppModelType, DbModelType>> {\n  const firestore = cast(reference.firestore, Firestore);\n\n  const docRef = doc(reference);\n  const convertedValue = applyFirestoreDataConverter(reference.converter, data);\n\n  const dataReader = newUserDataReader(reference.firestore);\n  const parsed = parseSetData(\n    dataReader,\n    'addDoc',\n    docRef._key,\n    convertedValue,\n    reference.converter !== null,\n    {}\n  );\n\n  const mutation = parsed.toMutation(docRef._key, Precondition.exists(false));\n  return executeWrite(firestore, [mutation]).then(() => docRef);\n}\n\n/**\n * A function returned by `onSnapshot()` that removes the listener when invoked.\n */\nexport interface Unsubscribe {\n  /** Removes the listener when invoked. */\n  (): void;\n}\n\n// TODO(firestorexp): Make sure these overloads are tested via the Firestore\n// integration tests\n\n/**\n * Attaches a listener for `DocumentSnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param reference - A reference to the document to listen to.\n * @param observer - A single object containing `next` and `error` callbacks.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  observer: {\n    next?: (snapshot: DocumentSnapshot<AppModelType, DbModelType>) => void;\n    error?: (error: FirestoreError) => void;\n    complete?: () => void;\n  }\n): Unsubscribe;\n/**\n * Attaches a listener for `DocumentSnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param reference - A reference to the document to listen to.\n * @param options - Options controlling the listen behavior.\n * @param observer - A single object containing `next` and `error` callbacks.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  options: SnapshotListenOptions,\n  observer: {\n    next?: (snapshot: DocumentSnapshot<AppModelType, DbModelType>) => void;\n    error?: (error: FirestoreError) => void;\n    complete?: () => void;\n  }\n): Unsubscribe;\n/**\n * Attaches a listener for `DocumentSnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param reference - A reference to the document to listen to.\n * @param onNext - A callback to be called every time a new `DocumentSnapshot`\n * is available.\n * @param onError - A callback to be called if the listen fails or is\n * cancelled. No further callbacks will occur.\n * @param onCompletion - Can be provided, but will not be called since streams are\n * never ending.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  onNext: (snapshot: DocumentSnapshot<AppModelType, DbModelType>) => void,\n  onError?: (error: FirestoreError) => void,\n  onCompletion?: () => void\n): Unsubscribe;\n/**\n * Attaches a listener for `DocumentSnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param reference - A reference to the document to listen to.\n * @param options - Options controlling the listen behavior.\n * @param onNext - A callback to be called every time a new `DocumentSnapshot`\n * is available.\n * @param onError - A callback to be called if the listen fails or is\n * cancelled. No further callbacks will occur.\n * @param onCompletion - Can be provided, but will not be called since streams are\n * never ending.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  reference: DocumentReference<AppModelType, DbModelType>,\n  options: SnapshotListenOptions,\n  onNext: (snapshot: DocumentSnapshot<AppModelType, DbModelType>) => void,\n  onError?: (error: FirestoreError) => void,\n  onCompletion?: () => void\n): Unsubscribe;\n/**\n * Attaches a listener for `QuerySnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks. The listener can be cancelled by\n * calling the function that is returned when `onSnapshot` is called.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param query - The query to listen to.\n * @param observer - A single object containing `next` and `error` callbacks.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  observer: {\n    next?: (snapshot: QuerySnapshot<AppModelType, DbModelType>) => void;\n    error?: (error: FirestoreError) => void;\n    complete?: () => void;\n  }\n): Unsubscribe;\n/**\n * Attaches a listener for `QuerySnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks. The listener can be cancelled by\n * calling the function that is returned when `onSnapshot` is called.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param query - The query to listen to.\n * @param options - Options controlling the listen behavior.\n * @param observer - A single object containing `next` and `error` callbacks.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  options: SnapshotListenOptions,\n  observer: {\n    next?: (snapshot: QuerySnapshot<AppModelType, DbModelType>) => void;\n    error?: (error: FirestoreError) => void;\n    complete?: () => void;\n  }\n): Unsubscribe;\n/**\n * Attaches a listener for `QuerySnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks. The listener can be cancelled by\n * calling the function that is returned when `onSnapshot` is called.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param query - The query to listen to.\n * @param onNext - A callback to be called every time a new `QuerySnapshot`\n * is available.\n * @param onCompletion - Can be provided, but will not be called since streams are\n * never ending.\n * @param onError - A callback to be called if the listen fails or is\n * cancelled. No further callbacks will occur.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  onNext: (snapshot: QuerySnapshot<AppModelType, DbModelType>) => void,\n  onError?: (error: FirestoreError) => void,\n  onCompletion?: () => void\n): Unsubscribe;\n/**\n * Attaches a listener for `QuerySnapshot` events. You may either pass\n * individual `onNext` and `onError` callbacks or pass a single observer\n * object with `next` and `error` callbacks. The listener can be cancelled by\n * calling the function that is returned when `onSnapshot` is called.\n *\n * NOTE: Although an `onCompletion` callback can be provided, it will\n * never be called because the snapshot stream is never-ending.\n *\n * @param query - The query to listen to.\n * @param options - Options controlling the listen behavior.\n * @param onNext - A callback to be called every time a new `QuerySnapshot`\n * is available.\n * @param onCompletion - Can be provided, but will not be called since streams are\n * never ending.\n * @param onError - A callback to be called if the listen fails or is\n * cancelled. No further callbacks will occur.\n * @returns An unsubscribe function that can be called to cancel\n * the snapshot listener.\n */\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  query: Query<AppModelType, DbModelType>,\n  options: SnapshotListenOptions,\n  onNext: (snapshot: QuerySnapshot<AppModelType, DbModelType>) => void,\n  onError?: (error: FirestoreError) => void,\n  onCompletion?: () => void\n): Unsubscribe;\nexport function onSnapshot<AppModelType, DbModelType extends DocumentData>(\n  reference:\n    | Query<AppModelType, DbModelType>\n    | DocumentReference<AppModelType, DbModelType>,\n  ...args: unknown[]\n): Unsubscribe {\n  reference = getModularInstance(reference);\n\n  let options: SnapshotListenOptions = {\n    includeMetadataChanges: false,\n    source: 'default'\n  };\n  let currArg = 0;\n  if (typeof args[currArg] === 'object' && !isPartialObserver(args[currArg])) {\n    options = args[currArg] as SnapshotListenOptions;\n    currArg++;\n  }\n\n  const internalOptions = {\n    includeMetadataChanges: options.includeMetadataChanges,\n    source: options.source as ListenerDataSource\n  };\n\n  if (isPartialObserver(args[currArg])) {\n    const userObserver = args[currArg] as PartialObserver<\n      QuerySnapshot<AppModelType, DbModelType>\n    >;\n    args[currArg] = userObserver.next?.bind(userObserver);\n    args[currArg + 1] = userObserver.error?.bind(userObserver);\n    args[currArg + 2] = userObserver.complete?.bind(userObserver);\n  }\n\n  let observer: PartialObserver<ViewSnapshot>;\n  let firestore: Firestore;\n  let internalQuery: InternalQuery;\n\n  if (reference instanceof DocumentReference) {\n    firestore = cast(reference.firestore, Firestore);\n    internalQuery = newQueryForPath(reference._key.path);\n\n    observer = {\n      next: snapshot => {\n        if (args[currArg]) {\n          (\n            args[currArg] as NextFn<DocumentSnapshot<AppModelType, DbModelType>>\n          )(\n            convertToDocSnapshot(\n              firestore,\n              reference as DocumentReference<AppModelType, DbModelType>,\n              snapshot\n            )\n          );\n        }\n      },\n      error: args[currArg + 1] as ErrorFn,\n      complete: args[currArg + 2] as CompleteFn\n    };\n  } else {\n    const query = cast<Query<AppModelType, DbModelType>>(reference, Query);\n    firestore = cast(query.firestore, Firestore);\n    internalQuery = query._query;\n    const userDataWriter = new ExpUserDataWriter(firestore);\n\n    observer = {\n      next: snapshot => {\n        if (args[currArg]) {\n          (args[currArg] as NextFn<QuerySnapshot<AppModelType, DbModelType>>)(\n            new QuerySnapshot(firestore, userDataWriter, query, snapshot)\n          );\n        }\n      },\n      error: args[currArg + 1] as ErrorFn,\n      complete: args[currArg + 2] as CompleteFn\n    };\n\n    validateHasExplicitOrderByForLimitToLast(reference._query);\n  }\n\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientListen(\n    client,\n    internalQuery,\n    internalOptions,\n    observer\n  );\n}\n\n// TODO(firestorexp): Make sure these overloads are tested via the Firestore\n// integration tests\n\n/**\n * Attaches a listener for a snapshots-in-sync event. The snapshots-in-sync\n * event indicates that all listeners affected by a given change have fired,\n * even if a single server-generated change affects multiple listeners.\n *\n * NOTE: The snapshots-in-sync event only indicates that listeners are in sync\n * with each other, but does not relate to whether those snapshots are in sync\n * with the server. Use SnapshotMetadata in the individual listeners to\n * determine if a snapshot is from the cache or the server.\n *\n * @param firestore - The instance of Firestore for synchronizing snapshots.\n * @param observer - A single object containing `next` and `error` callbacks.\n * @returns An unsubscribe function that can be called to cancel the snapshot\n * listener.\n */\nexport function onSnapshotsInSync(\n  firestore: Firestore,\n  observer: {\n    next?: (value: void) => void;\n    error?: (error: FirestoreError) => void;\n    complete?: () => void;\n  }\n): Unsubscribe;\n/**\n * Attaches a listener for a snapshots-in-sync event. The snapshots-in-sync\n * event indicates that all listeners affected by a given change have fired,\n * even if a single server-generated change affects multiple listeners.\n *\n * NOTE: The snapshots-in-sync event only indicates that listeners are in sync\n * with each other, but does not relate to whether those snapshots are in sync\n * with the server. Use `SnapshotMetadata` in the individual listeners to\n * determine if a snapshot is from the cache or the server.\n *\n * @param firestore - The `Firestore` instance for synchronizing snapshots.\n * @param onSync - A callback to be called every time all snapshot listeners are\n * in sync with each other.\n * @returns An unsubscribe function that can be called to cancel the snapshot\n * listener.\n */\nexport function onSnapshotsInSync(\n  firestore: Firestore,\n  onSync: () => void\n): Unsubscribe;\nexport function onSnapshotsInSync(\n  firestore: Firestore,\n  arg: unknown\n): Unsubscribe {\n  firestore = cast(firestore, Firestore);\n  const client = ensureFirestoreConfigured(firestore);\n  const observer = isPartialObserver(arg)\n    ? (arg as PartialObserver<void>)\n    : {\n        next: arg as () => void\n      };\n\n  return firestoreClientAddSnapshotsInSyncListener(client, observer);\n}\n\n/**\n * Locally writes `mutations` on the async queue.\n * @internal\n */\nexport function executeWrite(\n  firestore: Firestore,\n  mutations: Mutation[]\n): Promise<void> {\n  const client = ensureFirestoreConfigured(firestore);\n  return firestoreClientWrite(client, mutations);\n}\n\n/**\n * Converts a {@link ViewSnapshot} that contains the single document specified by `ref`\n * to a {@link DocumentSnapshot}.\n */\nfunction convertToDocSnapshot<AppModelType, DbModelType extends DocumentData>(\n  firestore: Firestore,\n  ref: DocumentReference<AppModelType, DbModelType>,\n  snapshot: ViewSnapshot\n): DocumentSnapshot<AppModelType, DbModelType> {\n  debugAssert(\n    snapshot.docs.size <= 1,\n    'Expected zero or a single result on a document-only query'\n  );\n  const doc = snapshot.docs.get(ref._key);\n\n  const userDataWriter = new ExpUserDataWriter(firestore);\n  return new DocumentSnapshot<AppModelType, DbModelType>(\n    firestore,\n    userDataWriter,\n    ref._key,\n    doc,\n    new SnapshotMetadata(snapshot.hasPendingWrites, snapshot.fromCache),\n    ref.converter\n  );\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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  firestoreClientDeleteAllFieldIndexes,\n  firestoreClientSetPersistentCacheIndexAutoCreationEnabled\n} from '../core/firestore_client';\nimport { cast } from '../util/input_validation';\nimport { logDebug, logWarn } from '../util/log';\n\nimport { ensureFirestoreConfigured, Firestore } from './database';\n\n/**\n * A `PersistentCacheIndexManager` for configuring persistent cache indexes used\n * for local query execution.\n *\n * To use, call `getPersistentCacheIndexManager()` to get an instance.\n */\nexport class PersistentCacheIndexManager {\n  /** A type string to uniquely identify instances of this class. */\n  readonly type: 'PersistentCacheIndexManager' = 'PersistentCacheIndexManager';\n\n  /** @hideconstructor */\n  constructor(readonly _firestore: Firestore) {}\n}\n\n/**\n * Returns the PersistentCache Index Manager used by the given `Firestore`\n * object.\n *\n * @return The `PersistentCacheIndexManager` instance, or `null` if local\n * persistent storage is not in use.\n */\nexport function getPersistentCacheIndexManager(\n  firestore: Firestore\n): PersistentCacheIndexManager | null {\n  firestore = cast(firestore, Firestore);\n\n  const cachedInstance = persistentCacheIndexManagerByFirestore.get(firestore);\n  if (cachedInstance) {\n    return cachedInstance;\n  }\n\n  const client = ensureFirestoreConfigured(firestore);\n  if (client._uninitializedComponentsProvider?._offline.kind !== 'persistent') {\n    return null;\n  }\n\n  const instance = new PersistentCacheIndexManager(firestore);\n  persistentCacheIndexManagerByFirestore.set(firestore, instance);\n  return instance;\n}\n\n/**\n * Enables the SDK to create persistent cache indexes automatically for local\n * query execution when the SDK believes cache indexes can help improve\n * performance.\n *\n * This feature is disabled by default.\n */\nexport function enablePersistentCacheIndexAutoCreation(\n  indexManager: PersistentCacheIndexManager\n): void {\n  setPersistentCacheIndexAutoCreationEnabled(indexManager, true);\n}\n\n/**\n * Stops creating persistent cache indexes automatically for local query\n * execution. The indexes which have been created by calling\n * `enablePersistentCacheIndexAutoCreation()` still take effect.\n */\nexport function disablePersistentCacheIndexAutoCreation(\n  indexManager: PersistentCacheIndexManager\n): void {\n  setPersistentCacheIndexAutoCreationEnabled(indexManager, false);\n}\n\n/**\n * Removes all persistent cache indexes.\n *\n * Please note this function will also deletes indexes generated by\n * `setIndexConfiguration()`, which is deprecated.\n */\nexport function deleteAllPersistentCacheIndexes(\n  indexManager: PersistentCacheIndexManager\n): void {\n  const client = ensureFirestoreConfigured(indexManager._firestore);\n  const promise = firestoreClientDeleteAllFieldIndexes(client);\n\n  promise\n    .then(_ => logDebug('deleting all persistent cache indexes succeeded'))\n    .catch(error =>\n      logWarn('deleting all persistent cache indexes failed', error)\n    );\n}\n\nfunction setPersistentCacheIndexAutoCreationEnabled(\n  indexManager: PersistentCacheIndexManager,\n  isEnabled: boolean\n): void {\n  const client = ensureFirestoreConfigured(indexManager._firestore);\n  const promise = firestoreClientSetPersistentCacheIndexAutoCreationEnabled(\n    client,\n    isEnabled\n  );\n\n  promise\n    .then(_ =>\n      logDebug(\n        `setting persistent cache index auto creation ` +\n          `isEnabled=${isEnabled} succeeded`\n      )\n    )\n    .catch(error =>\n      logWarn(\n        `setting persistent cache index auto creation ` +\n          `isEnabled=${isEnabled} failed`,\n        error\n      )\n    );\n}\n\n/**\n * Maps `Firestore` instances to their corresponding\n * `PersistentCacheIndexManager` instances.\n *\n * Use a `WeakMap` so that the mapping will be automatically dropped when the\n * `Firestore` instance is garbage collected. This emulates a private member\n * as described in https://goo.gle/454yvug.\n */\nconst persistentCacheIndexManagerByFirestore = new WeakMap<\n  Firestore,\n  PersistentCacheIndexManager\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  _registerComponent,\n  registerVersion,\n  SDK_VERSION\n} from '@firebase/app';\nimport { Component, ComponentType } from '@firebase/component';\n\nimport { name, version } from '../package.json';\nimport {\n  FirebaseAppCheckTokenProvider,\n  FirebaseAuthCredentialsProvider\n} from '../src/api/credentials';\nimport { setSDKVersion } from '../src/core/version';\n\nimport { Firestore } from './api/database';\nimport { databaseIdFromApp } from './core/database_info';\n\nexport function registerFirestore(\n  variant?: string,\n  useFetchStreams = true\n): void {\n  setSDKVersion(SDK_VERSION);\n  _registerComponent(\n    new Component(\n      'firestore',\n      (container, { instanceIdentifier: databaseId, options: settings }) => {\n        const app = container.getProvider('app').getImmediate()!;\n        const firestoreInstance = new Firestore(\n          new FirebaseAuthCredentialsProvider(\n            container.getProvider('auth-internal')\n          ),\n          new FirebaseAppCheckTokenProvider(\n            container.getProvider('app-check-internal')\n          ),\n          databaseIdFromApp(app, databaseId),\n          app\n        );\n        settings = { useFetchStreams, ...settings };\n        firestoreInstance._setSettings(settings);\n        return firestoreInstance;\n      },\n      'PUBLIC' as ComponentType.PUBLIC\n    ).setMultipleInstances(true)\n  );\n  registerVersion(name, version, variant);\n  // BUILD_TARGET will be replaced by values like esm2017, cjs2017, etc during the compilation\n  registerVersion(name, version, '__BUILD_TARGET__');\n}\n","/**\n * Cloud Firestore\n *\n * @packageDocumentation\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 { Firestore } from './api/database';\nimport { registerFirestore } from './register';\n\nregisterFirestore();\n\nexport * from './api';\n\ndeclare module '@firebase/component' {\n  interface NameServiceMapping {\n    'firestore': Firestore;\n  }\n}\n","// Import the functions you need from the SDKs you need\nimport { initializeApp } from \"firebase/app\";\nimport { getFirestore } from \"firebase/firestore\";\n// TODO: Add SDKs for Firebase products that you want to use\n// https://firebase.google.com/docs/web/setup#available-libraries\n\n// Your web app's Firebase configuration\nconst firebaseConfig = {\n  apiKey: \"AIzaSyDudcnUt6QnmsXlhAWq-D_Q5ODcFxMvpLA\",\n  authDomain: \"turo-c5e5f.firebaseapp.com\",\n  databaseURL: \"https://turo-c5e5f-default-rtdb.firebaseio.com\",\n  projectId: \"turo-c5e5f\",\n  storageBucket: \"turo-c5e5f.firebasestorage.app\",\n  messagingSenderId: \"1005785021857\",\n  appId: \"1:1005785021857:web:9f38f089139eebffd79fe0\",\n};\n\n// Initialize Firebase\nconst app = initializeApp(firebaseConfig);\n\nconst db = getFirestore(app);\n\nexport default db;\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 * 1 second\n */\nexport const DEFAULT_MIN_SLEEP_TIME_MILLIS = 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","/**\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 { FirebaseError } from '@firebase/util';\n\nimport { CONFIG_STORAGE_BUCKET_KEY } from './constants';\n\n/**\n * An error returned by the Firebase Storage SDK.\n * @public\n */\nexport class StorageError extends FirebaseError {\n  private readonly _baseMessage: string;\n  /**\n   * Stores custom error data unique to the `StorageError`.\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   * @param status_ - Corresponding HTTP Status Code\n   */\n  constructor(code: StorageErrorCode, message: string, private status_ = 0) {\n    super(\n      prependCode(code),\n      `Firebase Storage: ${message} (${prependCode(code)})`\n    );\n    this._baseMessage = this.message;\n    // Without this, `instanceof StorageError`, in tests for example,\n    // returns false.\n    Object.setPrototypeOf(this, StorageError.prototype);\n  }\n\n  get status(): number {\n    return this.status_;\n  }\n\n  set status(status: number) {\n    this.status_ = status;\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   * 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    if (this.customData.serverResponse) {\n      this.message = `${this._baseMessage}\\n${this.customData.serverResponse}`;\n    } else {\n      this.message = this._baseMessage;\n    }\n  }\n}\n\nexport const errors = {};\n\n/**\n * @public\n * Error codes that can be attached to `StorageError` objects.\n */\nexport 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  UNAUTHORIZED_APP = 'unauthorized-app',\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(): StorageError {\n  const message =\n    'An unknown error occurred, please check the error payload for ' +\n    'server response.';\n  return new StorageError(StorageErrorCode.UNKNOWN, message);\n}\n\nexport function objectNotFound(path: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.OBJECT_NOT_FOUND,\n    \"Object '\" + path + \"' does not exist.\"\n  );\n}\n\nexport function bucketNotFound(bucket: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.BUCKET_NOT_FOUND,\n    \"Bucket '\" + bucket + \"' does not exist.\"\n  );\n}\n\nexport function projectNotFound(project: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.PROJECT_NOT_FOUND,\n    \"Project '\" + project + \"' does not exist.\"\n  );\n}\n\nexport function quotaExceeded(bucket: string): StorageError {\n  return new StorageError(\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(): StorageError {\n  const message =\n    'User is not authenticated, please authenticate using Firebase ' +\n    'Authentication and try again.';\n  return new StorageError(StorageErrorCode.UNAUTHENTICATED, message);\n}\n\nexport function unauthorizedApp(): StorageError {\n  return new StorageError(\n    StorageErrorCode.UNAUTHORIZED_APP,\n    'This app does not have permission to access Firebase Storage on this project.'\n  );\n}\n\nexport function unauthorized(path: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.UNAUTHORIZED,\n    \"User does not have permission to access '\" + path + \"'.\"\n  );\n}\n\nexport function retryLimitExceeded(): StorageError {\n  return new StorageError(\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): StorageError {\n  return new StorageError(\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(): StorageError {\n  return new StorageError(\n    StorageErrorCode.CANCELED,\n    'User canceled the upload/download.'\n  );\n}\n\nexport function invalidEventName(name: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.INVALID_EVENT_NAME,\n    \"Invalid event name '\" + name + \"'.\"\n  );\n}\n\nexport function invalidUrl(url: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.INVALID_URL,\n    \"Invalid URL '\" + url + \"'.\"\n  );\n}\n\nexport function invalidDefaultBucket(bucket: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.INVALID_DEFAULT_BUCKET,\n    \"Invalid default bucket '\" + bucket + \"'.\"\n  );\n}\n\nexport function noDefaultBucket(): StorageError {\n  return new StorageError(\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(): StorageError {\n  return new StorageError(\n    StorageErrorCode.CANNOT_SLICE_BLOB,\n    'Cannot slice blob for upload. Please retry the upload.'\n  );\n}\n\nexport function serverFileWrongSize(): StorageError {\n  return new StorageError(\n    StorageErrorCode.SERVER_FILE_WRONG_SIZE,\n    'Server recorded incorrect upload file size, please retry the upload.'\n  );\n}\n\nexport function noDownloadURL(): StorageError {\n  return new StorageError(\n    StorageErrorCode.NO_DOWNLOAD_URL,\n    'The given file does not have any download URLs.'\n  );\n}\n\nexport function missingPolyFill(polyFill: string): StorageError {\n  return new StorageError(\n    StorageErrorCode.UNSUPPORTED_ENVIRONMENT,\n    `${polyFill} is missing. Make sure to install the required polyfills. See https://firebase.google.com/docs/web/environments-js-sdk#polyfills for more information.`\n  );\n}\n\n/**\n * @internal\n */\nexport function invalidArgument(message: string): StorageError {\n  return new StorageError(StorageErrorCode.INVALID_ARGUMENT, message);\n}\n\nexport function invalidArgumentCount(\n  argMin: number,\n  argMax: number,\n  fnName: string,\n  real: number\n): StorageError {\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 StorageError(\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(): StorageError {\n  return new StorageError(\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 *\n * @internal\n */\nexport function invalidRootOperation(name: string): StorageError {\n  return new StorageError(\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(format: string, message: string): StorageError {\n  return new StorageError(\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): StorageError {\n  throw new StorageError(StorageErrorCode.UNSUPPORTED_ENVIRONMENT, message);\n}\n\n/**\n * @param message - A message describing the internal error.\n */\nexport function internalError(message: string): StorageError {\n  throw new StorageError(\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/** Network headers */\nexport type Headers = Record<string, string>;\n\n/** Response type exposed by the networking APIs. */\nexport type ConnectionType =\n  | string\n  | ArrayBuffer\n  | Blob\n  | ReadableStream<Uint8Array>;\n\n/**\n * A lightweight wrapper around XMLHttpRequest with a\n * goog.net.XhrIo-like interface.\n *\n * You can create a new connection by invoking `newTextConnection()`,\n * `newBytesConnection()` or `newStreamConnection()`.\n */\nexport interface Connection<T extends ConnectionType> {\n  /**\n   * Sends a request to the provided URL.\n   *\n   * This method never rejects its promise. In case of encountering an error,\n   * it sets an error code internally which can be accessed by calling\n   * getErrorCode() by callers.\n   */\n  send(\n    url: string,\n    method: string,\n    body?: ArrayBufferView | Blob | string | null,\n    headers?: Headers\n  ): Promise<void>;\n\n  getErrorCode(): ErrorCode;\n\n  getStatus(): number;\n\n  getResponse(): T;\n\n  getErrorText(): 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 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 */\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 *\n * @internal\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, host: string): Location {\n    let bucketLocation;\n    try {\n      bucketLocation = Location.makeFromUrl(bucketString, host);\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, host: 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 = 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      host === DEFAULT_HOST\n        ? '(?:storage.googleapis.com|storage.cloud.google.com)'\n        : host;\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 { StorageError } 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: StorageError) {\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\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/**\n * @fileoverview Functions to create and manipulate URLs for the server API.\n */\nimport { UrlParams } from './requestinfo';\n\nexport function makeUrl(\n  urlPart: string,\n  host: string,\n  protocol: string\n): string {\n  let origin = host;\n  if (protocol == null) {\n    origin = `https://${host}`;\n  }\n  return `${protocol}://${origin}/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 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 * Checks the status code to see if the action should be retried.\n *\n * @param status Current HTTP status code returned by server.\n * @param additionalRetryCodes additional retry codes to check against\n */\nexport function isRetryStatusCode(\n  status: number,\n  additionalRetryCodes: number[]\n): 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 isAdditionalRetryCode = additionalRetryCodes.indexOf(status) !== -1;\n  return isFiveHundredCode || isExtraRetryCode || isAdditionalRetryCode;\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 { id as backoffId, start, stop } from './backoff';\nimport { appDeleted, canceled, retryLimitExceeded, unknown } from './error';\nimport { ErrorHandler, RequestHandler, RequestInfo } from './requestinfo';\nimport { isJustDef } from './type';\nimport { makeQueryString } from './url';\nimport { Connection, ErrorCode, Headers, ConnectionType } from './connection';\nimport { isRetryStatusCode } from './utils';\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\n/**\n * Handles network logic for all Storage Requests, including error reporting and\n * retries with backoff.\n *\n * @param I - the type of the backend's network response.\n * @param - O the output type used by the rest of the SDK. The conversion\n * happens in the specified `callback_`.\n */\nclass NetworkRequest<I extends ConnectionType, O> implements Request<O> {\n  private pendingConnection_: Connection<I> | null = null;\n  private backoffId_: backoffId | null = null;\n  private resolve_!: (value?: O | PromiseLike<O>) => 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 promise_: Promise<O>;\n\n  constructor(\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 callback_: RequestHandler<I, O>,\n    private errorCallback_: ErrorHandler | null,\n    private timeout_: number,\n    private progressCallback_: ((p1: number, p2: number) => void) | null,\n    private connectionFactory_: () => Connection<I>,\n    private retry = true\n  ) {\n    this.promise_ = new Promise((resolve, reject) => {\n      this.resolve_ = resolve as (value?: O | PromiseLike<O>) => 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 doTheRequest: (\n      backoffCallback: (success: boolean, ...p2: unknown[]) => void,\n      canceled: boolean\n    ) => void = (backoffCallback, canceled) => {\n      if (canceled) {\n        backoffCallback(false, new RequestEndStatus(false, null, true));\n        return;\n      }\n      const connection = this.connectionFactory_();\n      this.pendingConnection_ = connection;\n\n      const progressListener: (\n        progressEvent: ProgressEvent\n      ) => void = progressEvent => {\n        const loaded = progressEvent.loaded;\n        const total = progressEvent.lengthComputable ? progressEvent.total : -1;\n        if (this.progressCallback_ !== null) {\n          this.progressCallback_(loaded, total);\n        }\n      };\n      if (this.progressCallback_ !== null) {\n        connection.addUploadProgressListener(progressListener);\n      }\n\n      // connection.send() never rejects, so we don't need to have a error handler or use catch on the returned promise.\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      connection\n        .send(this.url_, this.method_, this.body_, this.headers_)\n        .then(() => {\n          if (this.progressCallback_ !== null) {\n            connection.removeUploadProgressListener(progressListener);\n          }\n          this.pendingConnection_ = null;\n          const hitServer = connection.getErrorCode() === ErrorCode.NO_ERROR;\n          const status = connection.getStatus();\n          if (\n            !hitServer ||\n            (isRetryStatusCode(status, this.additionalRetryCodes_) &&\n              this.retry)\n          ) {\n            const wasCanceled = connection.getErrorCode() === ErrorCode.ABORT;\n            backoffCallback(\n              false,\n              new RequestEndStatus(false, null, wasCanceled)\n            );\n            return;\n          }\n          const successCode = this.successCodes_.indexOf(status) !== -1;\n          backoffCallback(true, new RequestEndStatus(successCode, connection));\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    const backoffDone: (\n      requestWentThrough: boolean,\n      status: RequestEndStatus<I>\n    ) => void = (requestWentThrough, status) => {\n      const resolve = this.resolve_;\n      const reject = this.reject_;\n      const connection = status.connection as Connection<I>;\n      if (status.wasSuccessCode) {\n        try {\n          const result = this.callback_(connection, connection.getResponse());\n          if (isJustDef(result)) {\n            resolve(result);\n          } else {\n            resolve();\n          }\n        } catch (e) {\n          reject(e);\n        }\n      } else {\n        if (connection !== null) {\n          const err = unknown();\n          err.serverResponse = connection.getErrorText();\n          if (this.errorCallback_) {\n            reject(this.errorCallback_(connection, err));\n          } else {\n            reject(err);\n          }\n        } else {\n          if (status.canceled) {\n            const err = this.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<O> {\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.pendingConnection_ !== null) {\n      this.pendingConnection_.abort();\n    }\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<I extends ConnectionType> {\n  /**\n   * True if the request was canceled.\n   */\n  canceled: boolean;\n\n  constructor(\n    public wasSuccessCode: boolean,\n    public connection: Connection<I> | 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 addAppCheckHeader_(\n  headers: Headers,\n  appCheckToken: string | null\n): void {\n  if (appCheckToken !== null) {\n    headers['X-Firebase-AppCheck'] = appCheckToken;\n  }\n}\n\nexport function makeRequest<I extends ConnectionType, O>(\n  requestInfo: RequestInfo<I, O>,\n  appId: string | null,\n  authToken: string | null,\n  appCheckToken: string | null,\n  requestFactory: () => Connection<I>,\n  firebaseVersion?: string,\n  retry = true\n): Request<O> {\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  addAppCheckHeader_(headers, appCheckToken);\n  return new NetworkRequest<I, O>(\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    requestFactory,\n    retry\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 * Accepts a callback for an action to perform (`doRequest`),\n * and then a callback for when the backoff has completed (`backoffCompleteCb`).\n * The callback sent to start requires an argument to call (`onRequestComplete`).\n * When `start` calls `doRequest`, it passes a callback for when the request has\n * completed, `onRequestComplete`. Based on this, the backoff continues, with\n * another call to `doRequest` and the above loop continues until the timeout\n * is hit, or a successful response occurs.\n * @description\n * @param doRequest Callback to perform request\n * @param backoffCompleteCb Callback to call when backoff has been completed\n */\nexport function start(\n  doRequest: (\n    onRequestComplete: (success: boolean) => void,\n    canceled: boolean\n  ) => void,\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  backoffCompleteCb: (...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 retryTimeoutId: any = null;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let globalTimeoutId: 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      backoffCompleteCb.apply(null, args);\n    }\n  }\n\n  function callWithDelay(millis: number): void {\n    retryTimeoutId = setTimeout(() => {\n      retryTimeoutId = null;\n      doRequest(responseHandler, canceled());\n    }, millis);\n  }\n\n  function clearGlobalTimeout(): void {\n    if (globalTimeoutId) {\n      clearTimeout(globalTimeoutId);\n    }\n  }\n\n  function responseHandler(success: boolean, ...args: any[]): void {\n    if (triggeredCallback) {\n      clearGlobalTimeout();\n      return;\n    }\n    if (success) {\n      clearGlobalTimeout();\n      triggerCallback.call(null, success, ...args);\n      return;\n    }\n    const mustStop = canceled() || hitTimeout;\n    if (mustStop) {\n      clearGlobalTimeout();\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    clearGlobalTimeout();\n    if (triggeredCallback) {\n      return;\n    }\n    if (retryTimeoutId !== null) {\n      if (!wasTimeout) {\n        cancelState = 2;\n      }\n      clearTimeout(retryTimeoutId);\n      callWithDelay(0);\n    } else {\n      if (!wasTimeout) {\n        cancelState = 1;\n      }\n    }\n  }\n  callWithDelay(0);\n  globalTimeoutId = 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/**\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, StorageError } 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 StorageError(\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 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { missingPolyFill } from '../../implementation/error';\n\n/** Converts a Base64 encoded string to a binary string. */\nexport function decodeBase64(encoded: string): string {\n  if (typeof atob === 'undefined') {\n    throw missingPolyFill('base-64');\n  }\n  return atob(encoded);\n}\n\nexport function decodeUint8Array(data: Uint8Array): string {\n  return new TextDecoder().decode(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 { unknown, invalidFormat } from './error';\nimport { decodeBase64 } from '../platform/base64';\n\n/**\n * An enumeration of the possible string formats for upload.\n * @public\n */\nexport type StringFormat = (typeof StringFormat)[keyof typeof StringFormat];\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} as const;\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\n/**\n * @internal\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 = decodeBase64(value);\n  } catch (e) {\n    if ((e as Error).message.includes('polyfill')) {\n      throw e;\n    }\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 * @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 *\n * @internal\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 */\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 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 { FirebaseStorageImpl } 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: FirebaseStorageImpl): 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: FirebaseStorageImpl,\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: FirebaseStorageImpl,\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  host: string,\n  protocol: 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, host, protocol);\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 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 { StorageError } from './error';\nimport { Headers, Connection, ConnectionType } from './connection';\n\n/**\n * Type for url params stored in RequestInfo.\n */\nexport interface UrlParams {\n  [name: string]: string | number;\n}\n\n/**\n * A function that converts a server response to the API type expected by the\n * SDK.\n *\n * @param I - the type of the backend's network response\n * @param O - the output response type used by the rest of the SDK.\n */\nexport type RequestHandler<I extends ConnectionType, O> = (\n  connection: Connection<I>,\n  response: I\n) => O;\n\n/** A function to handle an error. */\nexport type ErrorHandler = (\n  connection: Connection<ConnectionType>,\n  response: StorageError\n) => StorageError;\n\n/**\n * Contains a fully specified request.\n *\n * @param I - the type of the backend's network response.\n * @param O - the output response type used by the rest of the SDK.\n */\nexport class RequestInfo<I extends ConnectionType, O> {\n  urlParams: UrlParams = {};\n  headers: Headers = {};\n  body: Blob | string | Uint8Array | null = null;\n  errorHandler: ErrorHandler | 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: RequestHandler<I, O>,\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  StorageError,\n  cannotSliceBlob,\n  unauthenticated,\n  quotaExceeded,\n  unauthorized,\n  objectNotFound,\n  serverFileWrongSize,\n  unknown,\n  unauthorizedApp\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 { Connection, ConnectionType } from './connection';\nimport { FirebaseStorageImpl } from '../service';\n\n/**\n * Throws the UNKNOWN StorageError 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: FirebaseStorageImpl,\n  mappings: Mappings\n): (p1: Connection<string>, p2: string) => Metadata {\n  function handler(xhr: Connection<string>, 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: FirebaseStorageImpl,\n  bucket: string\n): (p1: Connection<string>, p2: string) => ListResult {\n  function handler(xhr: Connection<string>, 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: FirebaseStorageImpl,\n  mappings: Mappings\n): (p1: Connection<string>, p2: string) => string | null {\n  function handler(xhr: Connection<string>, text: string): string | null {\n    const metadata = fromResourceString(service, text, mappings);\n    handlerCheck(metadata !== null);\n    return downloadUrlFromResourceString(\n      metadata as Metadata,\n      text,\n      service.host,\n      service._protocol\n    );\n  }\n  return handler;\n}\n\nexport function sharedErrorHandler(\n  location: Location\n): (p1: Connection<ConnectionType>, p2: StorageError) => StorageError {\n  function errorHandler(\n    xhr: Connection<ConnectionType>,\n    err: StorageError\n  ): StorageError {\n    let newErr: StorageError;\n    if (xhr.getStatus() === 401) {\n      if (\n        // This exact message string is the only consistent part of the\n        // server's error response that identifies it as an App Check error.\n        xhr.getErrorText().includes('Firebase App Check token is invalid')\n      ) {\n        newErr = unauthorizedApp();\n      } else {\n        newErr = unauthenticated();\n      }\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.status = xhr.getStatus();\n    newErr.serverResponse = err.serverResponse;\n    return newErr;\n  }\n  return errorHandler;\n}\n\nexport function objectErrorHandler(\n  location: Location\n): (p1: Connection<ConnectionType>, p2: StorageError) => StorageError {\n  const shared = sharedErrorHandler(location);\n\n  function errorHandler(\n    xhr: Connection<ConnectionType>,\n    err: StorageError\n  ): StorageError {\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: FirebaseStorageImpl,\n  location: Location,\n  mappings: Mappings\n): RequestInfo<string, Metadata> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart, service.host, service._protocol);\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: FirebaseStorageImpl,\n  location: Location,\n  delimiter?: string,\n  pageToken?: string | null,\n  maxResults?: number | null\n): RequestInfo<string, 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, service.host, service._protocol);\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 getBytes<I extends ConnectionType>(\n  service: FirebaseStorageImpl,\n  location: Location,\n  maxDownloadSizeBytes?: number\n): RequestInfo<I, I> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart, service.host, service._protocol) + '?alt=media';\n  const method = 'GET';\n  const timeout = service.maxOperationRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    (_: Connection<I>, data: I) => data,\n    timeout\n  );\n  requestInfo.errorHandler = objectErrorHandler(location);\n  if (maxDownloadSizeBytes !== undefined) {\n    requestInfo.headers['Range'] = `bytes=0-${maxDownloadSizeBytes}`;\n    requestInfo.successCodes = [200 /* OK */, 206 /* Partial Content */];\n  }\n  return requestInfo;\n}\n\nexport function getDownloadUrl(\n  service: FirebaseStorageImpl,\n  location: Location,\n  mappings: Mappings\n): RequestInfo<string, string | null> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart, service.host, service._protocol);\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: FirebaseStorageImpl,\n  location: Location,\n  metadata: Partial<Metadata>,\n  mappings: Mappings\n): RequestInfo<string, Metadata> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart, service.host, service._protocol);\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: FirebaseStorageImpl,\n  location: Location\n): RequestInfo<string, void> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart, service.host, service._protocol);\n  const method = 'DELETE';\n  const timeout = service.maxOperationRetryTime;\n\n  function handler(_xhr: Connection<string>, _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: FirebaseStorageImpl,\n  location: Location,\n  mappings: Mappings,\n  blob: FbsBlob,\n  metadata?: Metadata | null\n): RequestInfo<string, 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, service.host, service._protocol);\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_(\n  xhr: Connection<string>,\n  allowed?: string[]\n): 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: FirebaseStorageImpl,\n  location: Location,\n  mappings: Mappings,\n  blob: FbsBlob,\n  metadata?: Metadata | null\n): RequestInfo<string, 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, service.host, service._protocol);\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: Connection<string>): 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: FirebaseStorageImpl,\n  location: Location,\n  url: string,\n  blob: FbsBlob\n): RequestInfo<string, ResumableUploadStatus> {\n  const headers = { 'X-Goog-Upload-Command': 'query' };\n\n  function handler(xhr: Connection<string>): 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: FirebaseStorageImpl,\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<string, 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  let uploadCommand = '';\n  if (bytesToUpload === 0) {\n    uploadCommand = 'finalize';\n  } else if (bytesLeft === bytesToUpload) {\n    uploadCommand = 'upload, finalize';\n  } else {\n    uploadCommand = 'upload';\n  }\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(\n    xhr: Connection<string>,\n    text: string\n  ): 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 */\n\n/**\n * @fileoverview Enumerations used for upload tasks.\n */\n\n/**\n * An event that is triggered on a task.\n * @internal\n */\nexport type TaskEvent = string;\n\n/**\n * An event that is triggered on a task.\n * @internal\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 * @internal\n */\nexport type TaskState = (typeof TaskState)[keyof typeof TaskState];\n\n// type keys = keyof TaskState\n/**\n * Represents the current state of a running upload.\n * @internal\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} as const;\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 */\nimport { isFunction } from './type';\nimport { StorageError } 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 `StorageError`\n * if the event stream ends due to an error.\n */\nexport type ErrorFn = (error: StorageError) => 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 `StorageError`.\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 `StorageError`\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 ?? undefined;\n      this.complete = complete ?? undefined;\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\nimport {\n  Connection,\n  ConnectionType,\n  ErrorCode,\n  Headers\n} from '../../implementation/connection';\nimport { internalError } from '../../implementation/error';\n\n/** An override for the text-based Connection. Used in tests. */\nlet textFactoryOverride: (() => Connection<string>) | null = null;\n\n/**\n * Network layer for browsers. We use this instead of goog.net.XhrIo because\n * goog.net.XhrIo is hyuuuuge and doesn't work in React Native on Android.\n */\nabstract class XhrConnection<T extends ConnectionType>\n  implements Connection<T>\n{\n  protected xhr_: XMLHttpRequest;\n  private errorCode_: ErrorCode;\n  private sendPromise_: Promise<void>;\n  protected sent_: boolean = false;\n\n  constructor() {\n    this.xhr_ = new XMLHttpRequest();\n    this.initXhr();\n    this.errorCode_ = ErrorCode.NO_ERROR;\n    this.sendPromise_ = new Promise(resolve => {\n      this.xhr_.addEventListener('abort', () => {\n        this.errorCode_ = ErrorCode.ABORT;\n        resolve();\n      });\n      this.xhr_.addEventListener('error', () => {\n        this.errorCode_ = ErrorCode.NETWORK_ERROR;\n        resolve();\n      });\n      this.xhr_.addEventListener('load', () => {\n        resolve();\n      });\n    });\n  }\n\n  abstract initXhr(): void;\n\n  send(\n    url: string,\n    method: string,\n    body?: ArrayBufferView | Blob | string,\n    headers?: Headers\n  ): Promise<void> {\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  getErrorCode(): ErrorCode {\n    if (!this.sent_) {\n      throw internalError('cannot .getErrorCode() before sending');\n    }\n    return this.errorCode_;\n  }\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  getResponse(): T {\n    if (!this.sent_) {\n      throw internalError('cannot .getResponse() before sending');\n    }\n    return this.xhr_.response;\n  }\n\n  getErrorText(): string {\n    if (!this.sent_) {\n      throw internalError('cannot .getErrorText() before sending');\n    }\n    return this.xhr_.statusText;\n  }\n\n  /** Aborts the request. */\n  abort(): void {\n    this.xhr_.abort();\n  }\n\n  getResponseHeader(header: string): string | null {\n    return this.xhr_.getResponseHeader(header);\n  }\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  removeUploadProgressListener(listener: (p1: ProgressEvent) => void): void {\n    if (this.xhr_.upload != null) {\n      this.xhr_.upload.removeEventListener('progress', listener);\n    }\n  }\n}\n\nexport class XhrTextConnection extends XhrConnection<string> {\n  initXhr(): void {\n    this.xhr_.responseType = 'text';\n  }\n}\n\nexport function newTextConnection(): Connection<string> {\n  return textFactoryOverride ? textFactoryOverride() : new XhrTextConnection();\n}\n\nexport class XhrBytesConnection extends XhrConnection<ArrayBuffer> {\n  private data_?: ArrayBuffer;\n\n  initXhr(): void {\n    this.xhr_.responseType = 'arraybuffer';\n  }\n}\n\nexport function newBytesConnection(): Connection<ArrayBuffer> {\n  return new XhrBytesConnection();\n}\n\nexport class XhrBlobConnection extends XhrConnection<Blob> {\n  initXhr(): void {\n    this.xhr_.responseType = 'blob';\n  }\n}\n\nexport function newBlobConnection(): Connection<Blob> {\n  return new XhrBlobConnection();\n}\n\nexport function newStreamConnection(): Connection<ReadableStream> {\n  throw new Error('Streams are only supported on Node');\n}\n\nexport function injectTestConnection(\n  factory: (() => Connection<string>) | null\n): void {\n  textFactoryOverride = factory;\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  StorageError,\n  retryLimitExceeded\n} from './implementation/error';\nimport {\n  InternalTaskState,\n  TaskEvent,\n  TaskState,\n  taskStateFromInternalTaskState\n} from './implementation/taskenums';\nimport { Metadata } from './metadata';\nimport {\n  Observer,\n  Subscribe,\n  Unsubscribe,\n  StorageObserver as StorageObserverInternal,\n  NextFn\n} from './implementation/observer';\nimport { Request } from './implementation/request';\nimport { UploadTaskSnapshot, StorageObserver } from './public-types';\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';\nimport { newTextConnection } from './platform/connection';\nimport { isRetryStatusCode } from './implementation/utils';\nimport { CompleteFn } from '@firebase/util';\nimport { DEFAULT_MIN_SLEEP_TIME_MILLIS } from './implementation/constants';\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 * @internal\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<StorageObserverInternal<UploadTaskSnapshot>> = [];\n  private _resumable: boolean;\n  /**\n   * Upload state.\n   */\n  _state: InternalTaskState;\n  private _error?: StorageError = undefined;\n  private _uploadUrl?: string = undefined;\n  private _request?: Request<unknown> = undefined;\n  private _chunkMultiplier: number = 1;\n  private _errorHandler: (p1: StorageError) => void;\n  private _metadataErrorHandler: (p1: StorageError) => void;\n  private _resolve?: (p1: UploadTaskSnapshot) => void = undefined;\n  private _reject?: (p1: StorageError) => void = undefined;\n  private pendingTimeout?: ReturnType<typeof setTimeout>;\n  private _promise: Promise<UploadTaskSnapshot>;\n\n  private sleepTime: number;\n\n  private maxSleepTime: number;\n\n  isExponentialBackoffExpired(): boolean {\n    return this.sleepTime > this.maxSleepTime;\n  }\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        const backoffExpired = this.isExponentialBackoffExpired();\n        if (isRetryStatusCode(error.status, [])) {\n          if (backoffExpired) {\n            error = retryLimitExceeded();\n          } else {\n            this.sleepTime = Math.max(\n              this.sleepTime * 2,\n              DEFAULT_MIN_SLEEP_TIME_MILLIS\n            );\n            this._needToFetchStatus = true;\n            this.completeTransitions_();\n            return;\n          }\n        }\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.sleepTime = 0;\n    this.maxSleepTime = this._ref.storage.maxUploadRetryTime;\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.pendingTimeout = setTimeout(() => {\n              this.pendingTimeout = undefined;\n              this._continueUpload();\n            }, this.sleepTime);\n          }\n        }\n      }\n    } else {\n      this._oneShotUpload();\n    }\n  }\n\n  private _resolveToken(\n    callback: (authToken: string | null, appCheckToken: string | null) => void\n  ): void {\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    Promise.all([\n      this._ref.storage._getAuthToken(),\n      this._ref.storage._getAppCheckToken()\n    ]).then(([authToken, appCheckToken]) => {\n      switch (this._state) {\n        case InternalTaskState.RUNNING:\n          callback(authToken, appCheckToken);\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, appCheckToken) => {\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        newTextConnection,\n        authToken,\n        appCheckToken\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, appCheckToken) => {\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        newTextConnection,\n        authToken,\n        appCheckToken\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, appCheckToken) => {\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 as StorageError;\n        this._transition(InternalTaskState.ERROR);\n        return;\n      }\n      const uploadRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        newTextConnection,\n        authToken,\n        appCheckToken,\n        /*retry=*/ false // Upload requests should not be retried as each retry should be preceded by another query request. Which is handled in this file.\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 * 2 < 32 * 1024 * 1024) {\n      this._chunkMultiplier *= 2;\n    }\n  }\n\n  private _fetchMetadata(): void {\n    this._resolveToken((authToken, appCheckToken) => {\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        newTextConnection,\n        authToken,\n        appCheckToken\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, appCheckToken) => {\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        newTextConnection,\n        authToken,\n        appCheckToken\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      case InternalTaskState.PAUSING:\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        } else if (this.pendingTimeout) {\n          clearTimeout(this.pendingTimeout);\n          this.pendingTimeout = undefined;\n          this.completeTransitions_();\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 `StorageError`\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      | null\n      | ((snapshot: UploadTaskSnapshot) => unknown),\n    error?: ((a: StorageError) => unknown) | null,\n    completed?: CompleteFn | null\n  ): Unsubscribe | Subscribe<UploadTaskSnapshot> {\n    // Note: `type` isn't being used. Its type is also incorrect. TaskEvent should not be a string.\n    const observer = new Observer(\n      (nextOrObserver as\n        | StorageObserverInternal<UploadTaskSnapshot>\n        | NextFn<UploadTaskSnapshot>) || undefined,\n      error || undefined,\n      completed || undefined\n    );\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: StorageError) => 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>(onRejected: (p1: StorageError) => T | Promise<T>): 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: StorageError) => void;\n          fbsAsync(toCall.bind(null, this._error as StorageError))();\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 StorageError)\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 StorageError)\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, lastComponent, parent } from './implementation/path';\nimport {\n  deleteObject as requestsDeleteObject,\n  getBytes,\n  getDownloadUrl as requestsGetDownloadUrl,\n  getMetadata as requestsGetMetadata,\n  list as requestsList,\n  multipartUpload,\n  updateMetadata as requestsUpdateMetadata\n} from './implementation/requests';\nimport { ListOptions, UploadResult } from './public-types';\nimport { dataFromString, StringFormat } from './implementation/string';\nimport { Metadata } from './metadata';\nimport { FirebaseStorageImpl } from './service';\nimport { ListResult } from './list';\nimport { UploadTask } from './task';\nimport { invalidRootOperation, noDownloadURL } from './implementation/error';\nimport { validateNumber } from './implementation/type';\nimport {\n  newBlobConnection,\n  newBytesConnection,\n  newStreamConnection,\n  newTextConnection\n} from './platform/connection';\nimport { RequestInfo } from './implementation/requestinfo';\n\n/**\n * Provides methods to interact with a bucket in the Firebase Storage service.\n * @internal\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(\n    private _service: FirebaseStorageImpl,\n    location: string | Location\n  ) {\n    if (location instanceof Location) {\n      this._location = location;\n    } else {\n      this._location = Location.makeFromUrl(location, _service.host);\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(\n    service: FirebaseStorageImpl,\n    location: Location\n  ): 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(): FirebaseStorageImpl {\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 * Download the bytes at the object's location.\n * @returns A Promise containing the downloaded bytes.\n */\nexport function getBytesInternal(\n  ref: Reference,\n  maxDownloadSizeBytes?: number\n): Promise<ArrayBuffer> {\n  ref._throwIfRoot('getBytes');\n  const requestInfo = getBytes(\n    ref.storage,\n    ref._location,\n    maxDownloadSizeBytes\n  );\n  return ref.storage\n    .makeRequestWithTokens(requestInfo, newBytesConnection)\n    .then(bytes =>\n      maxDownloadSizeBytes !== undefined\n        ? // GCS may not honor the Range header for small files\n          (bytes as ArrayBuffer).slice(0, maxDownloadSizeBytes)\n        : (bytes as ArrayBuffer)\n    );\n}\n\n/**\n * Download the bytes at the object's location.\n * @returns A Promise containing the downloaded blob.\n */\nexport function getBlobInternal(\n  ref: Reference,\n  maxDownloadSizeBytes?: number\n): Promise<Blob> {\n  ref._throwIfRoot('getBlob');\n  const requestInfo = getBytes(\n    ref.storage,\n    ref._location,\n    maxDownloadSizeBytes\n  );\n  return ref.storage\n    .makeRequestWithTokens(requestInfo, newBlobConnection)\n    .then(blob =>\n      maxDownloadSizeBytes !== undefined\n        ? // GCS may not honor the Range header for small files\n          (blob as Blob).slice(0, maxDownloadSizeBytes)\n        : (blob as Blob)\n    );\n}\n\n/** Stream the bytes at the object's location. */\nexport function getStreamInternal(\n  ref: Reference,\n  maxDownloadSizeBytes?: number\n): ReadableStream {\n  ref._throwIfRoot('getStream');\n  const requestInfo: RequestInfo<ReadableStream, ReadableStream> = getBytes(\n    ref.storage,\n    ref._location,\n    maxDownloadSizeBytes\n  );\n\n  // Transforms the stream so that only `maxDownloadSizeBytes` bytes are piped to the result\n  const newMaxSizeTransform = (n: number): Transformer => {\n    let missingBytes = n;\n    return {\n      transform(chunk, controller: TransformStreamDefaultController) {\n        // GCS may not honor the Range header for small files\n        if (chunk.length < missingBytes) {\n          controller.enqueue(chunk);\n          missingBytes -= chunk.length;\n        } else {\n          controller.enqueue(chunk.slice(0, missingBytes));\n          controller.terminate();\n        }\n      }\n    };\n  };\n\n  const result =\n    maxDownloadSizeBytes !== undefined\n      ? new TransformStream(newMaxSizeTransform(maxDownloadSizeBytes))\n      : new TransformStream(); // The default transformer forwards all chunks to its readable side\n\n  ref.storage\n    .makeRequestWithTokens(requestInfo, newStreamConnection)\n    .then(readableStream => readableStream.pipeThrough(result))\n    .catch(err => result.writable.abort(err));\n\n  return result.readable;\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  const requestInfo = multipartUpload(\n    ref.storage,\n    ref._location,\n    getMappings(),\n    new FbsBlob(data, true),\n    metadata\n  );\n  return ref.storage\n    .makeRequestWithTokens(requestInfo, newTextConnection)\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 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 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.makeRequestWithTokens(requestInfo, newTextConnection);\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 retrieved, the promise is\n * rejected.\n * @public\n * @param ref - StorageReference to get metadata from.\n */\nexport function getMetadata(ref: Reference): Promise<Metadata> {\n  ref._throwIfRoot('getMetadata');\n  const requestInfo = requestsGetMetadata(\n    ref.storage,\n    ref._location,\n    getMappings()\n  );\n  return ref.storage.makeRequestWithTokens(requestInfo, newTextConnection);\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 function updateMetadata(\n  ref: Reference,\n  metadata: Partial<Metadata>\n): Promise<Metadata> {\n  ref._throwIfRoot('updateMetadata');\n  const requestInfo = requestsUpdateMetadata(\n    ref.storage,\n    ref._location,\n    metadata,\n    getMappings()\n  );\n  return ref.storage.makeRequestWithTokens(requestInfo, newTextConnection);\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 function getDownloadURL(ref: Reference): Promise<string> {\n  ref._throwIfRoot('getDownloadURL');\n  const requestInfo = requestsGetDownloadUrl(\n    ref.storage,\n    ref._location,\n    getMappings()\n  );\n  return ref.storage\n    .makeRequestWithTokens(requestInfo, newTextConnection)\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 function deleteObject(ref: Reference): Promise<void> {\n  ref._throwIfRoot('deleteObject');\n  const requestInfo = requestsDeleteObject(ref.storage, ref._location);\n  return ref.storage.makeRequestWithTokens(requestInfo, newTextConnection);\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 *\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 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 { Reference, _getChild } from './reference';\nimport { Provider } from '@firebase/component';\nimport { FirebaseAuthInternalName } from '@firebase/auth-interop-types';\nimport { AppCheckInternalComponentName } from '@firebase/app-check-interop-types';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { FirebaseApp, FirebaseOptions } from '@firebase/app';\nimport {\n  CONFIG_STORAGE_BUCKET_KEY,\n  DEFAULT_HOST,\n  DEFAULT_MAX_OPERATION_RETRY_TIME,\n  DEFAULT_MAX_UPLOAD_RETRY_TIME\n} from './implementation/constants';\nimport {\n  invalidArgument,\n  appDeleted,\n  noDefaultBucket\n} from './implementation/error';\nimport { validateNumber } from './implementation/type';\nimport { FirebaseStorage } from './public-types';\nimport { createMockUserToken, EmulatorMockTokenOptions } from '@firebase/util';\nimport { Connection, ConnectionType } from './implementation/connection';\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: FirebaseStorageImpl, 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: FirebaseStorageImpl | Reference,\n  path?: string\n): Reference {\n  if (ref instanceof FirebaseStorageImpl) {\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      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: FirebaseStorageImpl, 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: FirebaseStorageImpl | Reference,\n  path?: string\n): Reference;\nexport function ref(\n  serviceOrRef: FirebaseStorageImpl | Reference,\n  pathOrUrl?: string\n): Reference | null {\n  if (pathOrUrl && isUrl(pathOrUrl)) {\n    if (serviceOrRef instanceof FirebaseStorageImpl) {\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(\n  host: string,\n  config?: FirebaseOptions\n): Location | null {\n  const bucketString = config?.[CONFIG_STORAGE_BUCKET_KEY];\n  if (bucketString == null) {\n    return null;\n  }\n  return Location.makeFromBucketSpec(bucketString, host);\n}\n\nexport function connectStorageEmulator(\n  storage: FirebaseStorageImpl,\n  host: string,\n  port: number,\n  options: {\n    mockUserToken?: EmulatorMockTokenOptions | string;\n  } = {}\n): void {\n  storage.host = `${host}:${port}`;\n  storage._protocol = 'http';\n  const { mockUserToken } = options;\n  if (mockUserToken) {\n    storage._overrideAuthToken =\n      typeof mockUserToken === 'string'\n        ? mockUserToken\n        : createMockUserToken(mockUserToken, storage.app.options.projectId);\n  }\n}\n\n/**\n * A service that provides Firebase Storage Reference instances.\n * @param opt_url - gs:// url to a custom Storage Bucket\n *\n * @internal\n */\nexport class FirebaseStorageImpl implements FirebaseStorage {\n  _bucket: Location | null = null;\n  /**\n   * This string can be in the formats:\n   * - host\n   * - host:port\n   */\n  private _host: string = DEFAULT_HOST;\n  _protocol: string = 'https';\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  _overrideAuthToken?: string;\n\n  constructor(\n    /**\n     * FirebaseApp associated with this StorageService instance.\n     */\n    readonly app: FirebaseApp,\n    readonly _authProvider: Provider<FirebaseAuthInternalName>,\n    /**\n     * @internal\n     */\n    readonly _appCheckProvider: Provider<AppCheckInternalComponentName>,\n    /**\n     * @internal\n     */\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, this._host);\n    } else {\n      this._bucket = extractBucket(this._host, this.app.options);\n    }\n  }\n\n  /**\n   * The host string for this service, in the form of `host` or\n   * `host:port`.\n   */\n  get host(): string {\n    return this._host;\n  }\n\n  set host(host: string) {\n    this._host = host;\n    if (this._url != null) {\n      this._bucket = Location.makeFromBucketSpec(this._url, host);\n    } else {\n      this._bucket = extractBucket(host, 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    if (this._overrideAuthToken) {\n      return this._overrideAuthToken;\n    }\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  async _getAppCheckToken(): Promise<string | null> {\n    const appCheck = this._appCheckProvider.getImmediate({ optional: true });\n    if (appCheck) {\n      const result = await appCheck.getToken();\n      // TODO: What do we want to do if there is an error getting the token?\n      // Context: appCheck.getToken() will never throw even if an error happened. In the error case, a dummy token will be\n      // returned along with an error field describing the error. In general, we shouldn't care about the error condition and just use\n      // the token (actual or dummy) to send requests.\n      return result.token;\n    }\n    return null;\n  }\n\n  /**\n   * Stop running requests and prevent more from being created.\n   */\n  _delete(): Promise<void> {\n    if (!this._deleted) {\n      this._deleted = true;\n      this._requests.forEach(request => request.cancel());\n      this._requests.clear();\n    }\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<I extends ConnectionType, O>(\n    requestInfo: RequestInfo<I, O>,\n    requestFactory: () => Connection<I>,\n    authToken: string | null,\n    appCheckToken: string | null,\n    retry = true\n  ): Request<O> {\n    if (!this._deleted) {\n      const request = makeRequest(\n        requestInfo,\n        this._appId,\n        authToken,\n        appCheckToken,\n        requestFactory,\n        this._firebaseVersion,\n        retry\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  async makeRequestWithTokens<I extends ConnectionType, O>(\n    requestInfo: RequestInfo<I, O>,\n    requestFactory: () => Connection<I>\n  ): Promise<O> {\n    const [authToken, appCheckToken] = await Promise.all([\n      this._getAuthToken(),\n      this._getAppCheckToken()\n    ]);\n\n    return this._makeRequest(\n      requestInfo,\n      requestFactory,\n      authToken,\n      appCheckToken\n    ).getPromise();\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/**\n * Type constant for Firebase Storage.\n */\nexport const STORAGE_TYPE = 'storage';\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 */\nimport { _getProvider, FirebaseApp, getApp } from '@firebase/app';\n\nimport {\n  ref as refInternal,\n  FirebaseStorageImpl,\n  connectStorageEmulator as connectEmulatorInternal\n} from './service';\nimport { Provider } from '@firebase/component';\n\nimport {\n  StorageReference,\n  FirebaseStorage,\n  UploadResult,\n  ListOptions,\n  ListResult,\n  UploadTask,\n  SettableMetadata,\n  UploadMetadata,\n  FullMetadata\n} from './public-types';\nimport { Metadata as MetadataInternal } from './metadata';\nimport {\n  uploadBytes as uploadBytesInternal,\n  uploadBytesResumable as uploadBytesResumableInternal,\n  uploadString as uploadStringInternal,\n  getMetadata as getMetadataInternal,\n  updateMetadata as updateMetadataInternal,\n  list as listInternal,\n  listAll as listAllInternal,\n  getDownloadURL as getDownloadURLInternal,\n  deleteObject as deleteObjectInternal,\n  Reference,\n  _getChild as _getChildInternal,\n  getBytesInternal\n} from './reference';\nimport { STORAGE_TYPE } from './constants';\nimport {\n  EmulatorMockTokenOptions,\n  getModularInstance,\n  getDefaultEmulatorHostnameAndPort\n} from '@firebase/util';\nimport { StringFormat } from './implementation/string';\n\nexport { EmulatorMockTokenOptions } from '@firebase/util';\n\nexport { StorageError, StorageErrorCode } from './implementation/error';\n\n/**\n * Public types.\n */\nexport * from './public-types';\n\nexport { Location as _Location } from './implementation/location';\nexport { UploadTask as _UploadTask } from './task';\nexport type { Reference as _Reference } from './reference';\nexport type { FirebaseStorageImpl as _FirebaseStorageImpl } from './service';\nexport { FbsBlob as _FbsBlob } from './implementation/blob';\nexport { dataFromString as _dataFromString } from './implementation/string';\nexport {\n  invalidRootOperation as _invalidRootOperation,\n  invalidArgument as _invalidArgument\n} from './implementation/error';\nexport {\n  TaskEvent as _TaskEvent,\n  TaskState as _TaskState\n} from './implementation/taskenums';\nexport { StringFormat };\n\n/**\n * Downloads the data at the object's location. Returns an error if the object\n * is not found.\n *\n * To use this functionality, you have to whitelist your app's origin in your\n * Cloud Storage bucket. See also\n * https://cloud.google.com/storage/docs/configuring-cors\n *\n * @public\n * @param ref - StorageReference where data should be downloaded.\n * @param maxDownloadSizeBytes - If set, the maximum allowed size in bytes to\n * retrieve.\n * @returns A Promise containing the object's bytes\n */\nexport function getBytes(\n  ref: StorageReference,\n  maxDownloadSizeBytes?: number\n): Promise<ArrayBuffer> {\n  ref = getModularInstance(ref);\n  return getBytesInternal(ref as Reference, maxDownloadSizeBytes);\n}\n\n/**\n * Uploads data to this object's location.\n * The upload is not resumable.\n * @public\n * @param ref - {@link StorageReference} where data should be uploaded.\n * @param data - The data to upload.\n * @param metadata - Metadata for the data to upload.\n * @returns A Promise containing an UploadResult\n */\nexport function uploadBytes(\n  ref: StorageReference,\n  data: Blob | Uint8Array | ArrayBuffer,\n  metadata?: UploadMetadata\n): Promise<UploadResult> {\n  ref = getModularInstance(ref);\n  return uploadBytesInternal(\n    ref as Reference,\n    data,\n    metadata as MetadataInternal\n  );\n}\n\n/**\n * Uploads a string to this object's location.\n * The upload is not resumable.\n * @public\n * @param ref - {@link 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 string to upload.\n * @returns A Promise containing an UploadResult\n */\nexport function uploadString(\n  ref: StorageReference,\n  value: string,\n  format?: StringFormat,\n  metadata?: UploadMetadata\n): Promise<UploadResult> {\n  ref = getModularInstance(ref);\n  return uploadStringInternal(\n    ref as Reference,\n    value,\n    format,\n    metadata as MetadataInternal\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 - {@link StorageReference} where data should be uploaded.\n * @param data - The data to upload.\n * @param metadata - Metadata for the data to upload.\n * @returns An UploadTask\n */\nexport function uploadBytesResumable(\n  ref: StorageReference,\n  data: Blob | Uint8Array | ArrayBuffer,\n  metadata?: UploadMetadata\n): UploadTask {\n  ref = getModularInstance(ref);\n  return uploadBytesResumableInternal(\n    ref as Reference,\n    data,\n    metadata as MetadataInternal\n  ) as UploadTask;\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 retrieved, the promise is\n * rejected.\n * @public\n * @param ref - {@link StorageReference} to get metadata from.\n */\nexport function getMetadata(ref: StorageReference): Promise<FullMetadata> {\n  ref = getModularInstance(ref);\n  return getMetadataInternal(ref as Reference) as Promise<FullMetadata>;\n}\n\n/**\n * Updates the metadata for this object.\n * @public\n * @param ref - {@link 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 with the new metadata for this object.\n */\nexport function updateMetadata(\n  ref: StorageReference,\n  metadata: SettableMetadata\n): Promise<FullMetadata> {\n  ref = getModularInstance(ref);\n  return updateMetadataInternal(\n    ref as Reference,\n    metadata as Partial<MetadataInternal>\n  ) as Promise<FullMetadata>;\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 - {@link StorageReference} to get list from.\n * @param options - See {@link 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 function list(\n  ref: StorageReference,\n  options?: ListOptions\n): Promise<ListResult> {\n  ref = getModularInstance(ref);\n  return listInternal(ref as Reference, options);\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 - {@link 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: StorageReference): Promise<ListResult> {\n  ref = getModularInstance(ref);\n  return listAllInternal(ref as Reference);\n}\n\n/**\n * Returns the download URL for the given {@link StorageReference}.\n * @public\n * @param ref - {@link StorageReference} to get the download URL for.\n * @returns A `Promise` that resolves with the download\n *     URL for this object.\n */\nexport function getDownloadURL(ref: StorageReference): Promise<string> {\n  ref = getModularInstance(ref);\n  return getDownloadURLInternal(ref as Reference);\n}\n\n/**\n * Deletes the object at this location.\n * @public\n * @param ref - {@link StorageReference} for object to delete.\n * @returns A `Promise` that resolves if the deletion succeeds.\n */\nexport function deleteObject(ref: StorageReference): Promise<void> {\n  ref = getModularInstance(ref);\n  return deleteObjectInternal(ref as Reference);\n}\n\n/**\n * Returns a {@link StorageReference} for the given url.\n * @param storage - {@link FirebaseStorage} instance.\n * @param url - URL. If empty, returns root reference.\n * @public\n */\nexport function ref(storage: FirebaseStorage, url?: string): StorageReference;\n/**\n * Returns a {@link StorageReference} for the given path in the\n * default bucket.\n * @param storageOrRef - {@link FirebaseStorage} or {@link StorageReference}.\n * @param pathOrUrlStorage - path. If empty, returns root reference (if {@link FirebaseStorage}\n * instance provided) or returns same reference (if {@link StorageReference} provided).\n * @public\n */\nexport function ref(\n  storageOrRef: FirebaseStorage | StorageReference,\n  path?: string\n): StorageReference;\nexport function ref(\n  serviceOrRef: FirebaseStorage | StorageReference,\n  pathOrUrl?: string\n): StorageReference | null {\n  serviceOrRef = getModularInstance(serviceOrRef);\n  return refInternal(\n    serviceOrRef as FirebaseStorageImpl | Reference,\n    pathOrUrl\n  );\n}\n\n/**\n * @internal\n */\nexport function _getChild(ref: StorageReference, childPath: string): Reference {\n  return _getChildInternal(ref as Reference, childPath);\n}\n\n/**\n * Gets a {@link FirebaseStorage} instance for the given Firebase app.\n * @public\n * @param app - Firebase app to get {@link FirebaseStorage} instance for.\n * @param bucketUrl - The gs:// url to your Firebase Storage Bucket.\n * If not passed, uses the app's default Storage Bucket.\n * @returns A {@link FirebaseStorage} instance.\n */\nexport function getStorage(\n  app: FirebaseApp = getApp(),\n  bucketUrl?: string\n): FirebaseStorage {\n  app = getModularInstance(app);\n  const storageProvider: Provider<'storage'> = _getProvider(app, STORAGE_TYPE);\n  const storageInstance = storageProvider.getImmediate({\n    identifier: bucketUrl\n  });\n  const emulator = getDefaultEmulatorHostnameAndPort('storage');\n  if (emulator) {\n    connectStorageEmulator(storageInstance, ...emulator);\n  }\n  return storageInstance;\n}\n\n/**\n * Modify this {@link FirebaseStorage} instance to communicate with the Cloud Storage emulator.\n *\n * @param storage - The {@link FirebaseStorage} instance\n * @param host - The emulator host (ex: localhost)\n * @param port - The emulator port (ex: 5001)\n * @param options - Emulator options. `options.mockUserToken` is the mock auth\n * token to use for unit testing Security Rules.\n * @public\n */\nexport function connectStorageEmulator(\n  storage: FirebaseStorage,\n  host: string,\n  port: number,\n  options: {\n    mockUserToken?: EmulatorMockTokenOptions | string;\n  } = {}\n): void {\n  connectEmulatorInternal(storage as FirebaseStorageImpl, host, port, options);\n}\n","/**\n * Cloud Storage for Firebase\n *\n * @packageDocumentation\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// eslint-disable-next-line import/no-extraneous-dependencies\nimport {\n  _registerComponent,\n  registerVersion,\n  SDK_VERSION\n} from '@firebase/app';\n\nimport { FirebaseStorageImpl } from '../src/service';\nimport {\n  Component,\n  ComponentType,\n  ComponentContainer,\n  InstanceFactoryOptions\n} from '@firebase/component';\n\nimport { name, version } from '../package.json';\n\nimport { FirebaseStorage } from './public-types';\nimport { STORAGE_TYPE } from './constants';\n\nexport * from './api';\nexport * from './api.browser';\n\nfunction factory(\n  container: ComponentContainer,\n  { instanceIdentifier: url }: InstanceFactoryOptions\n): FirebaseStorage {\n  const app = container.getProvider('app').getImmediate();\n  const authProvider = container.getProvider('auth-internal');\n  const appCheckProvider = container.getProvider('app-check-internal');\n\n  return new FirebaseStorageImpl(\n    app,\n    authProvider,\n    appCheckProvider,\n    url,\n    SDK_VERSION\n  );\n}\n\nfunction registerStorage(): void {\n  _registerComponent(\n    new Component(\n      STORAGE_TYPE,\n      factory,\n      ComponentType.PUBLIC\n    ).setMultipleInstances(true)\n  );\n  //RUNTIME_ENV will be replaced during the compilation to \"node\" for nodejs and an empty string for browser\n  registerVersion(name, version, '__RUNTIME_ENV__');\n  // BUILD_TARGET will be replaced by values like esm2017, cjs2017, etc during the compilation\n  registerVersion(name, version, '__BUILD_TARGET__');\n}\n\nregisterStorage();\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nexport default listCacheClear;\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 */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n","import eq from './eq.js';\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 */\nfunction 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\nexport default assocIndexOf;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\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 */\nfunction 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\nexport default listCacheDelete;\n","import assocIndexOf from './_assocIndexOf.js';\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 */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n","import assocIndexOf from './_assocIndexOf.js';\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 */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n","import assocIndexOf from './_assocIndexOf.js';\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 */\nfunction 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\nexport default listCacheSet;\n","import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n","import ListCache from './_ListCache.js';\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nexport default stackClear;\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 */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nexport default stackDelete;\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 */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nexport default stackGet;\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 */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nexport default stackHas;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\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 */\nfunction 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\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\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 */\nvar nativeObjectToString = objectProto.toString;\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 */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\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 */\nfunction 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\nexport default baseGetTag;\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 */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\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 */\nfunction 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\nexport default isFunction;\n","import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n","import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\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 */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\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 */\nfunction 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\nexport default toSource;\n","import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\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 */\nfunction 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\nexport default baseIsNative;\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 */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n","import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\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 */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n","import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n","import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nexport default hashClear;\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 */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nexport default hashDelete;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default hashGet;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\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 */\nfunction 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\nexport default hashSet;\n","import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction 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// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n","import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nexport default mapCacheClear;\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 */\nfunction 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\nexport default isKeyable;\n","import isKeyable from './_isKeyable.js';\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 */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nexport default getMapData;\n","import getMapData from './_getMapData.js';\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 */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nexport default mapCacheDelete;\n","import getMapData from './_getMapData.js';\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 */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n","import getMapData from './_getMapData.js';\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 */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n","import getMapData from './_getMapData.js';\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 */\nfunction 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\nexport default mapCacheSet;\n","import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\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 */\nfunction 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// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n","import ListCache from './_ListCache.js';\nimport Map from './_Map.js';\nimport MapCache from './_MapCache.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\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 */\nfunction 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\nexport default stackSet;\n","import ListCache from './_ListCache.js';\nimport stackClear from './_stackClear.js';\nimport stackDelete from './_stackDelete.js';\nimport stackGet from './_stackGet.js';\nimport stackHas from './_stackHas.js';\nimport stackSet from './_stackSet.js';\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 */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nexport default Stack;\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n  try {\n    var func = getNative(Object, 'defineProperty');\n    func({}, '', {});\n    return func;\n  } catch (e) {}\n}());\n\nexport default defineProperty;\n","import defineProperty from './_defineProperty.js';\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 */\nfunction 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\nexport default baseAssignValue;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\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 */\nfunction 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\nexport default assignMergeValue;\n","import createBaseFor from './_createBaseFor.js';\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 */\nvar baseFor = createBaseFor();\n\nexport default baseFor;\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 */\nfunction 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\nexport default createBaseFor;\n","import root from './_root.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\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 */\nfunction 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\nexport default cloneBuffer;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nexport default Uint8Array;\n","import Uint8Array from './_Uint8Array.js';\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 */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nexport default cloneArrayBuffer;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\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 */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\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 */\nfunction 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\nexport default copyArray;\n","import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\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 */\nvar 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\nexport default baseCreate;\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 */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nexport default overArg;\n","import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\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 */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nexport default isPrototype;\n","import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\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 */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\nexport default initCloneObject;\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 */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\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 */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nexport default baseIsArguments;\n","import baseIsArguments from './_baseIsArguments.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\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 */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nexport default isArguments;\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 */\nvar isArray = Array.isArray;\n\nexport default isArray;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\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 */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isLength;\n","import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\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 */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n","import isArrayLike from './isArrayLike.js';\nimport isObjectLike from './isObjectLike.js';\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 */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nexport default isArrayLikeObject;\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 */\nfunction stubFalse() {\n  return false;\n}\n\nexport default stubFalse;\n","import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\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 */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n","import baseGetTag from './_baseGetTag.js';\nimport getPrototype from './_getPrototype.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\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 */\nfunction 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\nexport default isPlainObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isLength from './isLength.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar 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 identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\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 */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nexport default baseIsTypedArray;\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 */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nexport default baseUnary;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar 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\nexport default nodeUtil;\n","import baseIsTypedArray from './_baseIsTypedArray.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\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 */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nexport default isTypedArray;\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 */\nfunction 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\nexport default safeGet;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default assignValue;\n","import assignValue from './_assignValue.js';\nimport baseAssignValue from './_baseAssignValue.js';\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 */\nfunction 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\nexport default copyObject;\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 */\nfunction 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\nexport default baseTimes;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\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 */\nfunction 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\nexport default isIndex;\n","import baseTimes from './_baseTimes.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isIndex from './_isIndex.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default arrayLikeKeys;\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 */\nfunction 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\nexport default nativeKeysIn;\n","import isObject from './isObject.js';\nimport isPrototype from './_isPrototype.js';\nimport nativeKeysIn from './_nativeKeysIn.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default baseKeysIn;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeysIn from './_baseKeysIn.js';\nimport isArrayLike from './isArrayLike.js';\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 */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nexport default keysIn;\n","import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\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 */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\nexport default toPlainObject;\n","import assignMergeValue from './_assignMergeValue.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\nimport copyArray from './_copyArray.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport isBuffer from './isBuffer.js';\nimport isFunction from './isFunction.js';\nimport isObject from './isObject.js';\nimport isPlainObject from './isPlainObject.js';\nimport isTypedArray from './isTypedArray.js';\nimport safeGet from './_safeGet.js';\nimport toPlainObject from './toPlainObject.js';\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 */\nfunction 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\nexport default baseMergeDeep;\n","import Stack from './_Stack.js';\nimport assignMergeValue from './_assignMergeValue.js';\nimport baseFor from './_baseFor.js';\nimport baseMergeDeep from './_baseMergeDeep.js';\nimport isObject from './isObject.js';\nimport keysIn from './keysIn.js';\nimport safeGet from './_safeGet.js';\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 */\nfunction 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\nexport default baseMerge;\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 */\nfunction identity(value) {\n  return value;\n}\n\nexport default identity;\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 */\nfunction 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\nexport default apply;\n","import apply from './_apply.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\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 */\nfunction 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\nexport default overRest;\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 */\nfunction constant(value) {\n  return function() {\n    return value;\n  };\n}\n\nexport default constant;\n","import constant from './constant.js';\nimport defineProperty from './_defineProperty.js';\nimport identity from './identity.js';\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 */\nvar 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\nexport default baseSetToString;\n","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n    HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\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 */\nfunction 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\nexport default shortOut;\n","import baseSetToString from './_baseSetToString.js';\nimport shortOut from './_shortOut.js';\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 */\nvar setToString = shortOut(baseSetToString);\n\nexport default setToString;\n","import identity from './identity.js';\nimport overRest from './_overRest.js';\nimport setToString from './_setToString.js';\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 */\nfunction baseRest(func, start) {\n  return setToString(overRest(func, start, identity), func + '');\n}\n\nexport default baseRest;\n","import eq from './eq.js';\nimport isArrayLike from './isArrayLike.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\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 */\nfunction 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\nexport default isIterateeCall;\n","import baseMerge from './_baseMerge.js';\nimport createAssigner from './_createAssigner.js';\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 */\nvar merge = createAssigner(function(object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\nexport default merge;\n","import baseRest from './_baseRest.js';\nimport isIterateeCall from './_isIterateeCall.js';\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 */\nfunction 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\nexport default createAssigner;\n","enum Scope {\n  TYPE = (1 << 2) - 1, // 0011 Lower two bits\n  LEVEL = ((1 << 2) - 1) << 2, // 1100 Higher two bits\n\n  ATTRIBUTE = (1 << 0) | LEVEL, // 1101\n  BLOT = (1 << 1) | LEVEL, // 1110\n  INLINE = (1 << 2) | TYPE, // 0111\n  BLOCK = (1 << 3) | TYPE, // 1011\n\n  BLOCK_BLOT = BLOCK & BLOT, // 1010\n  INLINE_BLOT = INLINE & BLOT, // 0110\n  BLOCK_ATTRIBUTE = BLOCK & ATTRIBUTE, // 1001\n  INLINE_ATTRIBUTE = INLINE & ATTRIBUTE, // 0101\n\n  ANY = TYPE | LEVEL,\n}\n\nexport default Scope;\n","import Scope from '../scope.js';\n\nexport interface AttributorOptions {\n  scope?: Scope;\n  whitelist?: string[];\n}\n\nexport default class Attributor {\n  public static keys(node: HTMLElement): string[] {\n    return Array.from(node.attributes).map((item: Attr) => item.name);\n  }\n\n  public scope: Scope;\n  public whitelist: string[] | undefined;\n\n  constructor(\n    public readonly attrName: string,\n    public readonly keyName: string,\n    options: AttributorOptions = {},\n  ) {\n    const attributeBit = Scope.TYPE & Scope.ATTRIBUTE;\n    this.scope =\n      options.scope != null\n        ? // Ignore type bits, force attribute bit\n          (options.scope & Scope.LEVEL) | attributeBit\n        : Scope.ATTRIBUTE;\n    if (options.whitelist != null) {\n      this.whitelist = options.whitelist;\n    }\n  }\n\n  public add(node: HTMLElement, value: any): boolean {\n    if (!this.canAdd(node, value)) {\n      return false;\n    }\n    node.setAttribute(this.keyName, value);\n    return true;\n  }\n\n  public canAdd(_node: HTMLElement, value: any): boolean {\n    if (this.whitelist == null) {\n      return true;\n    }\n    if (typeof value === 'string') {\n      return this.whitelist.indexOf(value.replace(/[\"']/g, '')) > -1;\n    } else {\n      return this.whitelist.indexOf(value) > -1;\n    }\n  }\n\n  public remove(node: HTMLElement): void {\n    node.removeAttribute(this.keyName);\n  }\n\n  public value(node: HTMLElement): any {\n    const value = node.getAttribute(this.keyName);\n    if (this.canAdd(node, value) && value) {\n      return value;\n    }\n    return '';\n  }\n}\n","export default class ParchmentError extends Error {\n  public message: string;\n  public name: string;\n  public stack!: string;\n\n  constructor(message: string) {\n    message = '[Parchment] ' + message;\n    super(message);\n    this.message = message;\n    this.name = this.constructor.name;\n  }\n}\n","import Attributor from './attributor/attributor.js';\nimport {\n  type Blot,\n  type BlotConstructor,\n  type Root,\n} from './blot/abstract/blot.js';\nimport ParchmentError from './error.js';\nimport Scope from './scope.js';\n\nexport type RegistryDefinition = Attributor | BlotConstructor;\n\nexport interface RegistryInterface {\n  create(scroll: Root, input: Node | string | Scope, value?: any): Blot;\n  query(query: string | Node | Scope, scope: Scope): RegistryDefinition | null;\n  register(...definitions: any[]): any;\n}\n\nexport default class Registry implements RegistryInterface {\n  public static blots = new WeakMap<Node, Blot>();\n\n  public static find(node?: Node | null, bubble = false): Blot | null {\n    if (node == null) {\n      return null;\n    }\n    if (this.blots.has(node)) {\n      return this.blots.get(node) || null;\n    }\n    if (bubble) {\n      let parentNode: Node | null = null;\n      try {\n        parentNode = node.parentNode;\n      } catch (err) {\n        // Probably hit a permission denied error.\n        // A known case is in Firefox, event targets can be anonymous DIVs\n        // inside an input element.\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=208427\n        return null;\n      }\n      return this.find(parentNode, bubble);\n    }\n    return null;\n  }\n\n  private attributes: { [key: string]: Attributor } = {};\n  private classes: { [key: string]: BlotConstructor } = {};\n  private tags: { [key: string]: BlotConstructor } = {};\n  private types: { [key: string]: RegistryDefinition } = {};\n\n  public create(scroll: Root, input: Node | string | Scope, value?: any): Blot {\n    const match = this.query(input);\n    if (match == null) {\n      throw new ParchmentError(`Unable to create ${input} blot`);\n    }\n    const blotClass = match as BlotConstructor;\n    const node =\n      // @ts-expect-error Fix me later\n      input instanceof Node || input.nodeType === Node.TEXT_NODE\n        ? input\n        : blotClass.create(value);\n\n    const blot = new blotClass(scroll, node as Node, value);\n    Registry.blots.set(blot.domNode, blot);\n    return blot;\n  }\n\n  public find(node: Node | null, bubble = false): Blot | null {\n    return Registry.find(node, bubble);\n  }\n\n  public query(\n    query: string | Node | Scope,\n    scope: Scope = Scope.ANY,\n  ): RegistryDefinition | null {\n    let match;\n    if (typeof query === 'string') {\n      match = this.types[query] || this.attributes[query];\n      // @ts-expect-error Fix me later\n    } else if (query instanceof Text || query.nodeType === Node.TEXT_NODE) {\n      match = this.types.text;\n    } else if (typeof query === 'number') {\n      if (query & Scope.LEVEL & Scope.BLOCK) {\n        match = this.types.block;\n      } else if (query & Scope.LEVEL & Scope.INLINE) {\n        match = this.types.inline;\n      }\n    } else if (query instanceof Element) {\n      const names = (query.getAttribute('class') || '').split(/\\s+/);\n      names.some((name) => {\n        match = this.classes[name];\n        if (match) {\n          return true;\n        }\n        return false;\n      });\n      match = match || this.tags[query.tagName];\n    }\n    if (match == null) {\n      return null;\n    }\n    if (\n      'scope' in match &&\n      scope & Scope.LEVEL & match.scope &&\n      scope & Scope.TYPE & match.scope\n    ) {\n      return match;\n    }\n    return null;\n  }\n\n  public register(...definitions: RegistryDefinition[]): RegistryDefinition[] {\n    return definitions.map((definition) => {\n      const isBlot = 'blotName' in definition;\n      const isAttr = 'attrName' in definition;\n      if (!isBlot && !isAttr) {\n        throw new ParchmentError('Invalid definition');\n      } else if (isBlot && definition.blotName === 'abstract') {\n        throw new ParchmentError('Cannot register abstract class');\n      }\n      const key = isBlot\n        ? definition.blotName\n        : isAttr\n          ? definition.attrName\n          : (undefined as never); // already handled by above checks\n      this.types[key] = definition;\n\n      if (isAttr) {\n        if (typeof definition.keyName === 'string') {\n          this.attributes[definition.keyName] = definition;\n        }\n      } else if (isBlot) {\n        if (definition.className) {\n          this.classes[definition.className] = definition;\n        }\n        if (definition.tagName) {\n          if (Array.isArray(definition.tagName)) {\n            definition.tagName = definition.tagName.map((tagName: string) => {\n              return tagName.toUpperCase();\n            });\n          } else {\n            definition.tagName = definition.tagName.toUpperCase();\n          }\n          const tagNames = Array.isArray(definition.tagName)\n            ? definition.tagName\n            : [definition.tagName];\n          tagNames.forEach((tag: string) => {\n            if (this.tags[tag] == null || definition.className == null) {\n              this.tags[tag] = definition;\n            }\n          });\n        }\n      }\n      return definition;\n    });\n  }\n}\n","import Attributor from './attributor.js';\n\nfunction match(node: HTMLElement, prefix: string): string[] {\n  const className = node.getAttribute('class') || '';\n  return className\n    .split(/\\s+/)\n    .filter((name) => name.indexOf(`${prefix}-`) === 0);\n}\n\nclass ClassAttributor extends Attributor {\n  public static keys(node: HTMLElement): string[] {\n    return (node.getAttribute('class') || '')\n      .split(/\\s+/)\n      .map((name) => name.split('-').slice(0, -1).join('-'));\n  }\n\n  public add(node: HTMLElement, value: any): boolean {\n    if (!this.canAdd(node, value)) {\n      return false;\n    }\n    this.remove(node);\n    node.classList.add(`${this.keyName}-${value}`);\n    return true;\n  }\n\n  public remove(node: HTMLElement): void {\n    const matches = match(node, this.keyName);\n    matches.forEach((name) => {\n      node.classList.remove(name);\n    });\n    if (node.classList.length === 0) {\n      node.removeAttribute('class');\n    }\n  }\n\n  public value(node: HTMLElement): any {\n    const result = match(node, this.keyName)[0] || '';\n    const value = result.slice(this.keyName.length + 1); // +1 for hyphen\n    return this.canAdd(node, value) ? value : '';\n  }\n}\n\nexport default ClassAttributor;\n","import Attributor from './attributor.js';\n\nfunction camelize(name: string): string {\n  const parts = name.split('-');\n  const rest = parts\n    .slice(1)\n    .map((part: string) => part[0].toUpperCase() + part.slice(1))\n    .join('');\n  return parts[0] + rest;\n}\n\nclass StyleAttributor extends Attributor {\n  public static keys(node: HTMLElement): string[] {\n    return (node.getAttribute('style') || '').split(';').map((value) => {\n      const arr = value.split(':');\n      return arr[0].trim();\n    });\n  }\n\n  public add(node: HTMLElement, value: any): boolean {\n    if (!this.canAdd(node, value)) {\n      return false;\n    }\n    // @ts-expect-error Fix me later\n    node.style[camelize(this.keyName)] = value;\n    return true;\n  }\n\n  public remove(node: HTMLElement): void {\n    // @ts-expect-error Fix me later\n    node.style[camelize(this.keyName)] = '';\n    if (!node.getAttribute('style')) {\n      node.removeAttribute('style');\n    }\n  }\n\n  public value(node: HTMLElement): any {\n    // @ts-expect-error Fix me later\n    const value = node.style[camelize(this.keyName)];\n    return this.canAdd(node, value) ? value : '';\n  }\n}\n\nexport default StyleAttributor;\n","import type { Formattable } from '../blot/abstract/blot.js';\nimport Registry from '../registry.js';\nimport Scope from '../scope.js';\nimport Attributor from './attributor.js';\nimport ClassAttributor from './class.js';\nimport StyleAttributor from './style.js';\n\nclass AttributorStore {\n  private attributes: { [key: string]: Attributor } = {};\n  private domNode: HTMLElement;\n\n  constructor(domNode: HTMLElement) {\n    this.domNode = domNode;\n    this.build();\n  }\n\n  public attribute(attribute: Attributor, value: any): void {\n    // verb\n    if (value) {\n      if (attribute.add(this.domNode, value)) {\n        if (attribute.value(this.domNode) != null) {\n          this.attributes[attribute.attrName] = attribute;\n        } else {\n          delete this.attributes[attribute.attrName];\n        }\n      }\n    } else {\n      attribute.remove(this.domNode);\n      delete this.attributes[attribute.attrName];\n    }\n  }\n\n  public build(): void {\n    this.attributes = {};\n    const blot = Registry.find(this.domNode);\n    if (blot == null) {\n      return;\n    }\n    const attributes = Attributor.keys(this.domNode);\n    const classes = ClassAttributor.keys(this.domNode);\n    const styles = StyleAttributor.keys(this.domNode);\n    attributes\n      .concat(classes)\n      .concat(styles)\n      .forEach((name) => {\n        const attr = blot.scroll.query(name, Scope.ATTRIBUTE);\n        if (attr instanceof Attributor) {\n          this.attributes[attr.attrName] = attr;\n        }\n      });\n  }\n\n  public copy(target: Formattable): void {\n    Object.keys(this.attributes).forEach((key) => {\n      const value = this.attributes[key].value(this.domNode);\n      target.format(key, value);\n    });\n  }\n\n  public move(target: Formattable): void {\n    this.copy(target);\n    Object.keys(this.attributes).forEach((key) => {\n      this.attributes[key].remove(this.domNode);\n    });\n    this.attributes = {};\n  }\n\n  public values(): { [key: string]: any } {\n    return Object.keys(this.attributes).reduce(\n      (attributes: { [key: string]: any }, name: string) => {\n        attributes[name] = this.attributes[name].value(this.domNode);\n        return attributes;\n      },\n      {},\n    );\n  }\n}\n\nexport default AttributorStore;\n","import ParchmentError from '../../error.js';\nimport Registry from '../../registry.js';\nimport Scope from '../../scope.js';\nimport type {\n  Blot,\n  BlotConstructor,\n  Formattable,\n  Parent,\n  Root,\n} from './blot.js';\n\nclass ShadowBlot implements Blot {\n  public static blotName = 'abstract';\n  public static className: string;\n  public static requiredContainer: BlotConstructor;\n  public static scope: Scope;\n  public static tagName: string | string[];\n\n  public static create(rawValue?: unknown): Node {\n    if (this.tagName == null) {\n      throw new ParchmentError('Blot definition missing tagName');\n    }\n    let node: HTMLElement;\n    let value: string | number | undefined;\n    if (Array.isArray(this.tagName)) {\n      if (typeof rawValue === 'string') {\n        value = rawValue.toUpperCase();\n        if (parseInt(value, 10).toString() === value) {\n          value = parseInt(value, 10);\n        }\n      } else if (typeof rawValue === 'number') {\n        value = rawValue;\n      }\n      if (typeof value === 'number') {\n        node = document.createElement(this.tagName[value - 1]);\n      } else if (value && this.tagName.indexOf(value) > -1) {\n        node = document.createElement(value);\n      } else {\n        node = document.createElement(this.tagName[0]);\n      }\n    } else {\n      node = document.createElement(this.tagName);\n    }\n    if (this.className) {\n      node.classList.add(this.className);\n    }\n    return node;\n  }\n\n  public prev: Blot | null;\n  public next: Blot | null;\n  // @ts-expect-error Fix me later\n  public parent: Parent;\n\n  // Hack for accessing inherited static methods\n  get statics(): any {\n    return this.constructor;\n  }\n  constructor(\n    public scroll: Root,\n    public domNode: Node,\n  ) {\n    Registry.blots.set(domNode, this);\n    this.prev = null;\n    this.next = null;\n  }\n\n  public attach(): void {\n    // Nothing to do\n  }\n\n  public clone(): Blot {\n    const domNode = this.domNode.cloneNode(false);\n    return this.scroll.create(domNode);\n  }\n\n  public detach(): void {\n    if (this.parent != null) {\n      this.parent.removeChild(this);\n    }\n    Registry.blots.delete(this.domNode);\n  }\n\n  public deleteAt(index: number, length: number): void {\n    const blot = this.isolate(index, length);\n    blot.remove();\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    const blot = this.isolate(index, length);\n    if (this.scroll.query(name, Scope.BLOT) != null && value) {\n      blot.wrap(name, value);\n    } else if (this.scroll.query(name, Scope.ATTRIBUTE) != null) {\n      const parent = this.scroll.create(this.statics.scope) as Parent &\n        Formattable;\n      blot.wrap(parent);\n      parent.format(name, value);\n    }\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    const blot =\n      def == null\n        ? this.scroll.create('text', value)\n        : this.scroll.create(value, def);\n    const ref = this.split(index);\n    this.parent.insertBefore(blot, ref || undefined);\n  }\n\n  public isolate(index: number, length: number): Blot {\n    const target = this.split(index);\n    if (target == null) {\n      throw new Error('Attempt to isolate at end');\n    }\n    target.split(length);\n    return target;\n  }\n\n  public length(): number {\n    return 1;\n  }\n\n  public offset(root: Blot = this.parent): number {\n    if (this.parent == null || this === root) {\n      return 0;\n    }\n    return this.parent.children.offset(this) + this.parent.offset(root);\n  }\n\n  public optimize(_context?: { [key: string]: any }): void {\n    if (\n      this.statics.requiredContainer &&\n      !(this.parent instanceof this.statics.requiredContainer)\n    ) {\n      this.wrap(this.statics.requiredContainer.blotName);\n    }\n  }\n\n  public remove(): void {\n    if (this.domNode.parentNode != null) {\n      this.domNode.parentNode.removeChild(this.domNode);\n    }\n    this.detach();\n  }\n\n  public replaceWith(name: string | Blot, value?: any): Blot {\n    const replacement =\n      typeof name === 'string' ? this.scroll.create(name, value) : name;\n    if (this.parent != null) {\n      this.parent.insertBefore(replacement, this.next || undefined);\n      this.remove();\n    }\n    return replacement;\n  }\n\n  public split(index: number, _force?: boolean): Blot | null {\n    return index === 0 ? this : this.next;\n  }\n\n  public update(\n    _mutations: MutationRecord[],\n    _context: { [key: string]: any },\n  ): void {\n    // Nothing to do by default\n  }\n\n  public wrap(name: string | Parent, value?: any): Parent {\n    const wrapper =\n      typeof name === 'string'\n        ? (this.scroll.create(name, value) as Parent)\n        : name;\n    if (this.parent != null) {\n      this.parent.insertBefore(wrapper, this.next || undefined);\n    }\n    if (typeof wrapper.appendChild !== 'function') {\n      throw new ParchmentError(`Cannot wrap ${name}`);\n    }\n    wrapper.appendChild(this);\n    return wrapper;\n  }\n}\n\nexport default ShadowBlot;\n","import Scope from '../../scope.js';\nimport type { Leaf } from './blot.js';\nimport ShadowBlot from './shadow.js';\n\nclass LeafBlot extends ShadowBlot implements Leaf {\n  public static scope = Scope.INLINE_BLOT;\n\n  /**\n   * Returns the value represented by domNode if it is this Blot's type\n   * No checking that domNode can represent this Blot type is required so\n   * applications needing it should check externally before calling.\n   */\n  public static value(_domNode: Node): any {\n    return true;\n  }\n\n  /**\n   * Given location represented by node and offset from DOM Selection Range,\n   * return index to that location.\n   */\n  public index(node: Node, offset: number): number {\n    if (\n      this.domNode === node ||\n      this.domNode.compareDocumentPosition(node) &\n        Node.DOCUMENT_POSITION_CONTAINED_BY\n    ) {\n      return Math.min(offset, 1);\n    }\n    return -1;\n  }\n\n  /**\n   * Given index to location within blot, return node and offset representing\n   * that location, consumable by DOM Selection Range\n   */\n  public position(index: number, _inclusive?: boolean): [Node, number] {\n    const childNodes: Node[] = Array.from(this.parent.domNode.childNodes);\n    let offset = childNodes.indexOf(this.domNode);\n    if (index > 0) {\n      offset += 1;\n    }\n    return [this.parent.domNode, offset];\n  }\n\n  /**\n   * Return value represented by this blot\n   * Should not change without interaction from API or\n   * user change detectable by update()\n   */\n  public value(): any {\n    return {\n      [this.statics.blotName]: this.statics.value(this.domNode) || true,\n    };\n  }\n}\n\nexport default LeafBlot;\n","import type LinkedNode from './linked-node.js';\n\nclass LinkedList<T extends LinkedNode> {\n  public head: T | null;\n  public tail: T | null;\n  public length: number;\n\n  constructor() {\n    this.head = null;\n    this.tail = null;\n    this.length = 0;\n  }\n\n  public append(...nodes: T[]): void {\n    this.insertBefore(nodes[0], null);\n    if (nodes.length > 1) {\n      const rest = nodes.slice(1);\n      this.append(...rest);\n    }\n  }\n\n  public at(index: number): T | null {\n    const next = this.iterator();\n    let cur = next();\n    while (cur && index > 0) {\n      index -= 1;\n      cur = next();\n    }\n    return cur;\n  }\n\n  public contains(node: T): boolean {\n    const next = this.iterator();\n    let cur = next();\n    while (cur) {\n      if (cur === node) {\n        return true;\n      }\n      cur = next();\n    }\n    return false;\n  }\n\n  public indexOf(node: T): number {\n    const next = this.iterator();\n    let cur = next();\n    let index = 0;\n    while (cur) {\n      if (cur === node) {\n        return index;\n      }\n      index += 1;\n      cur = next();\n    }\n    return -1;\n  }\n\n  public insertBefore(node: T | null, refNode: T | null): void {\n    if (node == null) {\n      return;\n    }\n    this.remove(node);\n    node.next = refNode;\n    if (refNode != null) {\n      node.prev = refNode.prev;\n      if (refNode.prev != null) {\n        refNode.prev.next = node;\n      }\n      refNode.prev = node;\n      if (refNode === this.head) {\n        this.head = node;\n      }\n    } else if (this.tail != null) {\n      this.tail.next = node;\n      node.prev = this.tail;\n      this.tail = node;\n    } else {\n      node.prev = null;\n      this.head = this.tail = node;\n    }\n    this.length += 1;\n  }\n\n  public offset(target: T): number {\n    let index = 0;\n    let cur = this.head;\n    while (cur != null) {\n      if (cur === target) {\n        return index;\n      }\n      index += cur.length();\n      cur = cur.next as T;\n    }\n    return -1;\n  }\n\n  public remove(node: T): void {\n    if (!this.contains(node)) {\n      return;\n    }\n    if (node.prev != null) {\n      node.prev.next = node.next;\n    }\n    if (node.next != null) {\n      node.next.prev = node.prev;\n    }\n    if (node === this.head) {\n      this.head = node.next as T;\n    }\n    if (node === this.tail) {\n      this.tail = node.prev as T;\n    }\n    this.length -= 1;\n  }\n\n  public iterator(curNode: T | null = this.head): () => T | null {\n    // TODO use yield when we can\n    return (): T | null => {\n      const ret = curNode;\n      if (curNode != null) {\n        curNode = curNode.next as T;\n      }\n      return ret;\n    };\n  }\n\n  public find(index: number, inclusive = false): [T | null, number] {\n    const next = this.iterator();\n    let cur = next();\n    while (cur) {\n      const length = cur.length();\n      if (\n        index < length ||\n        (inclusive &&\n          index === length &&\n          (cur.next == null || cur.next.length() !== 0))\n      ) {\n        return [cur, index];\n      }\n      index -= length;\n      cur = next();\n    }\n    return [null, 0];\n  }\n\n  public forEach(callback: (cur: T) => void): void {\n    const next = this.iterator();\n    let cur = next();\n    while (cur) {\n      callback(cur);\n      cur = next();\n    }\n  }\n\n  public forEachAt(\n    index: number,\n    length: number,\n    callback: (cur: T, offset: number, length: number) => void,\n  ): void {\n    if (length <= 0) {\n      return;\n    }\n    const [startNode, offset] = this.find(index);\n    let curIndex = index - offset;\n    const next = this.iterator(startNode);\n    let cur = next();\n    while (cur && curIndex < index + length) {\n      const curLength = cur.length();\n      if (index > curIndex) {\n        callback(\n          cur,\n          index - curIndex,\n          Math.min(length, curIndex + curLength - index),\n        );\n      } else {\n        callback(cur, 0, Math.min(curLength, index + length - curIndex));\n      }\n      curIndex += curLength;\n      cur = next();\n    }\n  }\n\n  public map(callback: (cur: T) => any): any[] {\n    return this.reduce((memo: T[], cur: T) => {\n      memo.push(callback(cur));\n      return memo;\n    }, []);\n  }\n\n  public reduce<M>(callback: (memo: M, cur: T) => M, memo: M): M {\n    const next = this.iterator();\n    let cur = next();\n    while (cur) {\n      memo = callback(memo, cur);\n      cur = next();\n    }\n    return memo;\n  }\n}\n\nexport default LinkedList;\n","import LinkedList from '../../collection/linked-list.js';\nimport ParchmentError from '../../error.js';\nimport Scope from '../../scope.js';\nimport type { Blot, BlotConstructor, Parent, Root } from './blot.js';\nimport ShadowBlot from './shadow.js';\n\nfunction makeAttachedBlot(node: Node, scroll: Root): Blot {\n  const found = scroll.find(node);\n  if (found) return found;\n  try {\n    return scroll.create(node);\n  } catch (e) {\n    const blot = scroll.create(Scope.INLINE);\n    Array.from(node.childNodes).forEach((child: Node) => {\n      blot.domNode.appendChild(child);\n    });\n    if (node.parentNode) {\n      node.parentNode.replaceChild(blot.domNode, node);\n    }\n    blot.attach();\n    return blot;\n  }\n}\n\nclass ParentBlot extends ShadowBlot implements Parent {\n  /**\n   * Whitelist array of Blots that can be direct children.\n   */\n  public static allowedChildren?: BlotConstructor[];\n\n  /**\n   * Default child blot to be inserted if this blot becomes empty.\n   */\n  public static defaultChild?: BlotConstructor;\n  public static uiClass = '';\n\n  public children!: LinkedList<Blot>;\n  public domNode!: HTMLElement;\n  public uiNode: HTMLElement | null = null;\n\n  constructor(scroll: Root, domNode: Node) {\n    super(scroll, domNode);\n    this.build();\n  }\n\n  public appendChild(other: Blot): void {\n    this.insertBefore(other);\n  }\n\n  public attach(): void {\n    super.attach();\n    this.children.forEach((child) => {\n      child.attach();\n    });\n  }\n\n  public attachUI(node: HTMLElement): void {\n    if (this.uiNode != null) {\n      this.uiNode.remove();\n    }\n    this.uiNode = node;\n    if (ParentBlot.uiClass) {\n      this.uiNode.classList.add(ParentBlot.uiClass);\n    }\n    this.uiNode.setAttribute('contenteditable', 'false');\n    this.domNode.insertBefore(this.uiNode, this.domNode.firstChild);\n  }\n\n  /**\n   * Called during construction, should fill its own children LinkedList.\n   */\n  public build(): void {\n    this.children = new LinkedList<Blot>();\n    // Need to be reversed for if DOM nodes already in order\n    Array.from(this.domNode.childNodes)\n      .filter((node: Node) => node !== this.uiNode)\n      .reverse()\n      .forEach((node: Node) => {\n        try {\n          const child = makeAttachedBlot(node, this.scroll);\n          this.insertBefore(child, this.children.head || undefined);\n        } catch (err) {\n          if (err instanceof ParchmentError) {\n            return;\n          } else {\n            throw err;\n          }\n        }\n      });\n  }\n\n  public deleteAt(index: number, length: number): void {\n    if (index === 0 && length === this.length()) {\n      return this.remove();\n    }\n    this.children.forEachAt(index, length, (child, offset, childLength) => {\n      child.deleteAt(offset, childLength);\n    });\n  }\n\n  public descendant<T extends Blot>(\n    criteria: new (...args: any[]) => T,\n    index: number,\n  ): [T | null, number];\n  public descendant(\n    criteria: (blot: Blot) => boolean,\n    index: number,\n  ): [Blot | null, number];\n  public descendant(criteria: any, index = 0): [Blot | null, number] {\n    const [child, offset] = this.children.find(index);\n    if (\n      (criteria.blotName == null && criteria(child)) ||\n      (criteria.blotName != null && child instanceof criteria)\n    ) {\n      return [child as any, offset];\n    } else if (child instanceof ParentBlot) {\n      return child.descendant(criteria, offset);\n    } else {\n      return [null, -1];\n    }\n  }\n\n  public descendants<T extends Blot>(\n    criteria: new (...args: any[]) => T,\n    index?: number,\n    length?: number,\n  ): T[];\n  public descendants(\n    criteria: (blot: Blot) => boolean,\n    index?: number,\n    length?: number,\n  ): Blot[];\n  public descendants(\n    criteria: any,\n    index = 0,\n    length: number = Number.MAX_VALUE,\n  ): Blot[] {\n    let descendants: Blot[] = [];\n    let lengthLeft = length;\n    this.children.forEachAt(\n      index,\n      length,\n      (child: Blot, childIndex: number, childLength: number) => {\n        if (\n          (criteria.blotName == null && criteria(child)) ||\n          (criteria.blotName != null && child instanceof criteria)\n        ) {\n          descendants.push(child);\n        }\n        if (child instanceof ParentBlot) {\n          descendants = descendants.concat(\n            child.descendants(criteria, childIndex, lengthLeft),\n          );\n        }\n        lengthLeft -= childLength;\n      },\n    );\n    return descendants;\n  }\n\n  public detach(): void {\n    this.children.forEach((child) => {\n      child.detach();\n    });\n    super.detach();\n  }\n\n  public enforceAllowedChildren(): void {\n    let done = false;\n    this.children.forEach((child: Blot) => {\n      if (done) {\n        return;\n      }\n      const allowed = this.statics.allowedChildren.some(\n        (def: BlotConstructor) => child instanceof def,\n      );\n      if (allowed) {\n        return;\n      }\n      if (child.statics.scope === Scope.BLOCK_BLOT) {\n        if (child.next != null) {\n          this.splitAfter(child);\n        }\n        if (child.prev != null) {\n          this.splitAfter(child.prev);\n        }\n        child.parent.unwrap();\n        done = true;\n      } else if (child instanceof ParentBlot) {\n        child.unwrap();\n      } else {\n        child.remove();\n      }\n    });\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    this.children.forEachAt(index, length, (child, offset, childLength) => {\n      child.formatAt(offset, childLength, name, value);\n    });\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    const [child, offset] = this.children.find(index);\n    if (child) {\n      child.insertAt(offset, value, def);\n    } else {\n      const blot =\n        def == null\n          ? this.scroll.create('text', value)\n          : this.scroll.create(value, def);\n      this.appendChild(blot);\n    }\n  }\n\n  public insertBefore(childBlot: Blot, refBlot?: Blot | null): void {\n    if (childBlot.parent != null) {\n      childBlot.parent.children.remove(childBlot);\n    }\n    let refDomNode: Node | null = null;\n    this.children.insertBefore(childBlot, refBlot || null);\n    childBlot.parent = this;\n    if (refBlot != null) {\n      refDomNode = refBlot.domNode;\n    }\n    if (\n      this.domNode.parentNode !== childBlot.domNode ||\n      this.domNode.nextSibling !== refDomNode\n    ) {\n      this.domNode.insertBefore(childBlot.domNode, refDomNode);\n    }\n    childBlot.attach();\n  }\n\n  public length(): number {\n    return this.children.reduce((memo, child) => {\n      return memo + child.length();\n    }, 0);\n  }\n\n  public moveChildren(targetParent: Parent, refNode?: Blot | null): void {\n    this.children.forEach((child) => {\n      targetParent.insertBefore(child, refNode);\n    });\n  }\n\n  public optimize(context?: { [key: string]: any }): void {\n    super.optimize(context);\n    this.enforceAllowedChildren();\n    if (this.uiNode != null && this.uiNode !== this.domNode.firstChild) {\n      this.domNode.insertBefore(this.uiNode, this.domNode.firstChild);\n    }\n    if (this.children.length === 0) {\n      if (this.statics.defaultChild != null) {\n        const child = this.scroll.create(this.statics.defaultChild.blotName);\n        this.appendChild(child);\n        // TODO double check if necessary\n        // child.optimize(context);\n      } else {\n        this.remove();\n      }\n    }\n  }\n\n  public path(index: number, inclusive = false): [Blot, number][] {\n    const [child, offset] = this.children.find(index, inclusive);\n    const position: [Blot, number][] = [[this, index]];\n    if (child instanceof ParentBlot) {\n      return position.concat(child.path(offset, inclusive));\n    } else if (child != null) {\n      position.push([child, offset]);\n    }\n    return position;\n  }\n\n  public removeChild(child: Blot): void {\n    this.children.remove(child);\n  }\n\n  public replaceWith(name: string | Blot, value?: any): Blot {\n    const replacement =\n      typeof name === 'string' ? this.scroll.create(name, value) : name;\n    if (replacement instanceof ParentBlot) {\n      this.moveChildren(replacement);\n    }\n    return super.replaceWith(replacement);\n  }\n\n  public split(index: number, force = false): Blot | null {\n    if (!force) {\n      if (index === 0) {\n        return this;\n      }\n      if (index === this.length()) {\n        return this.next;\n      }\n    }\n    const after = this.clone() as ParentBlot;\n    if (this.parent) {\n      this.parent.insertBefore(after, this.next || undefined);\n    }\n    this.children.forEachAt(index, this.length(), (child, offset, _length) => {\n      const split = child.split(offset, force);\n      if (split != null) {\n        after.appendChild(split);\n      }\n    });\n    return after;\n  }\n\n  public splitAfter(child: Blot): Parent {\n    const after = this.clone() as ParentBlot;\n    while (child.next != null) {\n      after.appendChild(child.next);\n    }\n    if (this.parent) {\n      this.parent.insertBefore(after, this.next || undefined);\n    }\n    return after;\n  }\n\n  public unwrap(): void {\n    if (this.parent) {\n      this.moveChildren(this.parent, this.next || undefined);\n    }\n    this.remove();\n  }\n\n  public update(\n    mutations: MutationRecord[],\n    _context: { [key: string]: any },\n  ): void {\n    const addedNodes: Node[] = [];\n    const removedNodes: Node[] = [];\n    mutations.forEach((mutation) => {\n      if (mutation.target === this.domNode && mutation.type === 'childList') {\n        addedNodes.push(...mutation.addedNodes);\n        removedNodes.push(...mutation.removedNodes);\n      }\n    });\n    removedNodes.forEach((node: Node) => {\n      // Check node has actually been removed\n      // One exception is Chrome does not immediately remove IFRAMEs\n      // from DOM but MutationRecord is correct in its reported removal\n      if (\n        node.parentNode != null &&\n        // @ts-expect-error Fix me later\n        node.tagName !== 'IFRAME' &&\n        document.body.compareDocumentPosition(node) &\n          Node.DOCUMENT_POSITION_CONTAINED_BY\n      ) {\n        return;\n      }\n      const blot = this.scroll.find(node);\n      if (blot == null) {\n        return;\n      }\n      if (\n        blot.domNode.parentNode == null ||\n        blot.domNode.parentNode === this.domNode\n      ) {\n        blot.detach();\n      }\n    });\n    addedNodes\n      .filter((node) => {\n        return node.parentNode === this.domNode && node !== this.uiNode;\n      })\n      .sort((a, b) => {\n        if (a === b) {\n          return 0;\n        }\n        if (a.compareDocumentPosition(b) & Node.DOCUMENT_POSITION_FOLLOWING) {\n          return 1;\n        }\n        return -1;\n      })\n      .forEach((node) => {\n        let refBlot: Blot | null = null;\n        if (node.nextSibling != null) {\n          refBlot = this.scroll.find(node.nextSibling);\n        }\n        const blot = makeAttachedBlot(node, this.scroll);\n        if (blot.next !== refBlot || blot.next == null) {\n          if (blot.parent != null) {\n            blot.parent.removeChild(this);\n          }\n          this.insertBefore(blot, refBlot || undefined);\n        }\n      });\n    this.enforceAllowedChildren();\n  }\n}\n\nexport default ParentBlot;\n","import Attributor from '../attributor/attributor.js';\nimport AttributorStore from '../attributor/store.js';\nimport Scope from '../scope.js';\nimport type {\n  Blot,\n  BlotConstructor,\n  Formattable,\n  Parent,\n  Root,\n} from './abstract/blot.js';\nimport LeafBlot from './abstract/leaf.js';\nimport ParentBlot from './abstract/parent.js';\n\n// Shallow object comparison\nfunction isEqual(\n  obj1: Record<string, unknown>,\n  obj2: Record<string, unknown>,\n): boolean {\n  if (Object.keys(obj1).length !== Object.keys(obj2).length) {\n    return false;\n  }\n  for (const prop in obj1) {\n    if (obj1[prop] !== obj2[prop]) {\n      return false;\n    }\n  }\n  return true;\n}\n\nclass InlineBlot extends ParentBlot implements Formattable {\n  public static allowedChildren: BlotConstructor[] = [InlineBlot, LeafBlot];\n  public static blotName = 'inline';\n  public static scope = Scope.INLINE_BLOT;\n  public static tagName: string | string[] = 'SPAN';\n\n  static create(value?: unknown) {\n    return super.create(value) as HTMLElement;\n  }\n\n  public static formats(domNode: HTMLElement, scroll: Root): any {\n    const match = scroll.query(InlineBlot.blotName);\n    if (\n      match != null &&\n      domNode.tagName === (match as BlotConstructor).tagName\n    ) {\n      return undefined;\n    } else if (typeof this.tagName === 'string') {\n      return true;\n    } else if (Array.isArray(this.tagName)) {\n      return domNode.tagName.toLowerCase();\n    }\n    return undefined;\n  }\n\n  protected attributes: AttributorStore;\n\n  constructor(scroll: Root, domNode: Node) {\n    super(scroll, domNode);\n    this.attributes = new AttributorStore(this.domNode);\n  }\n\n  public format(name: string, value: any): void {\n    if (name === this.statics.blotName && !value) {\n      this.children.forEach((child) => {\n        if (!(child instanceof InlineBlot)) {\n          child = child.wrap(InlineBlot.blotName, true);\n        }\n        this.attributes.copy(child as InlineBlot);\n      });\n      this.unwrap();\n    } else {\n      const format = this.scroll.query(name, Scope.INLINE);\n      if (format == null) {\n        return;\n      }\n      if (format instanceof Attributor) {\n        this.attributes.attribute(format, value);\n      } else if (\n        value &&\n        (name !== this.statics.blotName || this.formats()[name] !== value)\n      ) {\n        this.replaceWith(name, value);\n      }\n    }\n  }\n\n  public formats(): { [index: string]: any } {\n    const formats = this.attributes.values();\n    const format = this.statics.formats(this.domNode, this.scroll);\n    if (format != null) {\n      formats[this.statics.blotName] = format;\n    }\n    return formats;\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    if (\n      this.formats()[name] != null ||\n      this.scroll.query(name, Scope.ATTRIBUTE)\n    ) {\n      const blot = this.isolate(index, length) as InlineBlot;\n      blot.format(name, value);\n    } else {\n      super.formatAt(index, length, name, value);\n    }\n  }\n\n  public optimize(context: { [key: string]: any }): void {\n    super.optimize(context);\n    const formats = this.formats();\n    if (Object.keys(formats).length === 0) {\n      return this.unwrap(); // unformatted span\n    }\n    const next = this.next;\n    if (\n      next instanceof InlineBlot &&\n      next.prev === this &&\n      isEqual(formats, next.formats())\n    ) {\n      next.moveChildren(this);\n      next.remove();\n    }\n  }\n\n  public replaceWith(name: string | Blot, value?: any): Blot {\n    const replacement = super.replaceWith(name, value) as InlineBlot;\n    this.attributes.copy(replacement);\n    return replacement;\n  }\n\n  public update(\n    mutations: MutationRecord[],\n    context: { [key: string]: any },\n  ): void {\n    super.update(mutations, context);\n    const attributeChanged = mutations.some(\n      (mutation) =>\n        mutation.target === this.domNode && mutation.type === 'attributes',\n    );\n    if (attributeChanged) {\n      this.attributes.build();\n    }\n  }\n\n  public wrap(name: string | Parent, value?: any): Parent {\n    const wrapper = super.wrap(name, value);\n    if (wrapper instanceof InlineBlot) {\n      this.attributes.move(wrapper);\n    }\n    return wrapper;\n  }\n}\n\nexport default InlineBlot;\n","import Attributor from '../attributor/attributor.js';\nimport AttributorStore from '../attributor/store.js';\nimport Scope from '../scope.js';\nimport type {\n  Blot,\n  BlotConstructor,\n  Formattable,\n  Root,\n} from './abstract/blot.js';\nimport LeafBlot from './abstract/leaf.js';\nimport ParentBlot from './abstract/parent.js';\nimport InlineBlot from './inline.js';\n\nclass BlockBlot extends ParentBlot implements Formattable {\n  public static blotName = 'block';\n  public static scope = Scope.BLOCK_BLOT;\n  public static tagName: string | string[] = 'P';\n  public static allowedChildren: BlotConstructor[] = [\n    InlineBlot,\n    BlockBlot,\n    LeafBlot,\n  ];\n\n  static create(value?: unknown) {\n    return super.create(value) as HTMLElement;\n  }\n\n  public static formats(domNode: HTMLElement, scroll: Root): any {\n    const match = scroll.query(BlockBlot.blotName);\n    if (\n      match != null &&\n      domNode.tagName === (match as BlotConstructor).tagName\n    ) {\n      return undefined;\n    } else if (typeof this.tagName === 'string') {\n      return true;\n    } else if (Array.isArray(this.tagName)) {\n      return domNode.tagName.toLowerCase();\n    }\n  }\n\n  protected attributes: AttributorStore;\n\n  constructor(scroll: Root, domNode: Node) {\n    super(scroll, domNode);\n    this.attributes = new AttributorStore(this.domNode);\n  }\n\n  public format(name: string, value: any): void {\n    const format = this.scroll.query(name, Scope.BLOCK);\n    if (format == null) {\n      return;\n    } else if (format instanceof Attributor) {\n      this.attributes.attribute(format, value);\n    } else if (name === this.statics.blotName && !value) {\n      this.replaceWith(BlockBlot.blotName);\n    } else if (\n      value &&\n      (name !== this.statics.blotName || this.formats()[name] !== value)\n    ) {\n      this.replaceWith(name, value);\n    }\n  }\n\n  public formats(): { [index: string]: any } {\n    const formats = this.attributes.values();\n    const format = this.statics.formats(this.domNode, this.scroll);\n    if (format != null) {\n      formats[this.statics.blotName] = format;\n    }\n    return formats;\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    if (this.scroll.query(name, Scope.BLOCK) != null) {\n      this.format(name, value);\n    } else {\n      super.formatAt(index, length, name, value);\n    }\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    if (def == null || this.scroll.query(value, Scope.INLINE) != null) {\n      // Insert text or inline\n      super.insertAt(index, value, def);\n    } else {\n      const after = this.split(index);\n      if (after != null) {\n        const blot = this.scroll.create(value, def);\n        after.parent.insertBefore(blot, after);\n      } else {\n        throw new Error('Attempt to insertAt after block boundaries');\n      }\n    }\n  }\n\n  public replaceWith(name: string | Blot, value?: any): Blot {\n    const replacement = super.replaceWith(name, value) as BlockBlot;\n    this.attributes.copy(replacement);\n    return replacement;\n  }\n\n  public update(\n    mutations: MutationRecord[],\n    context: { [key: string]: any },\n  ): void {\n    super.update(mutations, context);\n    const attributeChanged = mutations.some(\n      (mutation) =>\n        mutation.target === this.domNode && mutation.type === 'attributes',\n    );\n    if (attributeChanged) {\n      this.attributes.build();\n    }\n  }\n}\n\nexport default BlockBlot;\n","import Scope from '../../scope.js';\nimport BlockBlot from '../block.js';\nimport ParentBlot from './parent.js';\n\nclass ContainerBlot extends ParentBlot {\n  public static blotName = 'container';\n  public static scope = Scope.BLOCK_BLOT;\n  public static tagName: string | string[];\n\n  public prev!: BlockBlot | ContainerBlot | null;\n  public next!: BlockBlot | ContainerBlot | null;\n\n  public checkMerge(): boolean {\n    return (\n      this.next !== null && this.next.statics.blotName === this.statics.blotName\n    );\n  }\n\n  public deleteAt(index: number, length: number): void {\n    super.deleteAt(index, length);\n    this.enforceAllowedChildren();\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    super.formatAt(index, length, name, value);\n    this.enforceAllowedChildren();\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    super.insertAt(index, value, def);\n    this.enforceAllowedChildren();\n  }\n\n  public optimize(context: { [key: string]: any }): void {\n    super.optimize(context);\n    if (this.children.length > 0 && this.next != null && this.checkMerge()) {\n      this.next.moveChildren(this);\n      this.next.remove();\n    }\n  }\n}\n\nexport default ContainerBlot;\n","import type { Formattable, Root } from './abstract/blot.js';\nimport LeafBlot from './abstract/leaf.js';\n\nclass EmbedBlot extends LeafBlot implements Formattable {\n  public static formats(_domNode: HTMLElement, _scroll: Root): any {\n    return undefined;\n  }\n\n  public format(name: string, value: any): void {\n    // super.formatAt wraps, which is what we want in general,\n    // but this allows subclasses to overwrite for formats\n    // that just apply to particular embeds\n    super.formatAt(0, this.length(), name, value);\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    if (index === 0 && length === this.length()) {\n      this.format(name, value);\n    } else {\n      super.formatAt(index, length, name, value);\n    }\n  }\n\n  public formats(): { [index: string]: any } {\n    return this.statics.formats(this.domNode, this.scroll);\n  }\n}\n\nexport default EmbedBlot;\n","import Registry, { type RegistryDefinition } from '../registry.js';\nimport Scope from '../scope.js';\nimport type { Blot, BlotConstructor, Root } from './abstract/blot.js';\nimport ContainerBlot from './abstract/container.js';\nimport ParentBlot from './abstract/parent.js';\nimport BlockBlot from './block.js';\n\nconst OBSERVER_CONFIG = {\n  attributes: true,\n  characterData: true,\n  characterDataOldValue: true,\n  childList: true,\n  subtree: true,\n};\n\nconst MAX_OPTIMIZE_ITERATIONS = 100;\n\nclass ScrollBlot extends ParentBlot implements Root {\n  public static blotName = 'scroll';\n  public static defaultChild = BlockBlot;\n  public static allowedChildren: BlotConstructor[] = [BlockBlot, ContainerBlot];\n  public static scope = Scope.BLOCK_BLOT;\n  public static tagName = 'DIV';\n\n  public observer: MutationObserver;\n\n  constructor(\n    public registry: Registry,\n    node: HTMLDivElement,\n  ) {\n    // @ts-expect-error scroll is the root with no parent\n    super(null, node);\n    this.scroll = this;\n    this.build();\n    this.observer = new MutationObserver((mutations: MutationRecord[]) => {\n      this.update(mutations);\n    });\n    this.observer.observe(this.domNode, OBSERVER_CONFIG);\n    this.attach();\n  }\n\n  public create(input: Node | string | Scope, value?: any): Blot {\n    return this.registry.create(this, input, value);\n  }\n\n  public find(node: Node | null, bubble = false): Blot | null {\n    const blot = this.registry.find(node, bubble);\n    if (!blot) {\n      return null;\n    }\n    if (blot.scroll === this) {\n      return blot;\n    }\n    return bubble ? this.find(blot.scroll.domNode.parentNode, true) : null;\n  }\n\n  public query(\n    query: string | Node | Scope,\n    scope: Scope = Scope.ANY,\n  ): RegistryDefinition | null {\n    return this.registry.query(query, scope);\n  }\n\n  public register(...definitions: RegistryDefinition[]) {\n    return this.registry.register(...definitions);\n  }\n\n  public build(): void {\n    if (this.scroll == null) {\n      return;\n    }\n    super.build();\n  }\n\n  public detach(): void {\n    super.detach();\n    this.observer.disconnect();\n  }\n\n  public deleteAt(index: number, length: number): void {\n    this.update();\n    if (index === 0 && length === this.length()) {\n      this.children.forEach((child) => {\n        child.remove();\n      });\n    } else {\n      super.deleteAt(index, length);\n    }\n  }\n\n  public formatAt(\n    index: number,\n    length: number,\n    name: string,\n    value: any,\n  ): void {\n    this.update();\n    super.formatAt(index, length, name, value);\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    this.update();\n    super.insertAt(index, value, def);\n  }\n\n  public optimize(context?: { [key: string]: any }): void;\n  public optimize(\n    mutations: MutationRecord[],\n    context: { [key: string]: any },\n  ): void;\n  public optimize(mutations: any = [], context: any = {}): void {\n    super.optimize(context);\n    const mutationsMap = context.mutationsMap || new WeakMap();\n    // We must modify mutations directly, cannot make copy and then modify\n    let records = Array.from(this.observer.takeRecords());\n    // Array.push currently seems to be implemented by a non-tail recursive function\n    // so we cannot just mutations.push.apply(mutations, this.observer.takeRecords());\n    while (records.length > 0) {\n      mutations.push(records.pop());\n    }\n    const mark = (blot: Blot | null, markParent = true): void => {\n      if (blot == null || blot === this) {\n        return;\n      }\n      if (blot.domNode.parentNode == null) {\n        return;\n      }\n      if (!mutationsMap.has(blot.domNode)) {\n        mutationsMap.set(blot.domNode, []);\n      }\n      if (markParent) {\n        mark(blot.parent);\n      }\n    };\n    const optimize = (blot: Blot): void => {\n      // Post-order traversal\n      if (!mutationsMap.has(blot.domNode)) {\n        return;\n      }\n      if (blot instanceof ParentBlot) {\n        blot.children.forEach(optimize);\n      }\n      mutationsMap.delete(blot.domNode);\n      blot.optimize(context);\n    };\n    let remaining = mutations;\n    for (let i = 0; remaining.length > 0; i += 1) {\n      if (i >= MAX_OPTIMIZE_ITERATIONS) {\n        throw new Error('[Parchment] Maximum optimize iterations reached');\n      }\n      remaining.forEach((mutation: MutationRecord) => {\n        const blot = this.find(mutation.target, true);\n        if (blot == null) {\n          return;\n        }\n        if (blot.domNode === mutation.target) {\n          if (mutation.type === 'childList') {\n            mark(this.find(mutation.previousSibling, false));\n            Array.from(mutation.addedNodes).forEach((node: Node) => {\n              const child = this.find(node, false);\n              mark(child, false);\n              if (child instanceof ParentBlot) {\n                child.children.forEach((grandChild: Blot) => {\n                  mark(grandChild, false);\n                });\n              }\n            });\n          } else if (mutation.type === 'attributes') {\n            mark(blot.prev);\n          }\n        }\n        mark(blot);\n      });\n      this.children.forEach(optimize);\n      remaining = Array.from(this.observer.takeRecords());\n      records = remaining.slice();\n      while (records.length > 0) {\n        mutations.push(records.pop());\n      }\n    }\n  }\n\n  public update(\n    mutations?: MutationRecord[],\n    context: { [key: string]: any } = {},\n  ): void {\n    mutations = mutations || this.observer.takeRecords();\n    const mutationsMap = new WeakMap();\n    mutations\n      .map((mutation: MutationRecord) => {\n        const blot = this.find(mutation.target, true);\n        if (blot == null) {\n          return null;\n        }\n        if (mutationsMap.has(blot.domNode)) {\n          mutationsMap.get(blot.domNode).push(mutation);\n          return null;\n        } else {\n          mutationsMap.set(blot.domNode, [mutation]);\n          return blot;\n        }\n      })\n      .forEach((blot: Blot | null) => {\n        if (blot != null && blot !== this && mutationsMap.has(blot.domNode)) {\n          blot.update(mutationsMap.get(blot.domNode) || [], context);\n        }\n      });\n    context.mutationsMap = mutationsMap;\n    if (mutationsMap.has(this.domNode)) {\n      super.update(mutationsMap.get(this.domNode), context);\n    }\n    this.optimize(mutations, context);\n  }\n}\n\nexport default ScrollBlot;\n","import Scope from '../scope.js';\nimport type { Blot, Leaf, Root } from './abstract/blot.js';\nimport LeafBlot from './abstract/leaf.js';\n\nclass TextBlot extends LeafBlot implements Leaf {\n  public static readonly blotName = 'text';\n  public static scope = Scope.INLINE_BLOT;\n\n  public static create(value: string): Text {\n    return document.createTextNode(value);\n  }\n\n  public static value(domNode: Text): string {\n    return domNode.data;\n  }\n\n  public domNode!: Text;\n  protected text: string;\n\n  constructor(scroll: Root, node: Node) {\n    super(scroll, node);\n    this.text = this.statics.value(this.domNode);\n  }\n\n  public deleteAt(index: number, length: number): void {\n    this.domNode.data = this.text =\n      this.text.slice(0, index) + this.text.slice(index + length);\n  }\n\n  public index(node: Node, offset: number): number {\n    if (this.domNode === node) {\n      return offset;\n    }\n    return -1;\n  }\n\n  public insertAt(index: number, value: string, def?: any): void {\n    if (def == null) {\n      this.text = this.text.slice(0, index) + value + this.text.slice(index);\n      this.domNode.data = this.text;\n    } else {\n      super.insertAt(index, value, def);\n    }\n  }\n\n  public length(): number {\n    return this.text.length;\n  }\n\n  public optimize(context: { [key: string]: any }): void {\n    super.optimize(context);\n    this.text = this.statics.value(this.domNode);\n    if (this.text.length === 0) {\n      this.remove();\n    } else if (this.next instanceof TextBlot && this.next.prev === this) {\n      this.insertAt(this.length(), (this.next as TextBlot).value());\n      this.next.remove();\n    }\n  }\n\n  public position(index: number, _inclusive = false): [Node, number] {\n    return [this.domNode, index];\n  }\n\n  public split(index: number, force = false): Blot | null {\n    if (!force) {\n      if (index === 0) {\n        return this;\n      }\n      if (index === this.length()) {\n        return this.next;\n      }\n    }\n    const after = this.scroll.create(this.domNode.splitText(index));\n    this.parent.insertBefore(after, this.next || undefined);\n    this.text = this.statics.value(this.domNode);\n    return after;\n  }\n\n  public update(\n    mutations: MutationRecord[],\n    _context: { [key: string]: any },\n  ): void {\n    if (\n      mutations.some((mutation) => {\n        return (\n          mutation.type === 'characterData' && mutation.target === this.domNode\n        );\n      })\n    ) {\n      this.text = this.statics.value(this.domNode);\n    }\n  }\n\n  public value(): string {\n    return this.text;\n  }\n}\n\nexport default TextBlot;\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 */\nfunction 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\nexport default arrayEach;\n","import overArg from './_overArg.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nexport default nativeKeys;\n","import isPrototype from './_isPrototype.js';\nimport nativeKeys from './_nativeKeys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default baseKeys;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeys from './_baseKeys.js';\nimport isArrayLike from './isArrayLike.js';\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 */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nexport default keys;\n","import copyObject from './_copyObject.js';\nimport keys from './keys.js';\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 */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\n}\n\nexport default baseAssign;\n","import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\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 */\nfunction baseAssignIn(object, source) {\n  return object && copyObject(source, keysIn(source), object);\n}\n\nexport default baseAssignIn;\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 */\nfunction 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\nexport default arrayFilter;\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 */\nfunction stubArray() {\n  return [];\n}\n\nexport default stubArray;\n","import arrayFilter from './_arrayFilter.js';\nimport stubArray from './stubArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\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 */\nvar 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\nexport default getSymbols;\n","import copyObject from './_copyObject.js';\nimport getSymbols from './_getSymbols.js';\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 */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\n}\n\nexport default copySymbols;\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 */\nfunction 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\nexport default arrayPush;\n","import arrayPush from './_arrayPush.js';\nimport getPrototype from './_getPrototype.js';\nimport getSymbols from './_getSymbols.js';\nimport stubArray from './stubArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\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 */\nvar 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\nexport default getSymbolsIn;\n","import copyObject from './_copyObject.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\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 */\nfunction copySymbolsIn(source, object) {\n  return copyObject(source, getSymbolsIn(source), object);\n}\n\nexport default copySymbolsIn;\n","import arrayPush from './_arrayPush.js';\nimport isArray from './isArray.js';\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 */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n  var result = keysFunc(object);\n  return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nexport default baseGetAllKeys;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbols from './_getSymbols.js';\nimport keys from './keys.js';\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 */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\n}\n\nexport default getAllKeys;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\nimport keysIn from './keysIn.js';\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 */\nfunction getAllKeysIn(object) {\n  return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nexport default getAllKeysIn;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nexport default DataView;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nexport default Promise;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nexport default Set;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nexport default WeakMap;\n","import DataView from './_DataView.js';\nimport Map from './_Map.js';\nimport Promise from './_Promise.js';\nimport Set from './_Set.js';\nimport WeakMap from './_WeakMap.js';\nimport baseGetTag from './_baseGetTag.js';\nimport toSource from './_toSource.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    objectTag = '[object Object]',\n    promiseTag = '[object Promise]',\n    setTag = '[object Set]',\n    weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n    mapCtorString = toSource(Map),\n    promiseCtorString = toSource(Promise),\n    setCtorString = toSource(Set),\n    weakMapCtorString = toSource(WeakMap);\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 */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((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\nexport default getTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default initCloneArray;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\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 */\nfunction cloneDataView(dataView, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n  return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nexport default cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\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 */\nfunction cloneRegExp(regexp) {\n  var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n  result.lastIndex = regexp.lastIndex;\n  return result;\n}\n\nexport default cloneRegExp;\n","import Symbol from './_Symbol.js';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\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 */\nfunction cloneSymbol(symbol) {\n  return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nexport default cloneSymbol;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\nimport cloneDataView from './_cloneDataView.js';\nimport cloneRegExp from './_cloneRegExp.js';\nimport cloneSymbol from './_cloneSymbol.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar 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/**\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 */\nfunction 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\nexport default initCloneByTag;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\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 */\nfunction baseIsMap(value) {\n  return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nexport default baseIsMap;\n","import baseIsMap from './_baseIsMap.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\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 */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nexport default isMap;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\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 */\nfunction baseIsSet(value) {\n  return isObjectLike(value) && getTag(value) == setTag;\n}\n\nexport default baseIsSet;\n","import baseIsSet from './_baseIsSet.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\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 */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nexport default isSet;\n","import Stack from './_Stack.js';\nimport arrayEach from './_arrayEach.js';\nimport assignValue from './_assignValue.js';\nimport baseAssign from './_baseAssign.js';\nimport baseAssignIn from './_baseAssignIn.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport copyArray from './_copyArray.js';\nimport copySymbols from './_copySymbols.js';\nimport copySymbolsIn from './_copySymbolsIn.js';\nimport getAllKeys from './_getAllKeys.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\nimport getTag from './_getTag.js';\nimport initCloneArray from './_initCloneArray.js';\nimport initCloneByTag from './_initCloneByTag.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isMap from './isMap.js';\nimport isObject from './isObject.js';\nimport isSet from './isSet.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_FLAT_FLAG = 2,\n    CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]',\n    weakMapTag = '[object WeakMap]';\n\nvar 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 identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\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 */\nfunction 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\nexport default baseClone;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_SYMBOLS_FLAG = 4;\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 */\nfunction cloneDeep(value) {\n  return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nexport default cloneDeep;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\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 */\nfunction setCacheAdd(value) {\n  this.__data__.set(value, HASH_UNDEFINED);\n  return this;\n}\n\nexport default setCacheAdd;\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 */\nfunction setCacheHas(value) {\n  return this.__data__.has(value);\n}\n\nexport default setCacheHas;\n","import MapCache from './_MapCache.js';\nimport setCacheAdd from './_setCacheAdd.js';\nimport setCacheHas from './_setCacheHas.js';\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 */\nfunction 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// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nexport default SetCache;\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 */\nfunction 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\nexport default arraySome;\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 */\nfunction cacheHas(cache, key) {\n  return cache.has(key);\n}\n\nexport default cacheHas;\n","import SetCache from './_SetCache.js';\nimport arraySome from './_arraySome.js';\nimport cacheHas from './_cacheHas.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\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 */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      arrLength = array.length,\n      othLength = other.length;\n\n  if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n    return false;\n  }\n  // Check that cyclic values are equal.\n  var arrStacked = stack.get(array);\n  var othStacked = stack.get(other);\n  if (arrStacked && othStacked) {\n    return arrStacked == other && othStacked == array;\n  }\n  var index = -1,\n      result = true,\n      seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n  stack.set(array, other);\n  stack.set(other, array);\n\n  // Ignore non-index properties.\n  while (++index < arrLength) {\n    var arrValue = array[index],\n        othValue = other[index];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, arrValue, index, other, array, stack)\n        : customizer(arrValue, othValue, index, array, other, stack);\n    }\n    if (compared !== undefined) {\n      if (compared) {\n        continue;\n      }\n      result = false;\n      break;\n    }\n    // Recursively compare arrays (susceptible to call stack limits).\n    if (seen) {\n      if (!arraySome(other, function(othValue, othIndex) {\n            if (!cacheHas(seen, othIndex) &&\n                (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n              return seen.push(othIndex);\n            }\n          })) {\n        result = false;\n        break;\n      }\n    } else if (!(\n          arrValue === othValue ||\n            equalFunc(arrValue, othValue, bitmask, customizer, stack)\n        )) {\n      result = false;\n      break;\n    }\n  }\n  stack['delete'](array);\n  stack['delete'](other);\n  return result;\n}\n\nexport default equalArrays;\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 */\nfunction 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\nexport default mapToArray;\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 */\nfunction 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\nexport default setToArray;\n","import Symbol from './_Symbol.js';\nimport Uint8Array from './_Uint8Array.js';\nimport eq from './eq.js';\nimport equalArrays from './_equalArrays.js';\nimport mapToArray from './_mapToArray.js';\nimport setToArray from './_setToArray.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\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 */\nfunction 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\nexport default equalByTag;\n","import getAllKeys from './_getAllKeys.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      objProps = getAllKeys(object),\n      objLength = objProps.length,\n      othProps = getAllKeys(other),\n      othLength = othProps.length;\n\n  if (objLength != othLength && !isPartial) {\n    return false;\n  }\n  var index = objLength;\n  while (index--) {\n    var key = objProps[index];\n    if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n      return false;\n    }\n  }\n  // Check that cyclic values are equal.\n  var objStacked = stack.get(object);\n  var othStacked = stack.get(other);\n  if (objStacked && othStacked) {\n    return objStacked == other && othStacked == object;\n  }\n  var result = true;\n  stack.set(object, other);\n  stack.set(other, object);\n\n  var skipCtor = isPartial;\n  while (++index < objLength) {\n    key = objProps[index];\n    var objValue = object[key],\n        othValue = other[key];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, objValue, key, other, object, stack)\n        : customizer(objValue, othValue, key, object, other, stack);\n    }\n    // Recursively compare objects (susceptible to call stack limits).\n    if (!(compared === undefined\n          ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n          : compared\n        )) {\n      result = false;\n      break;\n    }\n    skipCtor || (skipCtor = key == 'constructor');\n  }\n  if (result && !skipCtor) {\n    var objCtor = object.constructor,\n        othCtor = other.constructor;\n\n    // Non `Object` object instances with different constructors are not equal.\n    if (objCtor != othCtor &&\n        ('constructor' in object && 'constructor' in other) &&\n        !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n          typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n      result = false;\n    }\n  }\n  stack['delete'](object);\n  stack['delete'](other);\n  return result;\n}\n\nexport default equalObjects;\n","import Stack from './_Stack.js';\nimport equalArrays from './_equalArrays.js';\nimport equalByTag from './_equalByTag.js';\nimport equalObjects from './_equalObjects.js';\nimport getTag from './_getTag.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\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 */\nfunction 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\nexport default baseIsEqualDeep;\n","import baseIsEqualDeep from './_baseIsEqualDeep.js';\nimport isObjectLike from './isObjectLike.js';\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 */\nfunction 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\nexport default baseIsEqual;\n","import baseIsEqual from './_baseIsEqual.js';\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 */\nfunction isEqual(value, other) {\n  return baseIsEqual(value, other);\n}\n\nexport default isEqual;\n","import { EmbedBlot } from 'parchment';\n\nclass Break extends EmbedBlot {\n  static value() {\n    return undefined;\n  }\n\n  optimize() {\n    if (this.prev || this.next) {\n      this.remove();\n    }\n  }\n\n  length() {\n    return 0;\n  }\n\n  value() {\n    return '';\n  }\n}\nBreak.blotName = 'break';\nBreak.tagName = 'BR';\n\nexport default Break;\n","import { TextBlot } from 'parchment';\n\nclass Text extends TextBlot {}\n\n// https://lodash.com/docs#escape\nconst entityMap: Record<string, string> = {\n  '&': '&amp;',\n  '<': '&lt;',\n  '>': '&gt;',\n  '\"': '&quot;',\n  \"'\": '&#39;',\n};\n\nfunction escapeText(text: string) {\n  return text.replace(/[&<>\"']/g, (s) => entityMap[s]);\n}\n\nexport { Text as default, escapeText };\n","import { EmbedBlot, InlineBlot, Scope } from 'parchment';\nimport type { BlotConstructor } from 'parchment';\nimport Break from './break.js';\nimport Text from './text.js';\n\nclass Inline extends InlineBlot {\n  static allowedChildren: BlotConstructor[] = [Inline, Break, EmbedBlot, Text];\n  // Lower index means deeper in the DOM tree, since not found (-1) is for embeds\n  static order = [\n    'cursor',\n    'inline', // Must be lower\n    'link', // Chrome wants <a> to be lower\n    'underline',\n    'strike',\n    'italic',\n    'bold',\n    'script',\n    'code', // Must be higher\n  ];\n\n  static compare(self: string, other: string) {\n    const selfIndex = Inline.order.indexOf(self);\n    const otherIndex = Inline.order.indexOf(other);\n    if (selfIndex >= 0 || otherIndex >= 0) {\n      return selfIndex - otherIndex;\n    }\n    if (self === other) {\n      return 0;\n    }\n    if (self < other) {\n      return -1;\n    }\n    return 1;\n  }\n\n  formatAt(index: number, length: number, name: string, value: unknown) {\n    if (\n      Inline.compare(this.statics.blotName, name) < 0 &&\n      this.scroll.query(name, Scope.BLOT)\n    ) {\n      const blot = this.isolate(index, length);\n      if (value) {\n        blot.wrap(name, value);\n      }\n    } else {\n      super.formatAt(index, length, name, value);\n    }\n  }\n\n  optimize(context: { [key: string]: any }) {\n    super.optimize(context);\n    if (\n      this.parent instanceof Inline &&\n      Inline.compare(this.statics.blotName, this.parent.statics.blotName) > 0\n    ) {\n      const parent = this.parent.isolate(this.offset(), this.length());\n      // @ts-expect-error TODO: make isolate generic\n      this.moveChildren(parent);\n      parent.wrap(this);\n    }\n  }\n}\n\nexport default Inline;\n","import {\n  AttributorStore,\n  BlockBlot,\n  EmbedBlot,\n  LeafBlot,\n  Scope,\n} from 'parchment';\nimport type { Blot, Parent } from 'parchment';\nimport Delta from 'quill-delta';\nimport Break from './break.js';\nimport Inline from './inline.js';\nimport TextBlot from './text.js';\n\nconst NEWLINE_LENGTH = 1;\n\nclass Block extends BlockBlot {\n  cache: { delta?: Delta | null; length?: number } = {};\n\n  delta(): Delta {\n    if (this.cache.delta == null) {\n      this.cache.delta = blockDelta(this);\n    }\n    return this.cache.delta;\n  }\n\n  deleteAt(index: number, length: number) {\n    super.deleteAt(index, length);\n    this.cache = {};\n  }\n\n  formatAt(index: number, length: number, name: string, value: unknown) {\n    if (length <= 0) return;\n    if (this.scroll.query(name, Scope.BLOCK)) {\n      if (index + length === this.length()) {\n        this.format(name, value);\n      }\n    } else {\n      super.formatAt(\n        index,\n        Math.min(length, this.length() - index - 1),\n        name,\n        value,\n      );\n    }\n    this.cache = {};\n  }\n\n  insertAt(index: number, value: string, def?: unknown) {\n    if (def != null) {\n      super.insertAt(index, value, def);\n      this.cache = {};\n      return;\n    }\n    if (value.length === 0) return;\n    const lines = value.split('\\n');\n    const text = lines.shift() as string;\n    if (text.length > 0) {\n      if (index < this.length() - 1 || this.children.tail == null) {\n        super.insertAt(Math.min(index, this.length() - 1), text);\n      } else {\n        this.children.tail.insertAt(this.children.tail.length(), text);\n      }\n      this.cache = {};\n    }\n    // TODO: Fix this next time the file is edited.\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    let block: Blot | this = this;\n    lines.reduce((lineIndex, line) => {\n      // @ts-expect-error Fix me later\n      block = block.split(lineIndex, true);\n      block.insertAt(0, line);\n      return line.length;\n    }, index + text.length);\n  }\n\n  insertBefore(blot: Blot, ref?: Blot | null) {\n    const { head } = this.children;\n    super.insertBefore(blot, ref);\n    if (head instanceof Break) {\n      head.remove();\n    }\n    this.cache = {};\n  }\n\n  length() {\n    if (this.cache.length == null) {\n      this.cache.length = super.length() + NEWLINE_LENGTH;\n    }\n    return this.cache.length;\n  }\n\n  moveChildren(target: Parent, ref?: Blot | null) {\n    super.moveChildren(target, ref);\n    this.cache = {};\n  }\n\n  optimize(context: { [key: string]: any }) {\n    super.optimize(context);\n    this.cache = {};\n  }\n\n  path(index: number) {\n    return super.path(index, true);\n  }\n\n  removeChild(child: Blot) {\n    super.removeChild(child);\n    this.cache = {};\n  }\n\n  split(index: number, force: boolean | undefined = false): Blot | null {\n    if (force && (index === 0 || index >= this.length() - NEWLINE_LENGTH)) {\n      const clone = this.clone();\n      if (index === 0) {\n        this.parent.insertBefore(clone, this);\n        return this;\n      }\n      this.parent.insertBefore(clone, this.next);\n      return clone;\n    }\n    const next = super.split(index, force);\n    this.cache = {};\n    return next;\n  }\n}\nBlock.blotName = 'block';\nBlock.tagName = 'P';\nBlock.defaultChild = Break;\nBlock.allowedChildren = [Break, Inline, EmbedBlot, TextBlot];\n\nclass BlockEmbed extends EmbedBlot {\n  attributes: AttributorStore;\n  domNode: HTMLElement;\n\n  attach() {\n    super.attach();\n    this.attributes = new AttributorStore(this.domNode);\n  }\n\n  delta() {\n    return new Delta().insert(this.value(), {\n      ...this.formats(),\n      ...this.attributes.values(),\n    });\n  }\n\n  format(name: string, value: unknown) {\n    const attribute = this.scroll.query(name, Scope.BLOCK_ATTRIBUTE);\n    if (attribute != null) {\n      // @ts-expect-error TODO: Scroll#query() should return Attributor when scope is attribute\n      this.attributes.attribute(attribute, value);\n    }\n  }\n\n  formatAt(index: number, length: number, name: string, value: unknown) {\n    this.format(name, value);\n  }\n\n  insertAt(index: number, value: string, def?: unknown) {\n    if (def != null) {\n      super.insertAt(index, value, def);\n      return;\n    }\n    const lines = value.split('\\n');\n    const text = lines.pop();\n    const blocks = lines.map((line) => {\n      const block = this.scroll.create(Block.blotName);\n      block.insertAt(0, line);\n      return block;\n    });\n    const ref = this.split(index);\n    blocks.forEach((block) => {\n      this.parent.insertBefore(block, ref);\n    });\n    if (text) {\n      this.parent.insertBefore(this.scroll.create('text', text), ref);\n    }\n  }\n}\nBlockEmbed.scope = Scope.BLOCK_BLOT;\n// It is important for cursor behavior BlockEmbeds use tags that are block level elements\n\nfunction blockDelta(blot: BlockBlot, filter = true) {\n  return blot\n    .descendants(LeafBlot)\n    .reduce((delta, leaf) => {\n      if (leaf.length() === 0) {\n        return delta;\n      }\n      return delta.insert(leaf.value(), bubbleFormats(leaf, {}, filter));\n    }, new Delta())\n    .insert('\\n', bubbleFormats(blot));\n}\n\nfunction bubbleFormats(\n  blot: Blot | null,\n  formats: Record<string, unknown> = {},\n  filter = true,\n): Record<string, unknown> {\n  if (blot == null) return formats;\n  if ('formats' in blot && typeof blot.formats === 'function') {\n    formats = {\n      ...formats,\n      ...blot.formats(),\n    };\n    if (filter) {\n      // exclude syntax highlighting from deltas and getFormat()\n      delete formats['code-token'];\n    }\n  }\n  if (\n    blot.parent == null ||\n    blot.parent.statics.blotName === 'scroll' ||\n    blot.parent.statics.scope !== blot.statics.scope\n  ) {\n    return formats;\n  }\n  return bubbleFormats(blot.parent, formats, filter);\n}\n\nexport { blockDelta, bubbleFormats, BlockEmbed, Block as default };\n","import { EmbedBlot, Scope } from 'parchment';\nimport type { Parent, ScrollBlot } from 'parchment';\nimport type Selection from '../core/selection.js';\nimport TextBlot from './text.js';\nimport type { EmbedContextRange } from './embed.js';\n\nclass Cursor extends EmbedBlot {\n  static blotName = 'cursor';\n  static className = 'ql-cursor';\n  static tagName = 'span';\n  static CONTENTS = '\\uFEFF'; // Zero width no break space\n\n  static value() {\n    return undefined;\n  }\n\n  selection: Selection;\n  textNode: Text;\n  savedLength: number;\n\n  constructor(scroll: ScrollBlot, domNode: HTMLElement, selection: Selection) {\n    super(scroll, domNode);\n    this.selection = selection;\n    this.textNode = document.createTextNode(Cursor.CONTENTS);\n    this.domNode.appendChild(this.textNode);\n    this.savedLength = 0;\n  }\n\n  detach() {\n    // super.detach() will also clear domNode.__blot\n    if (this.parent != null) this.parent.removeChild(this);\n  }\n\n  format(name: string, value: unknown) {\n    if (this.savedLength !== 0) {\n      super.format(name, value);\n      return;\n    }\n    // TODO: Fix this next time the file is edited.\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    let target: Parent | this = this;\n    let index = 0;\n    while (target != null && target.statics.scope !== Scope.BLOCK_BLOT) {\n      index += target.offset(target.parent);\n      target = target.parent;\n    }\n    if (target != null) {\n      this.savedLength = Cursor.CONTENTS.length;\n      // @ts-expect-error TODO: allow empty context in Parchment\n      target.optimize();\n      target.formatAt(index, Cursor.CONTENTS.length, name, value);\n      this.savedLength = 0;\n    }\n  }\n\n  index(node: Node, offset: number) {\n    if (node === this.textNode) return 0;\n    return super.index(node, offset);\n  }\n\n  length() {\n    return this.savedLength;\n  }\n\n  position(): [Text, number] {\n    return [this.textNode, this.textNode.data.length];\n  }\n\n  remove() {\n    super.remove();\n    // @ts-expect-error Fix me later\n    this.parent = null;\n  }\n\n  restore(): EmbedContextRange | null {\n    if (this.selection.composing || this.parent == null) return null;\n    const range = this.selection.getNativeRange();\n    // Browser may push down styles/nodes inside the cursor blot.\n    // https://dvcs.w3.org/hg/editing/raw-file/tip/editing.html#push-down-values\n    while (\n      this.domNode.lastChild != null &&\n      this.domNode.lastChild !== this.textNode\n    ) {\n      // @ts-expect-error Fix me later\n      this.domNode.parentNode.insertBefore(\n        this.domNode.lastChild,\n        this.domNode,\n      );\n    }\n\n    const prevTextBlot = this.prev instanceof TextBlot ? this.prev : null;\n    const prevTextLength = prevTextBlot ? prevTextBlot.length() : 0;\n    const nextTextBlot = this.next instanceof TextBlot ? this.next : null;\n    // @ts-expect-error TODO: make TextBlot.text public\n    const nextText = nextTextBlot ? nextTextBlot.text : '';\n    const { textNode } = this;\n    // take text from inside this blot and reset it\n    const newText = textNode.data.split(Cursor.CONTENTS).join('');\n    textNode.data = Cursor.CONTENTS;\n\n    // proactively merge TextBlots around cursor so that optimization\n    // doesn't lose the cursor.  the reason we are here in cursor.restore\n    // could be that the user clicked in prevTextBlot or nextTextBlot, or\n    // the user typed something.\n    let mergedTextBlot;\n    if (prevTextBlot) {\n      mergedTextBlot = prevTextBlot;\n      if (newText || nextTextBlot) {\n        prevTextBlot.insertAt(prevTextBlot.length(), newText + nextText);\n        if (nextTextBlot) {\n          nextTextBlot.remove();\n        }\n      }\n    } else if (nextTextBlot) {\n      mergedTextBlot = nextTextBlot;\n      nextTextBlot.insertAt(0, newText);\n    } else {\n      const newTextNode = document.createTextNode(newText);\n      mergedTextBlot = this.scroll.create(newTextNode);\n      this.parent.insertBefore(mergedTextBlot, this);\n    }\n\n    this.remove();\n    if (range) {\n      // calculate selection to restore\n      const remapOffset = (node: Node, offset: number) => {\n        if (prevTextBlot && node === prevTextBlot.domNode) {\n          return offset;\n        }\n        if (node === textNode) {\n          return prevTextLength + offset - 1;\n        }\n        if (nextTextBlot && node === nextTextBlot.domNode) {\n          return prevTextLength + newText.length + offset;\n        }\n        return null;\n      };\n\n      const start = remapOffset(range.start.node, range.start.offset);\n      const end = remapOffset(range.end.node, range.end.offset);\n      if (start !== null && end !== null) {\n        return {\n          startNode: mergedTextBlot.domNode,\n          startOffset: start,\n          endNode: mergedTextBlot.domNode,\n          endOffset: end,\n        };\n      }\n    }\n    return null;\n  }\n\n  update(mutations: MutationRecord[], context: Record<string, unknown>) {\n    if (\n      mutations.some((mutation) => {\n        return (\n          mutation.type === 'characterData' && mutation.target === this.textNode\n        );\n      })\n    ) {\n      const range = this.restore();\n      if (range) context.range = range;\n    }\n  }\n\n  // Avoid .ql-cursor being a descendant of `<a/>`.\n  // The reason is Safari pushes down `<a/>` on text insertion.\n  // That will cause DOM nodes not sync with the model.\n  //\n  // For example ({I} is the caret), given the markup:\n  //    <a><span class=\"ql-cursor\">\\uFEFF{I}</span></a>\n  // When typing a char \"x\", `<a/>` will be pushed down inside the `<span>` first:\n  //    <span class=\"ql-cursor\"><a>\\uFEFF{I}</a></span>\n  // And then \"x\" will be inserted after `<a/>`:\n  //    <span class=\"ql-cursor\"><a>\\uFEFF</a>d{I}</span>\n  optimize(context?: unknown) {\n    // @ts-expect-error Fix me later\n    super.optimize(context);\n\n    let { parent } = this;\n    while (parent) {\n      if (parent.domNode.tagName === 'A') {\n        this.savedLength = Cursor.CONTENTS.length;\n        // @ts-expect-error TODO: make isolate generic\n        parent.isolate(this.offset(parent), this.length()).unwrap();\n        this.savedLength = 0;\n        break;\n      }\n      parent = parent.parent;\n    }\n  }\n\n  value() {\n    return '';\n  }\n}\n\nexport default Cursor;\n","import EventEmitter from './index.js'\n\nexport { EventEmitter }\nexport default EventEmitter\n","import type Quill from '../core.js';\n\nexport default new WeakMap<Node, Quill>();\n","const levels = ['error', 'warn', 'log', 'info'] as const;\nexport type DebugLevel = (typeof levels)[number];\nlet level: DebugLevel | false = 'warn';\n\nfunction debug(method: DebugLevel, ...args: unknown[]) {\n  if (level) {\n    if (levels.indexOf(method) <= levels.indexOf(level)) {\n      console[method](...args); // eslint-disable-line no-console\n    }\n  }\n}\n\nfunction namespace(\n  ns: string,\n): Record<DebugLevel, (...args: unknown[]) => void> {\n  return levels.reduce(\n    (logger, method) => {\n      logger[method] = debug.bind(console, method, ns);\n      return logger;\n    },\n    {} as Record<DebugLevel, (...args: unknown[]) => void>,\n  );\n}\n\nnamespace.level = (newLevel: DebugLevel | false) => {\n  level = newLevel;\n};\ndebug.level = namespace.level;\n\nexport default namespace;\n","import { EventEmitter } from 'eventemitter3';\nimport instances from './instances.js';\nimport logger from './logger.js';\n\nconst debug = logger('quill:events');\nconst EVENTS = ['selectionchange', 'mousedown', 'mouseup', 'click'];\n\nEVENTS.forEach((eventName) => {\n  document.addEventListener(eventName, (...args) => {\n    Array.from(document.querySelectorAll('.ql-container')).forEach((node) => {\n      const quill = instances.get(node);\n      if (quill && quill.emitter) {\n        quill.emitter.handleDOM(...args);\n      }\n    });\n  });\n});\n\nclass Emitter extends EventEmitter<string> {\n  static events = {\n    EDITOR_CHANGE: 'editor-change',\n    SCROLL_BEFORE_UPDATE: 'scroll-before-update',\n    SCROLL_BLOT_MOUNT: 'scroll-blot-mount',\n    SCROLL_BLOT_UNMOUNT: 'scroll-blot-unmount',\n    SCROLL_OPTIMIZE: 'scroll-optimize',\n    SCROLL_UPDATE: 'scroll-update',\n    SCROLL_EMBED_UPDATE: 'scroll-embed-update',\n    SELECTION_CHANGE: 'selection-change',\n    TEXT_CHANGE: 'text-change',\n    COMPOSITION_BEFORE_START: 'composition-before-start',\n    COMPOSITION_START: 'composition-start',\n    COMPOSITION_BEFORE_END: 'composition-before-end',\n    COMPOSITION_END: 'composition-end',\n  } as const;\n\n  static sources = {\n    API: 'api',\n    SILENT: 'silent',\n    USER: 'user',\n  } as const;\n\n  protected domListeners: Record<string, { node: Node; handler: Function }[]>;\n\n  constructor() {\n    super();\n    this.domListeners = {};\n    this.on('error', debug.error);\n  }\n\n  emit(...args: unknown[]): boolean {\n    debug.log.call(debug, ...args);\n    // @ts-expect-error\n    return super.emit(...args);\n  }\n\n  handleDOM(event: Event, ...args: unknown[]) {\n    (this.domListeners[event.type] || []).forEach(({ node, handler }) => {\n      if (event.target === node || node.contains(event.target as Node)) {\n        handler(event, ...args);\n      }\n    });\n  }\n\n  listenDOM(eventName: string, node: Node, handler: EventListener) {\n    if (!this.domListeners[eventName]) {\n      this.domListeners[eventName] = [];\n    }\n    this.domListeners[eventName].push({ node, handler });\n  }\n}\n\nexport type EmitterSource =\n  (typeof Emitter.sources)[keyof typeof Emitter.sources];\n\nexport default Emitter;\n","import { LeafBlot, Scope } from 'parchment';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport Emitter from './emitter.js';\nimport type { EmitterSource } from './emitter.js';\nimport logger from './logger.js';\nimport type Cursor from '../blots/cursor.js';\nimport type Scroll from '../blots/scroll.js';\n\nconst debug = logger('quill:selection');\n\ntype NativeRange = AbstractRange;\n\ninterface NormalizedRange {\n  start: {\n    node: NativeRange['startContainer'];\n    offset: NativeRange['startOffset'];\n  };\n  end: { node: NativeRange['endContainer']; offset: NativeRange['endOffset'] };\n  native: NativeRange;\n}\n\nexport interface Bounds {\n  bottom: number;\n  height: number;\n  left: number;\n  right: number;\n  top: number;\n  width: number;\n}\n\nexport class Range {\n  constructor(\n    public index: number,\n    public length = 0,\n  ) {}\n}\n\nclass Selection {\n  scroll: Scroll;\n  emitter: Emitter;\n  composing: boolean;\n  mouseDown: boolean;\n\n  root: HTMLElement;\n  cursor: Cursor;\n  savedRange: Range;\n  lastRange: Range | null;\n  lastNative: NormalizedRange | null;\n\n  constructor(scroll: Scroll, emitter: Emitter) {\n    this.emitter = emitter;\n    this.scroll = scroll;\n    this.composing = false;\n    this.mouseDown = false;\n    this.root = this.scroll.domNode;\n    // @ts-expect-error\n    this.cursor = this.scroll.create('cursor', this);\n    // savedRange is last non-null range\n    this.savedRange = new Range(0, 0);\n    this.lastRange = this.savedRange;\n    this.lastNative = null;\n    this.handleComposition();\n    this.handleDragging();\n    this.emitter.listenDOM('selectionchange', document, () => {\n      if (!this.mouseDown && !this.composing) {\n        setTimeout(this.update.bind(this, Emitter.sources.USER), 1);\n      }\n    });\n    this.emitter.on(Emitter.events.SCROLL_BEFORE_UPDATE, () => {\n      if (!this.hasFocus()) return;\n      const native = this.getNativeRange();\n      if (native == null) return;\n      if (native.start.node === this.cursor.textNode) return; // cursor.restore() will handle\n      this.emitter.once(\n        Emitter.events.SCROLL_UPDATE,\n        (source, mutations: MutationRecord[]) => {\n          try {\n            if (\n              this.root.contains(native.start.node) &&\n              this.root.contains(native.end.node)\n            ) {\n              this.setNativeRange(\n                native.start.node,\n                native.start.offset,\n                native.end.node,\n                native.end.offset,\n              );\n            }\n            const triggeredByTyping = mutations.some(\n              (mutation) =>\n                mutation.type === 'characterData' ||\n                mutation.type === 'childList' ||\n                (mutation.type === 'attributes' &&\n                  mutation.target === this.root),\n            );\n            this.update(triggeredByTyping ? Emitter.sources.SILENT : source);\n          } catch (ignored) {\n            // ignore\n          }\n        },\n      );\n    });\n    this.emitter.on(Emitter.events.SCROLL_OPTIMIZE, (mutations, context) => {\n      if (context.range) {\n        const { startNode, startOffset, endNode, endOffset } = context.range;\n        this.setNativeRange(startNode, startOffset, endNode, endOffset);\n        this.update(Emitter.sources.SILENT);\n      }\n    });\n    this.update(Emitter.sources.SILENT);\n  }\n\n  handleComposition() {\n    this.emitter.on(Emitter.events.COMPOSITION_BEFORE_START, () => {\n      this.composing = true;\n    });\n    this.emitter.on(Emitter.events.COMPOSITION_END, () => {\n      this.composing = false;\n      if (this.cursor.parent) {\n        const range = this.cursor.restore();\n        if (!range) return;\n        setTimeout(() => {\n          this.setNativeRange(\n            range.startNode,\n            range.startOffset,\n            range.endNode,\n            range.endOffset,\n          );\n        }, 1);\n      }\n    });\n  }\n\n  handleDragging() {\n    this.emitter.listenDOM('mousedown', document.body, () => {\n      this.mouseDown = true;\n    });\n    this.emitter.listenDOM('mouseup', document.body, () => {\n      this.mouseDown = false;\n      this.update(Emitter.sources.USER);\n    });\n  }\n\n  focus() {\n    if (this.hasFocus()) return;\n    this.root.focus({ preventScroll: true });\n    this.setRange(this.savedRange);\n  }\n\n  format(format: string, value: unknown) {\n    this.scroll.update();\n    const nativeRange = this.getNativeRange();\n    if (\n      nativeRange == null ||\n      !nativeRange.native.collapsed ||\n      this.scroll.query(format, Scope.BLOCK)\n    )\n      return;\n    if (nativeRange.start.node !== this.cursor.textNode) {\n      const blot = this.scroll.find(nativeRange.start.node, false);\n      if (blot == null) return;\n      // TODO Give blot ability to not split\n      if (blot instanceof LeafBlot) {\n        const after = blot.split(nativeRange.start.offset);\n        blot.parent.insertBefore(this.cursor, after);\n      } else {\n        // @ts-expect-error TODO: nativeRange.start.node doesn't seem to match function signature\n        blot.insertBefore(this.cursor, nativeRange.start.node); // Should never happen\n      }\n      this.cursor.attach();\n    }\n    this.cursor.format(format, value);\n    this.scroll.optimize();\n    this.setNativeRange(this.cursor.textNode, this.cursor.textNode.data.length);\n    this.update();\n  }\n\n  getBounds(index: number, length = 0) {\n    const scrollLength = this.scroll.length();\n    index = Math.min(index, scrollLength - 1);\n    length = Math.min(index + length, scrollLength - 1) - index;\n    let node: Node;\n    let [leaf, offset] = this.scroll.leaf(index);\n    if (leaf == null) return null;\n    if (length > 0 && offset === leaf.length()) {\n      const [next] = this.scroll.leaf(index + 1);\n      if (next) {\n        const [line] = this.scroll.line(index);\n        const [nextLine] = this.scroll.line(index + 1);\n        if (line === nextLine) {\n          leaf = next;\n          offset = 0;\n        }\n      }\n    }\n    [node, offset] = leaf.position(offset, true);\n    const range = document.createRange();\n    if (length > 0) {\n      range.setStart(node, offset);\n      [leaf, offset] = this.scroll.leaf(index + length);\n      if (leaf == null) return null;\n      [node, offset] = leaf.position(offset, true);\n      range.setEnd(node, offset);\n      return range.getBoundingClientRect();\n    }\n    let side: 'left' | 'right' = 'left';\n    let rect: DOMRect;\n    if (node instanceof Text) {\n      // Return null if the text node is empty because it is\n      // not able to get a useful client rect:\n      // https://github.com/w3c/csswg-drafts/issues/2514.\n      // Empty text nodes are most likely caused by TextBlot#optimize()\n      // not getting called when editor content changes.\n      if (!node.data.length) {\n        return null;\n      }\n      if (offset < node.data.length) {\n        range.setStart(node, offset);\n        range.setEnd(node, offset + 1);\n      } else {\n        range.setStart(node, offset - 1);\n        range.setEnd(node, offset);\n        side = 'right';\n      }\n      rect = range.getBoundingClientRect();\n    } else {\n      if (!(leaf.domNode instanceof Element)) return null;\n      rect = leaf.domNode.getBoundingClientRect();\n      if (offset > 0) side = 'right';\n    }\n    return {\n      bottom: rect.top + rect.height,\n      height: rect.height,\n      left: rect[side],\n      right: rect[side],\n      top: rect.top,\n      width: 0,\n    };\n  }\n\n  getNativeRange(): NormalizedRange | null {\n    const selection = document.getSelection();\n    if (selection == null || selection.rangeCount <= 0) return null;\n    const nativeRange = selection.getRangeAt(0);\n    if (nativeRange == null) return null;\n    const range = this.normalizeNative(nativeRange);\n    debug.info('getNativeRange', range);\n    return range;\n  }\n\n  getRange(): [Range, NormalizedRange] | [null, null] {\n    const root = this.scroll.domNode;\n    if ('isConnected' in root && !root.isConnected) {\n      // document.getSelection() forces layout on Blink, so we trend to\n      // not calling it.\n      return [null, null];\n    }\n    const normalized = this.getNativeRange();\n    if (normalized == null) return [null, null];\n    const range = this.normalizedToRange(normalized);\n    return [range, normalized];\n  }\n\n  hasFocus(): boolean {\n    return (\n      document.activeElement === this.root ||\n      (document.activeElement != null &&\n        contains(this.root, document.activeElement))\n    );\n  }\n\n  normalizedToRange(range: NormalizedRange) {\n    const positions: [Node, number][] = [\n      [range.start.node, range.start.offset],\n    ];\n    if (!range.native.collapsed) {\n      positions.push([range.end.node, range.end.offset]);\n    }\n    const indexes = positions.map((position) => {\n      const [node, offset] = position;\n      const blot = this.scroll.find(node, true);\n      // @ts-expect-error Fix me later\n      const index = blot.offset(this.scroll);\n      if (offset === 0) {\n        return index;\n      }\n      if (blot instanceof LeafBlot) {\n        return index + blot.index(node, offset);\n      }\n      // @ts-expect-error Fix me later\n      return index + blot.length();\n    });\n    const end = Math.min(Math.max(...indexes), this.scroll.length() - 1);\n    const start = Math.min(end, ...indexes);\n    return new Range(start, end - start);\n  }\n\n  normalizeNative(nativeRange: NativeRange) {\n    if (\n      !contains(this.root, nativeRange.startContainer) ||\n      (!nativeRange.collapsed && !contains(this.root, nativeRange.endContainer))\n    ) {\n      return null;\n    }\n    const range = {\n      start: {\n        node: nativeRange.startContainer,\n        offset: nativeRange.startOffset,\n      },\n      end: { node: nativeRange.endContainer, offset: nativeRange.endOffset },\n      native: nativeRange,\n    };\n    [range.start, range.end].forEach((position) => {\n      let { node, offset } = position;\n      while (!(node instanceof Text) && node.childNodes.length > 0) {\n        if (node.childNodes.length > offset) {\n          node = node.childNodes[offset];\n          offset = 0;\n        } else if (node.childNodes.length === offset) {\n          // @ts-expect-error Fix me later\n          node = node.lastChild;\n          if (node instanceof Text) {\n            offset = node.data.length;\n          } else if (node.childNodes.length > 0) {\n            // Container case\n            offset = node.childNodes.length;\n          } else {\n            // Embed case\n            offset = node.childNodes.length + 1;\n          }\n        } else {\n          break;\n        }\n      }\n      position.node = node;\n      position.offset = offset;\n    });\n    return range;\n  }\n\n  rangeToNative(range: Range): [Node | null, number, Node | null, number] {\n    const scrollLength = this.scroll.length();\n\n    const getPosition = (\n      index: number,\n      inclusive: boolean,\n    ): [Node | null, number] => {\n      index = Math.min(scrollLength - 1, index);\n      const [leaf, leafOffset] = this.scroll.leaf(index);\n      return leaf ? leaf.position(leafOffset, inclusive) : [null, -1];\n    };\n    return [\n      ...getPosition(range.index, false),\n      ...getPosition(range.index + range.length, true),\n    ];\n  }\n\n  setNativeRange(\n    startNode: Node | null,\n    startOffset?: number,\n    endNode = startNode,\n    endOffset = startOffset,\n    force = false,\n  ) {\n    debug.info('setNativeRange', startNode, startOffset, endNode, endOffset);\n    if (\n      startNode != null &&\n      (this.root.parentNode == null ||\n        startNode.parentNode == null ||\n        // @ts-expect-error Fix me later\n        endNode.parentNode == null)\n    ) {\n      return;\n    }\n    const selection = document.getSelection();\n    if (selection == null) return;\n    if (startNode != null) {\n      if (!this.hasFocus()) this.root.focus({ preventScroll: true });\n      const { native } = this.getNativeRange() || {};\n      if (\n        native == null ||\n        force ||\n        startNode !== native.startContainer ||\n        startOffset !== native.startOffset ||\n        endNode !== native.endContainer ||\n        endOffset !== native.endOffset\n      ) {\n        if (startNode instanceof Element && startNode.tagName === 'BR') {\n          // @ts-expect-error Fix me later\n          startOffset = Array.from(startNode.parentNode.childNodes).indexOf(\n            startNode,\n          );\n          startNode = startNode.parentNode;\n        }\n        if (endNode instanceof Element && endNode.tagName === 'BR') {\n          // @ts-expect-error Fix me later\n          endOffset = Array.from(endNode.parentNode.childNodes).indexOf(\n            endNode,\n          );\n          endNode = endNode.parentNode;\n        }\n        const range = document.createRange();\n        // @ts-expect-error Fix me later\n        range.setStart(startNode, startOffset);\n        // @ts-expect-error Fix me later\n        range.setEnd(endNode, endOffset);\n        selection.removeAllRanges();\n        selection.addRange(range);\n      }\n    } else {\n      selection.removeAllRanges();\n      this.root.blur();\n    }\n  }\n\n  setRange(range: Range | null, force: boolean, source?: EmitterSource): void;\n  setRange(range: Range | null, source?: EmitterSource): void;\n  setRange(\n    range: Range | null,\n    force: boolean | EmitterSource = false,\n    source: EmitterSource = Emitter.sources.API,\n  ): void {\n    if (typeof force === 'string') {\n      source = force;\n      force = false;\n    }\n    debug.info('setRange', range);\n    if (range != null) {\n      const args = this.rangeToNative(range);\n      this.setNativeRange(...args, force);\n    } else {\n      this.setNativeRange(null);\n    }\n    this.update(source);\n  }\n\n  update(source: EmitterSource = Emitter.sources.USER) {\n    const oldRange = this.lastRange;\n    const [lastRange, nativeRange] = this.getRange();\n    this.lastRange = lastRange;\n    this.lastNative = nativeRange;\n    if (this.lastRange != null) {\n      this.savedRange = this.lastRange;\n    }\n    if (!isEqual(oldRange, this.lastRange)) {\n      if (\n        !this.composing &&\n        nativeRange != null &&\n        nativeRange.native.collapsed &&\n        nativeRange.start.node !== this.cursor.textNode\n      ) {\n        const range = this.cursor.restore();\n        if (range) {\n          this.setNativeRange(\n            range.startNode,\n            range.startOffset,\n            range.endNode,\n            range.endOffset,\n          );\n        }\n      }\n      const args = [\n        Emitter.events.SELECTION_CHANGE,\n        cloneDeep(this.lastRange),\n        cloneDeep(oldRange),\n        source,\n      ];\n      this.emitter.emit(Emitter.events.EDITOR_CHANGE, ...args);\n      if (source !== Emitter.sources.SILENT) {\n        this.emitter.emit(...args);\n      }\n    }\n  }\n}\n\nfunction contains(parent: Node, descendant: Node) {\n  try {\n    // Firefox inserts inaccessible nodes around video elements\n    descendant.parentNode; // eslint-disable-line @typescript-eslint/no-unused-expressions\n  } catch (e) {\n    return false;\n  }\n  return parent.contains(descendant);\n}\n\nexport default Selection;\n","import { cloneDeep, isEqual, merge } from 'lodash-es';\nimport { LeafBlot, EmbedBlot, Scope, ParentBlot } from 'parchment';\nimport type { Blot } from 'parchment';\nimport Delta, { AttributeMap, Op } from 'quill-delta';\nimport Block, { BlockEmbed, bubbleFormats } from '../blots/block.js';\nimport Break from '../blots/break.js';\nimport CursorBlot from '../blots/cursor.js';\nimport type Scroll from '../blots/scroll.js';\nimport TextBlot, { escapeText } from '../blots/text.js';\nimport { Range } from './selection.js';\n\nconst ASCII = /^[ -~]*$/;\n\ntype SelectionInfo = {\n  newRange: Range;\n  oldRange: Range;\n};\n\nclass Editor {\n  scroll: Scroll;\n  delta: Delta;\n\n  constructor(scroll: Scroll) {\n    this.scroll = scroll;\n    this.delta = this.getDelta();\n  }\n\n  applyDelta(delta: Delta): Delta {\n    this.scroll.update();\n    let scrollLength = this.scroll.length();\n    this.scroll.batchStart();\n    const normalizedDelta = normalizeDelta(delta);\n    const deleteDelta = new Delta();\n    const normalizedOps = splitOpLines(normalizedDelta.ops.slice());\n    normalizedOps.reduce((index, op) => {\n      const length = Op.length(op);\n      let attributes = op.attributes || {};\n      let isImplicitNewlinePrepended = false;\n      let isImplicitNewlineAppended = false;\n      if (op.insert != null) {\n        deleteDelta.retain(length);\n        if (typeof op.insert === 'string') {\n          const text = op.insert;\n          isImplicitNewlineAppended =\n            !text.endsWith('\\n') &&\n            (scrollLength <= index ||\n              !!this.scroll.descendant(BlockEmbed, index)[0]);\n          this.scroll.insertAt(index, text);\n          const [line, offset] = this.scroll.line(index);\n          let formats = merge({}, bubbleFormats(line));\n          if (line instanceof Block) {\n            const [leaf] = line.descendant(LeafBlot, offset);\n            if (leaf) {\n              formats = merge(formats, bubbleFormats(leaf));\n            }\n          }\n          attributes = AttributeMap.diff(formats, attributes) || {};\n        } else if (typeof op.insert === 'object') {\n          const key = Object.keys(op.insert)[0]; // There should only be one key\n          if (key == null) return index;\n          const isInlineEmbed = this.scroll.query(key, Scope.INLINE) != null;\n          if (isInlineEmbed) {\n            if (\n              scrollLength <= index ||\n              !!this.scroll.descendant(BlockEmbed, index)[0]\n            ) {\n              isImplicitNewlineAppended = true;\n            }\n          } else if (index > 0) {\n            const [leaf, offset] = this.scroll.descendant(LeafBlot, index - 1);\n            if (leaf instanceof TextBlot) {\n              const text = leaf.value();\n              if (text[offset] !== '\\n') {\n                isImplicitNewlinePrepended = true;\n              }\n            } else if (\n              leaf instanceof EmbedBlot &&\n              leaf.statics.scope === Scope.INLINE_BLOT\n            ) {\n              isImplicitNewlinePrepended = true;\n            }\n          }\n          this.scroll.insertAt(index, key, op.insert[key]);\n\n          if (isInlineEmbed) {\n            const [leaf] = this.scroll.descendant(LeafBlot, index);\n            if (leaf) {\n              const formats = merge({}, bubbleFormats(leaf));\n              attributes = AttributeMap.diff(formats, attributes) || {};\n            }\n          }\n        }\n        scrollLength += length;\n      } else {\n        deleteDelta.push(op);\n\n        if (op.retain !== null && typeof op.retain === 'object') {\n          const key = Object.keys(op.retain)[0];\n          if (key == null) return index;\n          this.scroll.updateEmbedAt(index, key, op.retain[key]);\n        }\n      }\n      Object.keys(attributes).forEach((name) => {\n        this.scroll.formatAt(index, length, name, attributes[name]);\n      });\n      const prependedLength = isImplicitNewlinePrepended ? 1 : 0;\n      const addedLength = isImplicitNewlineAppended ? 1 : 0;\n      scrollLength += prependedLength + addedLength;\n      deleteDelta.retain(prependedLength);\n      deleteDelta.delete(addedLength);\n      return index + length + prependedLength + addedLength;\n    }, 0);\n    deleteDelta.reduce((index, op) => {\n      if (typeof op.delete === 'number') {\n        this.scroll.deleteAt(index, op.delete);\n        return index;\n      }\n      return index + Op.length(op);\n    }, 0);\n    this.scroll.batchEnd();\n    this.scroll.optimize();\n    return this.update(normalizedDelta);\n  }\n\n  deleteText(index: number, length: number): Delta {\n    this.scroll.deleteAt(index, length);\n    return this.update(new Delta().retain(index).delete(length));\n  }\n\n  formatLine(\n    index: number,\n    length: number,\n    formats: Record<string, unknown> = {},\n  ): Delta {\n    this.scroll.update();\n    Object.keys(formats).forEach((format) => {\n      this.scroll.lines(index, Math.max(length, 1)).forEach((line) => {\n        line.format(format, formats[format]);\n      });\n    });\n    this.scroll.optimize();\n    const delta = new Delta().retain(index).retain(length, cloneDeep(formats));\n    return this.update(delta);\n  }\n\n  formatText(\n    index: number,\n    length: number,\n    formats: Record<string, unknown> = {},\n  ): Delta {\n    Object.keys(formats).forEach((format) => {\n      this.scroll.formatAt(index, length, format, formats[format]);\n    });\n    const delta = new Delta().retain(index).retain(length, cloneDeep(formats));\n    return this.update(delta);\n  }\n\n  getContents(index: number, length: number): Delta {\n    return this.delta.slice(index, index + length);\n  }\n\n  getDelta(): Delta {\n    return this.scroll.lines().reduce((delta, line) => {\n      return delta.concat(line.delta());\n    }, new Delta());\n  }\n\n  getFormat(index: number, length = 0): Record<string, unknown> {\n    let lines: (Block | BlockEmbed)[] = [];\n    let leaves: LeafBlot[] = [];\n    if (length === 0) {\n      this.scroll.path(index).forEach((path) => {\n        const [blot] = path;\n        if (blot instanceof Block) {\n          lines.push(blot);\n        } else if (blot instanceof LeafBlot) {\n          leaves.push(blot);\n        }\n      });\n    } else {\n      lines = this.scroll.lines(index, length);\n      leaves = this.scroll.descendants(LeafBlot, index, length);\n    }\n    const [lineFormats, leafFormats] = [lines, leaves].map((blots) => {\n      const blot = blots.shift();\n      if (blot == null) return {};\n      let formats = bubbleFormats(blot);\n      while (Object.keys(formats).length > 0) {\n        const blot = blots.shift();\n        if (blot == null) return formats;\n        formats = combineFormats(bubbleFormats(blot), formats);\n      }\n      return formats;\n    });\n    return { ...lineFormats, ...leafFormats };\n  }\n\n  getHTML(index: number, length: number): string {\n    const [line, lineOffset] = this.scroll.line(index);\n    if (line) {\n      const lineLength = line.length();\n      const isWithinLine = line.length() >= lineOffset + length;\n      if (isWithinLine && !(lineOffset === 0 && length === lineLength)) {\n        return convertHTML(line, lineOffset, length, true);\n      }\n      return convertHTML(this.scroll, index, length, true);\n    }\n    return '';\n  }\n\n  getText(index: number, length: number): string {\n    return this.getContents(index, length)\n      .filter((op) => typeof op.insert === 'string')\n      .map((op) => op.insert)\n      .join('');\n  }\n\n  insertContents(index: number, contents: Delta): Delta {\n    const normalizedDelta = normalizeDelta(contents);\n    const change = new Delta().retain(index).concat(normalizedDelta);\n    this.scroll.insertContents(index, normalizedDelta);\n    return this.update(change);\n  }\n\n  insertEmbed(index: number, embed: string, value: unknown): Delta {\n    this.scroll.insertAt(index, embed, value);\n    return this.update(new Delta().retain(index).insert({ [embed]: value }));\n  }\n\n  insertText(\n    index: number,\n    text: string,\n    formats: Record<string, unknown> = {},\n  ): Delta {\n    text = text.replace(/\\r\\n/g, '\\n').replace(/\\r/g, '\\n');\n    this.scroll.insertAt(index, text);\n    Object.keys(formats).forEach((format) => {\n      this.scroll.formatAt(index, text.length, format, formats[format]);\n    });\n    return this.update(\n      new Delta().retain(index).insert(text, cloneDeep(formats)),\n    );\n  }\n\n  isBlank(): boolean {\n    if (this.scroll.children.length === 0) return true;\n    if (this.scroll.children.length > 1) return false;\n    const blot = this.scroll.children.head;\n    if (blot?.statics.blotName !== Block.blotName) return false;\n    const block = blot as Block;\n    if (block.children.length > 1) return false;\n    return block.children.head instanceof Break;\n  }\n\n  removeFormat(index: number, length: number): Delta {\n    const text = this.getText(index, length);\n    const [line, offset] = this.scroll.line(index + length);\n    let suffixLength = 0;\n    let suffix = new Delta();\n    if (line != null) {\n      suffixLength = line.length() - offset;\n      suffix = line\n        .delta()\n        .slice(offset, offset + suffixLength - 1)\n        .insert('\\n');\n    }\n    const contents = this.getContents(index, length + suffixLength);\n    const diff = contents.diff(new Delta().insert(text).concat(suffix));\n    const delta = new Delta().retain(index).concat(diff);\n    return this.applyDelta(delta);\n  }\n\n  update(\n    change: Delta | null,\n    mutations: MutationRecord[] = [],\n    selectionInfo: SelectionInfo | undefined = undefined,\n  ): Delta {\n    const oldDelta = this.delta;\n    if (\n      mutations.length === 1 &&\n      mutations[0].type === 'characterData' &&\n      // @ts-expect-error Fix me later\n      mutations[0].target.data.match(ASCII) &&\n      this.scroll.find(mutations[0].target)\n    ) {\n      // Optimization for character changes\n      const textBlot = this.scroll.find(mutations[0].target) as Blot;\n      const formats = bubbleFormats(textBlot);\n      const index = textBlot.offset(this.scroll);\n      // @ts-expect-error Fix me later\n      const oldValue = mutations[0].oldValue.replace(CursorBlot.CONTENTS, '');\n      const oldText = new Delta().insert(oldValue);\n      // @ts-expect-error\n      const newText = new Delta().insert(textBlot.value());\n      const relativeSelectionInfo = selectionInfo && {\n        oldRange: shiftRange(selectionInfo.oldRange, -index),\n        newRange: shiftRange(selectionInfo.newRange, -index),\n      };\n      const diffDelta = new Delta()\n        .retain(index)\n        .concat(oldText.diff(newText, relativeSelectionInfo));\n      change = diffDelta.reduce((delta, op) => {\n        if (op.insert) {\n          return delta.insert(op.insert, formats);\n        }\n        return delta.push(op);\n      }, new Delta());\n      this.delta = oldDelta.compose(change);\n    } else {\n      this.delta = this.getDelta();\n      if (!change || !isEqual(oldDelta.compose(change), this.delta)) {\n        change = oldDelta.diff(this.delta, selectionInfo);\n      }\n    }\n    return change;\n  }\n}\n\ninterface ListItem {\n  child: Blot;\n  offset: number;\n  length: number;\n  indent: number;\n  type: string;\n}\nfunction convertListHTML(\n  items: ListItem[],\n  lastIndent: number,\n  types: string[],\n): string {\n  if (items.length === 0) {\n    const [endTag] = getListType(types.pop());\n    if (lastIndent <= 0) {\n      return `</li></${endTag}>`;\n    }\n    return `</li></${endTag}>${convertListHTML([], lastIndent - 1, types)}`;\n  }\n  const [{ child, offset, length, indent, type }, ...rest] = items;\n  const [tag, attribute] = getListType(type);\n  if (indent > lastIndent) {\n    types.push(type);\n    if (indent === lastIndent + 1) {\n      return `<${tag}><li${attribute}>${convertHTML(\n        child,\n        offset,\n        length,\n      )}${convertListHTML(rest, indent, types)}`;\n    }\n    return `<${tag}><li>${convertListHTML(items, lastIndent + 1, types)}`;\n  }\n  const previousType = types[types.length - 1];\n  if (indent === lastIndent && type === previousType) {\n    return `</li><li${attribute}>${convertHTML(\n      child,\n      offset,\n      length,\n    )}${convertListHTML(rest, indent, types)}`;\n  }\n  const [endTag] = getListType(types.pop());\n  return `</li></${endTag}>${convertListHTML(items, lastIndent - 1, types)}`;\n}\n\nfunction convertHTML(\n  blot: Blot,\n  index: number,\n  length: number,\n  isRoot = false,\n): string {\n  if ('html' in blot && typeof blot.html === 'function') {\n    return blot.html(index, length);\n  }\n  if (blot instanceof TextBlot) {\n    const escapedText = escapeText(blot.value().slice(index, index + length));\n    return escapedText.replaceAll(' ', '&nbsp;');\n  }\n  if (blot instanceof ParentBlot) {\n    // TODO fix API\n    if (blot.statics.blotName === 'list-container') {\n      const items: any[] = [];\n      blot.children.forEachAt(index, length, (child, offset, childLength) => {\n        const formats =\n          'formats' in child && typeof child.formats === 'function'\n            ? child.formats()\n            : {};\n        items.push({\n          child,\n          offset,\n          length: childLength,\n          indent: formats.indent || 0,\n          type: formats.list,\n        });\n      });\n      return convertListHTML(items, -1, []);\n    }\n    const parts: string[] = [];\n    blot.children.forEachAt(index, length, (child, offset, childLength) => {\n      parts.push(convertHTML(child, offset, childLength));\n    });\n    if (isRoot || blot.statics.blotName === 'list') {\n      return parts.join('');\n    }\n    const { outerHTML, innerHTML } = blot.domNode as Element;\n    const [start, end] = outerHTML.split(`>${innerHTML}<`);\n    // TODO cleanup\n    if (start === '<table') {\n      return `<table style=\"border: 1px solid #000;\">${parts.join('')}<${end}`;\n    }\n    return `${start}>${parts.join('')}<${end}`;\n  }\n  return blot.domNode instanceof Element ? blot.domNode.outerHTML : '';\n}\n\nfunction combineFormats(\n  formats: Record<string, unknown>,\n  combined: Record<string, unknown>,\n): Record<string, unknown> {\n  return Object.keys(combined).reduce(\n    (merged, name) => {\n      if (formats[name] == null) return merged;\n      const combinedValue = combined[name];\n      if (combinedValue === formats[name]) {\n        merged[name] = combinedValue;\n      } else if (Array.isArray(combinedValue)) {\n        if (combinedValue.indexOf(formats[name]) < 0) {\n          merged[name] = combinedValue.concat([formats[name]]);\n        } else {\n          // If style already exists, don't add to an array, but don't lose other styles\n          merged[name] = combinedValue;\n        }\n      } else {\n        merged[name] = [combinedValue, formats[name]];\n      }\n      return merged;\n    },\n    {} as Record<string, unknown>,\n  );\n}\n\nfunction getListType(type: string | undefined) {\n  const tag = type === 'ordered' ? 'ol' : 'ul';\n  switch (type) {\n    case 'checked':\n      return [tag, ' data-list=\"checked\"'];\n    case 'unchecked':\n      return [tag, ' data-list=\"unchecked\"'];\n    default:\n      return [tag, ''];\n  }\n}\n\nfunction normalizeDelta(delta: Delta) {\n  return delta.reduce((normalizedDelta, op) => {\n    if (typeof op.insert === 'string') {\n      const text = op.insert.replace(/\\r\\n/g, '\\n').replace(/\\r/g, '\\n');\n      return normalizedDelta.insert(text, op.attributes);\n    }\n    return normalizedDelta.push(op);\n  }, new Delta());\n}\n\nfunction shiftRange({ index, length }: Range, amount: number) {\n  return new Range(index + amount, length);\n}\n\nfunction splitOpLines(ops: Op[]) {\n  const split: Op[] = [];\n  ops.forEach((op) => {\n    if (typeof op.insert === 'string') {\n      const lines = op.insert.split('\\n');\n      lines.forEach((line, index) => {\n        if (index) split.push({ insert: '\\n', attributes: op.attributes });\n        if (line) split.push({ insert: line, attributes: op.attributes });\n      });\n    } else {\n      split.push(op);\n    }\n  });\n\n  return split;\n}\n\nexport default Editor;\n","import type Quill from './quill.js';\n\nabstract class Module<T extends {} = {}> {\n  static DEFAULTS = {};\n\n  constructor(\n    public quill: Quill,\n    protected options: Partial<T> = {},\n  ) {}\n}\n\nexport default Module;\n","import type { ScrollBlot } from 'parchment';\nimport { EmbedBlot } from 'parchment';\nimport TextBlot from './text.js';\n\nconst GUARD_TEXT = '\\uFEFF';\n\nexport interface EmbedContextRange {\n  startNode: Node | Text;\n  startOffset: number;\n  endNode?: Node | Text;\n  endOffset?: number;\n}\n\nclass Embed extends EmbedBlot {\n  contentNode: HTMLSpanElement;\n  leftGuard: Text;\n  rightGuard: Text;\n\n  constructor(scroll: ScrollBlot, node: Node) {\n    super(scroll, node);\n    this.contentNode = document.createElement('span');\n    this.contentNode.setAttribute('contenteditable', 'false');\n    Array.from(this.domNode.childNodes).forEach((childNode) => {\n      this.contentNode.appendChild(childNode);\n    });\n    this.leftGuard = document.createTextNode(GUARD_TEXT);\n    this.rightGuard = document.createTextNode(GUARD_TEXT);\n    this.domNode.appendChild(this.leftGuard);\n    this.domNode.appendChild(this.contentNode);\n    this.domNode.appendChild(this.rightGuard);\n  }\n\n  index(node: Node, offset: number) {\n    if (node === this.leftGuard) return 0;\n    if (node === this.rightGuard) return 1;\n    return super.index(node, offset);\n  }\n\n  restore(node: Text): EmbedContextRange | null {\n    let range: EmbedContextRange | null = null;\n    let textNode: Text;\n    const text = node.data.split(GUARD_TEXT).join('');\n    if (node === this.leftGuard) {\n      if (this.prev instanceof TextBlot) {\n        const prevLength = this.prev.length();\n        this.prev.insertAt(prevLength, text);\n        range = {\n          startNode: this.prev.domNode,\n          startOffset: prevLength + text.length,\n        };\n      } else {\n        textNode = document.createTextNode(text);\n        this.parent.insertBefore(this.scroll.create(textNode), this);\n        range = {\n          startNode: textNode,\n          startOffset: text.length,\n        };\n      }\n    } else if (node === this.rightGuard) {\n      if (this.next instanceof TextBlot) {\n        this.next.insertAt(0, text);\n        range = {\n          startNode: this.next.domNode,\n          startOffset: text.length,\n        };\n      } else {\n        textNode = document.createTextNode(text);\n        this.parent.insertBefore(this.scroll.create(textNode), this.next);\n        range = {\n          startNode: textNode,\n          startOffset: text.length,\n        };\n      }\n    }\n    node.data = GUARD_TEXT;\n    return range;\n  }\n\n  update(mutations: MutationRecord[], context: Record<string, unknown>) {\n    mutations.forEach((mutation) => {\n      if (\n        mutation.type === 'characterData' &&\n        (mutation.target === this.leftGuard ||\n          mutation.target === this.rightGuard)\n      ) {\n        const range = this.restore(mutation.target as Text);\n        if (range) context.range = range;\n      }\n    });\n  }\n}\n\nexport default Embed;\n","import Embed from '../blots/embed.js';\nimport type Scroll from '../blots/scroll.js';\nimport Emitter from './emitter.js';\n\nclass Composition {\n  isComposing = false;\n\n  constructor(\n    private scroll: Scroll,\n    private emitter: Emitter,\n  ) {\n    this.setupListeners();\n  }\n\n  private setupListeners() {\n    this.scroll.domNode.addEventListener('compositionstart', (event) => {\n      if (!this.isComposing) {\n        this.handleCompositionStart(event);\n      }\n    });\n\n    this.scroll.domNode.addEventListener('compositionend', (event) => {\n      if (this.isComposing) {\n        // Webkit makes DOM changes after compositionend, so we use microtask to\n        // ensure the order.\n        // https://bugs.webkit.org/show_bug.cgi?id=31902\n        queueMicrotask(() => {\n          this.handleCompositionEnd(event);\n        });\n      }\n    });\n  }\n\n  private handleCompositionStart(event: CompositionEvent) {\n    const blot =\n      event.target instanceof Node\n        ? this.scroll.find(event.target, true)\n        : null;\n\n    if (blot && !(blot instanceof Embed)) {\n      this.emitter.emit(Emitter.events.COMPOSITION_BEFORE_START, event);\n      this.scroll.batchStart();\n      this.emitter.emit(Emitter.events.COMPOSITION_START, event);\n      this.isComposing = true;\n    }\n  }\n\n  private handleCompositionEnd(event: CompositionEvent) {\n    this.emitter.emit(Emitter.events.COMPOSITION_BEFORE_END, event);\n    this.scroll.batchEnd();\n    this.emitter.emit(Emitter.events.COMPOSITION_END, event);\n    this.isComposing = false;\n  }\n}\n\nexport default Composition;\n","import type Quill from '../core.js';\nimport type Clipboard from '../modules/clipboard.js';\nimport type History from '../modules/history.js';\nimport type Keyboard from '../modules/keyboard.js';\nimport type { ToolbarProps } from '../modules/toolbar.js';\nimport type Uploader from '../modules/uploader.js';\n\nexport interface ThemeOptions {\n  modules: Record<string, unknown> & {\n    toolbar?: null | ToolbarProps;\n  };\n}\n\nclass Theme {\n  static DEFAULTS: ThemeOptions = {\n    modules: {},\n  };\n\n  static themes = {\n    default: Theme,\n  };\n\n  modules: ThemeOptions['modules'] = {};\n\n  constructor(\n    protected quill: Quill,\n    protected options: ThemeOptions,\n  ) {}\n\n  init() {\n    Object.keys(this.options.modules).forEach((name) => {\n      if (this.modules[name] == null) {\n        this.addModule(name);\n      }\n    });\n  }\n\n  addModule(name: 'clipboard'): Clipboard;\n  addModule(name: 'keyboard'): Keyboard;\n  addModule(name: 'uploader'): Uploader;\n  addModule(name: 'history'): History;\n  addModule(name: string): unknown;\n  addModule(name: string) {\n    // @ts-expect-error\n    const ModuleClass = this.quill.constructor.import(`modules/${name}`);\n    this.modules[name] = new ModuleClass(\n      this.quill,\n      this.options.modules[name] || {},\n    );\n    return this.modules[name];\n  }\n}\n\nexport interface ThemeConstructor {\n  new (quill: Quill, options: unknown): Theme;\n  DEFAULTS: ThemeOptions;\n}\n\nexport default Theme;\n","export type Rect = {\n  top: number;\n  right: number;\n  bottom: number;\n  left: number;\n};\n\nconst getParentElement = (element: Node): Element | null =>\n  element.parentElement || (element.getRootNode() as ShadowRoot).host || null;\n\nconst getElementRect = (element: Element): Rect => {\n  const rect = element.getBoundingClientRect();\n  const scaleX =\n    ('offsetWidth' in element &&\n      Math.abs(rect.width) / (element as HTMLElement).offsetWidth) ||\n    1;\n  const scaleY =\n    ('offsetHeight' in element &&\n      Math.abs(rect.height) / (element as HTMLElement).offsetHeight) ||\n    1;\n  return {\n    top: rect.top,\n    right: rect.left + element.clientWidth * scaleX,\n    bottom: rect.top + element.clientHeight * scaleY,\n    left: rect.left,\n  };\n};\n\nconst paddingValueToInt = (value: string) => {\n  const number = parseInt(value, 10);\n  return Number.isNaN(number) ? 0 : number;\n};\n\n// Follow the steps described in https://www.w3.org/TR/cssom-view-1/#element-scrolling-members,\n// assuming that the scroll option is set to 'nearest'.\nconst getScrollDistance = (\n  targetStart: number,\n  targetEnd: number,\n  scrollStart: number,\n  scrollEnd: number,\n  scrollPaddingStart: number,\n  scrollPaddingEnd: number,\n) => {\n  if (targetStart < scrollStart && targetEnd > scrollEnd) {\n    return 0;\n  }\n\n  if (targetStart < scrollStart) {\n    return -(scrollStart - targetStart + scrollPaddingStart);\n  }\n\n  if (targetEnd > scrollEnd) {\n    return targetEnd - targetStart > scrollEnd - scrollStart\n      ? targetStart + scrollPaddingStart - scrollStart\n      : targetEnd - scrollEnd + scrollPaddingEnd;\n  }\n  return 0;\n};\n\nconst scrollRectIntoView = (root: HTMLElement, targetRect: Rect) => {\n  const document = root.ownerDocument;\n\n  let rect = targetRect;\n\n  let current: Element | null = root;\n  while (current) {\n    const isDocumentBody: boolean = current === document.body;\n    const bounding = isDocumentBody\n      ? {\n          top: 0,\n          right:\n            window.visualViewport?.width ??\n            document.documentElement.clientWidth,\n          bottom:\n            window.visualViewport?.height ??\n            document.documentElement.clientHeight,\n          left: 0,\n        }\n      : getElementRect(current);\n\n    const style = getComputedStyle(current);\n    const scrollDistanceX = getScrollDistance(\n      rect.left,\n      rect.right,\n      bounding.left,\n      bounding.right,\n      paddingValueToInt(style.scrollPaddingLeft),\n      paddingValueToInt(style.scrollPaddingRight),\n    );\n    const scrollDistanceY = getScrollDistance(\n      rect.top,\n      rect.bottom,\n      bounding.top,\n      bounding.bottom,\n      paddingValueToInt(style.scrollPaddingTop),\n      paddingValueToInt(style.scrollPaddingBottom),\n    );\n    if (scrollDistanceX || scrollDistanceY) {\n      if (isDocumentBody) {\n        document.defaultView?.scrollBy(scrollDistanceX, scrollDistanceY);\n      } else {\n        const { scrollLeft, scrollTop } = current;\n        if (scrollDistanceY) {\n          current.scrollTop += scrollDistanceY;\n        }\n        if (scrollDistanceX) {\n          current.scrollLeft += scrollDistanceX;\n        }\n        const scrolledLeft = current.scrollLeft - scrollLeft;\n        const scrolledTop = current.scrollTop - scrollTop;\n        rect = {\n          left: rect.left - scrolledLeft,\n          top: rect.top - scrolledTop,\n          right: rect.right - scrolledLeft,\n          bottom: rect.bottom - scrolledTop,\n        };\n      }\n    }\n\n    current =\n      isDocumentBody || style.position === 'fixed'\n        ? null\n        : getParentElement(current);\n  }\n};\n\nexport default scrollRectIntoView;\n","import { Registry } from 'parchment';\n\nconst MAX_REGISTER_ITERATIONS = 100;\nconst CORE_FORMATS = ['block', 'break', 'cursor', 'inline', 'scroll', 'text'];\n\nconst createRegistryWithFormats = (\n  formats: string[],\n  sourceRegistry: Registry,\n  debug: { error: (errorMessage: string) => void },\n) => {\n  const registry = new Registry();\n  CORE_FORMATS.forEach((name) => {\n    const coreBlot = sourceRegistry.query(name);\n    if (coreBlot) registry.register(coreBlot);\n  });\n\n  formats.forEach((name) => {\n    let format = sourceRegistry.query(name);\n    if (!format) {\n      debug.error(\n        `Cannot register \"${name}\" specified in \"formats\" config. Are you sure it was registered?`,\n      );\n    }\n    let iterations = 0;\n    while (format) {\n      registry.register(format);\n      format = 'blotName' in format ? format.requiredContainer ?? null : null;\n\n      iterations += 1;\n      if (iterations > MAX_REGISTER_ITERATIONS) {\n        debug.error(\n          `Cycle detected in registering blot requiredContainer: \"${name}\"`,\n        );\n        break;\n      }\n    }\n  });\n\n  return registry;\n};\n\nexport default createRegistryWithFormats;\n","import { merge } from 'lodash-es';\nimport * as Parchment from 'parchment';\nimport type { Op } from 'quill-delta';\nimport Delta from 'quill-delta';\nimport type { BlockEmbed } from '../blots/block.js';\nimport type Block from '../blots/block.js';\nimport type Scroll from '../blots/scroll.js';\nimport type Clipboard from '../modules/clipboard.js';\nimport type History from '../modules/history.js';\nimport type Keyboard from '../modules/keyboard.js';\nimport type Uploader from '../modules/uploader.js';\nimport Editor from './editor.js';\nimport Emitter from './emitter.js';\nimport type { EmitterSource } from './emitter.js';\nimport instances from './instances.js';\nimport logger from './logger.js';\nimport type { DebugLevel } from './logger.js';\nimport Module from './module.js';\nimport Selection, { Range } from './selection.js';\nimport type { Bounds } from './selection.js';\nimport Composition from './composition.js';\nimport Theme from './theme.js';\nimport type { ThemeConstructor } from './theme.js';\nimport scrollRectIntoView from './utils/scrollRectIntoView.js';\nimport type { Rect } from './utils/scrollRectIntoView.js';\nimport createRegistryWithFormats from './utils/createRegistryWithFormats.js';\n\nconst debug = logger('quill');\n\nconst globalRegistry = new Parchment.Registry();\nParchment.ParentBlot.uiClass = 'ql-ui';\n\n/**\n * Options for initializing a Quill instance\n */\nexport interface QuillOptions {\n  theme?: string;\n  debug?: DebugLevel | boolean;\n  registry?: Parchment.Registry;\n  /**\n   * Whether to disable the editing\n   * @default false\n   */\n  readOnly?: boolean;\n\n  /**\n   * Placeholder text to display when the editor is empty\n   * @default \"\"\n   */\n  placeholder?: string;\n  bounds?: HTMLElement | string | null;\n  modules?: Record<string, unknown>;\n\n  /**\n   * A list of formats that are recognized and can exist within the editor contents.\n   * `null` means all formats are allowed.\n   * @default null\n   */\n  formats?: string[] | null;\n}\n\n/**\n * Similar to QuillOptions, but with all properties expanded to their default values,\n * and all selectors resolved to HTMLElements.\n */\nexport interface ExpandedQuillOptions\n  extends Omit<QuillOptions, 'theme' | 'formats'> {\n  theme: ThemeConstructor;\n  registry: Parchment.Registry;\n  container: HTMLElement;\n  modules: Record<string, unknown>;\n  bounds?: HTMLElement | null;\n  readOnly: boolean;\n}\n\nclass Quill {\n  static DEFAULTS = {\n    bounds: null,\n    modules: {\n      clipboard: true,\n      keyboard: true,\n      history: true,\n      uploader: true,\n    },\n    placeholder: '',\n    readOnly: false,\n    registry: globalRegistry,\n    theme: 'default',\n  } satisfies Partial<QuillOptions>;\n  static events = Emitter.events;\n  static sources = Emitter.sources;\n  static version = typeof QUILL_VERSION === 'undefined' ? 'dev' : QUILL_VERSION;\n\n  static imports: Record<string, unknown> = {\n    delta: Delta,\n    parchment: Parchment,\n    'core/module': Module,\n    'core/theme': Theme,\n  };\n\n  static debug(limit: DebugLevel | boolean) {\n    if (limit === true) {\n      limit = 'log';\n    }\n    logger.level(limit);\n  }\n\n  static find(node: Node, bubble = false) {\n    return instances.get(node) || globalRegistry.find(node, bubble);\n  }\n\n  static import(name: 'core/module'): typeof Module;\n  static import(name: `themes/${string}`): typeof Theme;\n  static import(name: 'parchment'): typeof Parchment;\n  static import(name: 'delta'): typeof Delta;\n  static import(name: string): unknown;\n  static import(name: string) {\n    if (this.imports[name] == null) {\n      debug.error(`Cannot import ${name}. Are you sure it was registered?`);\n    }\n    return this.imports[name];\n  }\n\n  static register(\n    targets: Record<\n      string,\n      | Parchment.RegistryDefinition\n      | Record<string, unknown> // any objects\n      | Theme\n      | Module\n      | Function // ES5 constructors\n    >,\n    overwrite?: boolean,\n  ): void;\n  static register(\n    target: Parchment.RegistryDefinition,\n    overwrite?: boolean,\n  ): void;\n  static register(path: string, target: any, overwrite?: boolean): void;\n  static register(...args: any[]): void {\n    if (typeof args[0] !== 'string') {\n      const target = args[0];\n      const overwrite = !!args[1];\n\n      const name = 'attrName' in target ? target.attrName : target.blotName;\n      if (typeof name === 'string') {\n        // Shortcut for formats:\n        // register(Blot | Attributor, overwrite)\n        this.register(`formats/${name}`, target, overwrite);\n      } else {\n        Object.keys(target).forEach((key) => {\n          this.register(key, target[key], overwrite);\n        });\n      }\n    } else {\n      const path = args[0];\n      const target = args[1];\n      const overwrite = !!args[2];\n\n      if (this.imports[path] != null && !overwrite) {\n        debug.warn(`Overwriting ${path} with`, target);\n      }\n      this.imports[path] = target;\n      if (\n        (path.startsWith('blots/') || path.startsWith('formats/')) &&\n        target &&\n        typeof target !== 'boolean' &&\n        target.blotName !== 'abstract'\n      ) {\n        globalRegistry.register(target);\n      }\n      if (typeof target.register === 'function') {\n        target.register(globalRegistry);\n      }\n    }\n  }\n\n  container: HTMLElement;\n  root: HTMLDivElement;\n  scroll: Scroll;\n  emitter: Emitter;\n  protected allowReadOnlyEdits: boolean;\n  editor: Editor;\n  composition: Composition;\n  selection: Selection;\n\n  theme: Theme;\n  keyboard: Keyboard;\n  clipboard: Clipboard;\n  history: History;\n  uploader: Uploader;\n\n  options: ExpandedQuillOptions;\n\n  constructor(container: HTMLElement | string, options: QuillOptions = {}) {\n    this.options = expandConfig(container, options);\n    this.container = this.options.container;\n    if (this.container == null) {\n      debug.error('Invalid Quill container', container);\n      return;\n    }\n    if (this.options.debug) {\n      Quill.debug(this.options.debug);\n    }\n    const html = this.container.innerHTML.trim();\n    this.container.classList.add('ql-container');\n    this.container.innerHTML = '';\n    instances.set(this.container, this);\n    this.root = this.addContainer('ql-editor');\n    this.root.classList.add('ql-blank');\n    this.emitter = new Emitter();\n    const scrollBlotName = Parchment.ScrollBlot.blotName;\n    const ScrollBlot = this.options.registry.query(scrollBlotName);\n    if (!ScrollBlot || !('blotName' in ScrollBlot)) {\n      throw new Error(\n        `Cannot initialize Quill without \"${scrollBlotName}\" blot`,\n      );\n    }\n    this.scroll = new ScrollBlot(this.options.registry, this.root, {\n      emitter: this.emitter,\n    }) as Scroll;\n    this.editor = new Editor(this.scroll);\n    this.selection = new Selection(this.scroll, this.emitter);\n    this.composition = new Composition(this.scroll, this.emitter);\n    this.theme = new this.options.theme(this, this.options); // eslint-disable-line new-cap\n    this.keyboard = this.theme.addModule('keyboard');\n    this.clipboard = this.theme.addModule('clipboard');\n    this.history = this.theme.addModule('history');\n    this.uploader = this.theme.addModule('uploader');\n    this.theme.addModule('input');\n    this.theme.addModule('uiNode');\n    this.theme.init();\n    this.emitter.on(Emitter.events.EDITOR_CHANGE, (type) => {\n      if (type === Emitter.events.TEXT_CHANGE) {\n        this.root.classList.toggle('ql-blank', this.editor.isBlank());\n      }\n    });\n    this.emitter.on(Emitter.events.SCROLL_UPDATE, (source, mutations) => {\n      const oldRange = this.selection.lastRange;\n      const [newRange] = this.selection.getRange();\n      const selectionInfo =\n        oldRange && newRange ? { oldRange, newRange } : undefined;\n      modify.call(\n        this,\n        () => this.editor.update(null, mutations, selectionInfo),\n        source,\n      );\n    });\n    this.emitter.on(Emitter.events.SCROLL_EMBED_UPDATE, (blot, delta) => {\n      const oldRange = this.selection.lastRange;\n      const [newRange] = this.selection.getRange();\n      const selectionInfo =\n        oldRange && newRange ? { oldRange, newRange } : undefined;\n      modify.call(\n        this,\n        () => {\n          const change = new Delta()\n            .retain(blot.offset(this))\n            .retain({ [blot.statics.blotName]: delta });\n          return this.editor.update(change, [], selectionInfo);\n        },\n        Quill.sources.USER,\n      );\n    });\n    if (html) {\n      const contents = this.clipboard.convert({\n        html: `${html}<p><br></p>`,\n        text: '\\n',\n      });\n      this.setContents(contents);\n    }\n    this.history.clear();\n    if (this.options.placeholder) {\n      this.root.setAttribute('data-placeholder', this.options.placeholder);\n    }\n    if (this.options.readOnly) {\n      this.disable();\n    }\n    this.allowReadOnlyEdits = false;\n  }\n\n  addContainer(container: string, refNode?: Node | null): HTMLDivElement;\n  addContainer(container: HTMLElement, refNode?: Node | null): HTMLElement;\n  addContainer(\n    container: string | HTMLElement,\n    refNode: Node | null = null,\n  ): HTMLDivElement | HTMLElement {\n    if (typeof container === 'string') {\n      const className = container;\n      container = document.createElement('div');\n      container.classList.add(className);\n    }\n    this.container.insertBefore(container, refNode);\n    return container;\n  }\n\n  blur() {\n    this.selection.setRange(null);\n  }\n\n  deleteText(range: Range, source?: EmitterSource): Delta;\n  deleteText(index: number, length: number, source?: EmitterSource): Delta;\n  deleteText(\n    index: number | Range,\n    length?: number | EmitterSource,\n    source?: EmitterSource,\n  ): Delta {\n    // @ts-expect-error\n    [index, length, , source] = overload(index, length, source);\n    return modify.call(\n      this,\n      () => {\n        return this.editor.deleteText(index, length);\n      },\n      source,\n      index,\n      -1 * length,\n    );\n  }\n\n  disable() {\n    this.enable(false);\n  }\n\n  editReadOnly<T>(modifier: () => T): T {\n    this.allowReadOnlyEdits = true;\n    const value = modifier();\n    this.allowReadOnlyEdits = false;\n    return value;\n  }\n\n  enable(enabled = true) {\n    this.scroll.enable(enabled);\n    this.container.classList.toggle('ql-disabled', !enabled);\n  }\n\n  focus(options: { preventScroll?: boolean } = {}) {\n    this.selection.focus();\n    if (!options.preventScroll) {\n      this.scrollSelectionIntoView();\n    }\n  }\n\n  format(\n    name: string,\n    value: unknown,\n    source: EmitterSource = Emitter.sources.API,\n  ): Delta {\n    return modify.call(\n      this,\n      () => {\n        const range = this.getSelection(true);\n        let change = new Delta();\n        if (range == null) return change;\n        if (this.scroll.query(name, Parchment.Scope.BLOCK)) {\n          change = this.editor.formatLine(range.index, range.length, {\n            [name]: value,\n          });\n        } else if (range.length === 0) {\n          this.selection.format(name, value);\n          return change;\n        } else {\n          change = this.editor.formatText(range.index, range.length, {\n            [name]: value,\n          });\n        }\n        this.setSelection(range, Emitter.sources.SILENT);\n        return change;\n      },\n      source,\n    );\n  }\n\n  formatLine(\n    index: number,\n    length: number,\n    formats: Record<string, unknown>,\n    source?: EmitterSource,\n  ): Delta;\n  formatLine(\n    index: number,\n    length: number,\n    name: string,\n    value?: unknown,\n    source?: EmitterSource,\n  ): Delta;\n  formatLine(\n    index: number,\n    length: number,\n    name: string | Record<string, unknown>,\n    value?: unknown | EmitterSource,\n    source?: EmitterSource,\n  ): Delta {\n    let formats: Record<string, unknown>;\n    // eslint-disable-next-line prefer-const\n    [index, length, formats, source] = overload(\n      index,\n      length,\n      // @ts-expect-error\n      name,\n      value,\n      source,\n    );\n    return modify.call(\n      this,\n      () => {\n        return this.editor.formatLine(index, length, formats);\n      },\n      source,\n      index,\n      0,\n    );\n  }\n\n  formatText(\n    range: Range,\n    name: string,\n    value: unknown,\n    source?: EmitterSource,\n  ): Delta;\n  formatText(\n    index: number,\n    length: number,\n    name: string,\n    value: unknown,\n    source?: EmitterSource,\n  ): Delta;\n  formatText(\n    index: number,\n    length: number,\n    formats: Record<string, unknown>,\n    source?: EmitterSource,\n  ): Delta;\n  formatText(\n    index: number | Range,\n    length: number | string,\n    name: string | unknown,\n    value?: unknown | EmitterSource,\n    source?: EmitterSource,\n  ): Delta {\n    let formats: Record<string, unknown>;\n    // eslint-disable-next-line prefer-const\n    [index, length, formats, source] = overload(\n      // @ts-expect-error\n      index,\n      length,\n      name,\n      value,\n      source,\n    );\n    return modify.call(\n      this,\n      () => {\n        return this.editor.formatText(index, length, formats);\n      },\n      source,\n      index,\n      0,\n    );\n  }\n\n  getBounds(index: number | Range, length = 0): Bounds | null {\n    let bounds: Bounds | null = null;\n    if (typeof index === 'number') {\n      bounds = this.selection.getBounds(index, length);\n    } else {\n      bounds = this.selection.getBounds(index.index, index.length);\n    }\n    if (!bounds) return null;\n    const containerBounds = this.container.getBoundingClientRect();\n    return {\n      bottom: bounds.bottom - containerBounds.top,\n      height: bounds.height,\n      left: bounds.left - containerBounds.left,\n      right: bounds.right - containerBounds.left,\n      top: bounds.top - containerBounds.top,\n      width: bounds.width,\n    };\n  }\n\n  getContents(index = 0, length = this.getLength() - index) {\n    [index, length] = overload(index, length);\n    return this.editor.getContents(index, length);\n  }\n\n  getFormat(index?: number, length?: number): { [format: string]: unknown };\n  getFormat(range?: Range): {\n    [format: string]: unknown;\n  };\n  getFormat(\n    index: Range | number = this.getSelection(true),\n    length = 0,\n  ): { [format: string]: unknown } {\n    if (typeof index === 'number') {\n      return this.editor.getFormat(index, length);\n    }\n    return this.editor.getFormat(index.index, index.length);\n  }\n\n  getIndex(blot: Parchment.Blot) {\n    return blot.offset(this.scroll);\n  }\n\n  getLength() {\n    return this.scroll.length();\n  }\n\n  getLeaf(index: number) {\n    return this.scroll.leaf(index);\n  }\n\n  getLine(index: number) {\n    return this.scroll.line(index);\n  }\n\n  getLines(range: Range): (Block | BlockEmbed)[];\n  getLines(index?: number, length?: number): (Block | BlockEmbed)[];\n  getLines(\n    index: Range | number = 0,\n    length = Number.MAX_VALUE,\n  ): (Block | BlockEmbed)[] {\n    if (typeof index !== 'number') {\n      return this.scroll.lines(index.index, index.length);\n    }\n    return this.scroll.lines(index, length);\n  }\n\n  getModule(name: string) {\n    return this.theme.modules[name];\n  }\n\n  getSelection(focus: true): Range;\n  getSelection(focus?: boolean): Range | null;\n  getSelection(focus = false): Range | null {\n    if (focus) this.focus();\n    this.update(); // Make sure we access getRange with editor in consistent state\n    return this.selection.getRange()[0];\n  }\n\n  getSemanticHTML(range: Range): string;\n  getSemanticHTML(index?: number, length?: number): string;\n  getSemanticHTML(index: Range | number = 0, length?: number) {\n    if (typeof index === 'number') {\n      length = length ?? this.getLength() - index;\n    }\n    // @ts-expect-error\n    [index, length] = overload(index, length);\n    return this.editor.getHTML(index, length);\n  }\n\n  getText(range?: Range): string;\n  getText(index?: number, length?: number): string;\n  getText(index: Range | number = 0, length?: number): string {\n    if (typeof index === 'number') {\n      length = length ?? this.getLength() - index;\n    }\n    // @ts-expect-error\n    [index, length] = overload(index, length);\n    return this.editor.getText(index, length);\n  }\n\n  hasFocus() {\n    return this.selection.hasFocus();\n  }\n\n  insertEmbed(\n    index: number,\n    embed: string,\n    value: unknown,\n    source: EmitterSource = Quill.sources.API,\n  ): Delta {\n    return modify.call(\n      this,\n      () => {\n        return this.editor.insertEmbed(index, embed, value);\n      },\n      source,\n      index,\n    );\n  }\n\n  insertText(index: number, text: string, source?: EmitterSource): Delta;\n  insertText(\n    index: number,\n    text: string,\n    formats: Record<string, unknown>,\n    source?: EmitterSource,\n  ): Delta;\n  insertText(\n    index: number,\n    text: string,\n    name: string,\n    value: unknown,\n    source?: EmitterSource,\n  ): Delta;\n  insertText(\n    index: number,\n    text: string,\n    name?: string | Record<string, unknown> | EmitterSource,\n    value?: unknown,\n    source?: EmitterSource,\n  ): Delta {\n    let formats: Record<string, unknown>;\n    // eslint-disable-next-line prefer-const\n    // @ts-expect-error\n    [index, , formats, source] = overload(index, 0, name, value, source);\n    return modify.call(\n      this,\n      () => {\n        return this.editor.insertText(index, text, formats);\n      },\n      source,\n      index,\n      text.length,\n    );\n  }\n\n  isEnabled() {\n    return this.scroll.isEnabled();\n  }\n\n  off(...args: Parameters<(typeof Emitter)['prototype']['off']>) {\n    return this.emitter.off(...args);\n  }\n\n  on(\n    event: (typeof Emitter)['events']['TEXT_CHANGE'],\n    handler: (delta: Delta, oldContent: Delta, source: EmitterSource) => void,\n  ): Emitter;\n  on(\n    event: (typeof Emitter)['events']['SELECTION_CHANGE'],\n    handler: (range: Range, oldRange: Range, source: EmitterSource) => void,\n  ): Emitter;\n  on(\n    event: (typeof Emitter)['events']['EDITOR_CHANGE'],\n    handler: (\n      ...args:\n        | [\n            (typeof Emitter)['events']['TEXT_CHANGE'],\n            Delta,\n            Delta,\n            EmitterSource,\n          ]\n        | [\n            (typeof Emitter)['events']['SELECTION_CHANGE'],\n            Range,\n            Range,\n            EmitterSource,\n          ]\n    ) => void,\n  ): Emitter;\n  on(event: string, ...args: unknown[]): Emitter;\n  on(...args: Parameters<(typeof Emitter)['prototype']['on']>): Emitter {\n    return this.emitter.on(...args);\n  }\n\n  once(...args: Parameters<(typeof Emitter)['prototype']['once']>) {\n    return this.emitter.once(...args);\n  }\n\n  removeFormat(index: number, length: number, source?: EmitterSource): Delta {\n    [index, length, , source] = overload(index, length, source);\n    return modify.call(\n      this,\n      () => {\n        return this.editor.removeFormat(index, length);\n      },\n      source,\n      index,\n    );\n  }\n\n  scrollRectIntoView(rect: Rect) {\n    scrollRectIntoView(this.root, rect);\n  }\n\n  /**\n   * @deprecated Use Quill#scrollSelectionIntoView() instead.\n   */\n  scrollIntoView() {\n    console.warn(\n      'Quill#scrollIntoView() has been deprecated and will be removed in the near future. Please use Quill#scrollSelectionIntoView() instead.',\n    );\n    this.scrollSelectionIntoView();\n  }\n\n  /**\n   * Scroll the current selection into the visible area.\n   * If the selection is already visible, no scrolling will occur.\n   */\n  scrollSelectionIntoView() {\n    const range = this.selection.lastRange;\n    const bounds = range && this.selection.getBounds(range.index, range.length);\n    if (bounds) {\n      this.scrollRectIntoView(bounds);\n    }\n  }\n\n  setContents(\n    delta: Delta | Op[],\n    source: EmitterSource = Emitter.sources.API,\n  ): Delta {\n    return modify.call(\n      this,\n      () => {\n        delta = new Delta(delta);\n        const length = this.getLength();\n        // Quill will set empty editor to \\n\n        const delete1 = this.editor.deleteText(0, length);\n        const applied = this.editor.insertContents(0, delta);\n        // Remove extra \\n from empty editor initialization\n        const delete2 = this.editor.deleteText(this.getLength() - 1, 1);\n        return delete1.compose(applied).compose(delete2);\n      },\n      source,\n    );\n  }\n  setSelection(range: Range | null, source?: EmitterSource): void;\n  setSelection(index: number, source?: EmitterSource): void;\n  setSelection(index: number, length?: number, source?: EmitterSource): void;\n  setSelection(index: number, source?: EmitterSource): void;\n  setSelection(\n    index: Range | null | number,\n    length?: EmitterSource | number,\n    source?: EmitterSource,\n  ): void {\n    if (index == null) {\n      // @ts-expect-error https://github.com/microsoft/TypeScript/issues/22609\n      this.selection.setRange(null, length || Quill.sources.API);\n    } else {\n      // @ts-expect-error\n      [index, length, , source] = overload(index, length, source);\n      this.selection.setRange(new Range(Math.max(0, index), length), source);\n      if (source !== Emitter.sources.SILENT) {\n        this.scrollSelectionIntoView();\n      }\n    }\n  }\n\n  setText(text: string, source: EmitterSource = Emitter.sources.API) {\n    const delta = new Delta().insert(text);\n    return this.setContents(delta, source);\n  }\n\n  update(source: EmitterSource = Emitter.sources.USER) {\n    const change = this.scroll.update(source); // Will update selection before selection.update() does if text changes\n    this.selection.update(source);\n    // TODO this is usually undefined\n    return change;\n  }\n\n  updateContents(\n    delta: Delta | Op[],\n    source: EmitterSource = Emitter.sources.API,\n  ): Delta {\n    return modify.call(\n      this,\n      () => {\n        delta = new Delta(delta);\n        return this.editor.applyDelta(delta);\n      },\n      source,\n      true,\n    );\n  }\n}\n\nfunction resolveSelector(selector: string | HTMLElement | null | undefined) {\n  return typeof selector === 'string'\n    ? document.querySelector<HTMLElement>(selector)\n    : selector;\n}\n\nfunction expandModuleConfig(config: Record<string, unknown> | undefined) {\n  return Object.entries(config ?? {}).reduce(\n    (expanded, [key, value]) => ({\n      ...expanded,\n      [key]: value === true ? {} : value,\n    }),\n    {} as Record<string, unknown>,\n  );\n}\n\nfunction omitUndefinedValuesFromOptions(obj: QuillOptions) {\n  return Object.fromEntries(\n    Object.entries(obj).filter((entry) => entry[1] !== undefined),\n  );\n}\n\nfunction expandConfig(\n  containerOrSelector: HTMLElement | string,\n  options: QuillOptions,\n): ExpandedQuillOptions {\n  const container = resolveSelector(containerOrSelector);\n  if (!container) {\n    throw new Error('Invalid Quill container');\n  }\n\n  const shouldUseDefaultTheme =\n    !options.theme || options.theme === Quill.DEFAULTS.theme;\n  const theme = shouldUseDefaultTheme\n    ? Theme\n    : Quill.import(`themes/${options.theme}`);\n  if (!theme) {\n    throw new Error(`Invalid theme ${options.theme}. Did you register it?`);\n  }\n\n  const { modules: quillModuleDefaults, ...quillDefaults } = Quill.DEFAULTS;\n  const { modules: themeModuleDefaults, ...themeDefaults } = theme.DEFAULTS;\n\n  let userModuleOptions = expandModuleConfig(options.modules);\n  // Special case toolbar shorthand\n  if (\n    userModuleOptions != null &&\n    userModuleOptions.toolbar &&\n    userModuleOptions.toolbar.constructor !== Object\n  ) {\n    userModuleOptions = {\n      ...userModuleOptions,\n      toolbar: { container: userModuleOptions.toolbar },\n    };\n  }\n\n  const modules: ExpandedQuillOptions['modules'] = merge(\n    {},\n    expandModuleConfig(quillModuleDefaults),\n    expandModuleConfig(themeModuleDefaults),\n    userModuleOptions,\n  );\n\n  const config = {\n    ...quillDefaults,\n    ...omitUndefinedValuesFromOptions(themeDefaults),\n    ...omitUndefinedValuesFromOptions(options),\n  };\n\n  let registry = options.registry;\n  if (registry) {\n    if (options.formats) {\n      debug.warn('Ignoring \"formats\" option because \"registry\" is specified');\n    }\n  } else {\n    registry = options.formats\n      ? createRegistryWithFormats(options.formats, config.registry, debug)\n      : config.registry;\n  }\n\n  return {\n    ...config,\n    registry,\n    container,\n    theme,\n    modules: Object.entries(modules).reduce(\n      (modulesWithDefaults, [name, value]) => {\n        if (!value) return modulesWithDefaults;\n\n        const moduleClass = Quill.import(`modules/${name}`);\n        if (moduleClass == null) {\n          debug.error(\n            `Cannot load ${name} module. Are you sure you registered it?`,\n          );\n          return modulesWithDefaults;\n        }\n        return {\n          ...modulesWithDefaults,\n          // @ts-expect-error\n          [name]: merge({}, moduleClass.DEFAULTS || {}, value),\n        };\n      },\n      {},\n    ),\n    bounds: resolveSelector(config.bounds),\n  };\n}\n\n// Handle selection preservation and TEXT_CHANGE emission\n// common to modification APIs\nfunction modify(\n  modifier: () => Delta,\n  source: EmitterSource,\n  index: number | boolean,\n  shift: number | null,\n) {\n  if (\n    !this.isEnabled() &&\n    source === Emitter.sources.USER &&\n    !this.allowReadOnlyEdits\n  ) {\n    return new Delta();\n  }\n  let range = index == null ? null : this.getSelection();\n  const oldDelta = this.editor.delta;\n  const change = modifier();\n  if (range != null) {\n    if (index === true) {\n      index = range.index; // eslint-disable-line prefer-destructuring\n    }\n    if (shift == null) {\n      range = shiftRange(range, change, source);\n    } else if (shift !== 0) {\n      // @ts-expect-error index should always be number\n      range = shiftRange(range, index, shift, source);\n    }\n    this.setSelection(range, Emitter.sources.SILENT);\n  }\n  if (change.length() > 0) {\n    const args = [Emitter.events.TEXT_CHANGE, change, oldDelta, source];\n    this.emitter.emit(Emitter.events.EDITOR_CHANGE, ...args);\n    if (source !== Emitter.sources.SILENT) {\n      this.emitter.emit(...args);\n    }\n  }\n  return change;\n}\n\ntype NormalizedIndexLength = [\n  number,\n  number,\n  Record<string, unknown>,\n  EmitterSource,\n];\nfunction overload(index: number, source?: EmitterSource): NormalizedIndexLength;\nfunction overload(\n  index: number,\n  length: number,\n  source?: EmitterSource,\n): NormalizedIndexLength;\nfunction overload(\n  index: number,\n  length: number,\n  format: string,\n  value: unknown,\n  source?: EmitterSource,\n): NormalizedIndexLength;\nfunction overload(\n  index: number,\n  length: number,\n  format: Record<string, unknown>,\n  source?: EmitterSource,\n): NormalizedIndexLength;\nfunction overload(range: Range, source?: EmitterSource): NormalizedIndexLength;\nfunction overload(\n  range: Range,\n  format: string,\n  value: unknown,\n  source?: EmitterSource,\n): NormalizedIndexLength;\nfunction overload(\n  range: Range,\n  format: Record<string, unknown>,\n  source?: EmitterSource,\n): NormalizedIndexLength;\nfunction overload(\n  index: Range | number,\n  length?: number | string | Record<string, unknown> | EmitterSource,\n  name?: string | unknown | Record<string, unknown> | EmitterSource,\n  value?: unknown | EmitterSource,\n  source?: EmitterSource,\n): NormalizedIndexLength {\n  let formats: Record<string, unknown> = {};\n  // @ts-expect-error\n  if (typeof index.index === 'number' && typeof index.length === 'number') {\n    // Allow for throwaway end (used by insertText/insertEmbed)\n    if (typeof length !== 'number') {\n      // @ts-expect-error\n      source = value;\n      value = name;\n      name = length;\n      // @ts-expect-error\n      length = index.length; // eslint-disable-line prefer-destructuring\n      // @ts-expect-error\n      index = index.index; // eslint-disable-line prefer-destructuring\n    } else {\n      // @ts-expect-error\n      length = index.length; // eslint-disable-line prefer-destructuring\n      // @ts-expect-error\n      index = index.index; // eslint-disable-line prefer-destructuring\n    }\n  } else if (typeof length !== 'number') {\n    // @ts-expect-error\n    source = value;\n    value = name;\n    name = length;\n    length = 0;\n  }\n  // Handle format being object, two format name/value strings or excluded\n  if (typeof name === 'object') {\n    // @ts-expect-error Fix me later\n    formats = name;\n    // @ts-expect-error\n    source = value;\n  } else if (typeof name === 'string') {\n    if (value != null) {\n      formats[name] = value;\n    } else {\n      // @ts-expect-error\n      source = name;\n    }\n  }\n  // Handle optional source\n  source = source || Emitter.sources.API;\n  // @ts-expect-error\n  return [index, length, formats, source];\n}\n\nfunction shiftRange(range: Range, change: Delta, source?: EmitterSource): Range;\nfunction shiftRange(\n  range: Range,\n  index: number,\n  length?: number,\n  source?: EmitterSource,\n): Range;\nfunction shiftRange(\n  range: Range,\n  index: number | Delta,\n  lengthOrSource?: number | EmitterSource,\n  source?: EmitterSource,\n) {\n  const length = typeof lengthOrSource === 'number' ? lengthOrSource : 0;\n  if (range == null) return null;\n  let start;\n  let end;\n  // @ts-expect-error -- TODO: add a better type guard around `index`\n  if (index && typeof index.transformPosition === 'function') {\n    [start, end] = [range.index, range.index + range.length].map((pos) =>\n      // @ts-expect-error -- TODO: add a better type guard around `index`\n      index.transformPosition(pos, source !== Emitter.sources.USER),\n    );\n  } else {\n    [start, end] = [range.index, range.index + range.length].map((pos) => {\n      // @ts-expect-error -- TODO: add a better type guard around `index`\n      if (pos < index || (pos === index && source === Emitter.sources.USER))\n        return pos;\n      if (length >= 0) {\n        return pos + length;\n      }\n      // @ts-expect-error -- TODO: add a better type guard around `index`\n      return Math.max(index, pos + length);\n    });\n  }\n  return new Range(start, end - start);\n}\n\nexport type { Bounds, DebugLevel, EmitterSource };\nexport { Parchment, Range };\n\nexport { globalRegistry, expandConfig, overload, Quill as default };\n","import { ContainerBlot } from 'parchment';\n\nclass Container extends ContainerBlot {}\n\nexport default Container;\n","import { ContainerBlot, LeafBlot, Scope, ScrollBlot } from 'parchment';\nimport type { Blot, Parent, EmbedBlot, ParentBlot, Registry } from 'parchment';\nimport Delta, { AttributeMap, Op } from 'quill-delta';\nimport Emitter from '../core/emitter.js';\nimport type { EmitterSource } from '../core/emitter.js';\nimport Block, { BlockEmbed, bubbleFormats } from './block.js';\nimport Break from './break.js';\nimport Container from './container.js';\n\ntype RenderBlock =\n  | {\n      type: 'blockEmbed';\n      attributes: AttributeMap;\n      key: string;\n      value: unknown;\n    }\n  | { type: 'block'; attributes: AttributeMap; delta: Delta };\n\nfunction isLine(blot: unknown): blot is Block | BlockEmbed {\n  return blot instanceof Block || blot instanceof BlockEmbed;\n}\n\ninterface UpdatableEmbed {\n  updateContent(change: unknown): void;\n}\n\nfunction isUpdatable(blot: Blot): blot is Blot & UpdatableEmbed {\n  return typeof (blot as unknown as any).updateContent === 'function';\n}\n\nclass Scroll extends ScrollBlot {\n  static blotName = 'scroll';\n  static className = 'ql-editor';\n  static tagName = 'DIV';\n  static defaultChild = Block;\n  static allowedChildren = [Block, BlockEmbed, Container];\n\n  emitter: Emitter;\n  batch: false | MutationRecord[];\n\n  constructor(\n    registry: Registry,\n    domNode: HTMLDivElement,\n    { emitter }: { emitter: Emitter },\n  ) {\n    super(registry, domNode);\n    this.emitter = emitter;\n    this.batch = false;\n    this.optimize();\n    this.enable();\n    this.domNode.addEventListener('dragstart', (e) => this.handleDragStart(e));\n  }\n\n  batchStart() {\n    if (!Array.isArray(this.batch)) {\n      this.batch = [];\n    }\n  }\n\n  batchEnd() {\n    if (!this.batch) return;\n    const mutations = this.batch;\n    this.batch = false;\n    this.update(mutations);\n  }\n\n  emitMount(blot: Blot) {\n    this.emitter.emit(Emitter.events.SCROLL_BLOT_MOUNT, blot);\n  }\n\n  emitUnmount(blot: Blot) {\n    this.emitter.emit(Emitter.events.SCROLL_BLOT_UNMOUNT, blot);\n  }\n\n  emitEmbedUpdate(blot: Blot, change: unknown) {\n    this.emitter.emit(Emitter.events.SCROLL_EMBED_UPDATE, blot, change);\n  }\n\n  deleteAt(index: number, length: number) {\n    const [first, offset] = this.line(index);\n    const [last] = this.line(index + length);\n    super.deleteAt(index, length);\n    if (last != null && first !== last && offset > 0) {\n      if (first instanceof BlockEmbed || last instanceof BlockEmbed) {\n        this.optimize();\n        return;\n      }\n      const ref =\n        last.children.head instanceof Break ? null : last.children.head;\n      // @ts-expect-error\n      first.moveChildren(last, ref);\n      // @ts-expect-error\n      first.remove();\n    }\n    this.optimize();\n  }\n\n  enable(enabled = true) {\n    this.domNode.setAttribute('contenteditable', enabled ? 'true' : 'false');\n  }\n\n  formatAt(index: number, length: number, format: string, value: unknown) {\n    super.formatAt(index, length, format, value);\n    this.optimize();\n  }\n\n  insertAt(index: number, value: string, def?: unknown) {\n    if (index >= this.length()) {\n      if (def == null || this.scroll.query(value, Scope.BLOCK) == null) {\n        const blot = this.scroll.create(this.statics.defaultChild.blotName);\n        this.appendChild(blot);\n        if (def == null && value.endsWith('\\n')) {\n          blot.insertAt(0, value.slice(0, -1), def);\n        } else {\n          blot.insertAt(0, value, def);\n        }\n      } else {\n        const embed = this.scroll.create(value, def);\n        this.appendChild(embed);\n      }\n    } else {\n      super.insertAt(index, value, def);\n    }\n    this.optimize();\n  }\n\n  insertBefore(blot: Blot, ref?: Blot | null) {\n    if (blot.statics.scope === Scope.INLINE_BLOT) {\n      const wrapper = this.scroll.create(\n        this.statics.defaultChild.blotName,\n      ) as Parent;\n      wrapper.appendChild(blot);\n      super.insertBefore(wrapper, ref);\n    } else {\n      super.insertBefore(blot, ref);\n    }\n  }\n\n  insertContents(index: number, delta: Delta) {\n    const renderBlocks = this.deltaToRenderBlocks(\n      delta.concat(new Delta().insert('\\n')),\n    );\n    const last = renderBlocks.pop();\n    if (last == null) return;\n\n    this.batchStart();\n\n    const first = renderBlocks.shift();\n    if (first) {\n      const shouldInsertNewlineChar =\n        first.type === 'block' &&\n        (first.delta.length() === 0 ||\n          (!this.descendant(BlockEmbed, index)[0] && index < this.length()));\n      const delta =\n        first.type === 'block'\n          ? first.delta\n          : new Delta().insert({ [first.key]: first.value });\n      insertInlineContents(this, index, delta);\n      const newlineCharLength = first.type === 'block' ? 1 : 0;\n      const lineEndIndex = index + delta.length() + newlineCharLength;\n      if (shouldInsertNewlineChar) {\n        this.insertAt(lineEndIndex - 1, '\\n');\n      }\n\n      const formats = bubbleFormats(this.line(index)[0]);\n      const attributes = AttributeMap.diff(formats, first.attributes) || {};\n      Object.keys(attributes).forEach((name) => {\n        this.formatAt(lineEndIndex - 1, 1, name, attributes[name]);\n      });\n\n      index = lineEndIndex;\n    }\n\n    let [refBlot, refBlotOffset] = this.children.find(index);\n    if (renderBlocks.length) {\n      if (refBlot) {\n        refBlot = refBlot.split(refBlotOffset);\n        refBlotOffset = 0;\n      }\n\n      renderBlocks.forEach((renderBlock) => {\n        if (renderBlock.type === 'block') {\n          const block = this.createBlock(\n            renderBlock.attributes,\n            refBlot || undefined,\n          );\n          insertInlineContents(block, 0, renderBlock.delta);\n        } else {\n          const blockEmbed = this.create(\n            renderBlock.key,\n            renderBlock.value,\n          ) as EmbedBlot;\n          this.insertBefore(blockEmbed, refBlot || undefined);\n          Object.keys(renderBlock.attributes).forEach((name) => {\n            blockEmbed.format(name, renderBlock.attributes[name]);\n          });\n        }\n      });\n    }\n\n    if (last.type === 'block' && last.delta.length()) {\n      const offset = refBlot\n        ? refBlot.offset(refBlot.scroll) + refBlotOffset\n        : this.length();\n      insertInlineContents(this, offset, last.delta);\n    }\n\n    this.batchEnd();\n    this.optimize();\n  }\n\n  isEnabled() {\n    return this.domNode.getAttribute('contenteditable') === 'true';\n  }\n\n  leaf(index: number): [LeafBlot | null, number] {\n    const last = this.path(index).pop();\n    if (!last) {\n      return [null, -1];\n    }\n\n    const [blot, offset] = last;\n    return blot instanceof LeafBlot ? [blot, offset] : [null, -1];\n  }\n\n  line(index: number): [Block | BlockEmbed | null, number] {\n    if (index === this.length()) {\n      return this.line(index - 1);\n    }\n    // @ts-expect-error TODO: make descendant() generic\n    return this.descendant(isLine, index);\n  }\n\n  lines(index = 0, length = Number.MAX_VALUE): (Block | BlockEmbed)[] {\n    const getLines = (\n      blot: ParentBlot,\n      blotIndex: number,\n      blotLength: number,\n    ) => {\n      let lines: (Block | BlockEmbed)[] = [];\n      let lengthLeft = blotLength;\n      blot.children.forEachAt(\n        blotIndex,\n        blotLength,\n        (child, childIndex, childLength) => {\n          if (isLine(child)) {\n            lines.push(child);\n          } else if (child instanceof ContainerBlot) {\n            lines = lines.concat(getLines(child, childIndex, lengthLeft));\n          }\n          lengthLeft -= childLength;\n        },\n      );\n      return lines;\n    };\n    return getLines(this, index, length);\n  }\n\n  optimize(context?: { [key: string]: any }): void;\n  optimize(\n    mutations?: MutationRecord[],\n    context?: { [key: string]: any },\n  ): void;\n  optimize(mutations = [], context = {}) {\n    if (this.batch) return;\n    super.optimize(mutations, context);\n    if (mutations.length > 0) {\n      this.emitter.emit(Emitter.events.SCROLL_OPTIMIZE, mutations, context);\n    }\n  }\n\n  path(index: number) {\n    return super.path(index).slice(1); // Exclude self\n  }\n\n  remove() {\n    // Never remove self\n  }\n\n  update(source?: EmitterSource): void;\n  update(mutations?: MutationRecord[]): void;\n  update(mutations?: MutationRecord[] | EmitterSource): void {\n    if (this.batch) {\n      if (Array.isArray(mutations)) {\n        this.batch = this.batch.concat(mutations);\n      }\n      return;\n    }\n    let source: EmitterSource = Emitter.sources.USER;\n    if (typeof mutations === 'string') {\n      source = mutations;\n    }\n    if (!Array.isArray(mutations)) {\n      mutations = this.observer.takeRecords();\n    }\n    mutations = mutations.filter(({ target }) => {\n      const blot = this.find(target, true);\n      return blot && !isUpdatable(blot);\n    });\n    if (mutations.length > 0) {\n      this.emitter.emit(Emitter.events.SCROLL_BEFORE_UPDATE, source, mutations);\n    }\n    super.update(mutations.concat([])); // pass copy\n    if (mutations.length > 0) {\n      this.emitter.emit(Emitter.events.SCROLL_UPDATE, source, mutations);\n    }\n  }\n\n  updateEmbedAt(index: number, key: string, change: unknown) {\n    // Currently it only supports top-level embeds (BlockEmbed).\n    // We can update `ParentBlot` in parchment to support inline embeds.\n    const [blot] = this.descendant((b: Blot) => b instanceof BlockEmbed, index);\n    if (blot && blot.statics.blotName === key && isUpdatable(blot)) {\n      blot.updateContent(change);\n    }\n  }\n\n  protected handleDragStart(event: DragEvent) {\n    event.preventDefault();\n  }\n\n  private deltaToRenderBlocks(delta: Delta) {\n    const renderBlocks: RenderBlock[] = [];\n\n    let currentBlockDelta = new Delta();\n    delta.forEach((op) => {\n      const insert = op?.insert;\n      if (!insert) return;\n      if (typeof insert === 'string') {\n        const splitted = insert.split('\\n');\n        splitted.slice(0, -1).forEach((text) => {\n          currentBlockDelta.insert(text, op.attributes);\n          renderBlocks.push({\n            type: 'block',\n            delta: currentBlockDelta,\n            attributes: op.attributes ?? {},\n          });\n          currentBlockDelta = new Delta();\n        });\n        const last = splitted[splitted.length - 1];\n        if (last) {\n          currentBlockDelta.insert(last, op.attributes);\n        }\n      } else {\n        const key = Object.keys(insert)[0];\n        if (!key) return;\n        if (this.query(key, Scope.INLINE)) {\n          currentBlockDelta.push(op);\n        } else {\n          if (currentBlockDelta.length()) {\n            renderBlocks.push({\n              type: 'block',\n              delta: currentBlockDelta,\n              attributes: {},\n            });\n          }\n          currentBlockDelta = new Delta();\n          renderBlocks.push({\n            type: 'blockEmbed',\n            key,\n            value: insert[key],\n            attributes: op.attributes ?? {},\n          });\n        }\n      }\n    });\n\n    if (currentBlockDelta.length()) {\n      renderBlocks.push({\n        type: 'block',\n        delta: currentBlockDelta,\n        attributes: {},\n      });\n    }\n\n    return renderBlocks;\n  }\n\n  private createBlock(attributes: AttributeMap, refBlot?: Blot) {\n    let blotName: string | undefined;\n    const formats: AttributeMap = {};\n\n    Object.entries(attributes).forEach(([key, value]) => {\n      const isBlockBlot = this.query(key, Scope.BLOCK & Scope.BLOT) != null;\n      if (isBlockBlot) {\n        blotName = key;\n      } else {\n        formats[key] = value;\n      }\n    });\n\n    const block = this.create(\n      blotName || this.statics.defaultChild.blotName,\n      blotName ? attributes[blotName] : undefined,\n    ) as ParentBlot;\n\n    this.insertBefore(block, refBlot || undefined);\n\n    const length = block.length();\n    Object.entries(formats).forEach(([key, value]) => {\n      block.formatAt(0, length, key, value);\n    });\n\n    return block;\n  }\n}\n\nfunction insertInlineContents(\n  parent: ParentBlot,\n  index: number,\n  inlineContents: Delta,\n) {\n  inlineContents.reduce((index, op) => {\n    const length = Op.length(op);\n    let attributes = op.attributes || {};\n    if (op.insert != null) {\n      if (typeof op.insert === 'string') {\n        const text = op.insert;\n        parent.insertAt(index, text);\n        const [leaf] = parent.descendant(LeafBlot, index);\n        const formats = bubbleFormats(leaf);\n        attributes = AttributeMap.diff(formats, attributes) || {};\n      } else if (typeof op.insert === 'object') {\n        const key = Object.keys(op.insert)[0]; // There should only be one key\n        if (key == null) return index;\n        parent.insertAt(index, key, op.insert[key]);\n        const isInlineEmbed = parent.scroll.query(key, Scope.INLINE) != null;\n        if (isInlineEmbed) {\n          const [leaf] = parent.descendant(LeafBlot, index);\n          const formats = bubbleFormats(leaf);\n          attributes = AttributeMap.diff(formats, attributes) || {};\n        }\n      }\n    }\n    Object.keys(attributes).forEach((key) => {\n      parent.formatAt(index, length, key, attributes[key]);\n    });\n    return index + length;\n  }, index);\n}\n\nexport default Scroll;\n","import { Attributor, ClassAttributor, Scope, StyleAttributor } from 'parchment';\n\nconst config = {\n  scope: Scope.BLOCK,\n  whitelist: ['right', 'center', 'justify'],\n};\n\nconst AlignAttribute = new Attributor('align', 'align', config);\nconst AlignClass = new ClassAttributor('align', 'ql-align', config);\nconst AlignStyle = new StyleAttributor('align', 'text-align', config);\n\nexport { AlignAttribute, AlignClass, AlignStyle };\n","import { ClassAttributor, Scope, StyleAttributor } from 'parchment';\n\nclass ColorAttributor extends StyleAttributor {\n  value(domNode: HTMLElement) {\n    let value = super.value(domNode) as string;\n    if (!value.startsWith('rgb(')) return value;\n    value = value.replace(/^[^\\d]+/, '').replace(/[^\\d]+$/, '');\n    const hex = value\n      .split(',')\n      .map((component) => `00${parseInt(component, 10).toString(16)}`.slice(-2))\n      .join('');\n    return `#${hex}`;\n  }\n}\n\nconst ColorClass = new ClassAttributor('color', 'ql-color', {\n  scope: Scope.INLINE,\n});\nconst ColorStyle = new ColorAttributor('color', 'color', {\n  scope: Scope.INLINE,\n});\n\nexport { ColorAttributor, ColorClass, ColorStyle };\n","import { ClassAttributor, Scope } from 'parchment';\nimport { ColorAttributor } from './color.js';\n\nconst BackgroundClass = new ClassAttributor('background', 'ql-bg', {\n  scope: Scope.INLINE,\n});\nconst BackgroundStyle = new ColorAttributor('background', 'background-color', {\n  scope: Scope.INLINE,\n});\n\nexport { BackgroundClass, BackgroundStyle };\n","import Block from '../blots/block.js';\nimport Break from '../blots/break.js';\nimport Cursor from '../blots/cursor.js';\nimport Inline from '../blots/inline.js';\nimport TextBlot, { escapeText } from '../blots/text.js';\nimport Container from '../blots/container.js';\nimport Quill from '../core/quill.js';\n\nclass CodeBlockContainer extends Container {\n  static create(value: string) {\n    const domNode = super.create(value) as Element;\n    domNode.setAttribute('spellcheck', 'false');\n    return domNode;\n  }\n\n  code(index: number, length: number) {\n    return (\n      this.children\n        // @ts-expect-error\n        .map((child) => (child.length() <= 1 ? '' : child.domNode.innerText))\n        .join('\\n')\n        .slice(index, index + length)\n    );\n  }\n\n  html(index: number, length: number) {\n    // `\\n`s are needed in order to support empty lines at the beginning and the end.\n    // https://html.spec.whatwg.org/multipage/syntax.html#element-restrictions\n    return `<pre>\\n${escapeText(this.code(index, length))}\\n</pre>`;\n  }\n}\n\nclass CodeBlock extends Block {\n  static TAB = '  ';\n\n  static register() {\n    Quill.register(CodeBlockContainer);\n  }\n}\n\nclass Code extends Inline {}\nCode.blotName = 'code';\nCode.tagName = 'CODE';\n\nCodeBlock.blotName = 'code-block';\nCodeBlock.className = 'ql-code-block';\nCodeBlock.tagName = 'DIV';\nCodeBlockContainer.blotName = 'code-block-container';\nCodeBlockContainer.className = 'ql-code-block-container';\nCodeBlockContainer.tagName = 'DIV';\n\nCodeBlockContainer.allowedChildren = [CodeBlock];\n\nCodeBlock.allowedChildren = [TextBlot, Break, Cursor];\nCodeBlock.requiredContainer = CodeBlockContainer;\n\nexport { Code, CodeBlockContainer, CodeBlock as default };\n","import { Attributor, ClassAttributor, Scope, StyleAttributor } from 'parchment';\n\nconst config = {\n  scope: Scope.BLOCK,\n  whitelist: ['rtl'],\n};\n\nconst DirectionAttribute = new Attributor('direction', 'dir', config);\nconst DirectionClass = new ClassAttributor('direction', 'ql-direction', config);\nconst DirectionStyle = new StyleAttributor('direction', 'direction', config);\n\nexport { DirectionAttribute, DirectionClass, DirectionStyle };\n","import { ClassAttributor, Scope, StyleAttributor } from 'parchment';\n\nconst config = {\n  scope: Scope.INLINE,\n  whitelist: ['serif', 'monospace'],\n};\n\nconst FontClass = new ClassAttributor('font', 'ql-font', config);\n\nclass FontStyleAttributor extends StyleAttributor {\n  value(node: HTMLElement) {\n    return super.value(node).replace(/[\"']/g, '');\n  }\n}\n\nconst FontStyle = new FontStyleAttributor('font', 'font-family', config);\n\nexport { FontStyle, FontClass };\n","import { ClassAttributor, Scope, StyleAttributor } from 'parchment';\n\nconst SizeClass = new ClassAttributor('size', 'ql-size', {\n  scope: Scope.INLINE,\n  whitelist: ['small', 'large', 'huge'],\n});\nconst SizeStyle = new StyleAttributor('size', 'font-size', {\n  scope: Scope.INLINE,\n  whitelist: ['10px', '18px', '32px'],\n});\n\nexport { SizeClass, SizeStyle };\n","import { cloneDeep, isEqual } from 'lodash-es';\nimport Delta, { AttributeMap } from 'quill-delta';\nimport { EmbedBlot, Scope, TextBlot } from 'parchment';\nimport type { Blot, BlockBlot } from 'parchment';\nimport Quill from '../core/quill.js';\nimport logger from '../core/logger.js';\nimport Module from '../core/module.js';\nimport type { BlockEmbed } from '../blots/block.js';\nimport type { Range } from '../core/selection.js';\n\nconst debug = logger('quill:keyboard');\n\nconst SHORTKEY = /Mac/i.test(navigator.platform) ? 'metaKey' : 'ctrlKey';\n\nexport interface Context {\n  collapsed: boolean;\n  empty: boolean;\n  offset: number;\n  prefix: string;\n  suffix: string;\n  format: Record<string, unknown>;\n  event: KeyboardEvent;\n  line: BlockEmbed | BlockBlot;\n}\n\ninterface BindingObject\n  extends Partial<Omit<Context, 'prefix' | 'suffix' | 'format'>> {\n  key: number | string | string[];\n  shortKey?: boolean | null;\n  shiftKey?: boolean | null;\n  altKey?: boolean | null;\n  metaKey?: boolean | null;\n  ctrlKey?: boolean | null;\n  prefix?: RegExp;\n  suffix?: RegExp;\n  format?: Record<string, unknown> | string[];\n  handler?: (\n    this: { quill: Quill },\n    range: Range,\n    curContext: Context,\n    // eslint-disable-next-line no-use-before-define\n    binding: NormalizedBinding,\n  ) => boolean | void;\n}\n\ntype Binding = BindingObject | string | number;\n\ninterface NormalizedBinding extends Omit<BindingObject, 'key' | 'shortKey'> {\n  key: string | number;\n}\n\ninterface KeyboardOptions {\n  bindings: Record<string, Binding>;\n}\n\ninterface KeyboardOptions {\n  bindings: Record<string, Binding>;\n}\n\nclass Keyboard extends Module<KeyboardOptions> {\n  static DEFAULTS: KeyboardOptions;\n\n  static match(evt: KeyboardEvent, binding: BindingObject) {\n    if (\n      (['altKey', 'ctrlKey', 'metaKey', 'shiftKey'] as const).some((key) => {\n        return !!binding[key] !== evt[key] && binding[key] !== null;\n      })\n    ) {\n      return false;\n    }\n    return binding.key === evt.key || binding.key === evt.which;\n  }\n\n  bindings: Record<string, NormalizedBinding[]>;\n\n  constructor(quill: Quill, options: Partial<KeyboardOptions>) {\n    super(quill, options);\n    this.bindings = {};\n    // @ts-expect-error Fix me later\n    Object.keys(this.options.bindings).forEach((name) => {\n      // @ts-expect-error Fix me later\n      if (this.options.bindings[name]) {\n        // @ts-expect-error Fix me later\n        this.addBinding(this.options.bindings[name]);\n      }\n    });\n    this.addBinding({ key: 'Enter', shiftKey: null }, this.handleEnter);\n    this.addBinding(\n      { key: 'Enter', metaKey: null, ctrlKey: null, altKey: null },\n      () => {},\n    );\n    if (/Firefox/i.test(navigator.userAgent)) {\n      // Need to handle delete and backspace for Firefox in the general case #1171\n      this.addBinding(\n        { key: 'Backspace' },\n        { collapsed: true },\n        this.handleBackspace,\n      );\n      this.addBinding(\n        { key: 'Delete' },\n        { collapsed: true },\n        this.handleDelete,\n      );\n    } else {\n      this.addBinding(\n        { key: 'Backspace' },\n        { collapsed: true, prefix: /^.?$/ },\n        this.handleBackspace,\n      );\n      this.addBinding(\n        { key: 'Delete' },\n        { collapsed: true, suffix: /^.?$/ },\n        this.handleDelete,\n      );\n    }\n    this.addBinding(\n      { key: 'Backspace' },\n      { collapsed: false },\n      this.handleDeleteRange,\n    );\n    this.addBinding(\n      { key: 'Delete' },\n      { collapsed: false },\n      this.handleDeleteRange,\n    );\n    this.addBinding(\n      {\n        key: 'Backspace',\n        altKey: null,\n        ctrlKey: null,\n        metaKey: null,\n        shiftKey: null,\n      },\n      { collapsed: true, offset: 0 },\n      this.handleBackspace,\n    );\n    this.listen();\n  }\n\n  addBinding(\n    keyBinding: Binding,\n    context:\n      | Required<BindingObject['handler']>\n      | Partial<Omit<BindingObject, 'key' | 'handler'>> = {},\n    handler:\n      | Required<BindingObject['handler']>\n      | Partial<Omit<BindingObject, 'key' | 'handler'>> = {},\n  ) {\n    const binding = normalize(keyBinding);\n    if (binding == null) {\n      debug.warn('Attempted to add invalid keyboard binding', binding);\n      return;\n    }\n    if (typeof context === 'function') {\n      context = { handler: context };\n    }\n    if (typeof handler === 'function') {\n      handler = { handler };\n    }\n    const keys = Array.isArray(binding.key) ? binding.key : [binding.key];\n    keys.forEach((key) => {\n      const singleBinding = {\n        ...binding,\n        key,\n        ...context,\n        ...handler,\n      };\n      this.bindings[singleBinding.key] = this.bindings[singleBinding.key] || [];\n      this.bindings[singleBinding.key].push(singleBinding);\n    });\n  }\n\n  listen() {\n    this.quill.root.addEventListener('keydown', (evt) => {\n      if (evt.defaultPrevented || evt.isComposing) return;\n\n      // evt.isComposing is false when pressing Enter/Backspace when composing in Safari\n      // https://bugs.webkit.org/show_bug.cgi?id=165004\n      const isComposing =\n        evt.keyCode === 229 && (evt.key === 'Enter' || evt.key === 'Backspace');\n      if (isComposing) return;\n\n      const bindings = (this.bindings[evt.key] || []).concat(\n        this.bindings[evt.which] || [],\n      );\n      const matches = bindings.filter((binding) =>\n        Keyboard.match(evt, binding),\n      );\n      if (matches.length === 0) return;\n      // @ts-expect-error\n      const blot = Quill.find(evt.target, true);\n      if (blot && blot.scroll !== this.quill.scroll) return;\n      const range = this.quill.getSelection();\n      if (range == null || !this.quill.hasFocus()) return;\n      const [line, offset] = this.quill.getLine(range.index);\n      const [leafStart, offsetStart] = this.quill.getLeaf(range.index);\n      const [leafEnd, offsetEnd] =\n        range.length === 0\n          ? [leafStart, offsetStart]\n          : this.quill.getLeaf(range.index + range.length);\n      const prefixText =\n        leafStart instanceof TextBlot\n          ? leafStart.value().slice(0, offsetStart)\n          : '';\n      const suffixText =\n        leafEnd instanceof TextBlot ? leafEnd.value().slice(offsetEnd) : '';\n      const curContext = {\n        collapsed: range.length === 0,\n        // @ts-expect-error Fix me later\n        empty: range.length === 0 && line.length() <= 1,\n        format: this.quill.getFormat(range),\n        line,\n        offset,\n        prefix: prefixText,\n        suffix: suffixText,\n        event: evt,\n      };\n      const prevented = matches.some((binding) => {\n        if (\n          binding.collapsed != null &&\n          binding.collapsed !== curContext.collapsed\n        ) {\n          return false;\n        }\n        if (binding.empty != null && binding.empty !== curContext.empty) {\n          return false;\n        }\n        if (binding.offset != null && binding.offset !== curContext.offset) {\n          return false;\n        }\n        if (Array.isArray(binding.format)) {\n          // any format is present\n          if (binding.format.every((name) => curContext.format[name] == null)) {\n            return false;\n          }\n        } else if (typeof binding.format === 'object') {\n          // all formats must match\n          if (\n            !Object.keys(binding.format).every((name) => {\n              // @ts-expect-error Fix me later\n              if (binding.format[name] === true)\n                return curContext.format[name] != null;\n              // @ts-expect-error Fix me later\n              if (binding.format[name] === false)\n                return curContext.format[name] == null;\n              // @ts-expect-error Fix me later\n              return isEqual(binding.format[name], curContext.format[name]);\n            })\n          ) {\n            return false;\n          }\n        }\n        if (binding.prefix != null && !binding.prefix.test(curContext.prefix)) {\n          return false;\n        }\n        if (binding.suffix != null && !binding.suffix.test(curContext.suffix)) {\n          return false;\n        }\n        // @ts-expect-error Fix me later\n        return binding.handler.call(this, range, curContext, binding) !== true;\n      });\n      if (prevented) {\n        evt.preventDefault();\n      }\n    });\n  }\n\n  handleBackspace(range: Range, context: Context) {\n    // Check for astral symbols\n    const length = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]$/.test(context.prefix)\n      ? 2\n      : 1;\n    if (range.index === 0 || this.quill.getLength() <= 1) return;\n    let formats = {};\n    const [line] = this.quill.getLine(range.index);\n    let delta = new Delta().retain(range.index - length).delete(length);\n    if (context.offset === 0) {\n      // Always deleting newline here, length always 1\n      const [prev] = this.quill.getLine(range.index - 1);\n      if (prev) {\n        const isPrevLineEmpty =\n          prev.statics.blotName === 'block' && prev.length() <= 1;\n        if (!isPrevLineEmpty) {\n          // @ts-expect-error Fix me later\n          const curFormats = line.formats();\n          const prevFormats = this.quill.getFormat(range.index - 1, 1);\n          formats = AttributeMap.diff(curFormats, prevFormats) || {};\n          if (Object.keys(formats).length > 0) {\n            // line.length() - 1 targets \\n in line, another -1 for newline being deleted\n            const formatDelta = new Delta()\n              // @ts-expect-error Fix me later\n              .retain(range.index + line.length() - 2)\n              .retain(1, formats);\n            delta = delta.compose(formatDelta);\n          }\n        }\n      }\n    }\n    this.quill.updateContents(delta, Quill.sources.USER);\n    this.quill.focus();\n  }\n\n  handleDelete(range: Range, context: Context) {\n    // Check for astral symbols\n    const length = /^[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/.test(context.suffix)\n      ? 2\n      : 1;\n    if (range.index >= this.quill.getLength() - length) return;\n    let formats = {};\n    const [line] = this.quill.getLine(range.index);\n    let delta = new Delta().retain(range.index).delete(length);\n    // @ts-expect-error Fix me later\n    if (context.offset >= line.length() - 1) {\n      const [next] = this.quill.getLine(range.index + 1);\n      if (next) {\n        // @ts-expect-error Fix me later\n        const curFormats = line.formats();\n        const nextFormats = this.quill.getFormat(range.index, 1);\n        formats = AttributeMap.diff(curFormats, nextFormats) || {};\n        if (Object.keys(formats).length > 0) {\n          delta = delta.retain(next.length() - 1).retain(1, formats);\n        }\n      }\n    }\n    this.quill.updateContents(delta, Quill.sources.USER);\n    this.quill.focus();\n  }\n\n  handleDeleteRange(range: Range) {\n    deleteRange({ range, quill: this.quill });\n    this.quill.focus();\n  }\n\n  handleEnter(range: Range, context: Context) {\n    const lineFormats = Object.keys(context.format).reduce(\n      (formats: Record<string, unknown>, format) => {\n        if (\n          this.quill.scroll.query(format, Scope.BLOCK) &&\n          !Array.isArray(context.format[format])\n        ) {\n          formats[format] = context.format[format];\n        }\n        return formats;\n      },\n      {},\n    );\n    const delta = new Delta()\n      .retain(range.index)\n      .delete(range.length)\n      .insert('\\n', lineFormats);\n    this.quill.updateContents(delta, Quill.sources.USER);\n    this.quill.setSelection(range.index + 1, Quill.sources.SILENT);\n    this.quill.focus();\n  }\n}\n\nconst defaultOptions: KeyboardOptions = {\n  bindings: {\n    bold: makeFormatHandler('bold'),\n    italic: makeFormatHandler('italic'),\n    underline: makeFormatHandler('underline'),\n    indent: {\n      // highlight tab or tab at beginning of list, indent or blockquote\n      key: 'Tab',\n      format: ['blockquote', 'indent', 'list'],\n      handler(range, context) {\n        if (context.collapsed && context.offset !== 0) return true;\n        this.quill.format('indent', '+1', Quill.sources.USER);\n        return false;\n      },\n    },\n    outdent: {\n      key: 'Tab',\n      shiftKey: true,\n      format: ['blockquote', 'indent', 'list'],\n      // highlight tab or tab at beginning of list, indent or blockquote\n      handler(range, context) {\n        if (context.collapsed && context.offset !== 0) return true;\n        this.quill.format('indent', '-1', Quill.sources.USER);\n        return false;\n      },\n    },\n    'outdent backspace': {\n      key: 'Backspace',\n      collapsed: true,\n      shiftKey: null,\n      metaKey: null,\n      ctrlKey: null,\n      altKey: null,\n      format: ['indent', 'list'],\n      offset: 0,\n      handler(range, context) {\n        if (context.format.indent != null) {\n          this.quill.format('indent', '-1', Quill.sources.USER);\n        } else if (context.format.list != null) {\n          this.quill.format('list', false, Quill.sources.USER);\n        }\n      },\n    },\n    'indent code-block': makeCodeBlockHandler(true),\n    'outdent code-block': makeCodeBlockHandler(false),\n    'remove tab': {\n      key: 'Tab',\n      shiftKey: true,\n      collapsed: true,\n      prefix: /\\t$/,\n      handler(range) {\n        this.quill.deleteText(range.index - 1, 1, Quill.sources.USER);\n      },\n    },\n    tab: {\n      key: 'Tab',\n      handler(range, context) {\n        if (context.format.table) return true;\n        this.quill.history.cutoff();\n        const delta = new Delta()\n          .retain(range.index)\n          .delete(range.length)\n          .insert('\\t');\n        this.quill.updateContents(delta, Quill.sources.USER);\n        this.quill.history.cutoff();\n        this.quill.setSelection(range.index + 1, Quill.sources.SILENT);\n        return false;\n      },\n    },\n    'blockquote empty enter': {\n      key: 'Enter',\n      collapsed: true,\n      format: ['blockquote'],\n      empty: true,\n      handler() {\n        this.quill.format('blockquote', false, Quill.sources.USER);\n      },\n    },\n    'list empty enter': {\n      key: 'Enter',\n      collapsed: true,\n      format: ['list'],\n      empty: true,\n      handler(range, context) {\n        const formats: Record<string, unknown> = { list: false };\n        if (context.format.indent) {\n          formats.indent = false;\n        }\n        this.quill.formatLine(\n          range.index,\n          range.length,\n          formats,\n          Quill.sources.USER,\n        );\n      },\n    },\n    'checklist enter': {\n      key: 'Enter',\n      collapsed: true,\n      format: { list: 'checked' },\n      handler(range) {\n        const [line, offset] = this.quill.getLine(range.index);\n        const formats = {\n          // @ts-expect-error Fix me later\n          ...line.formats(),\n          list: 'checked',\n        };\n        const delta = new Delta()\n          .retain(range.index)\n          .insert('\\n', formats)\n          // @ts-expect-error Fix me later\n          .retain(line.length() - offset - 1)\n          .retain(1, { list: 'unchecked' });\n        this.quill.updateContents(delta, Quill.sources.USER);\n        this.quill.setSelection(range.index + 1, Quill.sources.SILENT);\n        this.quill.scrollSelectionIntoView();\n      },\n    },\n    'header enter': {\n      key: 'Enter',\n      collapsed: true,\n      format: ['header'],\n      suffix: /^$/,\n      handler(range, context) {\n        const [line, offset] = this.quill.getLine(range.index);\n        const delta = new Delta()\n          .retain(range.index)\n          .insert('\\n', context.format)\n          // @ts-expect-error Fix me later\n          .retain(line.length() - offset - 1)\n          .retain(1, { header: null });\n        this.quill.updateContents(delta, Quill.sources.USER);\n        this.quill.setSelection(range.index + 1, Quill.sources.SILENT);\n        this.quill.scrollSelectionIntoView();\n      },\n    },\n    'table backspace': {\n      key: 'Backspace',\n      format: ['table'],\n      collapsed: true,\n      offset: 0,\n      handler() {},\n    },\n    'table delete': {\n      key: 'Delete',\n      format: ['table'],\n      collapsed: true,\n      suffix: /^$/,\n      handler() {},\n    },\n    'table enter': {\n      key: 'Enter',\n      shiftKey: null,\n      format: ['table'],\n      handler(range) {\n        const module = this.quill.getModule('table');\n        if (module) {\n          // @ts-expect-error\n          const [table, row, cell, offset] = module.getTable(range);\n          const shift = tableSide(table, row, cell, offset);\n          if (shift == null) return;\n          let index = table.offset();\n          if (shift < 0) {\n            const delta = new Delta().retain(index).insert('\\n');\n            this.quill.updateContents(delta, Quill.sources.USER);\n            this.quill.setSelection(\n              range.index + 1,\n              range.length,\n              Quill.sources.SILENT,\n            );\n          } else if (shift > 0) {\n            index += table.length();\n            const delta = new Delta().retain(index).insert('\\n');\n            this.quill.updateContents(delta, Quill.sources.USER);\n            this.quill.setSelection(index, Quill.sources.USER);\n          }\n        }\n      },\n    },\n    'table tab': {\n      key: 'Tab',\n      shiftKey: null,\n      format: ['table'],\n      handler(range, context) {\n        const { event, line: cell } = context;\n        const offset = cell.offset(this.quill.scroll);\n        if (event.shiftKey) {\n          this.quill.setSelection(offset - 1, Quill.sources.USER);\n        } else {\n          this.quill.setSelection(offset + cell.length(), Quill.sources.USER);\n        }\n      },\n    },\n    'list autofill': {\n      key: ' ',\n      shiftKey: null,\n      collapsed: true,\n      format: {\n        'code-block': false,\n        blockquote: false,\n        table: false,\n      },\n      prefix: /^\\s*?(\\d+\\.|-|\\*|\\[ ?\\]|\\[x\\])$/,\n      handler(range, context) {\n        if (this.quill.scroll.query('list') == null) return true;\n        const { length } = context.prefix;\n        const [line, offset] = this.quill.getLine(range.index);\n        if (offset > length) return true;\n        let value;\n        switch (context.prefix.trim()) {\n          case '[]':\n          case '[ ]':\n            value = 'unchecked';\n            break;\n          case '[x]':\n            value = 'checked';\n            break;\n          case '-':\n          case '*':\n            value = 'bullet';\n            break;\n          default:\n            value = 'ordered';\n        }\n        this.quill.insertText(range.index, ' ', Quill.sources.USER);\n        this.quill.history.cutoff();\n        const delta = new Delta()\n          .retain(range.index - offset)\n          .delete(length + 1)\n          // @ts-expect-error Fix me later\n          .retain(line.length() - 2 - offset)\n          .retain(1, { list: value });\n        this.quill.updateContents(delta, Quill.sources.USER);\n        this.quill.history.cutoff();\n        this.quill.setSelection(range.index - length, Quill.sources.SILENT);\n        return false;\n      },\n    },\n    'code exit': {\n      key: 'Enter',\n      collapsed: true,\n      format: ['code-block'],\n      prefix: /^$/,\n      suffix: /^\\s*$/,\n      handler(range) {\n        const [line, offset] = this.quill.getLine(range.index);\n        let numLines = 2;\n        let cur = line;\n        while (\n          cur != null &&\n          cur.length() <= 1 &&\n          cur.formats()['code-block']\n        ) {\n          // @ts-expect-error\n          cur = cur.prev;\n          numLines -= 1;\n          // Requisite prev lines are empty\n          if (numLines <= 0) {\n            const delta = new Delta()\n              // @ts-expect-error Fix me later\n              .retain(range.index + line.length() - offset - 2)\n              .retain(1, { 'code-block': null })\n              .delete(1);\n            this.quill.updateContents(delta, Quill.sources.USER);\n            this.quill.setSelection(range.index - 1, Quill.sources.SILENT);\n            return false;\n          }\n        }\n        return true;\n      },\n    },\n    'embed left': makeEmbedArrowHandler('ArrowLeft', false),\n    'embed left shift': makeEmbedArrowHandler('ArrowLeft', true),\n    'embed right': makeEmbedArrowHandler('ArrowRight', false),\n    'embed right shift': makeEmbedArrowHandler('ArrowRight', true),\n    'table down': makeTableArrowHandler(false),\n    'table up': makeTableArrowHandler(true),\n  },\n};\n\nKeyboard.DEFAULTS = defaultOptions;\n\nfunction makeCodeBlockHandler(indent: boolean): BindingObject {\n  return {\n    key: 'Tab',\n    shiftKey: !indent,\n    format: { 'code-block': true },\n    handler(range, { event }) {\n      const CodeBlock = this.quill.scroll.query('code-block');\n      // @ts-expect-error\n      const { TAB } = CodeBlock;\n      if (range.length === 0 && !event.shiftKey) {\n        this.quill.insertText(range.index, TAB, Quill.sources.USER);\n        this.quill.setSelection(range.index + TAB.length, Quill.sources.SILENT);\n        return;\n      }\n\n      const lines =\n        range.length === 0\n          ? this.quill.getLines(range.index, 1)\n          : this.quill.getLines(range);\n      let { index, length } = range;\n      lines.forEach((line, i) => {\n        if (indent) {\n          line.insertAt(0, TAB);\n          if (i === 0) {\n            index += TAB.length;\n          } else {\n            length += TAB.length;\n          }\n          // @ts-expect-error Fix me later\n        } else if (line.domNode.textContent.startsWith(TAB)) {\n          line.deleteAt(0, TAB.length);\n          if (i === 0) {\n            index -= TAB.length;\n          } else {\n            length -= TAB.length;\n          }\n        }\n      });\n      this.quill.update(Quill.sources.USER);\n      this.quill.setSelection(index, length, Quill.sources.SILENT);\n    },\n  };\n}\n\nfunction makeEmbedArrowHandler(\n  key: string,\n  shiftKey: boolean | null,\n): BindingObject {\n  const where = key === 'ArrowLeft' ? 'prefix' : 'suffix';\n  return {\n    key,\n    shiftKey,\n    altKey: null,\n    [where]: /^$/,\n    handler(range) {\n      let { index } = range;\n      if (key === 'ArrowRight') {\n        index += range.length + 1;\n      }\n      const [leaf] = this.quill.getLeaf(index);\n      if (!(leaf instanceof EmbedBlot)) return true;\n      if (key === 'ArrowLeft') {\n        if (shiftKey) {\n          this.quill.setSelection(\n            range.index - 1,\n            range.length + 1,\n            Quill.sources.USER,\n          );\n        } else {\n          this.quill.setSelection(range.index - 1, Quill.sources.USER);\n        }\n      } else if (shiftKey) {\n        this.quill.setSelection(\n          range.index,\n          range.length + 1,\n          Quill.sources.USER,\n        );\n      } else {\n        this.quill.setSelection(\n          range.index + range.length + 1,\n          Quill.sources.USER,\n        );\n      }\n      return false;\n    },\n  };\n}\n\nfunction makeFormatHandler(format: string): BindingObject {\n  return {\n    key: format[0],\n    shortKey: true,\n    handler(range, context) {\n      this.quill.format(format, !context.format[format], Quill.sources.USER);\n    },\n  };\n}\n\nfunction makeTableArrowHandler(up: boolean): BindingObject {\n  return {\n    key: up ? 'ArrowUp' : 'ArrowDown',\n    collapsed: true,\n    format: ['table'],\n    handler(range, context) {\n      // TODO move to table module\n      const key = up ? 'prev' : 'next';\n      const cell = context.line;\n      const targetRow = cell.parent[key];\n      if (targetRow != null) {\n        if (targetRow.statics.blotName === 'table-row') {\n          // @ts-expect-error\n          let targetCell = targetRow.children.head;\n          let cur = cell;\n          while (cur.prev != null) {\n            // @ts-expect-error\n            cur = cur.prev;\n            targetCell = targetCell.next;\n          }\n          const index =\n            targetCell.offset(this.quill.scroll) +\n            Math.min(context.offset, targetCell.length() - 1);\n          this.quill.setSelection(index, 0, Quill.sources.USER);\n        }\n      } else {\n        // @ts-expect-error\n        const targetLine = cell.table()[key];\n        if (targetLine != null) {\n          if (up) {\n            this.quill.setSelection(\n              targetLine.offset(this.quill.scroll) + targetLine.length() - 1,\n              0,\n              Quill.sources.USER,\n            );\n          } else {\n            this.quill.setSelection(\n              targetLine.offset(this.quill.scroll),\n              0,\n              Quill.sources.USER,\n            );\n          }\n        }\n      }\n      return false;\n    },\n  };\n}\n\nfunction normalize(binding: Binding): BindingObject | null {\n  if (typeof binding === 'string' || typeof binding === 'number') {\n    binding = { key: binding };\n  } else if (typeof binding === 'object') {\n    binding = cloneDeep(binding);\n  } else {\n    return null;\n  }\n  if (binding.shortKey) {\n    binding[SHORTKEY] = binding.shortKey;\n    delete binding.shortKey;\n  }\n  return binding;\n}\n\n// TODO: Move into quill.ts or editor.ts\nfunction deleteRange({ quill, range }: { quill: Quill; range: Range }) {\n  const lines = quill.getLines(range);\n  let formats = {};\n  if (lines.length > 1) {\n    const firstFormats = lines[0].formats();\n    const lastFormats = lines[lines.length - 1].formats();\n    formats = AttributeMap.diff(lastFormats, firstFormats) || {};\n  }\n  quill.deleteText(range, Quill.sources.USER);\n  if (Object.keys(formats).length > 0) {\n    quill.formatLine(range.index, 1, formats, Quill.sources.USER);\n  }\n  quill.setSelection(range.index, Quill.sources.SILENT);\n}\n\nfunction tableSide(_table: unknown, row: Blot, cell: Blot, offset: number) {\n  if (row.prev == null && row.next == null) {\n    if (cell.prev == null && cell.next == null) {\n      return offset === 0 ? -1 : 1;\n    }\n    return cell.prev == null ? -1 : 1;\n  }\n  if (row.prev == null) {\n    return -1;\n  }\n  if (row.next == null) {\n    return 1;\n  }\n  return null;\n}\n\nexport { Keyboard as default, SHORTKEY, normalize, deleteRange };\n","const normalWeightRegexp = /font-weight:\\s*normal/;\nconst blockTagNames = ['P', 'OL', 'UL'];\n\nconst isBlockElement = (element: Element | null) => {\n  return element && blockTagNames.includes(element.tagName);\n};\n\nconst normalizeEmptyLines = (doc: Document) => {\n  Array.from(doc.querySelectorAll('br'))\n    .filter(\n      (br) =>\n        isBlockElement(br.previousElementSibling) &&\n        isBlockElement(br.nextElementSibling),\n    )\n    .forEach((br) => {\n      br.parentNode?.removeChild(br);\n    });\n};\n\nconst normalizeFontWeight = (doc: Document) => {\n  Array.from(doc.querySelectorAll('b[style*=\"font-weight\"]'))\n    .filter((node) => node.getAttribute('style')?.match(normalWeightRegexp))\n    .forEach((node) => {\n      const fragment = doc.createDocumentFragment();\n      fragment.append(...node.childNodes);\n      node.parentNode?.replaceChild(fragment, node);\n    });\n};\n\nexport default function normalize(doc: Document) {\n  if (doc.querySelector('[id^=\"docs-internal-guid-\"]')) {\n    normalizeFontWeight(doc);\n    normalizeEmptyLines(doc);\n  }\n}\n","const ignoreRegexp = /\\bmso-list:[^;]*ignore/i;\nconst idRegexp = /\\bmso-list:[^;]*\\bl(\\d+)/i;\nconst indentRegexp = /\\bmso-list:[^;]*\\blevel(\\d+)/i;\n\nconst parseListItem = (element: Element, html: string) => {\n  const style = element.getAttribute('style');\n  const idMatch = style?.match(idRegexp);\n  if (!idMatch) {\n    return null;\n  }\n  const id = Number(idMatch[1]);\n\n  const indentMatch = style?.match(indentRegexp);\n  const indent = indentMatch ? Number(indentMatch[1]) : 1;\n\n  const typeRegexp = new RegExp(\n    `@list l${id}:level${indent}\\\\s*\\\\{[^\\\\}]*mso-level-number-format:\\\\s*([\\\\w-]+)`,\n    'i',\n  );\n  const typeMatch = html.match(typeRegexp);\n  const type = typeMatch && typeMatch[1] === 'bullet' ? 'bullet' : 'ordered';\n\n  return { id, indent, type, element };\n};\n\n// list items are represented as `p` tags with styles like `mso-list: l0 level1` where:\n// 1. \"0\" in \"l0\" means the list item id;\n// 2. \"1\" in \"level1\" means the indent level, starting from 1.\nconst normalizeListItem = (doc: Document) => {\n  const msoList = Array.from(doc.querySelectorAll('[style*=mso-list]'));\n  const ignored: Element[] = [];\n  const others: Element[] = [];\n  msoList.forEach((node) => {\n    const shouldIgnore = (node.getAttribute('style') || '').match(ignoreRegexp);\n    if (shouldIgnore) {\n      ignored.push(node);\n    } else {\n      others.push(node);\n    }\n  });\n\n  // Each list item contains a marker wrapped with \"mso-list: Ignore\".\n  ignored.forEach((node) => node.parentNode?.removeChild(node));\n\n  // The list stype is not defined inline with the tag, instead, it's in the\n  // style tag so we need to pass the html as a string.\n  const html = doc.documentElement.innerHTML;\n  const listItems = others\n    .map((element) => parseListItem(element, html))\n    .filter((parsed) => parsed);\n\n  while (listItems.length) {\n    const childListItems = [];\n\n    let current = listItems.shift();\n    // Group continuous items into the same group (aka \"ul\")\n    while (current) {\n      childListItems.push(current);\n      current =\n        listItems.length &&\n        listItems[0]?.element === current.element.nextElementSibling &&\n        // Different id means the next item doesn't belong to this group.\n        listItems[0].id === current.id\n          ? listItems.shift()\n          : null;\n    }\n\n    const ul = document.createElement('ul');\n    childListItems.forEach((listItem) => {\n      const li = document.createElement('li');\n      li.setAttribute('data-list', listItem.type);\n      if (listItem.indent > 1) {\n        li.setAttribute('class', `ql-indent-${listItem.indent - 1}`);\n      }\n      li.innerHTML = listItem.element.innerHTML;\n      ul.appendChild(li);\n    });\n\n    const element = childListItems[0]?.element;\n    const { parentNode } = element ?? {};\n    if (element) {\n      parentNode?.replaceChild(ul, element);\n    }\n    childListItems.slice(1).forEach(({ element: e }) => {\n      parentNode?.removeChild(e);\n    });\n  }\n};\n\nexport default function normalize(doc: Document) {\n  if (\n    doc.documentElement.getAttribute('xmlns:w') ===\n    'urn:schemas-microsoft-com:office:word'\n  ) {\n    normalizeListItem(doc);\n  }\n}\n","import googleDocs from './normalizers/googleDocs.js';\nimport msWord from './normalizers/msWord.js';\n\nconst NORMALIZERS = [msWord, googleDocs];\n\nconst normalizeExternalHTML = (doc: Document) => {\n  if (doc.documentElement) {\n    NORMALIZERS.forEach((normalize) => {\n      normalize(doc);\n    });\n  }\n};\n\nexport default normalizeExternalHTML;\n","import type { ScrollBlot } from 'parchment';\nimport {\n  Attributor,\n  BlockBlot,\n  ClassAttributor,\n  EmbedBlot,\n  Scope,\n  StyleAttributor,\n} from 'parchment';\nimport Delta from 'quill-delta';\nimport { BlockEmbed } from '../blots/block.js';\nimport type { EmitterSource } from '../core/emitter.js';\nimport logger from '../core/logger.js';\nimport Module from '../core/module.js';\nimport Quill from '../core/quill.js';\nimport type { Range } from '../core/selection.js';\nimport { AlignAttribute, AlignStyle } from '../formats/align.js';\nimport { BackgroundStyle } from '../formats/background.js';\nimport CodeBlock from '../formats/code.js';\nimport { ColorStyle } from '../formats/color.js';\nimport { DirectionAttribute, DirectionStyle } from '../formats/direction.js';\nimport { FontStyle } from '../formats/font.js';\nimport { SizeStyle } from '../formats/size.js';\nimport { deleteRange } from './keyboard.js';\nimport normalizeExternalHTML from './normalizeExternalHTML/index.js';\n\nconst debug = logger('quill:clipboard');\n\ntype Selector = string | Node['TEXT_NODE'] | Node['ELEMENT_NODE'];\ntype Matcher = (node: Node, delta: Delta, scroll: ScrollBlot) => Delta;\n\nconst CLIPBOARD_CONFIG: [Selector, Matcher][] = [\n  [Node.TEXT_NODE, matchText],\n  [Node.TEXT_NODE, matchNewline],\n  ['br', matchBreak],\n  [Node.ELEMENT_NODE, matchNewline],\n  [Node.ELEMENT_NODE, matchBlot],\n  [Node.ELEMENT_NODE, matchAttributor],\n  [Node.ELEMENT_NODE, matchStyles],\n  ['li', matchIndent],\n  ['ol, ul', matchList],\n  ['pre', matchCodeBlock],\n  ['tr', matchTable],\n  ['b', createMatchAlias('bold')],\n  ['i', createMatchAlias('italic')],\n  ['strike', createMatchAlias('strike')],\n  ['style', matchIgnore],\n];\n\nconst ATTRIBUTE_ATTRIBUTORS = [AlignAttribute, DirectionAttribute].reduce(\n  (memo: Record<string, Attributor>, attr) => {\n    memo[attr.keyName] = attr;\n    return memo;\n  },\n  {},\n);\n\nconst STYLE_ATTRIBUTORS = [\n  AlignStyle,\n  BackgroundStyle,\n  ColorStyle,\n  DirectionStyle,\n  FontStyle,\n  SizeStyle,\n].reduce((memo: Record<string, Attributor>, attr) => {\n  memo[attr.keyName] = attr;\n  return memo;\n}, {});\n\ninterface ClipboardOptions {\n  matchers: [Selector, Matcher][];\n}\n\nclass Clipboard extends Module<ClipboardOptions> {\n  static DEFAULTS: ClipboardOptions = {\n    matchers: [],\n  };\n\n  matchers: [Selector, Matcher][];\n\n  constructor(quill: Quill, options: Partial<ClipboardOptions>) {\n    super(quill, options);\n    this.quill.root.addEventListener('copy', (e) =>\n      this.onCaptureCopy(e, false),\n    );\n    this.quill.root.addEventListener('cut', (e) => this.onCaptureCopy(e, true));\n    this.quill.root.addEventListener('paste', this.onCapturePaste.bind(this));\n    this.matchers = [];\n    CLIPBOARD_CONFIG.concat(this.options.matchers ?? []).forEach(\n      ([selector, matcher]) => {\n        this.addMatcher(selector, matcher);\n      },\n    );\n  }\n\n  addMatcher(selector: Selector, matcher: Matcher) {\n    this.matchers.push([selector, matcher]);\n  }\n\n  convert(\n    { html, text }: { html?: string; text?: string },\n    formats: Record<string, unknown> = {},\n  ) {\n    if (formats[CodeBlock.blotName]) {\n      return new Delta().insert(text || '', {\n        [CodeBlock.blotName]: formats[CodeBlock.blotName],\n      });\n    }\n    if (!html) {\n      return new Delta().insert(text || '', formats);\n    }\n    const delta = this.convertHTML(html);\n    // Remove trailing newline\n    if (\n      deltaEndsWith(delta, '\\n') &&\n      (delta.ops[delta.ops.length - 1].attributes == null || formats.table)\n    ) {\n      return delta.compose(new Delta().retain(delta.length() - 1).delete(1));\n    }\n    return delta;\n  }\n\n  protected normalizeHTML(doc: Document) {\n    normalizeExternalHTML(doc);\n  }\n\n  protected convertHTML(html: string) {\n    const doc = new DOMParser().parseFromString(html, 'text/html');\n    this.normalizeHTML(doc);\n    const container = doc.body;\n    const nodeMatches = new WeakMap();\n    const [elementMatchers, textMatchers] = this.prepareMatching(\n      container,\n      nodeMatches,\n    );\n    return traverse(\n      this.quill.scroll,\n      container,\n      elementMatchers,\n      textMatchers,\n      nodeMatches,\n    );\n  }\n\n  dangerouslyPasteHTML(html: string, source?: EmitterSource): void;\n  dangerouslyPasteHTML(\n    index: number,\n    html: string,\n    source?: EmitterSource,\n  ): void;\n  dangerouslyPasteHTML(\n    index: number | string,\n    html?: string,\n    source: EmitterSource = Quill.sources.API,\n  ) {\n    if (typeof index === 'string') {\n      const delta = this.convert({ html: index, text: '' });\n      // @ts-expect-error\n      this.quill.setContents(delta, html);\n      this.quill.setSelection(0, Quill.sources.SILENT);\n    } else {\n      const paste = this.convert({ html, text: '' });\n      this.quill.updateContents(\n        new Delta().retain(index).concat(paste),\n        source,\n      );\n      this.quill.setSelection(index + paste.length(), Quill.sources.SILENT);\n    }\n  }\n\n  onCaptureCopy(e: ClipboardEvent, isCut = false) {\n    if (e.defaultPrevented) return;\n    e.preventDefault();\n    const [range] = this.quill.selection.getRange();\n    if (range == null) return;\n    const { html, text } = this.onCopy(range, isCut);\n    e.clipboardData?.setData('text/plain', text);\n    e.clipboardData?.setData('text/html', html);\n    if (isCut) {\n      deleteRange({ range, quill: this.quill });\n    }\n  }\n\n  /*\n   * https://www.iana.org/assignments/media-types/text/uri-list\n   */\n  private normalizeURIList(urlList: string) {\n    return (\n      urlList\n        .split(/\\r?\\n/)\n        // Ignore all comments\n        .filter((url) => url[0] !== '#')\n        .join('\\n')\n    );\n  }\n\n  onCapturePaste(e: ClipboardEvent) {\n    if (e.defaultPrevented || !this.quill.isEnabled()) return;\n    e.preventDefault();\n    const range = this.quill.getSelection(true);\n    if (range == null) return;\n    const html = e.clipboardData?.getData('text/html');\n    let text = e.clipboardData?.getData('text/plain');\n    if (!html && !text) {\n      const urlList = e.clipboardData?.getData('text/uri-list');\n      if (urlList) {\n        text = this.normalizeURIList(urlList);\n      }\n    }\n    const files = Array.from(e.clipboardData?.files || []);\n    if (!html && files.length > 0) {\n      this.quill.uploader.upload(range, files);\n      return;\n    }\n    if (html && files.length > 0) {\n      const doc = new DOMParser().parseFromString(html, 'text/html');\n      if (\n        doc.body.childElementCount === 1 &&\n        doc.body.firstElementChild?.tagName === 'IMG'\n      ) {\n        this.quill.uploader.upload(range, files);\n        return;\n      }\n    }\n    this.onPaste(range, { html, text });\n  }\n\n  onCopy(range: Range, isCut: boolean): { html: string; text: string };\n  onCopy(range: Range) {\n    const text = this.quill.getText(range);\n    const html = this.quill.getSemanticHTML(range);\n    return { html, text };\n  }\n\n  onPaste(range: Range, { text, html }: { text?: string; html?: string }) {\n    const formats = this.quill.getFormat(range.index);\n    const pastedDelta = this.convert({ text, html }, formats);\n    debug.log('onPaste', pastedDelta, { text, html });\n    const delta = new Delta()\n      .retain(range.index)\n      .delete(range.length)\n      .concat(pastedDelta);\n    this.quill.updateContents(delta, Quill.sources.USER);\n    // range.length contributes to delta.length()\n    this.quill.setSelection(\n      delta.length() - range.length,\n      Quill.sources.SILENT,\n    );\n    this.quill.scrollSelectionIntoView();\n  }\n\n  prepareMatching(container: Element, nodeMatches: WeakMap<Node, Matcher[]>) {\n    const elementMatchers: Matcher[] = [];\n    const textMatchers: Matcher[] = [];\n    this.matchers.forEach((pair) => {\n      const [selector, matcher] = pair;\n      switch (selector) {\n        case Node.TEXT_NODE:\n          textMatchers.push(matcher);\n          break;\n        case Node.ELEMENT_NODE:\n          elementMatchers.push(matcher);\n          break;\n        default:\n          Array.from(container.querySelectorAll(selector)).forEach((node) => {\n            if (nodeMatches.has(node)) {\n              const matches = nodeMatches.get(node);\n              matches?.push(matcher);\n            } else {\n              nodeMatches.set(node, [matcher]);\n            }\n          });\n          break;\n      }\n    });\n    return [elementMatchers, textMatchers];\n  }\n}\n\nfunction applyFormat(\n  delta: Delta,\n  format: string,\n  value: unknown,\n  scroll: ScrollBlot,\n): Delta {\n  if (!scroll.query(format)) {\n    return delta;\n  }\n\n  return delta.reduce((newDelta, op) => {\n    if (!op.insert) return newDelta;\n    if (op.attributes && op.attributes[format]) {\n      return newDelta.push(op);\n    }\n    const formats = value ? { [format]: value } : {};\n    return newDelta.insert(op.insert, { ...formats, ...op.attributes });\n  }, new Delta());\n}\n\nfunction deltaEndsWith(delta: Delta, text: string) {\n  let endText = '';\n  for (\n    let i = delta.ops.length - 1;\n    i >= 0 && endText.length < text.length;\n    --i // eslint-disable-line no-plusplus\n  ) {\n    const op = delta.ops[i];\n    if (typeof op.insert !== 'string') break;\n    endText = op.insert + endText;\n  }\n  return endText.slice(-1 * text.length) === text;\n}\n\nfunction isLine(node: Node, scroll: ScrollBlot) {\n  if (!(node instanceof Element)) return false;\n  const match = scroll.query(node);\n  // @ts-expect-error\n  if (match && match.prototype instanceof EmbedBlot) return false;\n\n  return [\n    'address',\n    'article',\n    'blockquote',\n    'canvas',\n    'dd',\n    'div',\n    'dl',\n    'dt',\n    'fieldset',\n    'figcaption',\n    'figure',\n    'footer',\n    'form',\n    'h1',\n    'h2',\n    'h3',\n    'h4',\n    'h5',\n    'h6',\n    'header',\n    'iframe',\n    'li',\n    'main',\n    'nav',\n    'ol',\n    'output',\n    'p',\n    'pre',\n    'section',\n    'table',\n    'td',\n    'tr',\n    'ul',\n    'video',\n  ].includes(node.tagName.toLowerCase());\n}\n\nfunction isBetweenInlineElements(node: HTMLElement, scroll: ScrollBlot) {\n  return (\n    node.previousElementSibling &&\n    node.nextElementSibling &&\n    !isLine(node.previousElementSibling, scroll) &&\n    !isLine(node.nextElementSibling, scroll)\n  );\n}\n\nconst preNodes = new WeakMap();\nfunction isPre(node: Node | null) {\n  if (node == null) return false;\n  if (!preNodes.has(node)) {\n    // @ts-expect-error\n    if (node.tagName === 'PRE') {\n      preNodes.set(node, true);\n    } else {\n      preNodes.set(node, isPre(node.parentNode));\n    }\n  }\n  return preNodes.get(node);\n}\n\nfunction traverse(\n  scroll: ScrollBlot,\n  node: ChildNode,\n  elementMatchers: Matcher[],\n  textMatchers: Matcher[],\n  nodeMatches: WeakMap<Node, Matcher[]>,\n): Delta {\n  // Post-order\n  if (node.nodeType === node.TEXT_NODE) {\n    return textMatchers.reduce((delta: Delta, matcher) => {\n      return matcher(node, delta, scroll);\n    }, new Delta());\n  }\n  if (node.nodeType === node.ELEMENT_NODE) {\n    return Array.from(node.childNodes || []).reduce((delta, childNode) => {\n      let childrenDelta = traverse(\n        scroll,\n        childNode,\n        elementMatchers,\n        textMatchers,\n        nodeMatches,\n      );\n      if (childNode.nodeType === node.ELEMENT_NODE) {\n        childrenDelta = elementMatchers.reduce((reducedDelta, matcher) => {\n          return matcher(childNode as HTMLElement, reducedDelta, scroll);\n        }, childrenDelta);\n        childrenDelta = (nodeMatches.get(childNode) || []).reduce(\n          (reducedDelta, matcher) => {\n            return matcher(childNode, reducedDelta, scroll);\n          },\n          childrenDelta,\n        );\n      }\n      return delta.concat(childrenDelta);\n    }, new Delta());\n  }\n  return new Delta();\n}\n\nfunction createMatchAlias(format: string) {\n  return (_node: Element, delta: Delta, scroll: ScrollBlot) => {\n    return applyFormat(delta, format, true, scroll);\n  };\n}\n\nfunction matchAttributor(node: HTMLElement, delta: Delta, scroll: ScrollBlot) {\n  const attributes = Attributor.keys(node);\n  const classes = ClassAttributor.keys(node);\n  const styles = StyleAttributor.keys(node);\n  const formats: Record<string, string | undefined> = {};\n  attributes\n    .concat(classes)\n    .concat(styles)\n    .forEach((name) => {\n      let attr = scroll.query(name, Scope.ATTRIBUTE) as Attributor;\n      if (attr != null) {\n        formats[attr.attrName] = attr.value(node);\n        if (formats[attr.attrName]) return;\n      }\n      attr = ATTRIBUTE_ATTRIBUTORS[name];\n      if (attr != null && (attr.attrName === name || attr.keyName === name)) {\n        formats[attr.attrName] = attr.value(node) || undefined;\n      }\n      attr = STYLE_ATTRIBUTORS[name];\n      if (attr != null && (attr.attrName === name || attr.keyName === name)) {\n        attr = STYLE_ATTRIBUTORS[name];\n        formats[attr.attrName] = attr.value(node) || undefined;\n      }\n    });\n\n  return Object.entries(formats).reduce(\n    (newDelta, [name, value]) => applyFormat(newDelta, name, value, scroll),\n    delta,\n  );\n}\n\nfunction matchBlot(node: Node, delta: Delta, scroll: ScrollBlot) {\n  const match = scroll.query(node);\n  if (match == null) return delta;\n  // @ts-expect-error\n  if (match.prototype instanceof EmbedBlot) {\n    const embed = {};\n    // @ts-expect-error\n    const value = match.value(node);\n    if (value != null) {\n      // @ts-expect-error\n      embed[match.blotName] = value;\n      // @ts-expect-error\n      return new Delta().insert(embed, match.formats(node, scroll));\n    }\n  } else {\n    // @ts-expect-error\n    if (match.prototype instanceof BlockBlot && !deltaEndsWith(delta, '\\n')) {\n      delta.insert('\\n');\n    }\n    if (\n      'blotName' in match &&\n      'formats' in match &&\n      typeof match.formats === 'function'\n    ) {\n      return applyFormat(\n        delta,\n        match.blotName,\n        match.formats(node, scroll),\n        scroll,\n      );\n    }\n  }\n  return delta;\n}\n\nfunction matchBreak(node: Node, delta: Delta) {\n  if (!deltaEndsWith(delta, '\\n')) {\n    delta.insert('\\n');\n  }\n  return delta;\n}\n\nfunction matchCodeBlock(node: Node, delta: Delta, scroll: ScrollBlot) {\n  const match = scroll.query('code-block');\n  const language =\n    match && 'formats' in match && typeof match.formats === 'function'\n      ? match.formats(node, scroll)\n      : true;\n  return applyFormat(delta, 'code-block', language, scroll);\n}\n\nfunction matchIgnore() {\n  return new Delta();\n}\n\nfunction matchIndent(node: Node, delta: Delta, scroll: ScrollBlot) {\n  const match = scroll.query(node);\n  if (\n    match == null ||\n    // @ts-expect-error\n    match.blotName !== 'list' ||\n    !deltaEndsWith(delta, '\\n')\n  ) {\n    return delta;\n  }\n  let indent = -1;\n  let parent = node.parentNode;\n  while (parent != null) {\n    // @ts-expect-error\n    if (['OL', 'UL'].includes(parent.tagName)) {\n      indent += 1;\n    }\n    parent = parent.parentNode;\n  }\n  if (indent <= 0) return delta;\n  return delta.reduce((composed, op) => {\n    if (!op.insert) return composed;\n    if (op.attributes && typeof op.attributes.indent === 'number') {\n      return composed.push(op);\n    }\n    return composed.insert(op.insert, { indent, ...(op.attributes || {}) });\n  }, new Delta());\n}\n\nfunction matchList(node: Node, delta: Delta, scroll: ScrollBlot) {\n  const element = node as Element;\n  let list = element.tagName === 'OL' ? 'ordered' : 'bullet';\n\n  const checkedAttr = element.getAttribute('data-checked');\n  if (checkedAttr) {\n    list = checkedAttr === 'true' ? 'checked' : 'unchecked';\n  }\n\n  return applyFormat(delta, 'list', list, scroll);\n}\n\nfunction matchNewline(node: Node, delta: Delta, scroll: ScrollBlot) {\n  if (!deltaEndsWith(delta, '\\n')) {\n    if (\n      isLine(node, scroll) &&\n      (node.childNodes.length > 0 || node instanceof HTMLParagraphElement)\n    ) {\n      return delta.insert('\\n');\n    }\n    if (delta.length() > 0 && node.nextSibling) {\n      let nextSibling: Node | null = node.nextSibling;\n      while (nextSibling != null) {\n        if (isLine(nextSibling, scroll)) {\n          return delta.insert('\\n');\n        }\n        const match = scroll.query(nextSibling);\n        // @ts-expect-error\n        if (match && match.prototype instanceof BlockEmbed) {\n          return delta.insert('\\n');\n        }\n        nextSibling = nextSibling.firstChild;\n      }\n    }\n  }\n  return delta;\n}\n\nfunction matchStyles(node: HTMLElement, delta: Delta, scroll: ScrollBlot) {\n  const formats: Record<string, unknown> = {};\n  const style: Partial<CSSStyleDeclaration> = node.style || {};\n  if (style.fontStyle === 'italic') {\n    formats.italic = true;\n  }\n  if (style.textDecoration === 'underline') {\n    formats.underline = true;\n  }\n  if (style.textDecoration === 'line-through') {\n    formats.strike = true;\n  }\n  if (\n    style.fontWeight?.startsWith('bold') ||\n    // @ts-expect-error Fix me later\n    parseInt(style.fontWeight, 10) >= 700\n  ) {\n    formats.bold = true;\n  }\n  delta = Object.entries(formats).reduce(\n    (newDelta, [name, value]) => applyFormat(newDelta, name, value, scroll),\n    delta,\n  );\n  // @ts-expect-error\n  if (parseFloat(style.textIndent || 0) > 0) {\n    // Could be 0.5in\n    return new Delta().insert('\\t').concat(delta);\n  }\n  return delta;\n}\n\nfunction matchTable(\n  node: HTMLTableRowElement,\n  delta: Delta,\n  scroll: ScrollBlot,\n) {\n  const table =\n    node.parentElement?.tagName === 'TABLE'\n      ? node.parentElement\n      : node.parentElement?.parentElement;\n  if (table != null) {\n    const rows = Array.from(table.querySelectorAll('tr'));\n    const row = rows.indexOf(node) + 1;\n    return applyFormat(delta, 'table', row, scroll);\n  }\n  return delta;\n}\n\nfunction matchText(node: HTMLElement, delta: Delta, scroll: ScrollBlot) {\n  // @ts-expect-error\n  let text = node.data as string;\n  // Word represents empty line with <o:p>&nbsp;</o:p>\n  if (node.parentElement?.tagName === 'O:P') {\n    return delta.insert(text.trim());\n  }\n  if (!isPre(node)) {\n    if (\n      text.trim().length === 0 &&\n      text.includes('\\n') &&\n      !isBetweenInlineElements(node, scroll)\n    ) {\n      return delta;\n    }\n    // convert all non-nbsp whitespace into regular space\n    text = text.replace(/[^\\S\\u00a0]/g, ' ');\n    // collapse consecutive spaces into one\n    text = text.replace(/ {2,}/g, ' ');\n    if (\n      (node.previousSibling == null &&\n        node.parentElement != null &&\n        isLine(node.parentElement, scroll)) ||\n      (node.previousSibling instanceof Element &&\n        isLine(node.previousSibling, scroll))\n    ) {\n      // block structure means we don't need leading space\n      text = text.replace(/^ /, '');\n    }\n    if (\n      (node.nextSibling == null &&\n        node.parentElement != null &&\n        isLine(node.parentElement, scroll)) ||\n      (node.nextSibling instanceof Element && isLine(node.nextSibling, scroll))\n    ) {\n      // block structure means we don't need trailing space\n      text = text.replace(/ $/, '');\n    }\n    // done removing whitespace and can normalize all to regular space\n    text = text.replaceAll('\\u00a0', ' ');\n  }\n  return delta.insert(text);\n}\n\nexport {\n  Clipboard as default,\n  matchAttributor,\n  matchBlot,\n  matchNewline,\n  matchText,\n  traverse,\n};\n","import { Scope } from 'parchment';\nimport type Delta from 'quill-delta';\nimport Module from '../core/module.js';\nimport Quill from '../core/quill.js';\nimport type Scroll from '../blots/scroll.js';\nimport type { Range } from '../core/selection.js';\n\nexport interface HistoryOptions {\n  userOnly: boolean;\n  delay: number;\n  maxStack: number;\n}\n\nexport interface StackItem {\n  delta: Delta;\n  range: Range | null;\n}\n\ninterface Stack {\n  undo: StackItem[];\n  redo: StackItem[];\n}\n\nclass History extends Module<HistoryOptions> {\n  static DEFAULTS: HistoryOptions = {\n    delay: 1000,\n    maxStack: 100,\n    userOnly: false,\n  };\n\n  lastRecorded = 0;\n  ignoreChange = false;\n  stack: Stack = { undo: [], redo: [] };\n  currentRange: Range | null = null;\n\n  constructor(quill: Quill, options: Partial<HistoryOptions>) {\n    super(quill, options);\n    this.quill.on(\n      Quill.events.EDITOR_CHANGE,\n      (eventName, value, oldValue, source) => {\n        if (eventName === Quill.events.SELECTION_CHANGE) {\n          if (value && source !== Quill.sources.SILENT) {\n            this.currentRange = value;\n          }\n        } else if (eventName === Quill.events.TEXT_CHANGE) {\n          if (!this.ignoreChange) {\n            if (!this.options.userOnly || source === Quill.sources.USER) {\n              this.record(value, oldValue);\n            } else {\n              this.transform(value);\n            }\n          }\n\n          this.currentRange = transformRange(this.currentRange, value);\n        }\n      },\n    );\n\n    this.quill.keyboard.addBinding(\n      { key: 'z', shortKey: true },\n      this.undo.bind(this),\n    );\n    this.quill.keyboard.addBinding(\n      { key: ['z', 'Z'], shortKey: true, shiftKey: true },\n      this.redo.bind(this),\n    );\n    if (/Win/i.test(navigator.platform)) {\n      this.quill.keyboard.addBinding(\n        { key: 'y', shortKey: true },\n        this.redo.bind(this),\n      );\n    }\n\n    this.quill.root.addEventListener('beforeinput', (event) => {\n      if (event.inputType === 'historyUndo') {\n        this.undo();\n        event.preventDefault();\n      } else if (event.inputType === 'historyRedo') {\n        this.redo();\n        event.preventDefault();\n      }\n    });\n  }\n\n  change(source: 'undo' | 'redo', dest: 'redo' | 'undo') {\n    if (this.stack[source].length === 0) return;\n    const item = this.stack[source].pop();\n    if (!item) return;\n    const base = this.quill.getContents();\n    const inverseDelta = item.delta.invert(base);\n    this.stack[dest].push({\n      delta: inverseDelta,\n      range: transformRange(item.range, inverseDelta),\n    });\n    this.lastRecorded = 0;\n    this.ignoreChange = true;\n    this.quill.updateContents(item.delta, Quill.sources.USER);\n    this.ignoreChange = false;\n\n    this.restoreSelection(item);\n  }\n\n  clear() {\n    this.stack = { undo: [], redo: [] };\n  }\n\n  cutoff() {\n    this.lastRecorded = 0;\n  }\n\n  record(changeDelta: Delta, oldDelta: Delta) {\n    if (changeDelta.ops.length === 0) return;\n    this.stack.redo = [];\n    let undoDelta = changeDelta.invert(oldDelta);\n    let undoRange = this.currentRange;\n    const timestamp = Date.now();\n    if (\n      // @ts-expect-error Fix me later\n      this.lastRecorded + this.options.delay > timestamp &&\n      this.stack.undo.length > 0\n    ) {\n      const item = this.stack.undo.pop();\n      if (item) {\n        undoDelta = undoDelta.compose(item.delta);\n        undoRange = item.range;\n      }\n    } else {\n      this.lastRecorded = timestamp;\n    }\n    if (undoDelta.length() === 0) return;\n    this.stack.undo.push({ delta: undoDelta, range: undoRange });\n    // @ts-expect-error Fix me later\n    if (this.stack.undo.length > this.options.maxStack) {\n      this.stack.undo.shift();\n    }\n  }\n\n  redo() {\n    this.change('redo', 'undo');\n  }\n\n  transform(delta: Delta) {\n    transformStack(this.stack.undo, delta);\n    transformStack(this.stack.redo, delta);\n  }\n\n  undo() {\n    this.change('undo', 'redo');\n  }\n\n  protected restoreSelection(stackItem: StackItem) {\n    if (stackItem.range) {\n      this.quill.setSelection(stackItem.range, Quill.sources.USER);\n    } else {\n      const index = getLastChangeIndex(this.quill.scroll, stackItem.delta);\n      this.quill.setSelection(index, Quill.sources.USER);\n    }\n  }\n}\n\nfunction transformStack(stack: StackItem[], delta: Delta) {\n  let remoteDelta = delta;\n  for (let i = stack.length - 1; i >= 0; i -= 1) {\n    const oldItem = stack[i];\n    stack[i] = {\n      delta: remoteDelta.transform(oldItem.delta, true),\n      range: oldItem.range && transformRange(oldItem.range, remoteDelta),\n    };\n    remoteDelta = oldItem.delta.transform(remoteDelta);\n    if (stack[i].delta.length() === 0) {\n      stack.splice(i, 1);\n    }\n  }\n}\n\nfunction endsWithNewlineChange(scroll: Scroll, delta: Delta) {\n  const lastOp = delta.ops[delta.ops.length - 1];\n  if (lastOp == null) return false;\n  if (lastOp.insert != null) {\n    return typeof lastOp.insert === 'string' && lastOp.insert.endsWith('\\n');\n  }\n  if (lastOp.attributes != null) {\n    return Object.keys(lastOp.attributes).some((attr) => {\n      return scroll.query(attr, Scope.BLOCK) != null;\n    });\n  }\n  return false;\n}\n\nfunction getLastChangeIndex(scroll: Scroll, delta: Delta) {\n  const deleteLength = delta.reduce((length, op) => {\n    return length + (op.delete || 0);\n  }, 0);\n  let changeIndex = delta.length() - deleteLength;\n  if (endsWithNewlineChange(scroll, delta)) {\n    changeIndex -= 1;\n  }\n  return changeIndex;\n}\n\nfunction transformRange(range: Range | null, delta: Delta) {\n  if (!range) return range;\n  const start = delta.transformPosition(range.index);\n  const end = delta.transformPosition(range.index + range.length);\n  return { index: start, length: end - start };\n}\n\nexport { History as default, getLastChangeIndex };\n","import Delta from 'quill-delta';\nimport type Quill from '../core/quill.js';\nimport Emitter from '../core/emitter.js';\nimport Module from '../core/module.js';\nimport type { Range } from '../core/selection.js';\n\ninterface UploaderOptions {\n  mimetypes: string[];\n  handler: (this: { quill: Quill }, range: Range, files: File[]) => void;\n}\n\nclass Uploader extends Module<UploaderOptions> {\n  static DEFAULTS: UploaderOptions;\n\n  constructor(quill: Quill, options: Partial<UploaderOptions>) {\n    super(quill, options);\n    quill.root.addEventListener('drop', (e) => {\n      e.preventDefault();\n      let native: ReturnType<typeof document.createRange> | null = null;\n      if (document.caretRangeFromPoint) {\n        native = document.caretRangeFromPoint(e.clientX, e.clientY);\n        // @ts-expect-error\n      } else if (document.caretPositionFromPoint) {\n        // @ts-expect-error\n        const position = document.caretPositionFromPoint(e.clientX, e.clientY);\n        native = document.createRange();\n        native.setStart(position.offsetNode, position.offset);\n        native.setEnd(position.offsetNode, position.offset);\n      }\n\n      const normalized = native && quill.selection.normalizeNative(native);\n      if (normalized) {\n        const range = quill.selection.normalizedToRange(normalized);\n        if (e.dataTransfer?.files) {\n          this.upload(range, e.dataTransfer.files);\n        }\n      }\n    });\n  }\n\n  upload(range: Range, files: FileList | File[]) {\n    const uploads: File[] = [];\n    Array.from(files).forEach((file) => {\n      if (file && this.options.mimetypes?.includes(file.type)) {\n        uploads.push(file);\n      }\n    });\n    if (uploads.length > 0) {\n      // @ts-expect-error Fix me later\n      this.options.handler.call(this, range, uploads);\n    }\n  }\n}\n\nUploader.DEFAULTS = {\n  mimetypes: ['image/png', 'image/jpeg'],\n  handler(range: Range, files: File[]) {\n    if (!this.quill.scroll.query('image')) {\n      return;\n    }\n    const promises = files.map<Promise<string>>((file) => {\n      return new Promise((resolve) => {\n        const reader = new FileReader();\n        reader.onload = () => {\n          resolve(reader.result as string);\n        };\n        reader.readAsDataURL(file);\n      });\n    });\n    Promise.all(promises).then((images) => {\n      const update = images.reduce((delta: Delta, image) => {\n        return delta.insert({ image });\n      }, new Delta().retain(range.index).delete(range.length)) as Delta;\n      this.quill.updateContents(update, Emitter.sources.USER);\n      this.quill.setSelection(\n        range.index + images.length,\n        Emitter.sources.SILENT,\n      );\n    });\n  },\n};\n\nexport default Uploader;\n","import Delta from 'quill-delta';\nimport Module from '../core/module.js';\nimport Quill from '../core/quill.js';\nimport type { Range } from '../core/selection.js';\nimport { deleteRange } from './keyboard.js';\n\nconst INSERT_TYPES = ['insertText', 'insertReplacementText'];\n\nclass Input extends Module {\n  constructor(quill: Quill, options: Record<string, never>) {\n    super(quill, options);\n\n    quill.root.addEventListener('beforeinput', (event) => {\n      this.handleBeforeInput(event);\n    });\n\n    // Gboard with English input on Android triggers `compositionstart` sometimes even\n    // users are not going to type anything.\n    if (!/Android/i.test(navigator.userAgent)) {\n      quill.on(Quill.events.COMPOSITION_BEFORE_START, () => {\n        this.handleCompositionStart();\n      });\n    }\n  }\n\n  private deleteRange(range: Range) {\n    deleteRange({ range, quill: this.quill });\n  }\n\n  private replaceText(range: Range, text = '') {\n    if (range.length === 0) return false;\n\n    if (text) {\n      // Follow the native behavior that inherits the formats of the first character\n      const formats = this.quill.getFormat(range.index, 1);\n      this.deleteRange(range);\n      this.quill.updateContents(\n        new Delta().retain(range.index).insert(text, formats),\n        Quill.sources.USER,\n      );\n    } else {\n      this.deleteRange(range);\n    }\n\n    this.quill.setSelection(range.index + text.length, 0, Quill.sources.SILENT);\n    return true;\n  }\n\n  private handleBeforeInput(event: InputEvent) {\n    if (\n      this.quill.composition.isComposing ||\n      event.defaultPrevented ||\n      !INSERT_TYPES.includes(event.inputType)\n    ) {\n      return;\n    }\n\n    const staticRange = event.getTargetRanges\n      ? event.getTargetRanges()[0]\n      : null;\n    if (!staticRange || staticRange.collapsed === true) {\n      return;\n    }\n\n    const text = getPlainTextFromInputEvent(event);\n    if (text == null) {\n      return;\n    }\n    const normalized = this.quill.selection.normalizeNative(staticRange);\n    const range = normalized\n      ? this.quill.selection.normalizedToRange(normalized)\n      : null;\n    if (range && this.replaceText(range, text)) {\n      event.preventDefault();\n    }\n  }\n\n  private handleCompositionStart() {\n    const range = this.quill.getSelection();\n    if (range) {\n      this.replaceText(range);\n    }\n  }\n}\n\nfunction getPlainTextFromInputEvent(event: InputEvent) {\n  // When `inputType` is \"insertText\":\n  // - `event.data` should be string (Safari uses `event.dataTransfer`).\n  // - `event.dataTransfer` should be null.\n  // When `inputType` is \"insertReplacementText\":\n  // - `event.data` should be null.\n  // - `event.dataTransfer` should contain \"text/plain\" data.\n\n  if (typeof event.data === 'string') {\n    return event.data;\n  }\n  if (event.dataTransfer?.types.includes('text/plain')) {\n    return event.dataTransfer.getData('text/plain');\n  }\n  return null;\n}\n\nexport default Input;\n","import { ParentBlot } from 'parchment';\nimport Module from '../core/module.js';\nimport Quill from '../core/quill.js';\n\nconst isMac = /Mac/i.test(navigator.platform);\n\n// Export for testing\nexport const TTL_FOR_VALID_SELECTION_CHANGE = 100;\n\n// A loose check to determine if the shortcut can move the caret before a UI node:\n// <ANY_PARENT>[CARET]<div class=\"ql-ui\"></div>[CONTENT]</ANY_PARENT>\nconst canMoveCaretBeforeUINode = (event: KeyboardEvent) => {\n  if (\n    event.key === 'ArrowLeft' ||\n    event.key === 'ArrowRight' || // RTL scripts or moving from the end of the previous line\n    event.key === 'ArrowUp' ||\n    event.key === 'ArrowDown' ||\n    event.key === 'Home'\n  ) {\n    return true;\n  }\n\n  if (isMac && event.key === 'a' && event.ctrlKey === true) {\n    return true;\n  }\n\n  return false;\n};\n\nclass UINode extends Module {\n  isListening = false;\n  selectionChangeDeadline = 0;\n\n  constructor(quill: Quill, options: Record<string, never>) {\n    super(quill, options);\n\n    this.handleArrowKeys();\n    this.handleNavigationShortcuts();\n  }\n\n  private handleArrowKeys() {\n    this.quill.keyboard.addBinding({\n      key: ['ArrowLeft', 'ArrowRight'],\n      offset: 0,\n      shiftKey: null,\n      handler(range, { line, event }) {\n        if (!(line instanceof ParentBlot) || !line.uiNode) {\n          return true;\n        }\n\n        const isRTL = getComputedStyle(line.domNode)['direction'] === 'rtl';\n        if (\n          (isRTL && event.key !== 'ArrowRight') ||\n          (!isRTL && event.key !== 'ArrowLeft')\n        ) {\n          return true;\n        }\n\n        this.quill.setSelection(\n          range.index - 1,\n          range.length + (event.shiftKey ? 1 : 0),\n          Quill.sources.USER,\n        );\n        return false;\n      },\n    });\n  }\n\n  private handleNavigationShortcuts() {\n    this.quill.root.addEventListener('keydown', (event) => {\n      if (!event.defaultPrevented && canMoveCaretBeforeUINode(event)) {\n        this.ensureListeningToSelectionChange();\n      }\n    });\n  }\n\n  /**\n   * We only listen to the `selectionchange` event when\n   * there is an intention of moving the caret to the beginning using shortcuts.\n   * This is primarily implemented to prevent infinite loops, as we are changing\n   * the selection within the handler of a `selectionchange` event.\n   */\n  private ensureListeningToSelectionChange() {\n    this.selectionChangeDeadline = Date.now() + TTL_FOR_VALID_SELECTION_CHANGE;\n\n    if (this.isListening) return;\n    this.isListening = true;\n\n    const listener = () => {\n      this.isListening = false;\n\n      if (Date.now() <= this.selectionChangeDeadline) {\n        this.handleSelectionChange();\n      }\n    };\n\n    document.addEventListener('selectionchange', listener, {\n      once: true,\n    });\n  }\n\n  private handleSelectionChange() {\n    const selection = document.getSelection();\n    if (!selection) return;\n    const range = selection.getRangeAt(0);\n    if (range.collapsed !== true || range.startOffset !== 0) return;\n\n    const line = this.quill.scroll.find(range.startContainer);\n    if (!(line instanceof ParentBlot) || !line.uiNode) return;\n\n    const newRange = document.createRange();\n    newRange.setStartAfter(line.uiNode);\n    newRange.setEndAfter(line.uiNode);\n    selection.removeAllRanges();\n    selection.addRange(newRange);\n  }\n}\n\nexport default UINode;\n","import Quill, { Parchment, Range } from './core/quill.js';\nimport type {\n  Bounds,\n  DebugLevel,\n  EmitterSource,\n  ExpandedQuillOptions,\n  QuillOptions,\n} from './core/quill.js';\n\nimport Block, { BlockEmbed } from './blots/block.js';\nimport Break from './blots/break.js';\nimport Container from './blots/container.js';\nimport Cursor from './blots/cursor.js';\nimport Embed from './blots/embed.js';\nimport Inline from './blots/inline.js';\nimport Scroll from './blots/scroll.js';\nimport TextBlot from './blots/text.js';\n\nimport Clipboard from './modules/clipboard.js';\nimport History from './modules/history.js';\nimport Keyboard from './modules/keyboard.js';\nimport Uploader from './modules/uploader.js';\nimport Delta, { Op, OpIterator, AttributeMap } from 'quill-delta';\nimport Input from './modules/input.js';\nimport UINode from './modules/uiNode.js';\n\nexport { default as Module } from './core/module.js';\nexport { Delta, Op, OpIterator, AttributeMap, Parchment, Range };\nexport type {\n  Bounds,\n  DebugLevel,\n  EmitterSource,\n  ExpandedQuillOptions,\n  QuillOptions,\n};\n\nQuill.register({\n  'blots/block': Block,\n  'blots/block/embed': BlockEmbed,\n  'blots/break': Break,\n  'blots/container': Container,\n  'blots/cursor': Cursor,\n  'blots/embed': Embed,\n  'blots/inline': Inline,\n  'blots/scroll': Scroll,\n  'blots/text': TextBlot,\n\n  'modules/clipboard': Clipboard,\n  'modules/history': History,\n  'modules/keyboard': Keyboard,\n  'modules/uploader': Uploader,\n  'modules/input': Input,\n  'modules/uiNode': UINode,\n});\n\nexport default Quill;\n","import { ClassAttributor, Scope } from 'parchment';\n\nclass IndentAttributor extends ClassAttributor {\n  add(node: HTMLElement, value: string | number) {\n    let normalizedValue = 0;\n    if (value === '+1' || value === '-1') {\n      const indent = this.value(node) || 0;\n      normalizedValue = value === '+1' ? indent + 1 : indent - 1;\n    } else if (typeof value === 'number') {\n      normalizedValue = value;\n    }\n    if (normalizedValue === 0) {\n      this.remove(node);\n      return true;\n    }\n    return super.add(node, normalizedValue.toString());\n  }\n\n  canAdd(node: HTMLElement, value: string) {\n    return super.canAdd(node, value) || super.canAdd(node, parseInt(value, 10));\n  }\n\n  value(node: HTMLElement) {\n    return parseInt(super.value(node), 10) || undefined; // Don't return NaN\n  }\n}\n\nconst IndentClass = new IndentAttributor('indent', 'ql-indent', {\n  scope: Scope.BLOCK,\n  // @ts-expect-error\n  whitelist: [1, 2, 3, 4, 5, 6, 7, 8],\n});\n\nexport default IndentClass;\n","import Block from '../blots/block.js';\n\nclass Blockquote extends Block {\n  static blotName = 'blockquote';\n  static tagName = 'blockquote';\n}\n\nexport default Blockquote;\n","import Block from '../blots/block.js';\n\nclass Header extends Block {\n  static blotName = 'header';\n  static tagName = ['H1', 'H2', 'H3', 'H4', 'H5', 'H6'];\n\n  static formats(domNode: Element) {\n    return this.tagName.indexOf(domNode.tagName) + 1;\n  }\n}\n\nexport default Header;\n","import Block from '../blots/block.js';\nimport Container from '../blots/container.js';\nimport type Scroll from '../blots/scroll.js';\nimport Quill from '../core/quill.js';\n\nclass ListContainer extends Container {}\nListContainer.blotName = 'list-container';\nListContainer.tagName = 'OL';\n\nclass ListItem extends Block {\n  static create(value: string) {\n    const node = super.create() as HTMLElement;\n    node.setAttribute('data-list', value);\n    return node;\n  }\n\n  static formats(domNode: HTMLElement) {\n    return domNode.getAttribute('data-list') || undefined;\n  }\n\n  static register() {\n    Quill.register(ListContainer);\n  }\n\n  constructor(scroll: Scroll, domNode: HTMLElement) {\n    super(scroll, domNode);\n    const ui = domNode.ownerDocument.createElement('span');\n    const listEventHandler = (e: Event) => {\n      if (!scroll.isEnabled()) return;\n      const format = this.statics.formats(domNode, scroll);\n      if (format === 'checked') {\n        this.format('list', 'unchecked');\n        e.preventDefault();\n      } else if (format === 'unchecked') {\n        this.format('list', 'checked');\n        e.preventDefault();\n      }\n    };\n    ui.addEventListener('mousedown', listEventHandler);\n    ui.addEventListener('touchstart', listEventHandler);\n    this.attachUI(ui);\n  }\n\n  format(name: string, value: string) {\n    if (name === this.statics.blotName && value) {\n      this.domNode.setAttribute('data-list', value);\n    } else {\n      super.format(name, value);\n    }\n  }\n}\nListItem.blotName = 'list';\nListItem.tagName = 'LI';\n\nListContainer.allowedChildren = [ListItem];\nListItem.requiredContainer = ListContainer;\n\nexport { ListContainer, ListItem as default };\n","import Inline from '../blots/inline.js';\n\nclass Bold extends Inline {\n  static blotName = 'bold';\n  static tagName = ['STRONG', 'B'];\n\n  static create() {\n    return super.create();\n  }\n\n  static formats() {\n    return true;\n  }\n\n  optimize(context: { [key: string]: any }) {\n    super.optimize(context);\n    if (this.domNode.tagName !== this.statics.tagName[0]) {\n      this.replaceWith(this.statics.blotName);\n    }\n  }\n}\n\nexport default Bold;\n","import Bold from './bold.js';\n\nclass Italic extends Bold {\n  static blotName = 'italic';\n  static tagName = ['EM', 'I'];\n}\n\nexport default Italic;\n","import Inline from '../blots/inline.js';\n\nclass Link extends Inline {\n  static blotName = 'link';\n  static tagName = 'A';\n  static SANITIZED_URL = 'about:blank';\n  static PROTOCOL_WHITELIST = ['http', 'https', 'mailto', 'tel', 'sms'];\n\n  static create(value: string) {\n    const node = super.create(value) as HTMLElement;\n    node.setAttribute('href', this.sanitize(value));\n    node.setAttribute('rel', 'noopener noreferrer');\n    node.setAttribute('target', '_blank');\n    return node;\n  }\n\n  static formats(domNode: HTMLElement) {\n    return domNode.getAttribute('href');\n  }\n\n  static sanitize(url: string) {\n    return sanitize(url, this.PROTOCOL_WHITELIST) ? url : this.SANITIZED_URL;\n  }\n\n  format(name: string, value: unknown) {\n    if (name !== this.statics.blotName || !value) {\n      super.format(name, value);\n    } else {\n      // @ts-expect-error\n      this.domNode.setAttribute('href', this.constructor.sanitize(value));\n    }\n  }\n}\n\nfunction sanitize(url: string, protocols: string[]) {\n  const anchor = document.createElement('a');\n  anchor.href = url;\n  const protocol = anchor.href.slice(0, anchor.href.indexOf(':'));\n  return protocols.indexOf(protocol) > -1;\n}\n\nexport { Link as default, sanitize };\n","import Inline from '../blots/inline.js';\n\nclass Script extends Inline {\n  static blotName = 'script';\n  static tagName = ['SUB', 'SUP'];\n\n  static create(value: 'super' | 'sub' | (string & {})) {\n    if (value === 'super') {\n      return document.createElement('sup');\n    }\n    if (value === 'sub') {\n      return document.createElement('sub');\n    }\n    return super.create(value);\n  }\n\n  static formats(domNode: HTMLElement) {\n    if (domNode.tagName === 'SUB') return 'sub';\n    if (domNode.tagName === 'SUP') return 'super';\n    return undefined;\n  }\n}\n\nexport default Script;\n","import Bold from './bold.js';\n\nclass Strike extends Bold {\n  static blotName = 'strike';\n  static tagName = ['S', 'STRIKE'];\n}\n\nexport default Strike;\n","import Inline from '../blots/inline.js';\n\nclass Underline extends Inline {\n  static blotName = 'underline';\n  static tagName = 'U';\n}\n\nexport default Underline;\n","import Embed from '../blots/embed.js';\n\nclass Formula extends Embed {\n  static blotName = 'formula';\n  static className = 'ql-formula';\n  static tagName = 'SPAN';\n\n  static create(value: string) {\n    // @ts-expect-error\n    if (window.katex == null) {\n      throw new Error('Formula module requires KaTeX.');\n    }\n    const node = super.create(value) as Element;\n    if (typeof value === 'string') {\n      // @ts-expect-error\n      window.katex.render(value, node, {\n        throwOnError: false,\n        errorColor: '#f00',\n      });\n      node.setAttribute('data-value', value);\n    }\n    return node;\n  }\n\n  static value(domNode: Element) {\n    return domNode.getAttribute('data-value');\n  }\n\n  html() {\n    const { formula } = this.value();\n    return `<span>${formula}</span>`;\n  }\n}\n\nexport default Formula;\n","import { EmbedBlot } from 'parchment';\nimport { sanitize } from './link.js';\n\nconst ATTRIBUTES = ['alt', 'height', 'width'];\n\nclass Image extends EmbedBlot {\n  static blotName = 'image';\n  static tagName = 'IMG';\n\n  static create(value: string) {\n    const node = super.create(value) as Element;\n    if (typeof value === 'string') {\n      node.setAttribute('src', this.sanitize(value));\n    }\n    return node;\n  }\n\n  static formats(domNode: Element) {\n    return ATTRIBUTES.reduce(\n      (formats: Record<string, string | null>, attribute) => {\n        if (domNode.hasAttribute(attribute)) {\n          formats[attribute] = domNode.getAttribute(attribute);\n        }\n        return formats;\n      },\n      {},\n    );\n  }\n\n  static match(url: string) {\n    return /\\.(jpe?g|gif|png)$/.test(url) || /^data:image\\/.+;base64/.test(url);\n  }\n\n  static sanitize(url: string) {\n    return sanitize(url, ['http', 'https', 'data']) ? url : '//:0';\n  }\n\n  static value(domNode: Element) {\n    return domNode.getAttribute('src');\n  }\n\n  domNode: HTMLImageElement;\n\n  format(name: string, value: string) {\n    if (ATTRIBUTES.indexOf(name) > -1) {\n      if (value) {\n        this.domNode.setAttribute(name, value);\n      } else {\n        this.domNode.removeAttribute(name);\n      }\n    } else {\n      super.format(name, value);\n    }\n  }\n}\n\nexport default Image;\n","import { BlockEmbed } from '../blots/block.js';\nimport Link from './link.js';\n\nconst ATTRIBUTES = ['height', 'width'];\n\nclass Video extends BlockEmbed {\n  static blotName = 'video';\n  static className = 'ql-video';\n  static tagName = 'IFRAME';\n\n  static create(value: string) {\n    const node = super.create(value) as Element;\n    node.setAttribute('frameborder', '0');\n    node.setAttribute('allowfullscreen', 'true');\n    node.setAttribute('src', this.sanitize(value));\n    return node;\n  }\n\n  static formats(domNode: Element) {\n    return ATTRIBUTES.reduce(\n      (formats: Record<string, string | null>, attribute) => {\n        if (domNode.hasAttribute(attribute)) {\n          formats[attribute] = domNode.getAttribute(attribute);\n        }\n        return formats;\n      },\n      {},\n    );\n  }\n\n  static sanitize(url: string) {\n    return Link.sanitize(url);\n  }\n\n  static value(domNode: Element) {\n    return domNode.getAttribute('src');\n  }\n\n  domNode: HTMLVideoElement;\n\n  format(name: string, value: string) {\n    if (ATTRIBUTES.indexOf(name) > -1) {\n      if (value) {\n        this.domNode.setAttribute(name, value);\n      } else {\n        this.domNode.removeAttribute(name);\n      }\n    } else {\n      super.format(name, value);\n    }\n  }\n\n  html() {\n    const { video } = this.value();\n    return `<a href=\"${video}\">${video}</a>`;\n  }\n}\n\nexport default Video;\n","import Delta from 'quill-delta';\nimport { ClassAttributor, Scope } from 'parchment';\nimport type { Blot, ScrollBlot } from 'parchment';\nimport Inline from '../blots/inline.js';\nimport Quill from '../core/quill.js';\nimport Module from '../core/module.js';\nimport { blockDelta } from '../blots/block.js';\nimport BreakBlot from '../blots/break.js';\nimport CursorBlot from '../blots/cursor.js';\nimport TextBlot, { escapeText } from '../blots/text.js';\nimport CodeBlock, { CodeBlockContainer } from '../formats/code.js';\nimport { traverse } from './clipboard.js';\n\nconst TokenAttributor = new ClassAttributor('code-token', 'hljs', {\n  scope: Scope.INLINE,\n});\nclass CodeToken extends Inline {\n  static formats(node: Element, scroll: ScrollBlot) {\n    while (node != null && node !== scroll.domNode) {\n      if (node.classList && node.classList.contains(CodeBlock.className)) {\n        // @ts-expect-error\n        return super.formats(node, scroll);\n      }\n      // @ts-expect-error\n      node = node.parentNode;\n    }\n    return undefined;\n  }\n\n  constructor(scroll: ScrollBlot, domNode: Node, value: unknown) {\n    // @ts-expect-error\n    super(scroll, domNode, value);\n    TokenAttributor.add(this.domNode, value);\n  }\n\n  format(format: string, value: unknown) {\n    if (format !== CodeToken.blotName) {\n      super.format(format, value);\n    } else if (value) {\n      TokenAttributor.add(this.domNode, value);\n    } else {\n      TokenAttributor.remove(this.domNode);\n      this.domNode.classList.remove(this.statics.className);\n    }\n  }\n\n  optimize(...args: unknown[]) {\n    // @ts-expect-error\n    super.optimize(...args);\n    if (!TokenAttributor.value(this.domNode)) {\n      this.unwrap();\n    }\n  }\n}\nCodeToken.blotName = 'code-token';\nCodeToken.className = 'ql-token';\n\nclass SyntaxCodeBlock extends CodeBlock {\n  static create(value: unknown) {\n    const domNode = super.create(value);\n    if (typeof value === 'string') {\n      domNode.setAttribute('data-language', value);\n    }\n    return domNode;\n  }\n\n  static formats(domNode: Node) {\n    // @ts-expect-error\n    return domNode.getAttribute('data-language') || 'plain';\n  }\n\n  static register() {} // Syntax module will register\n\n  format(name: string, value: unknown) {\n    if (name === this.statics.blotName && value) {\n      // @ts-expect-error\n      this.domNode.setAttribute('data-language', value);\n    } else {\n      super.format(name, value);\n    }\n  }\n\n  replaceWith(name: string | Blot, value?: any) {\n    this.formatAt(0, this.length(), CodeToken.blotName, false);\n    return super.replaceWith(name, value);\n  }\n}\n\nclass SyntaxCodeBlockContainer extends CodeBlockContainer {\n  forceNext?: boolean;\n  cachedText?: string | null;\n\n  attach() {\n    super.attach();\n    this.forceNext = false;\n    // @ts-expect-error\n    this.scroll.emitMount(this);\n  }\n\n  format(name: string, value: unknown) {\n    if (name === SyntaxCodeBlock.blotName) {\n      this.forceNext = true;\n      this.children.forEach((child) => {\n        // @ts-expect-error\n        child.format(name, value);\n      });\n    }\n  }\n\n  formatAt(index: number, length: number, name: string, value: unknown) {\n    if (name === SyntaxCodeBlock.blotName) {\n      this.forceNext = true;\n    }\n    super.formatAt(index, length, name, value);\n  }\n\n  highlight(\n    highlight: (text: string, language: string) => Delta,\n    forced = false,\n  ) {\n    if (this.children.head == null) return;\n    const nodes = Array.from(this.domNode.childNodes).filter(\n      (node) => node !== this.uiNode,\n    );\n    const text = `${nodes.map((node) => node.textContent).join('\\n')}\\n`;\n    const language = SyntaxCodeBlock.formats(this.children.head.domNode);\n    if (forced || this.forceNext || this.cachedText !== text) {\n      if (text.trim().length > 0 || this.cachedText == null) {\n        const oldDelta = this.children.reduce((delta, child) => {\n          // @ts-expect-error\n          return delta.concat(blockDelta(child, false));\n        }, new Delta());\n        const delta = highlight(text, language);\n        oldDelta.diff(delta).reduce((index, { retain, attributes }) => {\n          // Should be all retains\n          if (!retain) return index;\n          if (attributes) {\n            Object.keys(attributes).forEach((format) => {\n              if (\n                [SyntaxCodeBlock.blotName, CodeToken.blotName].includes(format)\n              ) {\n                // @ts-expect-error\n                this.formatAt(index, retain, format, attributes[format]);\n              }\n            });\n          }\n          // @ts-expect-error\n          return index + retain;\n        }, 0);\n      }\n      this.cachedText = text;\n      this.forceNext = false;\n    }\n  }\n\n  html(index: number, length: number) {\n    const [codeBlock] = this.children.find(index);\n    const language = codeBlock\n      ? SyntaxCodeBlock.formats(codeBlock.domNode)\n      : 'plain';\n\n    return `<pre data-language=\"${language}\">\\n${escapeText(\n      this.code(index, length),\n    )}\\n</pre>`;\n  }\n\n  optimize(context: Record<string, any>) {\n    super.optimize(context);\n    if (\n      this.parent != null &&\n      this.children.head != null &&\n      this.uiNode != null\n    ) {\n      const language = SyntaxCodeBlock.formats(this.children.head.domNode);\n      // @ts-expect-error\n      if (language !== this.uiNode.value) {\n        // @ts-expect-error\n        this.uiNode.value = language;\n      }\n    }\n  }\n}\n\nSyntaxCodeBlockContainer.allowedChildren = [SyntaxCodeBlock];\nSyntaxCodeBlock.requiredContainer = SyntaxCodeBlockContainer;\nSyntaxCodeBlock.allowedChildren = [CodeToken, CursorBlot, TextBlot, BreakBlot];\n\ninterface SyntaxOptions {\n  interval: number;\n  languages: { key: string; label: string }[];\n  hljs: any;\n}\n\nconst highlight = (lib: any, language: string, text: string) => {\n  if (typeof lib.versionString === 'string') {\n    const majorVersion = lib.versionString.split('.')[0];\n    if (parseInt(majorVersion, 10) >= 11) {\n      return lib.highlight(text, { language }).value;\n    }\n  }\n  return lib.highlight(language, text).value;\n};\n\nclass Syntax extends Module<SyntaxOptions> {\n  static DEFAULTS: SyntaxOptions & { hljs: any };\n\n  static register() {\n    Quill.register(CodeToken, true);\n    Quill.register(SyntaxCodeBlock, true);\n    Quill.register(SyntaxCodeBlockContainer, true);\n  }\n\n  languages: Record<string, true>;\n\n  constructor(quill: Quill, options: Partial<SyntaxOptions>) {\n    super(quill, options);\n    if (this.options.hljs == null) {\n      throw new Error(\n        'Syntax module requires highlight.js. Please include the library on the page before Quill.',\n      );\n    }\n    // @ts-expect-error Fix me later\n    this.languages = this.options.languages.reduce(\n      (memo: Record<string, unknown>, { key }) => {\n        memo[key] = true;\n        return memo;\n      },\n      {},\n    );\n    this.highlightBlot = this.highlightBlot.bind(this);\n    this.initListener();\n    this.initTimer();\n  }\n\n  initListener() {\n    this.quill.on(Quill.events.SCROLL_BLOT_MOUNT, (blot: Blot) => {\n      if (!(blot instanceof SyntaxCodeBlockContainer)) return;\n      const select = this.quill.root.ownerDocument.createElement('select');\n      // @ts-expect-error Fix me later\n      this.options.languages.forEach(({ key, label }) => {\n        const option = select.ownerDocument.createElement('option');\n        option.textContent = label;\n        option.setAttribute('value', key);\n        select.appendChild(option);\n      });\n      select.addEventListener('change', () => {\n        blot.format(SyntaxCodeBlock.blotName, select.value);\n        this.quill.root.focus(); // Prevent scrolling\n        this.highlight(blot, true);\n      });\n      if (blot.uiNode == null) {\n        blot.attachUI(select);\n        if (blot.children.head) {\n          select.value = SyntaxCodeBlock.formats(blot.children.head.domNode);\n        }\n      }\n    });\n  }\n\n  initTimer() {\n    let timer: ReturnType<typeof setTimeout> | null = null;\n    this.quill.on(Quill.events.SCROLL_OPTIMIZE, () => {\n      if (timer) {\n        clearTimeout(timer);\n      }\n      timer = setTimeout(() => {\n        this.highlight();\n        timer = null;\n      }, this.options.interval);\n    });\n  }\n\n  highlight(blot: SyntaxCodeBlockContainer | null = null, force = false) {\n    if (this.quill.selection.composing) return;\n    this.quill.update(Quill.sources.USER);\n    const range = this.quill.getSelection();\n    const blots =\n      blot == null\n        ? this.quill.scroll.descendants(SyntaxCodeBlockContainer)\n        : [blot];\n    blots.forEach((container) => {\n      container.highlight(this.highlightBlot, force);\n    });\n    this.quill.update(Quill.sources.SILENT);\n    if (range != null) {\n      this.quill.setSelection(range, Quill.sources.SILENT);\n    }\n  }\n\n  highlightBlot(text: string, language = 'plain') {\n    language = this.languages[language] ? language : 'plain';\n    if (language === 'plain') {\n      return escapeText(text)\n        .split('\\n')\n        .reduce((delta, line, i) => {\n          if (i !== 0) {\n            delta.insert('\\n', { [CodeBlock.blotName]: language });\n          }\n          return delta.insert(line);\n        }, new Delta());\n    }\n    const container = this.quill.root.ownerDocument.createElement('div');\n    container.classList.add(CodeBlock.className);\n    container.innerHTML = highlight(this.options.hljs, language, text);\n    return traverse(\n      this.quill.scroll,\n      container,\n      [\n        (node, delta) => {\n          // @ts-expect-error\n          const value = TokenAttributor.value(node);\n          if (value) {\n            return delta.compose(\n              new Delta().retain(delta.length(), {\n                [CodeToken.blotName]: value,\n              }),\n            );\n          }\n          return delta;\n        },\n      ],\n      [\n        (node, delta) => {\n          // @ts-expect-error\n          return node.data.split('\\n').reduce((memo, nodeText, i) => {\n            if (i !== 0) memo.insert('\\n', { [CodeBlock.blotName]: language });\n            return memo.insert(nodeText);\n          }, delta);\n        },\n      ],\n      new WeakMap(),\n    );\n  }\n}\nSyntax.DEFAULTS = {\n  hljs: (() => {\n    return window.hljs;\n  })(),\n  interval: 1000,\n  languages: [\n    { key: 'plain', label: 'Plain' },\n    { key: 'bash', label: 'Bash' },\n    { key: 'cpp', label: 'C++' },\n    { key: 'cs', label: 'C#' },\n    { key: 'css', label: 'CSS' },\n    { key: 'diff', label: 'Diff' },\n    { key: 'xml', label: 'HTML/XML' },\n    { key: 'java', label: 'Java' },\n    { key: 'javascript', label: 'JavaScript' },\n    { key: 'markdown', label: 'Markdown' },\n    { key: 'php', label: 'PHP' },\n    { key: 'python', label: 'Python' },\n    { key: 'ruby', label: 'Ruby' },\n    { key: 'sql', label: 'SQL' },\n  ],\n};\n\nexport { SyntaxCodeBlock as CodeBlock, CodeToken, Syntax as default };\n","import type { LinkedList } from 'parchment';\nimport Block from '../blots/block.js';\nimport Container from '../blots/container.js';\n\nclass TableCell extends Block {\n  static blotName = 'table';\n  static tagName = 'TD';\n\n  static create(value: string) {\n    const node = super.create() as HTMLElement;\n    if (value) {\n      node.setAttribute('data-row', value);\n    } else {\n      node.setAttribute('data-row', tableId());\n    }\n    return node;\n  }\n\n  static formats(domNode: HTMLElement) {\n    if (domNode.hasAttribute('data-row')) {\n      return domNode.getAttribute('data-row');\n    }\n    return undefined;\n  }\n\n  next: this | null;\n\n  cellOffset() {\n    if (this.parent) {\n      return this.parent.children.indexOf(this);\n    }\n    return -1;\n  }\n\n  format(name: string, value: string) {\n    if (name === TableCell.blotName && value) {\n      this.domNode.setAttribute('data-row', value);\n    } else {\n      super.format(name, value);\n    }\n  }\n\n  row(): TableRow {\n    return this.parent as TableRow;\n  }\n\n  rowOffset() {\n    if (this.row()) {\n      return this.row().rowOffset();\n    }\n    return -1;\n  }\n\n  table() {\n    return this.row() && this.row().table();\n  }\n}\n\nclass TableRow extends Container {\n  static blotName = 'table-row';\n  static tagName = 'TR';\n\n  children: LinkedList<TableCell>;\n  next: this | null;\n\n  checkMerge() {\n    // @ts-expect-error\n    if (super.checkMerge() && this.next.children.head != null) {\n      // @ts-expect-error\n      const thisHead = this.children.head.formats();\n      // @ts-expect-error\n      const thisTail = this.children.tail.formats();\n      // @ts-expect-error\n      const nextHead = this.next.children.head.formats();\n      // @ts-expect-error\n      const nextTail = this.next.children.tail.formats();\n      return (\n        thisHead.table === thisTail.table &&\n        thisHead.table === nextHead.table &&\n        thisHead.table === nextTail.table\n      );\n    }\n    return false;\n  }\n\n  optimize(context: { [key: string]: any }) {\n    super.optimize(context);\n    this.children.forEach((child) => {\n      if (child.next == null) return;\n      const childFormats = child.formats();\n      const nextFormats = child.next.formats();\n      if (childFormats.table !== nextFormats.table) {\n        const next = this.splitAfter(child);\n        if (next) {\n          // @ts-expect-error TODO: parameters of optimize() should be a optional\n          next.optimize();\n        }\n        // We might be able to merge with prev now\n        if (this.prev) {\n          // @ts-expect-error TODO: parameters of optimize() should be a optional\n          this.prev.optimize();\n        }\n      }\n    });\n  }\n\n  rowOffset() {\n    if (this.parent) {\n      return this.parent.children.indexOf(this);\n    }\n    return -1;\n  }\n\n  table() {\n    return this.parent && this.parent.parent;\n  }\n}\n\nclass TableBody extends Container {\n  static blotName = 'table-body';\n  static tagName = 'TBODY';\n\n  children: LinkedList<TableRow>;\n}\n\nclass TableContainer extends Container {\n  static blotName = 'table-container';\n  static tagName = 'TABLE';\n\n  children: LinkedList<TableBody>;\n\n  balanceCells() {\n    const rows = this.descendants(TableRow);\n    const maxColumns = rows.reduce((max, row) => {\n      return Math.max(row.children.length, max);\n    }, 0);\n    rows.forEach((row) => {\n      new Array(maxColumns - row.children.length).fill(0).forEach(() => {\n        let value;\n        if (row.children.head != null) {\n          value = TableCell.formats(row.children.head.domNode);\n        }\n        const blot = this.scroll.create(TableCell.blotName, value);\n        row.appendChild(blot);\n        // @ts-expect-error TODO: parameters of optimize() should be a optional\n        blot.optimize(); // Add break blot\n      });\n    });\n  }\n\n  cells(column: number) {\n    return this.rows().map((row) => row.children.at(column));\n  }\n\n  deleteColumn(index: number) {\n    // @ts-expect-error\n    const [body] = this.descendant(TableBody) as TableBody[];\n    if (body == null || body.children.head == null) return;\n    body.children.forEach((row) => {\n      const cell = row.children.at(index);\n      if (cell != null) {\n        cell.remove();\n      }\n    });\n  }\n\n  insertColumn(index: number) {\n    // @ts-expect-error\n    const [body] = this.descendant(TableBody) as TableBody[];\n    if (body == null || body.children.head == null) return;\n    body.children.forEach((row) => {\n      const ref = row.children.at(index);\n      // @ts-expect-error\n      const value = TableCell.formats(row.children.head.domNode);\n      const cell = this.scroll.create(TableCell.blotName, value);\n      row.insertBefore(cell, ref);\n    });\n  }\n\n  insertRow(index: number) {\n    // @ts-expect-error\n    const [body] = this.descendant(TableBody) as TableBody[];\n    if (body == null || body.children.head == null) return;\n    const id = tableId();\n    const row = this.scroll.create(TableRow.blotName) as TableRow;\n    body.children.head.children.forEach(() => {\n      const cell = this.scroll.create(TableCell.blotName, id);\n      row.appendChild(cell);\n    });\n    const ref = body.children.at(index);\n    body.insertBefore(row, ref);\n  }\n\n  rows() {\n    const body = this.children.head;\n    if (body == null) return [];\n    return body.children.map((row) => row);\n  }\n}\n\nTableContainer.allowedChildren = [TableBody];\nTableBody.requiredContainer = TableContainer;\n\nTableBody.allowedChildren = [TableRow];\nTableRow.requiredContainer = TableBody;\n\nTableRow.allowedChildren = [TableCell];\nTableCell.requiredContainer = TableRow;\n\nfunction tableId() {\n  const id = Math.random().toString(36).slice(2, 6);\n  return `row-${id}`;\n}\n\nexport { TableCell, TableRow, TableBody, TableContainer, tableId };\n","import Delta from 'quill-delta';\nimport Quill from '../core/quill.js';\nimport Module from '../core/module.js';\nimport {\n  TableCell,\n  TableRow,\n  TableBody,\n  TableContainer,\n  tableId,\n} from '../formats/table.js';\n\nclass Table extends Module {\n  static register() {\n    Quill.register(TableCell);\n    Quill.register(TableRow);\n    Quill.register(TableBody);\n    Quill.register(TableContainer);\n  }\n\n  constructor(...args: ConstructorParameters<typeof Module>) {\n    super(...args);\n    this.listenBalanceCells();\n  }\n\n  balanceTables() {\n    this.quill.scroll.descendants(TableContainer).forEach((table) => {\n      table.balanceCells();\n    });\n  }\n\n  deleteColumn() {\n    const [table, , cell] = this.getTable();\n    if (cell == null) return;\n    // @ts-expect-error\n    table.deleteColumn(cell.cellOffset());\n    this.quill.update(Quill.sources.USER);\n  }\n\n  deleteRow() {\n    const [, row] = this.getTable();\n    if (row == null) return;\n    row.remove();\n    this.quill.update(Quill.sources.USER);\n  }\n\n  deleteTable() {\n    const [table] = this.getTable();\n    if (table == null) return;\n    // @ts-expect-error\n    const offset = table.offset();\n    // @ts-expect-error\n    table.remove();\n    this.quill.update(Quill.sources.USER);\n    this.quill.setSelection(offset, Quill.sources.SILENT);\n  }\n\n  getTable(\n    range = this.quill.getSelection(),\n  ): [null, null, null, -1] | [Table, TableRow, TableCell, number] {\n    if (range == null) return [null, null, null, -1];\n    const [cell, offset] = this.quill.getLine(range.index);\n    if (cell == null || cell.statics.blotName !== TableCell.blotName) {\n      return [null, null, null, -1];\n    }\n    const row = cell.parent;\n    const table = row.parent.parent;\n    // @ts-expect-error\n    return [table, row, cell, offset];\n  }\n\n  insertColumn(offset: number) {\n    const range = this.quill.getSelection();\n    if (!range) return;\n    const [table, row, cell] = this.getTable(range);\n    if (cell == null) return;\n    const column = cell.cellOffset();\n    table.insertColumn(column + offset);\n    this.quill.update(Quill.sources.USER);\n    let shift = row.rowOffset();\n    if (offset === 0) {\n      shift += 1;\n    }\n    this.quill.setSelection(\n      range.index + shift,\n      range.length,\n      Quill.sources.SILENT,\n    );\n  }\n\n  insertColumnLeft() {\n    this.insertColumn(0);\n  }\n\n  insertColumnRight() {\n    this.insertColumn(1);\n  }\n\n  insertRow(offset: number) {\n    const range = this.quill.getSelection();\n    if (!range) return;\n    const [table, row, cell] = this.getTable(range);\n    if (cell == null) return;\n    const index = row.rowOffset();\n    table.insertRow(index + offset);\n    this.quill.update(Quill.sources.USER);\n    if (offset > 0) {\n      this.quill.setSelection(range, Quill.sources.SILENT);\n    } else {\n      this.quill.setSelection(\n        range.index + row.children.length,\n        range.length,\n        Quill.sources.SILENT,\n      );\n    }\n  }\n\n  insertRowAbove() {\n    this.insertRow(0);\n  }\n\n  insertRowBelow() {\n    this.insertRow(1);\n  }\n\n  insertTable(rows: number, columns: number) {\n    const range = this.quill.getSelection();\n    if (range == null) return;\n    const delta = new Array(rows).fill(0).reduce((memo) => {\n      const text = new Array(columns).fill('\\n').join('');\n      return memo.insert(text, { table: tableId() });\n    }, new Delta().retain(range.index));\n    this.quill.updateContents(delta, Quill.sources.USER);\n    this.quill.setSelection(range.index, Quill.sources.SILENT);\n    this.balanceTables();\n  }\n\n  listenBalanceCells() {\n    this.quill.on(\n      Quill.events.SCROLL_OPTIMIZE,\n      (mutations: MutationRecord[]) => {\n        mutations.some((mutation) => {\n          if (\n            ['TD', 'TR', 'TBODY', 'TABLE'].includes(\n              (mutation.target as HTMLElement).tagName,\n            )\n          ) {\n            this.quill.once(Quill.events.TEXT_CHANGE, (delta, old, source) => {\n              if (source !== Quill.sources.USER) return;\n              this.balanceTables();\n            });\n            return true;\n          }\n          return false;\n        });\n      },\n    );\n  }\n}\n\nexport default Table;\n","import Delta from 'quill-delta';\nimport { EmbedBlot, Scope } from 'parchment';\nimport Quill from '../core/quill.js';\nimport logger from '../core/logger.js';\nimport Module from '../core/module.js';\nimport type { Range } from '../core/selection.js';\n\nconst debug = logger('quill:toolbar');\n\ntype Handler = (this: Toolbar, value: any) => void;\n\nexport type ToolbarConfig = Array<\n  string[] | Array<string | Record<string, unknown>>\n>;\nexport interface ToolbarProps {\n  container?: HTMLElement | ToolbarConfig | null;\n  handlers?: Record<string, Handler>;\n  option?: number;\n  module?: boolean;\n  theme?: boolean;\n}\n\nclass Toolbar extends Module<ToolbarProps> {\n  static DEFAULTS: ToolbarProps;\n\n  container?: HTMLElement | null;\n  controls: [string, HTMLElement][];\n  handlers: Record<string, Handler>;\n\n  constructor(quill: Quill, options: Partial<ToolbarProps>) {\n    super(quill, options);\n    if (Array.isArray(this.options.container)) {\n      const container = document.createElement('div');\n      container.setAttribute('role', 'toolbar');\n      addControls(container, this.options.container);\n      quill.container?.parentNode?.insertBefore(container, quill.container);\n      this.container = container;\n    } else if (typeof this.options.container === 'string') {\n      this.container = document.querySelector(this.options.container);\n    } else {\n      this.container = this.options.container;\n    }\n    if (!(this.container instanceof HTMLElement)) {\n      debug.error('Container required for toolbar', this.options);\n      return;\n    }\n    this.container.classList.add('ql-toolbar');\n    this.controls = [];\n    this.handlers = {};\n    if (this.options.handlers) {\n      Object.keys(this.options.handlers).forEach((format) => {\n        const handler = this.options.handlers?.[format];\n        if (handler) {\n          this.addHandler(format, handler);\n        }\n      });\n    }\n    Array.from(this.container.querySelectorAll('button, select')).forEach(\n      (input) => {\n        // @ts-expect-error\n        this.attach(input);\n      },\n    );\n    this.quill.on(Quill.events.EDITOR_CHANGE, () => {\n      const [range] = this.quill.selection.getRange(); // quill.getSelection triggers update\n      this.update(range);\n    });\n  }\n\n  addHandler(format: string, handler: Handler) {\n    this.handlers[format] = handler;\n  }\n\n  attach(input: HTMLElement) {\n    let format = Array.from(input.classList).find((className) => {\n      return className.indexOf('ql-') === 0;\n    });\n    if (!format) return;\n    format = format.slice('ql-'.length);\n    if (input.tagName === 'BUTTON') {\n      input.setAttribute('type', 'button');\n    }\n    if (\n      this.handlers[format] == null &&\n      this.quill.scroll.query(format) == null\n    ) {\n      debug.warn('ignoring attaching to nonexistent format', format, input);\n      return;\n    }\n    const eventName = input.tagName === 'SELECT' ? 'change' : 'click';\n    input.addEventListener(eventName, (e) => {\n      let value;\n      if (input.tagName === 'SELECT') {\n        // @ts-expect-error\n        if (input.selectedIndex < 0) return;\n        // @ts-expect-error\n        const selected = input.options[input.selectedIndex];\n        if (selected.hasAttribute('selected')) {\n          value = false;\n        } else {\n          value = selected.value || false;\n        }\n      } else {\n        if (input.classList.contains('ql-active')) {\n          value = false;\n        } else {\n          // @ts-expect-error\n          value = input.value || !input.hasAttribute('value');\n        }\n        e.preventDefault();\n      }\n      this.quill.focus();\n      const [range] = this.quill.selection.getRange();\n      if (this.handlers[format] != null) {\n        this.handlers[format].call(this, value);\n      } else if (\n        // @ts-expect-error\n        this.quill.scroll.query(format).prototype instanceof EmbedBlot\n      ) {\n        value = prompt(`Enter ${format}`); // eslint-disable-line no-alert\n        if (!value) return;\n        this.quill.updateContents(\n          new Delta()\n            // @ts-expect-error Fix me later\n            .retain(range.index)\n            // @ts-expect-error Fix me later\n            .delete(range.length)\n            .insert({ [format]: value }),\n          Quill.sources.USER,\n        );\n      } else {\n        this.quill.format(format, value, Quill.sources.USER);\n      }\n      this.update(range);\n    });\n    this.controls.push([format, input]);\n  }\n\n  update(range: Range | null) {\n    const formats = range == null ? {} : this.quill.getFormat(range);\n    this.controls.forEach((pair) => {\n      const [format, input] = pair;\n      if (input.tagName === 'SELECT') {\n        let option: HTMLOptionElement | null = null;\n        if (range == null) {\n          option = null;\n        } else if (formats[format] == null) {\n          option = input.querySelector('option[selected]');\n        } else if (!Array.isArray(formats[format])) {\n          let value = formats[format];\n          if (typeof value === 'string') {\n            value = value.replace(/\"/g, '\\\\\"');\n          }\n          option = input.querySelector(`option[value=\"${value}\"]`);\n        }\n        if (option == null) {\n          // @ts-expect-error TODO fix me later\n          input.value = ''; // TODO make configurable?\n          // @ts-expect-error TODO fix me later\n          input.selectedIndex = -1;\n        } else {\n          option.selected = true;\n        }\n      } else if (range == null) {\n        input.classList.remove('ql-active');\n        input.setAttribute('aria-pressed', 'false');\n      } else if (input.hasAttribute('value')) {\n        // both being null should match (default values)\n        // '1' should match with 1 (headers)\n        const value = formats[format] as boolean | number | string | object;\n        const isActive =\n          value === input.getAttribute('value') ||\n          (value != null && value.toString() === input.getAttribute('value')) ||\n          (value == null && !input.getAttribute('value'));\n        input.classList.toggle('ql-active', isActive);\n        input.setAttribute('aria-pressed', isActive.toString());\n      } else {\n        const isActive = formats[format] != null;\n        input.classList.toggle('ql-active', isActive);\n        input.setAttribute('aria-pressed', isActive.toString());\n      }\n    });\n  }\n}\nToolbar.DEFAULTS = {};\n\nfunction addButton(container: HTMLElement, format: string, value?: string) {\n  const input = document.createElement('button');\n  input.setAttribute('type', 'button');\n  input.classList.add(`ql-${format}`);\n  input.setAttribute('aria-pressed', 'false');\n  if (value != null) {\n    input.value = value;\n    input.setAttribute('aria-label', `${format}: ${value}`);\n  } else {\n    input.setAttribute('aria-label', format);\n  }\n  container.appendChild(input);\n}\n\nfunction addControls(\n  container: HTMLElement,\n  groups:\n    | (string | Record<string, unknown>)[][]\n    | (string | Record<string, unknown>)[],\n) {\n  if (!Array.isArray(groups[0])) {\n    // @ts-expect-error\n    groups = [groups];\n  }\n  groups.forEach((controls: any) => {\n    const group = document.createElement('span');\n    group.classList.add('ql-formats');\n    controls.forEach((control: any) => {\n      if (typeof control === 'string') {\n        addButton(group, control);\n      } else {\n        const format = Object.keys(control)[0];\n        const value = control[format];\n        if (Array.isArray(value)) {\n          addSelect(group, format, value);\n        } else {\n          addButton(group, format, value);\n        }\n      }\n    });\n    container.appendChild(group);\n  });\n}\n\nfunction addSelect(\n  container: HTMLElement,\n  format: string,\n  values: Array<string | boolean>,\n) {\n  const input = document.createElement('select');\n  input.classList.add(`ql-${format}`);\n  values.forEach((value) => {\n    const option = document.createElement('option');\n    if (value !== false) {\n      option.setAttribute('value', String(value));\n    } else {\n      option.setAttribute('selected', 'selected');\n    }\n    input.appendChild(option);\n  });\n  container.appendChild(input);\n}\n\nToolbar.DEFAULTS = {\n  container: null,\n  handlers: {\n    clean() {\n      const range = this.quill.getSelection();\n      if (range == null) return;\n      if (range.length === 0) {\n        const formats = this.quill.getFormat();\n        Object.keys(formats).forEach((name) => {\n          // Clean functionality in existing apps only clean inline formats\n          if (this.quill.scroll.query(name, Scope.INLINE) != null) {\n            this.quill.format(name, false, Quill.sources.USER);\n          }\n        });\n      } else {\n        this.quill.removeFormat(range.index, range.length, Quill.sources.USER);\n      }\n    },\n    direction(value) {\n      const { align } = this.quill.getFormat();\n      if (value === 'rtl' && align == null) {\n        this.quill.format('align', 'right', Quill.sources.USER);\n      } else if (!value && align === 'right') {\n        this.quill.format('align', false, Quill.sources.USER);\n      }\n      this.quill.format('direction', value, Quill.sources.USER);\n    },\n    indent(value) {\n      const range = this.quill.getSelection();\n      // @ts-expect-error\n      const formats = this.quill.getFormat(range);\n      // @ts-expect-error\n      const indent = parseInt(formats.indent || 0, 10);\n      if (value === '+1' || value === '-1') {\n        let modifier = value === '+1' ? 1 : -1;\n        if (formats.direction === 'rtl') modifier *= -1;\n        this.quill.format('indent', indent + modifier, Quill.sources.USER);\n      }\n    },\n    link(value) {\n      if (value === true) {\n        value = prompt('Enter link URL:'); // eslint-disable-line no-alert\n      }\n      this.quill.format('link', value, Quill.sources.USER);\n    },\n    list(value) {\n      const range = this.quill.getSelection();\n      // @ts-expect-error\n      const formats = this.quill.getFormat(range);\n      if (value === 'check') {\n        if (formats.list === 'checked' || formats.list === 'unchecked') {\n          this.quill.format('list', false, Quill.sources.USER);\n        } else {\n          this.quill.format('list', 'unchecked', Quill.sources.USER);\n        }\n      } else {\n        this.quill.format('list', value, Quill.sources.USER);\n      }\n    },\n  },\n};\n\nexport { Toolbar as default, addControls };\n","import alignLeftIcon from '../assets/icons/align-left.svg';\nimport alignCenterIcon from '../assets/icons/align-center.svg';\nimport alignRightIcon from '../assets/icons/align-right.svg';\nimport alignJustifyIcon from '../assets/icons/align-justify.svg';\nimport backgroundIcon from '../assets/icons/background.svg';\nimport blockquoteIcon from '../assets/icons/blockquote.svg';\nimport boldIcon from '../assets/icons/bold.svg';\nimport cleanIcon from '../assets/icons/clean.svg';\nimport codeIcon from '../assets/icons/code.svg';\nimport colorIcon from '../assets/icons/color.svg';\nimport directionLeftToRightIcon from '../assets/icons/direction-ltr.svg';\nimport directionRightToLeftIcon from '../assets/icons/direction-rtl.svg';\nimport formulaIcon from '../assets/icons/formula.svg';\nimport headerIcon from '../assets/icons/header.svg';\nimport header2Icon from '../assets/icons/header-2.svg';\nimport header3Icon from '../assets/icons/header-3.svg';\nimport header4Icon from '../assets/icons/header-4.svg';\nimport header5Icon from '../assets/icons/header-5.svg';\nimport header6Icon from '../assets/icons/header-6.svg';\nimport italicIcon from '../assets/icons/italic.svg';\nimport imageIcon from '../assets/icons/image.svg';\nimport indentIcon from '../assets/icons/indent.svg';\nimport outdentIcon from '../assets/icons/outdent.svg';\nimport linkIcon from '../assets/icons/link.svg';\nimport listBulletIcon from '../assets/icons/list-bullet.svg';\nimport listCheckIcon from '../assets/icons/list-check.svg';\nimport listOrderedIcon from '../assets/icons/list-ordered.svg';\nimport subscriptIcon from '../assets/icons/subscript.svg';\nimport superscriptIcon from '../assets/icons/superscript.svg';\nimport strikeIcon from '../assets/icons/strike.svg';\nimport tableIcon from '../assets/icons/table.svg';\nimport underlineIcon from '../assets/icons/underline.svg';\nimport videoIcon from '../assets/icons/video.svg';\n\nexport default {\n  align: {\n    '': alignLeftIcon,\n    center: alignCenterIcon,\n    right: alignRightIcon,\n    justify: alignJustifyIcon,\n  },\n  background: backgroundIcon,\n  blockquote: blockquoteIcon,\n  bold: boldIcon,\n  clean: cleanIcon,\n  code: codeIcon,\n  'code-block': codeIcon,\n  color: colorIcon,\n  direction: {\n    '': directionLeftToRightIcon,\n    rtl: directionRightToLeftIcon,\n  },\n  formula: formulaIcon,\n  header: {\n    '1': headerIcon,\n    '2': header2Icon,\n    '3': header3Icon,\n    '4': header4Icon,\n    '5': header5Icon,\n    '6': header6Icon,\n  },\n  italic: italicIcon,\n  image: imageIcon,\n  indent: {\n    '+1': indentIcon,\n    '-1': outdentIcon,\n  },\n  link: linkIcon,\n  list: {\n    bullet: listBulletIcon,\n    check: listCheckIcon,\n    ordered: listOrderedIcon,\n  },\n  script: {\n    sub: subscriptIcon,\n    super: superscriptIcon,\n  },\n  strike: strikeIcon,\n  table: tableIcon,\n  underline: underlineIcon,\n  video: videoIcon,\n};\n","import DropdownIcon from '../assets/icons/dropdown.svg';\n\nlet optionsCounter = 0;\n\nfunction toggleAriaAttribute(element: HTMLElement, attribute: string) {\n  element.setAttribute(\n    attribute,\n    `${!(element.getAttribute(attribute) === 'true')}`,\n  );\n}\n\nclass Picker {\n  select: HTMLSelectElement;\n  container: HTMLElement;\n  label: HTMLElement;\n\n  constructor(select: HTMLSelectElement) {\n    this.select = select;\n    this.container = document.createElement('span');\n    this.buildPicker();\n    this.select.style.display = 'none';\n    // @ts-expect-error Fix me later\n    this.select.parentNode.insertBefore(this.container, this.select);\n\n    this.label.addEventListener('mousedown', () => {\n      this.togglePicker();\n    });\n    this.label.addEventListener('keydown', (event) => {\n      switch (event.key) {\n        case 'Enter':\n          this.togglePicker();\n          break;\n        case 'Escape':\n          this.escape();\n          event.preventDefault();\n          break;\n        default:\n      }\n    });\n    this.select.addEventListener('change', this.update.bind(this));\n  }\n\n  togglePicker() {\n    this.container.classList.toggle('ql-expanded');\n    // Toggle aria-expanded and aria-hidden to make the picker accessible\n    toggleAriaAttribute(this.label, 'aria-expanded');\n    // @ts-expect-error\n    toggleAriaAttribute(this.options, 'aria-hidden');\n  }\n\n  buildItem(option: HTMLOptionElement) {\n    const item = document.createElement('span');\n    // @ts-expect-error\n    item.tabIndex = '0';\n    item.setAttribute('role', 'button');\n    item.classList.add('ql-picker-item');\n    const value = option.getAttribute('value');\n    if (value) {\n      item.setAttribute('data-value', value);\n    }\n    if (option.textContent) {\n      item.setAttribute('data-label', option.textContent);\n    }\n    item.addEventListener('click', () => {\n      this.selectItem(item, true);\n    });\n    item.addEventListener('keydown', (event) => {\n      switch (event.key) {\n        case 'Enter':\n          this.selectItem(item, true);\n          event.preventDefault();\n          break;\n        case 'Escape':\n          this.escape();\n          event.preventDefault();\n          break;\n        default:\n      }\n    });\n\n    return item;\n  }\n\n  buildLabel() {\n    const label = document.createElement('span');\n    label.classList.add('ql-picker-label');\n    label.innerHTML = DropdownIcon;\n    // @ts-expect-error\n    label.tabIndex = '0';\n    label.setAttribute('role', 'button');\n    label.setAttribute('aria-expanded', 'false');\n    this.container.appendChild(label);\n    return label;\n  }\n\n  buildOptions() {\n    const options = document.createElement('span');\n    options.classList.add('ql-picker-options');\n\n    // Don't want screen readers to read this until options are visible\n    options.setAttribute('aria-hidden', 'true');\n    // @ts-expect-error\n    options.tabIndex = '-1';\n\n    // Need a unique id for aria-controls\n    options.id = `ql-picker-options-${optionsCounter}`;\n    optionsCounter += 1;\n    this.label.setAttribute('aria-controls', options.id);\n\n    // @ts-expect-error\n    this.options = options;\n\n    Array.from(this.select.options).forEach((option) => {\n      const item = this.buildItem(option);\n      options.appendChild(item);\n      if (option.selected === true) {\n        this.selectItem(item);\n      }\n    });\n    this.container.appendChild(options);\n  }\n\n  buildPicker() {\n    Array.from(this.select.attributes).forEach((item) => {\n      this.container.setAttribute(item.name, item.value);\n    });\n    this.container.classList.add('ql-picker');\n    this.label = this.buildLabel();\n    this.buildOptions();\n  }\n\n  escape() {\n    // Close menu and return focus to trigger label\n    this.close();\n    // Need setTimeout for accessibility to ensure that the browser executes\n    // focus on the next process thread and after any DOM content changes\n    setTimeout(() => this.label.focus(), 1);\n  }\n\n  close() {\n    this.container.classList.remove('ql-expanded');\n    this.label.setAttribute('aria-expanded', 'false');\n    // @ts-expect-error\n    this.options.setAttribute('aria-hidden', 'true');\n  }\n\n  selectItem(item: HTMLElement | null, trigger = false) {\n    const selected = this.container.querySelector('.ql-selected');\n    if (item === selected) return;\n    if (selected != null) {\n      selected.classList.remove('ql-selected');\n    }\n    if (item == null) return;\n    item.classList.add('ql-selected');\n    // @ts-expect-error Fix me later\n    this.select.selectedIndex = Array.from(item.parentNode.children).indexOf(\n      item,\n    );\n    if (item.hasAttribute('data-value')) {\n      // @ts-expect-error Fix me later\n      this.label.setAttribute('data-value', item.getAttribute('data-value'));\n    } else {\n      this.label.removeAttribute('data-value');\n    }\n    if (item.hasAttribute('data-label')) {\n      // @ts-expect-error Fix me later\n      this.label.setAttribute('data-label', item.getAttribute('data-label'));\n    } else {\n      this.label.removeAttribute('data-label');\n    }\n    if (trigger) {\n      this.select.dispatchEvent(new Event('change'));\n      this.close();\n    }\n  }\n\n  update() {\n    let option;\n    if (this.select.selectedIndex > -1) {\n      const item =\n        // @ts-expect-error Fix me later\n        this.container.querySelector('.ql-picker-options').children[\n          this.select.selectedIndex\n        ];\n      option = this.select.options[this.select.selectedIndex];\n      // @ts-expect-error\n      this.selectItem(item);\n    } else {\n      this.selectItem(null);\n    }\n    const isActive =\n      option != null &&\n      option !== this.select.querySelector('option[selected]');\n    this.label.classList.toggle('ql-active', isActive);\n  }\n}\n\nexport default Picker;\n","import Picker from './picker.js';\n\nclass ColorPicker extends Picker {\n  constructor(select: HTMLSelectElement, label: string) {\n    super(select);\n    this.label.innerHTML = label;\n    this.container.classList.add('ql-color-picker');\n    Array.from(this.container.querySelectorAll('.ql-picker-item'))\n      .slice(0, 7)\n      .forEach((item) => {\n        item.classList.add('ql-primary');\n      });\n  }\n\n  buildItem(option: HTMLOptionElement) {\n    const item = super.buildItem(option);\n    item.style.backgroundColor = option.getAttribute('value') || '';\n    return item;\n  }\n\n  selectItem(item: HTMLElement | null, trigger?: boolean) {\n    super.selectItem(item, trigger);\n    const colorLabel = this.label.querySelector<HTMLElement>('.ql-color-label');\n    const value = item ? item.getAttribute('data-value') || '' : '';\n    if (colorLabel) {\n      if (colorLabel.tagName === 'line') {\n        colorLabel.style.stroke = value;\n      } else {\n        colorLabel.style.fill = value;\n      }\n    }\n  }\n}\n\nexport default ColorPicker;\n","import Picker from './picker.js';\n\nclass IconPicker extends Picker {\n  defaultItem: HTMLElement | null;\n\n  constructor(select: HTMLSelectElement, icons: Record<string, string>) {\n    super(select);\n    this.container.classList.add('ql-icon-picker');\n    Array.from(this.container.querySelectorAll('.ql-picker-item')).forEach(\n      (item) => {\n        item.innerHTML = icons[item.getAttribute('data-value') || ''];\n      },\n    );\n    this.defaultItem = this.container.querySelector('.ql-selected');\n    this.selectItem(this.defaultItem);\n  }\n\n  selectItem(target: HTMLElement | null, trigger?: boolean) {\n    super.selectItem(target, trigger);\n    const item = target || this.defaultItem;\n    if (item != null) {\n      if (this.label.innerHTML === item.innerHTML) return;\n      this.label.innerHTML = item.innerHTML;\n    }\n  }\n}\n\nexport default IconPicker;\n","import type Quill from '../core.js';\nimport type { Bounds } from '../core/selection.js';\n\nconst isScrollable = (el: Element) => {\n  const { overflowY } = getComputedStyle(el, null);\n  return overflowY !== 'visible' && overflowY !== 'clip';\n};\n\nclass Tooltip {\n  quill: Quill;\n  boundsContainer: HTMLElement;\n  root: HTMLDivElement;\n\n  constructor(quill: Quill, boundsContainer?: HTMLElement) {\n    this.quill = quill;\n    this.boundsContainer = boundsContainer || document.body;\n    this.root = quill.addContainer('ql-tooltip');\n    // @ts-expect-error\n    this.root.innerHTML = this.constructor.TEMPLATE;\n    if (isScrollable(this.quill.root)) {\n      this.quill.root.addEventListener('scroll', () => {\n        this.root.style.marginTop = `${-1 * this.quill.root.scrollTop}px`;\n      });\n    }\n    this.hide();\n  }\n\n  hide() {\n    this.root.classList.add('ql-hidden');\n  }\n\n  position(reference: Bounds) {\n    const left =\n      reference.left + reference.width / 2 - this.root.offsetWidth / 2;\n    // root.scrollTop should be 0 if scrollContainer !== root\n    const top = reference.bottom + this.quill.root.scrollTop;\n    this.root.style.left = `${left}px`;\n    this.root.style.top = `${top}px`;\n    this.root.classList.remove('ql-flip');\n    const containerBounds = this.boundsContainer.getBoundingClientRect();\n    const rootBounds = this.root.getBoundingClientRect();\n    let shift = 0;\n    if (rootBounds.right > containerBounds.right) {\n      shift = containerBounds.right - rootBounds.right;\n      this.root.style.left = `${left + shift}px`;\n    }\n    if (rootBounds.left < containerBounds.left) {\n      shift = containerBounds.left - rootBounds.left;\n      this.root.style.left = `${left + shift}px`;\n    }\n    if (rootBounds.bottom > containerBounds.bottom) {\n      const height = rootBounds.bottom - rootBounds.top;\n      const verticalShift = reference.bottom - reference.top + height;\n      this.root.style.top = `${top - verticalShift}px`;\n      this.root.classList.add('ql-flip');\n    }\n    return shift;\n  }\n\n  show() {\n    this.root.classList.remove('ql-editing');\n    this.root.classList.remove('ql-hidden');\n  }\n}\n\nexport default Tooltip;\n","import { merge } from 'lodash-es';\nimport type Quill from '../core/quill.js';\nimport Emitter from '../core/emitter.js';\nimport Theme from '../core/theme.js';\nimport type { ThemeOptions } from '../core/theme.js';\nimport ColorPicker from '../ui/color-picker.js';\nimport IconPicker from '../ui/icon-picker.js';\nimport Picker from '../ui/picker.js';\nimport Tooltip from '../ui/tooltip.js';\nimport type { Range } from '../core/selection.js';\nimport type Clipboard from '../modules/clipboard.js';\nimport type History from '../modules/history.js';\nimport type Keyboard from '../modules/keyboard.js';\nimport type Uploader from '../modules/uploader.js';\nimport type Selection from '../core/selection.js';\n\nconst ALIGNS = [false, 'center', 'right', 'justify'];\n\nconst COLORS = [\n  '#000000',\n  '#e60000',\n  '#ff9900',\n  '#ffff00',\n  '#008a00',\n  '#0066cc',\n  '#9933ff',\n  '#ffffff',\n  '#facccc',\n  '#ffebcc',\n  '#ffffcc',\n  '#cce8cc',\n  '#cce0f5',\n  '#ebd6ff',\n  '#bbbbbb',\n  '#f06666',\n  '#ffc266',\n  '#ffff66',\n  '#66b966',\n  '#66a3e0',\n  '#c285ff',\n  '#888888',\n  '#a10000',\n  '#b26b00',\n  '#b2b200',\n  '#006100',\n  '#0047b2',\n  '#6b24b2',\n  '#444444',\n  '#5c0000',\n  '#663d00',\n  '#666600',\n  '#003700',\n  '#002966',\n  '#3d1466',\n];\n\nconst FONTS = [false, 'serif', 'monospace'];\n\nconst HEADERS = ['1', '2', '3', false];\n\nconst SIZES = ['small', false, 'large', 'huge'];\n\nclass BaseTheme extends Theme {\n  pickers: Picker[];\n  tooltip?: Tooltip;\n\n  constructor(quill: Quill, options: ThemeOptions) {\n    super(quill, options);\n    const listener = (e: MouseEvent) => {\n      if (!document.body.contains(quill.root)) {\n        document.body.removeEventListener('click', listener);\n        return;\n      }\n      if (\n        this.tooltip != null &&\n        // @ts-expect-error\n        !this.tooltip.root.contains(e.target) &&\n        // @ts-expect-error\n        document.activeElement !== this.tooltip.textbox &&\n        !this.quill.hasFocus()\n      ) {\n        this.tooltip.hide();\n      }\n      if (this.pickers != null) {\n        this.pickers.forEach((picker) => {\n          // @ts-expect-error\n          if (!picker.container.contains(e.target)) {\n            picker.close();\n          }\n        });\n      }\n    };\n    quill.emitter.listenDOM('click', document.body, listener);\n  }\n\n  addModule(name: 'clipboard'): Clipboard;\n  addModule(name: 'keyboard'): Keyboard;\n  addModule(name: 'uploader'): Uploader;\n  addModule(name: 'history'): History;\n  addModule(name: 'selection'): Selection;\n  addModule(name: string): unknown;\n  addModule(name: string) {\n    const module = super.addModule(name);\n    if (name === 'toolbar') {\n      // @ts-expect-error\n      this.extendToolbar(module);\n    }\n    return module;\n  }\n\n  buildButtons(\n    buttons: NodeListOf<HTMLElement>,\n    icons: Record<string, Record<string, string> | string>,\n  ) {\n    Array.from(buttons).forEach((button) => {\n      const className = button.getAttribute('class') || '';\n      className.split(/\\s+/).forEach((name) => {\n        if (!name.startsWith('ql-')) return;\n        name = name.slice('ql-'.length);\n        if (icons[name] == null) return;\n        if (name === 'direction') {\n          // @ts-expect-error\n          button.innerHTML = icons[name][''] + icons[name].rtl;\n        } else if (typeof icons[name] === 'string') {\n          // @ts-expect-error\n          button.innerHTML = icons[name];\n        } else {\n          // @ts-expect-error\n          const value = button.value || '';\n          // @ts-expect-error\n          if (value != null && icons[name][value]) {\n            // @ts-expect-error\n            button.innerHTML = icons[name][value];\n          }\n        }\n      });\n    });\n  }\n\n  buildPickers(\n    selects: NodeListOf<HTMLSelectElement>,\n    icons: Record<string, string | Record<string, string>>,\n  ) {\n    this.pickers = Array.from(selects).map((select) => {\n      if (select.classList.contains('ql-align')) {\n        if (select.querySelector('option') == null) {\n          fillSelect(select, ALIGNS);\n        }\n        if (typeof icons.align === 'object') {\n          return new IconPicker(select, icons.align);\n        }\n      }\n      if (\n        select.classList.contains('ql-background') ||\n        select.classList.contains('ql-color')\n      ) {\n        const format = select.classList.contains('ql-background')\n          ? 'background'\n          : 'color';\n        if (select.querySelector('option') == null) {\n          fillSelect(\n            select,\n            COLORS,\n            format === 'background' ? '#ffffff' : '#000000',\n          );\n        }\n        return new ColorPicker(select, icons[format] as string);\n      }\n      if (select.querySelector('option') == null) {\n        if (select.classList.contains('ql-font')) {\n          fillSelect(select, FONTS);\n        } else if (select.classList.contains('ql-header')) {\n          fillSelect(select, HEADERS);\n        } else if (select.classList.contains('ql-size')) {\n          fillSelect(select, SIZES);\n        }\n      }\n      return new Picker(select);\n    });\n    const update = () => {\n      this.pickers.forEach((picker) => {\n        picker.update();\n      });\n    };\n    this.quill.on(Emitter.events.EDITOR_CHANGE, update);\n  }\n}\nBaseTheme.DEFAULTS = merge({}, Theme.DEFAULTS, {\n  modules: {\n    toolbar: {\n      handlers: {\n        formula() {\n          this.quill.theme.tooltip.edit('formula');\n        },\n        image() {\n          let fileInput = this.container.querySelector(\n            'input.ql-image[type=file]',\n          );\n          if (fileInput == null) {\n            fileInput = document.createElement('input');\n            fileInput.setAttribute('type', 'file');\n            fileInput.setAttribute(\n              'accept',\n              this.quill.uploader.options.mimetypes.join(', '),\n            );\n            fileInput.classList.add('ql-image');\n            fileInput.addEventListener('change', () => {\n              const range = this.quill.getSelection(true);\n              this.quill.uploader.upload(range, fileInput.files);\n              fileInput.value = '';\n            });\n            this.container.appendChild(fileInput);\n          }\n          fileInput.click();\n        },\n        video() {\n          this.quill.theme.tooltip.edit('video');\n        },\n      },\n    },\n  },\n});\n\nclass BaseTooltip extends Tooltip {\n  textbox: HTMLInputElement | null;\n  linkRange?: Range;\n\n  constructor(quill: Quill, boundsContainer?: HTMLElement) {\n    super(quill, boundsContainer);\n    this.textbox = this.root.querySelector('input[type=\"text\"]');\n    this.listen();\n  }\n\n  listen() {\n    // @ts-expect-error Fix me later\n    this.textbox.addEventListener('keydown', (event) => {\n      if (event.key === 'Enter') {\n        this.save();\n        event.preventDefault();\n      } else if (event.key === 'Escape') {\n        this.cancel();\n        event.preventDefault();\n      }\n    });\n  }\n\n  cancel() {\n    this.hide();\n    this.restoreFocus();\n  }\n\n  edit(mode = 'link', preview: string | null = null) {\n    this.root.classList.remove('ql-hidden');\n    this.root.classList.add('ql-editing');\n    if (this.textbox == null) return;\n\n    if (preview != null) {\n      this.textbox.value = preview;\n    } else if (mode !== this.root.getAttribute('data-mode')) {\n      this.textbox.value = '';\n    }\n    const bounds = this.quill.getBounds(this.quill.selection.savedRange);\n    if (bounds != null) {\n      this.position(bounds);\n    }\n    this.textbox.select();\n    this.textbox.setAttribute(\n      'placeholder',\n      this.textbox.getAttribute(`data-${mode}`) || '',\n    );\n    this.root.setAttribute('data-mode', mode);\n  }\n\n  restoreFocus() {\n    this.quill.focus({ preventScroll: true });\n  }\n\n  save() {\n    // @ts-expect-error Fix me later\n    let { value } = this.textbox;\n    switch (this.root.getAttribute('data-mode')) {\n      case 'link': {\n        const { scrollTop } = this.quill.root;\n        if (this.linkRange) {\n          this.quill.formatText(\n            this.linkRange,\n            'link',\n            value,\n            Emitter.sources.USER,\n          );\n          delete this.linkRange;\n        } else {\n          this.restoreFocus();\n          this.quill.format('link', value, Emitter.sources.USER);\n        }\n        this.quill.root.scrollTop = scrollTop;\n        break;\n      }\n      case 'video': {\n        value = extractVideoUrl(value);\n      } // eslint-disable-next-line no-fallthrough\n      case 'formula': {\n        if (!value) break;\n        const range = this.quill.getSelection(true);\n        if (range != null) {\n          const index = range.index + range.length;\n          this.quill.insertEmbed(\n            index,\n            // @ts-expect-error Fix me later\n            this.root.getAttribute('data-mode'),\n            value,\n            Emitter.sources.USER,\n          );\n          if (this.root.getAttribute('data-mode') === 'formula') {\n            this.quill.insertText(index + 1, ' ', Emitter.sources.USER);\n          }\n          this.quill.setSelection(index + 2, Emitter.sources.USER);\n        }\n        break;\n      }\n      default:\n    }\n    // @ts-expect-error Fix me later\n    this.textbox.value = '';\n    this.hide();\n  }\n}\n\nfunction extractVideoUrl(url: string) {\n  let match =\n    url.match(\n      /^(?:(https?):\\/\\/)?(?:(?:www|m)\\.)?youtube\\.com\\/watch.*v=([a-zA-Z0-9_-]+)/,\n    ) ||\n    url.match(/^(?:(https?):\\/\\/)?(?:(?:www|m)\\.)?youtu\\.be\\/([a-zA-Z0-9_-]+)/);\n  if (match) {\n    return `${match[1] || 'https'}://www.youtube.com/embed/${\n      match[2]\n    }?showinfo=0`;\n  }\n  // eslint-disable-next-line no-cond-assign\n  if ((match = url.match(/^(?:(https?):\\/\\/)?(?:www\\.)?vimeo\\.com\\/(\\d+)/))) {\n    return `${match[1] || 'https'}://player.vimeo.com/video/${match[2]}/`;\n  }\n  return url;\n}\n\nfunction fillSelect(\n  select: HTMLSelectElement,\n  values: Array<string | boolean>,\n  defaultValue: unknown = false,\n) {\n  values.forEach((value) => {\n    const option = document.createElement('option');\n    if (value === defaultValue) {\n      option.setAttribute('selected', 'selected');\n    } else {\n      option.setAttribute('value', String(value));\n    }\n    select.appendChild(option);\n  });\n}\n\nexport { BaseTooltip, BaseTheme as default };\n","import { merge } from 'lodash-es';\nimport Emitter from '../core/emitter.js';\nimport BaseTheme, { BaseTooltip } from './base.js';\nimport { Range } from '../core/selection.js';\nimport type { Bounds } from '../core/selection.js';\nimport icons from '../ui/icons.js';\nimport Quill from '../core/quill.js';\nimport type { ThemeOptions } from '../core/theme.js';\nimport type Toolbar from '../modules/toolbar.js';\nimport type { ToolbarConfig } from '../modules/toolbar.js';\n\nconst TOOLBAR_CONFIG: ToolbarConfig = [\n  ['bold', 'italic', 'link'],\n  [{ header: 1 }, { header: 2 }, 'blockquote'],\n];\n\nclass BubbleTooltip extends BaseTooltip {\n  static TEMPLATE = [\n    '<span class=\"ql-tooltip-arrow\"></span>',\n    '<div class=\"ql-tooltip-editor\">',\n    '<input type=\"text\" data-formula=\"e=mc^2\" data-link=\"https://quilljs.com\" data-video=\"Embed URL\">',\n    '<a class=\"ql-close\"></a>',\n    '</div>',\n  ].join('');\n\n  constructor(quill: Quill, bounds?: HTMLElement) {\n    super(quill, bounds);\n    this.quill.on(\n      Emitter.events.EDITOR_CHANGE,\n      (type, range, oldRange, source) => {\n        if (type !== Emitter.events.SELECTION_CHANGE) return;\n        if (\n          range != null &&\n          range.length > 0 &&\n          source === Emitter.sources.USER\n        ) {\n          this.show();\n          // Lock our width so we will expand beyond our offsetParent boundaries\n          this.root.style.left = '0px';\n          this.root.style.width = '';\n          this.root.style.width = `${this.root.offsetWidth}px`;\n          const lines = this.quill.getLines(range.index, range.length);\n          if (lines.length === 1) {\n            const bounds = this.quill.getBounds(range);\n            if (bounds != null) {\n              this.position(bounds);\n            }\n          } else {\n            const lastLine = lines[lines.length - 1];\n            const index = this.quill.getIndex(lastLine);\n            const length = Math.min(\n              lastLine.length() - 1,\n              range.index + range.length - index,\n            );\n            const indexBounds = this.quill.getBounds(new Range(index, length));\n            if (indexBounds != null) {\n              this.position(indexBounds);\n            }\n          }\n        } else if (\n          document.activeElement !== this.textbox &&\n          this.quill.hasFocus()\n        ) {\n          this.hide();\n        }\n      },\n    );\n  }\n\n  listen() {\n    super.listen();\n    // @ts-expect-error Fix me later\n    this.root.querySelector('.ql-close').addEventListener('click', () => {\n      this.root.classList.remove('ql-editing');\n    });\n    this.quill.on(Emitter.events.SCROLL_OPTIMIZE, () => {\n      // Let selection be restored by toolbar handlers before repositioning\n      setTimeout(() => {\n        if (this.root.classList.contains('ql-hidden')) return;\n        const range = this.quill.getSelection();\n        if (range != null) {\n          const bounds = this.quill.getBounds(range);\n          if (bounds != null) {\n            this.position(bounds);\n          }\n        }\n      }, 1);\n    });\n  }\n\n  cancel() {\n    this.show();\n  }\n\n  position(reference: Bounds) {\n    const shift = super.position(reference);\n    const arrow = this.root.querySelector('.ql-tooltip-arrow');\n    // @ts-expect-error\n    arrow.style.marginLeft = '';\n    if (shift !== 0) {\n      // @ts-expect-error\n      arrow.style.marginLeft = `${-1 * shift - arrow.offsetWidth / 2}px`;\n    }\n    return shift;\n  }\n}\n\nclass BubbleTheme extends BaseTheme {\n  tooltip: BubbleTooltip;\n\n  constructor(quill: Quill, options: ThemeOptions) {\n    if (\n      options.modules.toolbar != null &&\n      options.modules.toolbar.container == null\n    ) {\n      options.modules.toolbar.container = TOOLBAR_CONFIG;\n    }\n    super(quill, options);\n    this.quill.container.classList.add('ql-bubble');\n  }\n\n  extendToolbar(toolbar: Toolbar) {\n    // @ts-expect-error\n    this.tooltip = new BubbleTooltip(this.quill, this.options.bounds);\n    if (toolbar.container != null) {\n      this.tooltip.root.appendChild<HTMLElement>(toolbar.container);\n      this.buildButtons(toolbar.container.querySelectorAll('button'), icons);\n      this.buildPickers(toolbar.container.querySelectorAll('select'), icons);\n    }\n  }\n}\nBubbleTheme.DEFAULTS = merge({}, BaseTheme.DEFAULTS, {\n  modules: {\n    toolbar: {\n      handlers: {\n        link(value: string) {\n          if (!value) {\n            this.quill.format('link', false, Quill.sources.USER);\n          } else {\n            // @ts-expect-error\n            this.quill.theme.tooltip.edit();\n          }\n        },\n      },\n    },\n  },\n} satisfies ThemeOptions);\n\nexport { BubbleTooltip, BubbleTheme as default };\n","import { merge } from 'lodash-es';\nimport Emitter from '../core/emitter.js';\nimport BaseTheme, { BaseTooltip } from './base.js';\nimport LinkBlot from '../formats/link.js';\nimport { Range } from '../core/selection.js';\nimport icons from '../ui/icons.js';\nimport Quill from '../core/quill.js';\nimport type { Context } from '../modules/keyboard.js';\nimport type Toolbar from '../modules/toolbar.js';\nimport type { ToolbarConfig } from '../modules/toolbar.js';\nimport type { ThemeOptions } from '../core/theme.js';\n\nconst TOOLBAR_CONFIG: ToolbarConfig = [\n  [{ header: ['1', '2', '3', false] }],\n  ['bold', 'italic', 'underline', 'link'],\n  [{ list: 'ordered' }, { list: 'bullet' }],\n  ['clean'],\n];\n\nclass SnowTooltip extends BaseTooltip {\n  static TEMPLATE = [\n    '<a class=\"ql-preview\" rel=\"noopener noreferrer\" target=\"_blank\" href=\"about:blank\"></a>',\n    '<input type=\"text\" data-formula=\"e=mc^2\" data-link=\"https://quilljs.com\" data-video=\"Embed URL\">',\n    '<a class=\"ql-action\"></a>',\n    '<a class=\"ql-remove\"></a>',\n  ].join('');\n\n  preview = this.root.querySelector('a.ql-preview');\n\n  listen() {\n    super.listen();\n    // @ts-expect-error Fix me later\n    this.root\n      .querySelector('a.ql-action')\n      .addEventListener('click', (event) => {\n        if (this.root.classList.contains('ql-editing')) {\n          this.save();\n        } else {\n          // @ts-expect-error Fix me later\n          this.edit('link', this.preview.textContent);\n        }\n        event.preventDefault();\n      });\n    // @ts-expect-error Fix me later\n    this.root\n      .querySelector('a.ql-remove')\n      .addEventListener('click', (event) => {\n        if (this.linkRange != null) {\n          const range = this.linkRange;\n          this.restoreFocus();\n          this.quill.formatText(range, 'link', false, Emitter.sources.USER);\n          delete this.linkRange;\n        }\n        event.preventDefault();\n        this.hide();\n      });\n    this.quill.on(\n      Emitter.events.SELECTION_CHANGE,\n      (range, oldRange, source) => {\n        if (range == null) return;\n        if (range.length === 0 && source === Emitter.sources.USER) {\n          const [link, offset] = this.quill.scroll.descendant(\n            LinkBlot,\n            range.index,\n          );\n          if (link != null) {\n            this.linkRange = new Range(range.index - offset, link.length());\n            const preview = LinkBlot.formats(link.domNode);\n            // @ts-expect-error Fix me later\n            this.preview.textContent = preview;\n            // @ts-expect-error Fix me later\n            this.preview.setAttribute('href', preview);\n            this.show();\n            const bounds = this.quill.getBounds(this.linkRange);\n            if (bounds != null) {\n              this.position(bounds);\n            }\n            return;\n          }\n        } else {\n          delete this.linkRange;\n        }\n        this.hide();\n      },\n    );\n  }\n\n  show() {\n    super.show();\n    this.root.removeAttribute('data-mode');\n  }\n}\n\nclass SnowTheme extends BaseTheme {\n  constructor(quill: Quill, options: ThemeOptions) {\n    if (\n      options.modules.toolbar != null &&\n      options.modules.toolbar.container == null\n    ) {\n      options.modules.toolbar.container = TOOLBAR_CONFIG;\n    }\n    super(quill, options);\n    this.quill.container.classList.add('ql-snow');\n  }\n\n  extendToolbar(toolbar: Toolbar) {\n    if (toolbar.container != null) {\n      toolbar.container.classList.add('ql-snow');\n      this.buildButtons(toolbar.container.querySelectorAll('button'), icons);\n      this.buildPickers(toolbar.container.querySelectorAll('select'), icons);\n      // @ts-expect-error\n      this.tooltip = new SnowTooltip(this.quill, this.options.bounds);\n      if (toolbar.container.querySelector('.ql-link')) {\n        this.quill.keyboard.addBinding(\n          { key: 'k', shortKey: true },\n          (_range: Range, context: Context) => {\n            toolbar.handlers.link.call(toolbar, !context.format.link);\n          },\n        );\n      }\n    }\n  }\n}\nSnowTheme.DEFAULTS = merge({}, BaseTheme.DEFAULTS, {\n  modules: {\n    toolbar: {\n      handlers: {\n        link(value: string) {\n          if (value) {\n            const range = this.quill.getSelection();\n            if (range == null || range.length === 0) return;\n            let preview = this.quill.getText(range);\n            if (\n              /^\\S+@\\S+\\.\\S+$/.test(preview) &&\n              preview.indexOf('mailto:') !== 0\n            ) {\n              preview = `mailto:${preview}`;\n            }\n            // @ts-expect-error\n            const { tooltip } = this.quill.theme;\n            tooltip.edit('link', preview);\n          } else {\n            this.quill.format('link', false, Quill.sources.USER);\n          }\n        },\n      },\n    },\n  },\n} satisfies ThemeOptions);\n\nexport default SnowTheme;\n","import Quill from './core.js';\nimport type {\n  Bounds,\n  DebugLevel,\n  EmitterSource,\n  ExpandedQuillOptions,\n  QuillOptions,\n} from './core.js';\n\nimport { AlignClass, AlignStyle } from './formats/align.js';\nimport {\n  DirectionAttribute,\n  DirectionClass,\n  DirectionStyle,\n} from './formats/direction.js';\nimport Indent from './formats/indent.js';\n\nimport Blockquote from './formats/blockquote.js';\nimport Header from './formats/header.js';\nimport List from './formats/list.js';\n\nimport { BackgroundClass, BackgroundStyle } from './formats/background.js';\nimport { ColorClass, ColorStyle } from './formats/color.js';\nimport { FontClass, FontStyle } from './formats/font.js';\nimport { SizeClass, SizeStyle } from './formats/size.js';\n\nimport Bold from './formats/bold.js';\nimport Italic from './formats/italic.js';\nimport Link from './formats/link.js';\nimport Script from './formats/script.js';\nimport Strike from './formats/strike.js';\nimport Underline from './formats/underline.js';\n\nimport Formula from './formats/formula.js';\nimport Image from './formats/image.js';\nimport Video from './formats/video.js';\n\nimport CodeBlock, { Code as InlineCode } from './formats/code.js';\n\nimport Syntax from './modules/syntax.js';\nimport Table from './modules/table.js';\nimport Toolbar from './modules/toolbar.js';\n\nimport Icons from './ui/icons.js';\nimport Picker from './ui/picker.js';\nimport ColorPicker from './ui/color-picker.js';\nimport IconPicker from './ui/icon-picker.js';\nimport Tooltip from './ui/tooltip.js';\n\nimport BubbleTheme from './themes/bubble.js';\nimport SnowTheme from './themes/snow.js';\n\nQuill.register(\n  {\n    'attributors/attribute/direction': DirectionAttribute,\n\n    'attributors/class/align': AlignClass,\n    'attributors/class/background': BackgroundClass,\n    'attributors/class/color': ColorClass,\n    'attributors/class/direction': DirectionClass,\n    'attributors/class/font': FontClass,\n    'attributors/class/size': SizeClass,\n\n    'attributors/style/align': AlignStyle,\n    'attributors/style/background': BackgroundStyle,\n    'attributors/style/color': ColorStyle,\n    'attributors/style/direction': DirectionStyle,\n    'attributors/style/font': FontStyle,\n    'attributors/style/size': SizeStyle,\n  },\n  true,\n);\n\nQuill.register(\n  {\n    'formats/align': AlignClass,\n    'formats/direction': DirectionClass,\n    'formats/indent': Indent,\n\n    'formats/background': BackgroundStyle,\n    'formats/color': ColorStyle,\n    'formats/font': FontClass,\n    'formats/size': SizeClass,\n\n    'formats/blockquote': Blockquote,\n    'formats/code-block': CodeBlock,\n    'formats/header': Header,\n    'formats/list': List,\n\n    'formats/bold': Bold,\n    'formats/code': InlineCode,\n    'formats/italic': Italic,\n    'formats/link': Link,\n    'formats/script': Script,\n    'formats/strike': Strike,\n    'formats/underline': Underline,\n\n    'formats/formula': Formula,\n    'formats/image': Image,\n    'formats/video': Video,\n\n    'modules/syntax': Syntax,\n    'modules/table': Table,\n    'modules/toolbar': Toolbar,\n\n    'themes/bubble': BubbleTheme,\n    'themes/snow': SnowTheme,\n\n    'ui/icons': Icons,\n    'ui/picker': Picker,\n    'ui/icon-picker': IconPicker,\n    'ui/color-picker': ColorPicker,\n    'ui/tooltip': Tooltip,\n  },\n  true,\n);\n\nexport {\n  AttributeMap,\n  Delta,\n  Module,\n  Op,\n  OpIterator,\n  Parchment,\n  Range,\n} from './core.js';\nexport type {\n  Bounds,\n  DebugLevel,\n  EmitterSource,\n  ExpandedQuillOptions,\n  QuillOptions,\n};\n\nexport default Quill;\n","/*\nReact-Quill\nhttps://github.com/zenoamaro/react-quill\n*/\n\nimport React, { createRef } from 'react';\nimport isEqual from 'lodash/isEqual.js';\n\nimport Quill, { type EmitterSource, type Range as RangeStatic, QuillOptions as QuillOptionsStatic } from 'quill';\nimport type DeltaStatic from 'quill-delta';\n\nexport { Quill }\nexport type { DeltaStatic, EmitterSource, RangeStatic, QuillOptionsStatic }\n\n// Merged namespace hack to export types along with default object\n// See: https://github.com/Microsoft/TypeScript/issues/2719\nnamespace ReactQuill {\n  export type Value = string | DeltaStatic;\n  export type Range = RangeStatic | null;\n\n  export interface QuillOptions extends QuillOptionsStatic {\n    tabIndex?: number,\n  }\n\n  export interface ReactQuillProps {\n    bounds?: string | HTMLElement,\n    children?: React.ReactElement<any>,\n    className?: string,\n    defaultValue?: Value,\n    formats?: string[],\n    id?: string,\n    modules?: QuillOptions['modules'],\n    onChange?(\n      value: string,\n      delta: DeltaStatic,\n      source: EmitterSource,\n      editor: UnprivilegedEditor,\n    ): void,\n    onChangeSelection?(\n      selection: Range,\n      source: EmitterSource,\n      editor: UnprivilegedEditor,\n    ): void,\n    onFocus?(\n      selection: Range,\n      source: EmitterSource,\n      editor: UnprivilegedEditor,\n    ): void,\n    onBlur?(\n      previousSelection: Range,\n      source: EmitterSource,\n      editor: UnprivilegedEditor,\n    ): void,\n    onKeyDown?: React.EventHandler<any>,\n    onKeyPress?: React.EventHandler<any>,\n    onKeyUp?: React.EventHandler<any>,\n    placeholder?: string,\n    preserveWhitespace?: boolean,\n    readOnly?: boolean,\n    style?: React.CSSProperties,\n    tabIndex?: number,\n    theme?: string,\n    value?: Value,\n  }\n\n  export interface UnprivilegedEditor {\n    getLength: Quill['getLength'];\n    getText: Quill['getText'];\n    getHTML: () => string;\n    getSemanticHTML: Quill['getSemanticHTML'];\n    getBounds: Quill['getBounds'];\n    getSelection: Quill['getSelection'];\n    getContents: Quill['getContents'];\n  }\n}\n\n// Re-import everything from namespace into scope for comfort\nimport Value = ReactQuill.Value;\nimport Range = ReactQuill.Range;\nimport QuillOptions = ReactQuill.QuillOptions;\nimport ReactQuillProps = ReactQuill.ReactQuillProps;\nimport UnprivilegedEditor = ReactQuill.UnprivilegedEditor;\n\ninterface ReactQuillState {\n  generation: number,\n}\n\nclass ReactQuill extends React.Component<ReactQuillProps, ReactQuillState> {\n  editingAreaRef = createRef<any>();\n\n  static displayName = 'React Quill'\n\n  /*\n  Export Quill to be able to call `register`\n  */\n  static Quill = Quill;\n\n  /*\n  Changing one of these props should cause a full re-render and a\n  re-instantiation of the Quill editor.\n  */\n  dirtyProps: (keyof ReactQuillProps)[] = [\n    'modules',\n    'formats',\n    'bounds',\n    'theme',\n    'children',\n  ]\n\n  /*\n  Changing one of these props should cause a regular update. These are mostly\n  props that act on the container, rather than the quillized editing area.\n  */\n  cleanProps: (keyof ReactQuillProps)[] = [\n    'id',\n    'className',\n    'style',\n    'placeholder',\n    'tabIndex',\n    'onChange',\n    'onChangeSelection',\n    'onFocus',\n    'onBlur',\n    'onKeyPress',\n    'onKeyDown',\n    'onKeyUp',\n  ]\n\n  static defaultProps = {\n    theme: 'snow',\n    modules: {},\n    readOnly: false,\n  }\n\n  state: ReactQuillState = {\n    generation: 0,\n  }\n\n  /*\n  The Quill Editor instance.\n  */\n  editor?: Quill\n\n  /*\n  Tracks the internal value of the Quill editor\n  */\n  value: Value\n\n  /*\n  Tracks the internal selection of the Quill editor\n  */\n  selection: Range = null\n\n  /*\n  Used to compare whether deltas from `onChange` are being used as `value`.\n  */\n  lastDeltaChangeSet?: DeltaStatic\n\n  /*\n  Stores the contents of the editor to be restored after regeneration.\n  */\n  regenerationSnapshot?: {\n    delta: DeltaStatic,\n    selection: Range,\n  }\n\n  /*\n  A weaker, unprivileged proxy for the editor that does not allow accidentally\n  modifying editor state.\n  */\n  unprivilegedEditor?: UnprivilegedEditor\n\n  constructor(props: ReactQuillProps) {\n    super(props);\n    const value = this.isControlled()? props.value : props.defaultValue;\n    this.value = value ?? '';\n  }\n\n  validateProps(props: ReactQuillProps): void {\n    if (React.Children.count(props.children) > 1) throw new Error(\n      'The Quill editing area can only be composed of a single React element.'\n    );\n\n    if (React.Children.count(props.children)) {\n      const child = React.Children.only(props.children);\n      if (child?.type === 'textarea') throw new Error(\n        'Quill does not support editing on a <textarea>. Use a <div> instead.'\n      );\n    }\n\n    if (\n      this.lastDeltaChangeSet &&\n      props.value === this.lastDeltaChangeSet\n    ) throw new Error(\n      'You are passing the `delta` object from the `onChange` event back ' +\n      'as `value`. You most probably want `editor.getContents()` instead. ' +\n      'See: https://github.com/zenoamaro/react-quill#using-deltas'\n    );\n  }\n\n  shouldComponentUpdate(nextProps: ReactQuillProps, nextState: ReactQuillState) {\n    this.validateProps(nextProps);\n\n    // If the editor hasn't been instantiated yet, or the component has been\n    // regenerated, we already know we should update.\n    if (!this.editor || this.state.generation !== nextState.generation) {\n      return true;\n    }\n\n    // Handle value changes in-place\n    if ('value' in nextProps) {\n      const prevContents = this.getEditorContents();\n      const nextContents = nextProps.value ?? '';\n\n      // NOTE: Seeing that Quill is missing a way to prevent edits, we have to\n      //       settle for a hybrid between controlled and uncontrolled mode. We\n      //       can't prevent the change, but we'll still override content\n      //       whenever `value` differs from current state.\n      // NOTE: Comparing an HTML string and a Quill Delta will always trigger a\n      //       change, regardless of whether they represent the same document.\n      if (!this.isEqualValue(nextContents, prevContents)) {\n        this.setEditorContents(this.editor, nextContents);\n      }\n    }\n\n    // Handle read-only changes in-place\n    if (nextProps.readOnly !== this.props.readOnly) {\n      this.setEditorReadOnly(this.editor, nextProps.readOnly!);\n    }\n\n    // Clean and Dirty props require a render\n    return [...this.cleanProps, ...this.dirtyProps].some((prop) => {\n      return !isEqual(nextProps[prop], this.props[prop]);\n    });\n  }\n\n  shouldComponentRegenerate(nextProps: ReactQuillProps): boolean {\n    // Whenever a `dirtyProp` changes, the editor needs reinstantiation.\n    return this.dirtyProps.some((prop) => {\n      return !isEqual(nextProps[prop], this.props[prop]);\n    });\n  }\n\n  componentDidMount() {\n    this.instantiateEditor();\n    this.setEditorContents(this.editor!, this.getEditorContents());\n  }\n\n  componentWillUnmount() {\n    this.destroyEditor();\n  }\n\n  componentDidUpdate(prevProps: ReactQuillProps, prevState: ReactQuillState) {\n    // If we're changing one of the `dirtyProps`, the entire Quill Editor needs\n    // to be re-instantiated. Regenerating the editor will cause the whole tree,\n    // including the container, to be cleaned up and re-rendered from scratch.\n    // Store the contents so they can be restored later.\n    if (this.editor && this.shouldComponentRegenerate(prevProps)) {\n      const delta = this.editor.getContents();\n      const selection = this.editor.getSelection();\n      this.regenerationSnapshot = {delta, selection};\n      this.setState({generation: this.state.generation + 1});\n      this.destroyEditor();\n    }\n\n    // The component has been regenerated, so it must be re-instantiated, and\n    // its content must be restored to the previous values from the snapshot.\n    if (this.state.generation !== prevState.generation) {\n      const {delta, selection} = this.regenerationSnapshot!;\n      delete this.regenerationSnapshot;\n      this.instantiateEditor();\n      const editor = this.editor!;\n      editor.setContents(delta);\n      postpone(() => this.setEditorSelection(editor, selection));\n    }\n  }\n\n  instantiateEditor(): void {\n    if (this.editor) {\n      this.hookEditor(this.editor);\n    } else {\n      this.editor = this.createEditor(\n        this.getEditingArea(),\n        this.getEditorConfig()\n      );\n    }\n  }\n\n  destroyEditor(): void {\n    if (!this.editor) return;\n    this.unhookEditor(this.editor);\n  }\n\n  /*\n  We consider the component to be controlled if `value` is being sent in props.\n  */\n  isControlled(): boolean {\n    return 'value' in this.props;\n  }\n\n  getEditorConfig(): QuillOptions {\n    return {\n      bounds: this.props.bounds,\n      formats: this.props.formats,\n      modules: this.props.modules,\n      placeholder: this.props.placeholder,\n      readOnly: this.props.readOnly,\n      tabIndex: this.props.tabIndex,\n      theme: this.props.theme,\n    };\n  }\n\n  getEditor(): Quill {\n    if (!this.editor) throw new Error('Accessing non-instantiated editor');\n    return this.editor;\n  }\n\n  /**\n  Creates an editor on the given element. The editor will be passed the\n  configuration, have its events bound,\n  */\n  createEditor(element: HTMLElement, config: QuillOptions) {\n    const editor = new Quill(element, config);\n    if (config.tabIndex != null) {\n      this.setEditorTabIndex(editor, config.tabIndex);\n    }\n    this.hookEditor(editor);\n    return editor;\n  }\n\n  hookEditor(editor: Quill) {\n    // Expose the editor on change events via a weaker, unprivileged proxy\n    // object that does not allow accidentally modifying editor state.\n    this.unprivilegedEditor = this.makeUnprivilegedEditor(editor);\n    // Using `editor-change` allows picking up silent updates, like selection\n    // changes on typing.\n    editor.on('editor-change', this.onEditorChange);\n  }\n\n  unhookEditor(editor: Quill) {\n    editor.off('editor-change', this.onEditorChange);\n  }\n\n  getEditorContents(): Value {\n    return this.value;\n  }\n\n  getEditorSelection(): Range {\n    return this.selection;\n  }\n\n  /*\n  True if the value is a Delta instance or a Delta look-alike.\n  */\n  isDelta(value: any): boolean {\n    return value && value.ops;\n  }\n\n  /*\n  Special comparison function that knows how to compare Deltas.\n  */\n  isEqualValue(value: any, nextValue: any): boolean {\n    if (this.isDelta(value) && this.isDelta(nextValue)) {\n      return isEqual(value.ops, nextValue.ops);\n    } else {\n      return isEqual(value, nextValue);\n    }\n  }\n\n  /*\n  Replace the contents of the editor, but keep the previous selection hanging\n  around so that the cursor won't move.\n  */\n  setEditorContents(editor: Quill, value: Value) {\n    this.value = value;\n    const sel = this.getEditorSelection();\n    if (typeof value === 'string') {\n      editor.setContents(editor.clipboard.convert({html: value}));\n    } else {\n      editor.setContents(value);\n    }\n    postpone(() => this.setEditorSelection(editor, sel));\n  }\n\n  setEditorSelection(editor: Quill, range: Range) {\n    this.selection = range;\n    if (range) {\n      // Validate bounds before applying.\n      const length = editor.getLength();\n      range.index = Math.max(0, Math.min(range.index, length-1));\n      range.length = Math.max(0, Math.min(range.length, (length-1) - range.index));\n      editor.setSelection(range);\n    }\n  }\n\n  setEditorTabIndex(editor: Quill, tabIndex: number) {\n    if (editor?.scroll?.domNode) {\n      (editor.scroll.domNode as HTMLElement).tabIndex = tabIndex;\n    }\n  }\n\n  setEditorReadOnly(editor: Quill, value: boolean) {\n    if (value) {\n      editor.disable();\n    } else {\n      editor.enable();\n    }\n  }\n\n  /*\n  Returns a weaker, unprivileged proxy object that only exposes read-only\n  accessors found on the editor instance, without any state-modifying methods.\n  */\n  makeUnprivilegedEditor(editor: Quill) {\n    const e = editor;\n    return {\n      getHTML:         () => e.root.innerHTML,\n      getSemanticHTML: e.getSemanticHTML.bind(e),\n      getLength:       e.getLength.bind(e),\n      getText:         e.getText.bind(e),\n      getContents:     e.getContents.bind(e),\n      getSelection:    e.getSelection.bind(e),\n      getBounds:       e.getBounds.bind(e),\n    };\n  }\n\n  getEditingArea(): HTMLElement {\n    const element = this.editingAreaRef.current;\n    if (!element) {\n      throw new Error('Cannot find element for editing area');\n    }\n    if (element.nodeType === 3) {\n      throw new Error('Editing area cannot be a text node');\n    }\n    return element as HTMLElement;\n  }\n\n  /*\n  Renders an editor area, unless it has been provided one to clone.\n  */\n  renderEditingArea(): JSX.Element {\n    const {children, preserveWhitespace} = this.props;\n    const {generation} = this.state;\n\n    const properties = {\n      key: generation,\n      ref: this.editingAreaRef,\n    };\n\n    if (React.Children.count(children)) {\n      return React.cloneElement(\n        React.Children.only(children)!,\n        properties\n      );\n    }\n\n    return preserveWhitespace ?\n      <pre {...properties}/> :\n      <div {...properties}/>;\n  }\n\n  render() {\n    return (\n      <div\n        id={this.props.id}\n        style={this.props.style}\n        key={this.state.generation}\n        className={`quill ${this.props.className ?? ''}`}\n        onKeyPress={this.props.onKeyPress}\n        onKeyDown={this.props.onKeyDown}\n        onKeyUp={this.props.onKeyUp}\n      >\n        {this.renderEditingArea()}\n      </div>\n    );\n  }\n\n  onEditorChange = (\n    eventName: 'text-change' | 'selection-change',\n    rangeOrDelta: Range | DeltaStatic,\n    oldRangeOrDelta: Range | DeltaStatic,\n    source: EmitterSource,\n  ) => {\n    if (eventName === 'text-change') {\n      this.onEditorChangeText?.(\n        this.editor!.root.innerHTML,\n        rangeOrDelta as DeltaStatic,\n        source,\n        this.unprivilegedEditor!\n      );\n    } else if (eventName === 'selection-change') {\n      this.onEditorChangeSelection?.(\n        rangeOrDelta as RangeStatic,\n        source,\n        this.unprivilegedEditor!\n      );\n    }\n  };\n\n  onEditorChangeText(\n    value: string,\n    delta: DeltaStatic,\n    source: EmitterSource,\n    editor: UnprivilegedEditor,\n  ): void {\n    if (!this.editor) return;\n\n    // We keep storing the same type of value as what the user gives us,\n    // so that value comparisons will be more stable and predictable.\n    const nextContents = this.isDelta(this.value)\n      ? editor.getContents()\n      : editor.getHTML();\n\n    if (nextContents !== this.getEditorContents()) {\n      // Taint this `delta` object, so we can recognize whether the user\n      // is trying to send it back as `value`, preventing a likely loop.\n      this.lastDeltaChangeSet = delta;\n\n      this.value = nextContents;\n      this.props.onChange?.(value, delta, source, editor);\n    }\n  }\n\n  onEditorChangeSelection(\n    nextSelection: RangeStatic,\n    source: EmitterSource,\n    editor: UnprivilegedEditor,\n  ): void {\n    if (!this.editor) return;\n    const currentSelection = this.getEditorSelection();\n    const hasGainedFocus = !currentSelection && nextSelection;\n    const hasLostFocus = currentSelection && !nextSelection;\n\n    if (isEqual(nextSelection, currentSelection)) return;\n\n    this.selection = nextSelection;\n    this.props.onChangeSelection?.(nextSelection, source, editor);\n\n    if (hasGainedFocus) {\n      this.props.onFocus?.(nextSelection, source, editor);\n    } else if (hasLostFocus) {\n      this.props.onBlur?.(currentSelection, source, editor);\n    }\n  }\n\n  focus(): void {\n    if (!this.editor) return;\n    this.editor.focus();\n  }\n\n  blur(): void {\n    if (!this.editor) return;\n    this.selection = null;\n    this.editor.blur();\n  }\n}\n\n/*\nSmall helper to execute a function in the next micro-tick.\n*/\nfunction postpone(fn: (value: void) => void) {\n  Promise.resolve().then(fn);\n}\n\nexport default ReactQuill;\n","import React, { useState, useEffect } from \"react\";\nimport db from \"./firebaseConfig\";\nimport {\n  collection,\n  addDoc,\n  getDocs,\n  deleteDoc,\n  doc,\n  updateDoc,\n} from \"firebase/firestore\";\nimport {\n  getStorage,\n  ref,\n  uploadBytesResumable,\n  getDownloadURL,\n} from \"firebase/storage\";\nimport ReactQuill from \"react-quill-new\";\nimport \"react-quill-new/dist/quill.snow.css\";\n\nconst AdminDashboard = () => {\n  const [tab, setTab] = useState(\"news\");\n  const [data, setData] = useState([]);\n  const [form, setForm] = useState({\n    title: \"\",\n    description: \"\",\n    rounds: [],\n    body: \"\",\n    author: \"\",\n    date: \"\",\n    logo: \"\",\n    socialLink: \"\",\n  });\n  const [editing, setEditing] = useState(null);\n  const [uploading, setUploading] = useState(false);\n  const storage = getStorage();\n\n  useEffect(() => {\n    fetchData(tab);\n    setForm({\n      title: \"\",\n      description: \"\",\n      rounds: [],\n      body: \"\",\n      author: \"\",\n      date: \"\",\n      logo: \"\",\n      socialLink: \"\",\n    }); // Reset form fields when tab changes\n    setEditing(null);\n  }, [tab]);\n\n  const fetchData = async (collectionName) => {\n    const querySnapshot = await getDocs(collection(db, collectionName));\n    const dataList = querySnapshot.docs.map((doc) => ({\n      id: doc.id,\n      ...doc.data(),\n    }));\n    setData(dataList);\n  };\n\n  const handleInputChange = (e) => {\n    const { name, value } = e.target;\n    setForm((prev) => ({ ...prev, [name]: value }));\n  };\n\n  const handleFileUpload = async (e) => {\n    const file = e.target.files[0];\n    if (!file) return;\n\n    const storageRef = ref(storage, `${tab}/${file.name}`);\n    const uploadTask = uploadBytesResumable(storageRef, file);\n    setUploading(true);\n\n    uploadTask.on(\n      \"state_changed\",\n      null,\n      (error) => {\n        console.error(\"Upload failed: \", error);\n        setUploading(false);\n      },\n      async () => {\n        const downloadURL = await getDownloadURL(uploadTask.snapshot.ref);\n        setForm((prev) => ({\n          ...prev,\n          logo:\n            tab === \"teams\"\n              ? downloadURL\n              : form.media\n              ? form.media\n              : downloadURL,\n        }));\n        setUploading(false);\n      }\n    );\n  };\n\n  const handleQuillChange = (value) => {\n    setForm((prev) => ({ ...prev, body: value }));\n  };\n\n  const handleAddRound = () => {\n    setForm((prev) => ({\n      ...prev,\n      rounds: [...prev.rounds, { title: \"\", seeds: [] }],\n    }));\n  };\n\n  const handleRemoveRound = (index) => {\n    setForm((prev) => ({\n      ...prev,\n      rounds: prev.rounds.filter((_, i) => i !== index),\n    }));\n  };\n\n  const handleRoundChange = (index, value) => {\n    const updatedRounds = [...form.rounds];\n    updatedRounds[index].title = value;\n    setForm((prev) => ({ ...prev, rounds: updatedRounds }));\n  };\n\n  const handleAddSeed = (roundIndex) => {\n    const updatedRounds = [...form.rounds];\n    updatedRounds[roundIndex].seeds.push({\n      teams: [{ name: \"\" }, { name: \"\" }],\n    });\n    setForm((prev) => ({ ...prev, rounds: updatedRounds }));\n  };\n\n  const handleRemoveSeed = (roundIndex, seedIndex) => {\n    const updatedRounds = [...form.rounds];\n    updatedRounds[roundIndex].seeds = updatedRounds[roundIndex].seeds.filter(\n      (_, i) => i !== seedIndex\n    );\n    setForm((prev) => ({ ...prev, rounds: updatedRounds }));\n  };\n\n  const handleTeamChange = (roundIndex, seedIndex, teamIndex, value) => {\n    const updatedRounds = [...form.rounds];\n    updatedRounds[roundIndex].seeds[seedIndex].teams[teamIndex].name = value;\n    setForm((prev) => ({ ...prev, rounds: updatedRounds }));\n  };\n\n  const handleAdd = async () => {\n    if (editing) {\n      const docRef = doc(db, tab, editing);\n      await updateDoc(docRef, form);\n      setEditing(null);\n    } else {\n      await addDoc(collection(db, tab), form);\n    }\n    setForm({\n      title: \"\",\n      description: \"\",\n      rounds: [],\n      body: \"\",\n      author: \"\",\n      date: \"\",\n      logo: \"\",\n      socialLink: \"\",\n    });\n    fetchData(tab);\n  };\n\n  const handleEdit = (item) => {\n    setEditing(item.id);\n    setForm(item);\n  };\n\n  const handleDelete = async (id) => {\n    await deleteDoc(doc(db, tab, id));\n    fetchData(tab);\n  };\n\n  return (\n    <div className=\"admin-dashboard\">\n      <h1>Admin Dashboard</h1>\n      <div className=\"tabs\">\n        <button onClick={() => setTab(\"news\")}>Noticias</button>\n        <button onClick={() => setTab(\"tournaments\")}>Torneos</button>\n        <button onClick={() => setTab(\"teams\")}>Equipos</button>\n        <button onClick={() => setTab(\"affiliates\")}>Afiliados</button>\n      </div>\n      <div className=\"form\">\n        <h2>{editing ? \"Edit Item\" : \"Add New Item\"}</h2>\n        {tab === \"news\" && (\n          <>\n            <input\n              type=\"text\"\n              name=\"title\"\n              placeholder=\"News Title\"\n              value={form.title || \"\"}\n              onChange={handleInputChange}\n            />\n            <input\n              type=\"text\"\n              name=\"author\"\n              placeholder=\"Author\"\n              value={form.author || \"\"}\n              onChange={handleInputChange}\n            />\n            <input\n              type=\"date\"\n              name=\"date\"\n              value={form.date || \"\"}\n              onChange={handleInputChange}\n            />\n            <input\n              type=\"file\"\n              name=\"media\"\n              placeholder=\"Upload Media\"\n              onChange={handleFileUpload}\n            />\n            {uploading && <p>Uploading...</p>}\n            <ReactQuill\n              theme=\"snow\"\n              value={form.body || \"\"}\n              onChange={handleQuillChange}\n              placeholder=\"Write the news body...\"\n            />\n          </>\n        )}\n        {tab === \"tournaments\" && (\n          <>\n            <input\n              type=\"text\"\n              name=\"title\"\n              placeholder=\"Tournament Title\"\n              value={form.title || \"\"}\n              onChange={handleInputChange}\n            />\n            <textarea\n              name=\"description\"\n              placeholder=\"Description\"\n              value={form.description || \"\"}\n              onChange={handleInputChange}\n            ></textarea>\n            <h3>Rounds</h3>\n            {form.rounds.map((round, roundIndex) => (\n              <div key={roundIndex} className=\"round\">\n                <input\n                  type=\"text\"\n                  placeholder=\"Round Title\"\n                  value={round.title || \"\"}\n                  onChange={(e) =>\n                    handleRoundChange(roundIndex, e.target.value)\n                  }\n                />\n                <button onClick={() => handleAddSeed(roundIndex)}>\n                  Add Match\n                </button>\n                {round.seeds.map((seed, seedIndex) => (\n                  <div key={seedIndex} className=\"seed\">\n                    <input\n                      type=\"text\"\n                      placeholder=\"Team 1\"\n                      value={seed.teams[0].name}\n                      onChange={(e) =>\n                        handleTeamChange(\n                          roundIndex,\n                          seedIndex,\n                          0,\n                          e.target.value\n                        )\n                      }\n                    />\n                    <input\n                      type=\"text\"\n                      placeholder=\"Team 2\"\n                      value={seed.teams[1].name}\n                      onChange={(e) =>\n                        handleTeamChange(\n                          roundIndex,\n                          seedIndex,\n                          1,\n                          e.target.value\n                        )\n                      }\n                    />\n                    <button\n                      onClick={() => handleRemoveSeed(roundIndex, seedIndex)}\n                    >\n                      Remove Match\n                    </button>\n                  </div>\n                ))}\n                <button onClick={() => handleRemoveRound(roundIndex)}>\n                  Remove Round\n                </button>\n              </div>\n            ))}\n            <button onClick={handleAddRound}>Add Round</button>\n          </>\n        )}\n        {tab === \"teams\" && (\n          <>\n            <input\n              type=\"text\"\n              name=\"name\"\n              placeholder=\"Team Name\"\n              value={form.name || \"\"}\n              onChange={handleInputChange}\n            />\n            <textarea\n              name=\"description\"\n              placeholder=\"Description\"\n              value={form.description || \"\"}\n              onChange={handleInputChange}\n            ></textarea>\n            <input\n              type=\"file\"\n              name=\"logo\"\n              placeholder=\"Upload Logo\"\n              onChange={handleFileUpload}\n            />\n            {uploading && <p>Uploading...</p>}\n          </>\n        )}\n        {tab === \"affiliates\" && (\n          <>\n            <input\n              type=\"text\"\n              name=\"name\"\n              placeholder=\"Name\"\n              value={form.name || \"\"}\n              onChange={handleInputChange}\n            />\n            <input\n              type=\"text\"\n              name=\"socialLink\"\n              placeholder=\"Social Link\"\n              value={form.socialLink || \"\"}\n              onChange={handleInputChange}\n            />\n            <textarea\n              name=\"description\"\n              placeholder=\"Description\"\n              value={form.description || \"\"}\n              onChange={handleInputChange}\n            ></textarea>\n            <input\n              type=\"file\"\n              name=\"logo\"\n              placeholder=\"Upload Logo\"\n              onChange={handleFileUpload}\n            />\n            {uploading && <p>Uploading...</p>}\n          </>\n        )}\n        <button onClick={handleAdd} disabled={uploading}>\n          {editing ? \"Update\" : \"Add\"}\n        </button>\n      </div>\n      <div className=\"list\">\n        <h2>{tab.charAt(0).toUpperCase() + tab.slice(1)}</h2>\n        <ul>\n          {data.map((item) => (\n            <li key={item.id}>\n              <div>\n                <strong>{item.title || item.name}</strong> -{\" \"}\n                {item.description || \"\"}\n              </div>\n              <button onClick={() => handleEdit(item)}>Edit</button>\n              <button onClick={() => handleDelete(item.id)}>Delete</button>\n            </li>\n          ))}\n        </ul>\n      </div>\n    </div>\n  );\n};\n\nexport default AdminDashboard;\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar 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\nexport function __extends(d, b) {\n  if (typeof b !== \"function\" && b !== null)\n      throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n  extendStatics(d, b);\n  function __() { this.constructor = d; }\n  d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n  __assign = Object.assign || function __assign(t) {\n      for (var s, i = 1, n = arguments.length; i < n; i++) {\n          s = arguments[i];\n          for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n      }\n      return t;\n  }\n  return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n  var t = {};\n  for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n      t[p] = s[p];\n  if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n      for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n          if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n              t[p[i]] = s[p[i]];\n      }\n  return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n  if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\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;\n  return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n  return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n  function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n  var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n  var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n  var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n  var _, done = false;\n  for (var i = decorators.length - 1; i >= 0; i--) {\n      var context = {};\n      for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n      for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n      context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n      var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n      if (kind === \"accessor\") {\n          if (result === void 0) continue;\n          if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n          if (_ = accept(result.get)) descriptor.get = _;\n          if (_ = accept(result.set)) descriptor.set = _;\n          if (_ = accept(result.init)) initializers.unshift(_);\n      }\n      else if (_ = accept(result)) {\n          if (kind === \"field\") initializers.unshift(_);\n          else descriptor[key] = _;\n      }\n  }\n  if (target) Object.defineProperty(target, contextIn.name, descriptor);\n  done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n  var useValue = arguments.length > 2;\n  for (var i = 0; i < initializers.length; i++) {\n      value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n  }\n  return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n  return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n  if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n  return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n  if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(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}\n\nexport function __generator(thisArg, body) {\n  var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n  return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n  function verb(n) { return function (v) { return step([n, v]); }; }\n  function step(op) {\n      if (f) throw new TypeError(\"Generator is already executing.\");\n      while (g && (g = 0, op[0] && (_ = 0)), _) try {\n          if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n          if (y = 0, t) op = [op[0] & 2, t.value];\n          switch (op[0]) {\n              case 0: case 1: t = op; break;\n              case 4: _.label++; return { value: op[1], done: false };\n              case 5: _.label++; y = op[1]; op = [0]; continue;\n              case 7: op = _.ops.pop(); _.trys.pop(); continue;\n              default:\n                  if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n                  if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n                  if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n                  if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n                  if (t[2]) _.ops.pop();\n                  _.trys.pop(); continue;\n          }\n          op = body.call(thisArg, _);\n      } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n      if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n  }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n  if (k2 === undefined) k2 = k;\n  var desc = Object.getOwnPropertyDescriptor(m, k);\n  if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n      desc = { enumerable: true, get: function() { return m[k]; } };\n  }\n  Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n  if (k2 === undefined) k2 = k;\n  o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n  for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n  var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n  if (m) return m.call(o);\n  if (o && typeof o.length === \"number\") return {\n      next: function () {\n          if (o && i >= o.length) o = void 0;\n          return { value: o && o[i++], done: !o };\n      }\n  };\n  throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n  var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n  if (!m) return o;\n  var i = m.call(o), r, ar = [], e;\n  try {\n      while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n  }\n  catch (error) { e = { error: error }; }\n  finally {\n      try {\n          if (r && !r.done && (m = i[\"return\"])) m.call(i);\n      }\n      finally { if (e) throw e.error; }\n  }\n  return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n  for (var ar = [], i = 0; i < arguments.length; i++)\n      ar = ar.concat(__read(arguments[i]));\n  return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n  for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n  for (var r = Array(s), k = 0, i = 0; i < il; i++)\n      for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n          r[k] = a[j];\n  return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n  if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n      if (ar || !(i in from)) {\n          if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n          ar[i] = from[i];\n      }\n  }\n  return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n  return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n  if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n  var g = generator.apply(thisArg, _arguments || []), i, q = [];\n  return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n  function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n  function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n  function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n  function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n  function fulfill(value) { resume(\"next\", value); }\n  function reject(value) { resume(\"throw\", value); }\n  function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n  var i, p;\n  return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n  function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n  if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n  var m = o[Symbol.asyncIterator], i;\n  return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\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); }); }; }\n  function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n  if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n  return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n  Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n  o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n  ownKeys = Object.getOwnPropertyNames || function (o) {\n    var ar = [];\n    for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n    return ar;\n  };\n  return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n  if (mod && mod.__esModule) return mod;\n  var result = {};\n  if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n  __setModuleDefault(result, mod);\n  return result;\n}\n\nexport function __importDefault(mod) {\n  return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n  if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n  if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n  return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n  if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n  if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n  if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n  return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n  if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n  return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n  if (value !== null && value !== void 0) {\n    if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n    var dispose, inner;\n    if (async) {\n      if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n      dispose = value[Symbol.asyncDispose];\n    }\n    if (dispose === void 0) {\n      if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n      dispose = value[Symbol.dispose];\n      if (async) inner = dispose;\n    }\n    if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n    if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n    env.stack.push({ value: value, dispose: dispose, async: async });\n  }\n  else if (async) {\n    env.stack.push({ async: true });\n  }\n  return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n  var e = new Error(message);\n  return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n  function fail(e) {\n    env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n    env.hasError = true;\n  }\n  var r, s = 0;\n  function next() {\n    while (r = env.stack.pop()) {\n      try {\n        if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n        if (r.dispose) {\n          var result = r.dispose.call(r.value);\n          if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n        }\n        else s |= 1;\n      }\n      catch (e) {\n        fail(e);\n      }\n    }\n    if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n    if (env.hasError) throw env.error;\n  }\n  return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n  if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n      return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n          return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n      });\n  }\n  return path;\n}\n\nexport default {\n  __extends,\n  __assign,\n  __rest,\n  __decorate,\n  __param,\n  __esDecorate,\n  __runInitializers,\n  __propKey,\n  __setFunctionName,\n  __metadata,\n  __awaiter,\n  __generator,\n  __createBinding,\n  __exportStar,\n  __values,\n  __read,\n  __spread,\n  __spreadArrays,\n  __spreadArray,\n  __await,\n  __asyncGenerator,\n  __asyncDelegator,\n  __asyncValues,\n  __makeTemplateObject,\n  __importStar,\n  __importDefault,\n  __classPrivateFieldGet,\n  __classPrivateFieldSet,\n  __classPrivateFieldIn,\n  __addDisposableResource,\n  __disposeResources,\n  __rewriteRelativeImportExtension,\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 { AuthErrorMap, User } from '../model/public_types';\nimport { ErrorFactory, ErrorMap } from '@firebase/util';\n\nimport { IdTokenMfaResponse } from '../api/authentication/mfa';\nimport { AppName } from '../model/auth';\nimport { AuthCredential } from './credentials';\n\n/**\n * Enumeration of Firebase Auth error codes.\n *\n * @internal\n */\nexport const enum AuthErrorCode {\n  ADMIN_ONLY_OPERATION = 'admin-restricted-operation',\n  ARGUMENT_ERROR = 'argument-error',\n  APP_NOT_AUTHORIZED = 'app-not-authorized',\n  APP_NOT_INSTALLED = 'app-not-installed',\n  CAPTCHA_CHECK_FAILED = 'captcha-check-failed',\n  CODE_EXPIRED = 'code-expired',\n  CORDOVA_NOT_READY = 'cordova-not-ready',\n  CORS_UNSUPPORTED = 'cors-unsupported',\n  CREDENTIAL_ALREADY_IN_USE = 'credential-already-in-use',\n  CREDENTIAL_MISMATCH = 'custom-token-mismatch',\n  CREDENTIAL_TOO_OLD_LOGIN_AGAIN = 'requires-recent-login',\n  DEPENDENT_SDK_INIT_BEFORE_AUTH = 'dependent-sdk-initialized-before-auth',\n  DYNAMIC_LINK_NOT_ACTIVATED = 'dynamic-link-not-activated',\n  EMAIL_CHANGE_NEEDS_VERIFICATION = 'email-change-needs-verification',\n  EMAIL_EXISTS = 'email-already-in-use',\n  EMULATOR_CONFIG_FAILED = 'emulator-config-failed',\n  EXPIRED_OOB_CODE = 'expired-action-code',\n  EXPIRED_POPUP_REQUEST = 'cancelled-popup-request',\n  INTERNAL_ERROR = 'internal-error',\n  INVALID_API_KEY = 'invalid-api-key',\n  INVALID_APP_CREDENTIAL = 'invalid-app-credential',\n  INVALID_APP_ID = 'invalid-app-id',\n  INVALID_AUTH = 'invalid-user-token',\n  INVALID_AUTH_EVENT = 'invalid-auth-event',\n  INVALID_CERT_HASH = 'invalid-cert-hash',\n  INVALID_CODE = 'invalid-verification-code',\n  INVALID_CONTINUE_URI = 'invalid-continue-uri',\n  INVALID_CORDOVA_CONFIGURATION = 'invalid-cordova-configuration',\n  INVALID_CUSTOM_TOKEN = 'invalid-custom-token',\n  INVALID_DYNAMIC_LINK_DOMAIN = 'invalid-dynamic-link-domain',\n  INVALID_EMAIL = 'invalid-email',\n  INVALID_EMULATOR_SCHEME = 'invalid-emulator-scheme',\n  INVALID_CREDENTIAL = 'invalid-credential',\n  INVALID_MESSAGE_PAYLOAD = 'invalid-message-payload',\n  INVALID_MFA_SESSION = 'invalid-multi-factor-session',\n  INVALID_OAUTH_CLIENT_ID = 'invalid-oauth-client-id',\n  INVALID_OAUTH_PROVIDER = 'invalid-oauth-provider',\n  INVALID_OOB_CODE = 'invalid-action-code',\n  INVALID_ORIGIN = 'unauthorized-domain',\n  INVALID_PASSWORD = 'wrong-password',\n  INVALID_PERSISTENCE = 'invalid-persistence-type',\n  INVALID_PHONE_NUMBER = 'invalid-phone-number',\n  INVALID_PROVIDER_ID = 'invalid-provider-id',\n  INVALID_RECIPIENT_EMAIL = 'invalid-recipient-email',\n  INVALID_SENDER = 'invalid-sender',\n  INVALID_SESSION_INFO = 'invalid-verification-id',\n  INVALID_TENANT_ID = 'invalid-tenant-id',\n  LOGIN_BLOCKED = 'login-blocked',\n  MFA_INFO_NOT_FOUND = 'multi-factor-info-not-found',\n  MFA_REQUIRED = 'multi-factor-auth-required',\n  MISSING_ANDROID_PACKAGE_NAME = 'missing-android-pkg-name',\n  MISSING_APP_CREDENTIAL = 'missing-app-credential',\n  MISSING_AUTH_DOMAIN = 'auth-domain-config-required',\n  MISSING_CODE = 'missing-verification-code',\n  MISSING_CONTINUE_URI = 'missing-continue-uri',\n  MISSING_IFRAME_START = 'missing-iframe-start',\n  MISSING_IOS_BUNDLE_ID = 'missing-ios-bundle-id',\n  MISSING_OR_INVALID_NONCE = 'missing-or-invalid-nonce',\n  MISSING_MFA_INFO = 'missing-multi-factor-info',\n  MISSING_MFA_SESSION = 'missing-multi-factor-session',\n  MISSING_PHONE_NUMBER = 'missing-phone-number',\n  MISSING_PASSWORD = 'missing-password',\n  MISSING_SESSION_INFO = 'missing-verification-id',\n  MODULE_DESTROYED = 'app-deleted',\n  NEED_CONFIRMATION = 'account-exists-with-different-credential',\n  NETWORK_REQUEST_FAILED = 'network-request-failed',\n  NULL_USER = 'null-user',\n  NO_AUTH_EVENT = 'no-auth-event',\n  NO_SUCH_PROVIDER = 'no-such-provider',\n  OPERATION_NOT_ALLOWED = 'operation-not-allowed',\n  OPERATION_NOT_SUPPORTED = 'operation-not-supported-in-this-environment',\n  POPUP_BLOCKED = 'popup-blocked',\n  POPUP_CLOSED_BY_USER = 'popup-closed-by-user',\n  PROVIDER_ALREADY_LINKED = 'provider-already-linked',\n  QUOTA_EXCEEDED = 'quota-exceeded',\n  REDIRECT_CANCELLED_BY_USER = 'redirect-cancelled-by-user',\n  REDIRECT_OPERATION_PENDING = 'redirect-operation-pending',\n  REJECTED_CREDENTIAL = 'rejected-credential',\n  SECOND_FACTOR_ALREADY_ENROLLED = 'second-factor-already-in-use',\n  SECOND_FACTOR_LIMIT_EXCEEDED = 'maximum-second-factor-count-exceeded',\n  TENANT_ID_MISMATCH = 'tenant-id-mismatch',\n  TIMEOUT = 'timeout',\n  TOKEN_EXPIRED = 'user-token-expired',\n  TOO_MANY_ATTEMPTS_TRY_LATER = 'too-many-requests',\n  UNAUTHORIZED_DOMAIN = 'unauthorized-continue-uri',\n  UNSUPPORTED_FIRST_FACTOR = 'unsupported-first-factor',\n  UNSUPPORTED_PERSISTENCE = 'unsupported-persistence-type',\n  UNSUPPORTED_TENANT_OPERATION = 'unsupported-tenant-operation',\n  UNVERIFIED_EMAIL = 'unverified-email',\n  USER_CANCELLED = 'user-cancelled',\n  USER_DELETED = 'user-not-found',\n  USER_DISABLED = 'user-disabled',\n  USER_MISMATCH = 'user-mismatch',\n  USER_SIGNED_OUT = 'user-signed-out',\n  WEAK_PASSWORD = 'weak-password',\n  WEB_STORAGE_UNSUPPORTED = 'web-storage-unsupported',\n  ALREADY_INITIALIZED = 'already-initialized',\n  RECAPTCHA_NOT_ENABLED = 'recaptcha-not-enabled',\n  MISSING_RECAPTCHA_TOKEN = 'missing-recaptcha-token',\n  INVALID_RECAPTCHA_TOKEN = 'invalid-recaptcha-token',\n  INVALID_RECAPTCHA_ACTION = 'invalid-recaptcha-action',\n  MISSING_CLIENT_TYPE = 'missing-client-type',\n  MISSING_RECAPTCHA_VERSION = 'missing-recaptcha-version',\n  INVALID_RECAPTCHA_VERSION = 'invalid-recaptcha-version',\n  INVALID_REQ_TYPE = 'invalid-req-type',\n  UNSUPPORTED_PASSWORD_POLICY_SCHEMA_VERSION = 'unsupported-password-policy-schema-version',\n  PASSWORD_DOES_NOT_MEET_REQUIREMENTS = 'password-does-not-meet-requirements'\n}\n\nfunction _debugErrorMap(): ErrorMap<AuthErrorCode> {\n  return {\n    [AuthErrorCode.ADMIN_ONLY_OPERATION]:\n      'This operation is restricted to administrators only.',\n    [AuthErrorCode.ARGUMENT_ERROR]: '',\n    [AuthErrorCode.APP_NOT_AUTHORIZED]:\n      \"This app, identified by the domain where it's hosted, is not \" +\n      'authorized to use Firebase Authentication with the provided API key. ' +\n      'Review your key configuration in the Google API console.',\n    [AuthErrorCode.APP_NOT_INSTALLED]:\n      'The requested mobile application corresponding to the identifier (' +\n      'Android package name or iOS bundle ID) provided is not installed on ' +\n      'this device.',\n    [AuthErrorCode.CAPTCHA_CHECK_FAILED]:\n      'The reCAPTCHA response token provided is either invalid, expired, ' +\n      'already used or the domain associated with it does not match the list ' +\n      'of whitelisted domains.',\n    [AuthErrorCode.CODE_EXPIRED]:\n      'The SMS code has expired. Please re-send the verification code to try ' +\n      'again.',\n    [AuthErrorCode.CORDOVA_NOT_READY]: 'Cordova framework is not ready.',\n    [AuthErrorCode.CORS_UNSUPPORTED]: 'This browser is not supported.',\n    [AuthErrorCode.CREDENTIAL_ALREADY_IN_USE]:\n      'This credential is already associated with a different user account.',\n    [AuthErrorCode.CREDENTIAL_MISMATCH]:\n      'The custom token corresponds to a different audience.',\n    [AuthErrorCode.CREDENTIAL_TOO_OLD_LOGIN_AGAIN]:\n      'This operation is sensitive and requires recent authentication. Log in ' +\n      'again before retrying this request.',\n    [AuthErrorCode.DEPENDENT_SDK_INIT_BEFORE_AUTH]:\n      'Another Firebase SDK was initialized and is trying to use Auth before Auth is ' +\n      'initialized. Please be sure to call `initializeAuth` or `getAuth` before ' +\n      'starting any other Firebase SDK.',\n    [AuthErrorCode.DYNAMIC_LINK_NOT_ACTIVATED]:\n      'Please activate Dynamic Links in the Firebase Console and agree to the terms and ' +\n      'conditions.',\n    [AuthErrorCode.EMAIL_CHANGE_NEEDS_VERIFICATION]:\n      'Multi-factor users must always have a verified email.',\n    [AuthErrorCode.EMAIL_EXISTS]:\n      'The email address is already in use by another account.',\n    [AuthErrorCode.EMULATOR_CONFIG_FAILED]:\n      'Auth instance has already been used to make a network call. Auth can ' +\n      'no longer be configured to use the emulator. Try calling ' +\n      '\"connectAuthEmulator()\" sooner.',\n    [AuthErrorCode.EXPIRED_OOB_CODE]: 'The action code has expired.',\n    [AuthErrorCode.EXPIRED_POPUP_REQUEST]:\n      'This operation has been cancelled due to another conflicting popup being opened.',\n    [AuthErrorCode.INTERNAL_ERROR]: 'An internal AuthError has occurred.',\n    [AuthErrorCode.INVALID_APP_CREDENTIAL]:\n      'The phone verification request contains an invalid application verifier.' +\n      ' The reCAPTCHA token response is either invalid or expired.',\n    [AuthErrorCode.INVALID_APP_ID]:\n      'The mobile app identifier is not registered for the current project.',\n    [AuthErrorCode.INVALID_AUTH]:\n      \"This user's credential isn't valid for this project. This can happen \" +\n      \"if the user's token has been tampered with, or if the user isn't for \" +\n      'the project associated with this API key.',\n    [AuthErrorCode.INVALID_AUTH_EVENT]: 'An internal AuthError has occurred.',\n    [AuthErrorCode.INVALID_CODE]:\n      'The SMS verification code used to create the phone auth credential is ' +\n      'invalid. Please resend the verification code sms and be sure to use the ' +\n      'verification code provided by the user.',\n    [AuthErrorCode.INVALID_CONTINUE_URI]:\n      'The continue URL provided in the request is invalid.',\n    [AuthErrorCode.INVALID_CORDOVA_CONFIGURATION]:\n      'The following Cordova plugins must be installed to enable OAuth sign-in: ' +\n      'cordova-plugin-buildinfo, cordova-universal-links-plugin, ' +\n      'cordova-plugin-browsertab, cordova-plugin-inappbrowser and ' +\n      'cordova-plugin-customurlscheme.',\n    [AuthErrorCode.INVALID_CUSTOM_TOKEN]:\n      'The custom token format is incorrect. Please check the documentation.',\n    [AuthErrorCode.INVALID_DYNAMIC_LINK_DOMAIN]:\n      'The provided dynamic link domain is not configured or authorized for the current project.',\n    [AuthErrorCode.INVALID_EMAIL]: 'The email address is badly formatted.',\n    [AuthErrorCode.INVALID_EMULATOR_SCHEME]:\n      'Emulator URL must start with a valid scheme (http:// or https://).',\n    [AuthErrorCode.INVALID_API_KEY]:\n      'Your API key is invalid, please check you have copied it correctly.',\n    [AuthErrorCode.INVALID_CERT_HASH]:\n      'The SHA-1 certificate hash provided is invalid.',\n    [AuthErrorCode.INVALID_CREDENTIAL]:\n      'The supplied auth credential is incorrect, malformed or has expired.',\n    [AuthErrorCode.INVALID_MESSAGE_PAYLOAD]:\n      'The email template corresponding to this action contains invalid characters in its message. ' +\n      'Please fix by going to the Auth email templates section in the Firebase Console.',\n    [AuthErrorCode.INVALID_MFA_SESSION]:\n      'The request does not contain a valid proof of first factor successful sign-in.',\n    [AuthErrorCode.INVALID_OAUTH_PROVIDER]:\n      'EmailAuthProvider is not supported for this operation. This operation ' +\n      'only supports OAuth providers.',\n    [AuthErrorCode.INVALID_OAUTH_CLIENT_ID]:\n      'The OAuth client ID provided is either invalid or does not match the ' +\n      'specified API key.',\n    [AuthErrorCode.INVALID_ORIGIN]:\n      'This domain is not authorized for OAuth operations for your Firebase ' +\n      'project. Edit the list of authorized domains from the Firebase console.',\n    [AuthErrorCode.INVALID_OOB_CODE]:\n      'The action code is invalid. This can happen if the code is malformed, ' +\n      'expired, or has already been used.',\n    [AuthErrorCode.INVALID_PASSWORD]:\n      'The password is invalid or the user does not have a password.',\n    [AuthErrorCode.INVALID_PERSISTENCE]:\n      'The specified persistence type is invalid. It can only be local, session or none.',\n    [AuthErrorCode.INVALID_PHONE_NUMBER]:\n      'The format of the phone number provided is incorrect. Please enter the ' +\n      'phone number in a format that can be parsed into E.164 format. E.164 ' +\n      'phone numbers are written in the format [+][country code][subscriber ' +\n      'number including area code].',\n    [AuthErrorCode.INVALID_PROVIDER_ID]:\n      'The specified provider ID is invalid.',\n    [AuthErrorCode.INVALID_RECIPIENT_EMAIL]:\n      'The email corresponding to this action failed to send as the provided ' +\n      'recipient email address is invalid.',\n    [AuthErrorCode.INVALID_SENDER]:\n      'The email template corresponding to this action contains an invalid sender email or name. ' +\n      'Please fix by going to the Auth email templates section in the Firebase Console.',\n    [AuthErrorCode.INVALID_SESSION_INFO]:\n      'The verification ID used to create the phone auth credential is invalid.',\n    [AuthErrorCode.INVALID_TENANT_ID]:\n      \"The Auth instance's tenant ID is invalid.\",\n    [AuthErrorCode.LOGIN_BLOCKED]:\n      'Login blocked by user-provided method: {$originalMessage}',\n    [AuthErrorCode.MISSING_ANDROID_PACKAGE_NAME]:\n      'An Android Package Name must be provided if the Android App is required to be installed.',\n    [AuthErrorCode.MISSING_AUTH_DOMAIN]:\n      'Be sure to include authDomain when calling firebase.initializeApp(), ' +\n      'by following the instructions in the Firebase console.',\n    [AuthErrorCode.MISSING_APP_CREDENTIAL]:\n      'The phone verification request is missing an application verifier ' +\n      'assertion. A reCAPTCHA response token needs to be provided.',\n    [AuthErrorCode.MISSING_CODE]:\n      'The phone auth credential was created with an empty SMS verification code.',\n    [AuthErrorCode.MISSING_CONTINUE_URI]:\n      'A continue URL must be provided in the request.',\n    [AuthErrorCode.MISSING_IFRAME_START]: 'An internal AuthError has occurred.',\n    [AuthErrorCode.MISSING_IOS_BUNDLE_ID]:\n      'An iOS Bundle ID must be provided if an App Store ID is provided.',\n    [AuthErrorCode.MISSING_OR_INVALID_NONCE]:\n      'The request does not contain a valid nonce. This can occur if the ' +\n      'SHA-256 hash of the provided raw nonce does not match the hashed nonce ' +\n      'in the ID token payload.',\n    [AuthErrorCode.MISSING_PASSWORD]: 'A non-empty password must be provided',\n    [AuthErrorCode.MISSING_MFA_INFO]:\n      'No second factor identifier is provided.',\n    [AuthErrorCode.MISSING_MFA_SESSION]:\n      'The request is missing proof of first factor successful sign-in.',\n    [AuthErrorCode.MISSING_PHONE_NUMBER]:\n      'To send verification codes, provide a phone number for the recipient.',\n    [AuthErrorCode.MISSING_SESSION_INFO]:\n      'The phone auth credential was created with an empty verification ID.',\n    [AuthErrorCode.MODULE_DESTROYED]:\n      'This instance of FirebaseApp has been deleted.',\n    [AuthErrorCode.MFA_INFO_NOT_FOUND]:\n      'The user does not have a second factor matching the identifier provided.',\n    [AuthErrorCode.MFA_REQUIRED]:\n      'Proof of ownership of a second factor is required to complete sign-in.',\n    [AuthErrorCode.NEED_CONFIRMATION]:\n      'An account already exists with the same email address but different ' +\n      'sign-in credentials. Sign in using a provider associated with this ' +\n      'email address.',\n    [AuthErrorCode.NETWORK_REQUEST_FAILED]:\n      'A network AuthError (such as timeout, interrupted connection or unreachable host) has occurred.',\n    [AuthErrorCode.NO_AUTH_EVENT]: 'An internal AuthError has occurred.',\n    [AuthErrorCode.NO_SUCH_PROVIDER]:\n      'User was not linked to an account with the given provider.',\n    [AuthErrorCode.NULL_USER]:\n      'A null user object was provided as the argument for an operation which ' +\n      'requires a non-null user object.',\n    [AuthErrorCode.OPERATION_NOT_ALLOWED]:\n      'The given sign-in provider is disabled for this Firebase project. ' +\n      'Enable it in the Firebase console, under the sign-in method tab of the ' +\n      'Auth section.',\n    [AuthErrorCode.OPERATION_NOT_SUPPORTED]:\n      'This operation is not supported in the environment this application is ' +\n      'running on. \"location.protocol\" must be http, https or chrome-extension' +\n      ' and web storage must be enabled.',\n    [AuthErrorCode.POPUP_BLOCKED]:\n      'Unable to establish a connection with the popup. It may have been blocked by the browser.',\n    [AuthErrorCode.POPUP_CLOSED_BY_USER]:\n      'The popup has been closed by the user before finalizing the operation.',\n    [AuthErrorCode.PROVIDER_ALREADY_LINKED]:\n      'User can only be linked to one identity for the given provider.',\n    [AuthErrorCode.QUOTA_EXCEEDED]:\n      \"The project's quota for this operation has been exceeded.\",\n    [AuthErrorCode.REDIRECT_CANCELLED_BY_USER]:\n      'The redirect operation has been cancelled by the user before finalizing.',\n    [AuthErrorCode.REDIRECT_OPERATION_PENDING]:\n      'A redirect sign-in operation is already pending.',\n    [AuthErrorCode.REJECTED_CREDENTIAL]:\n      'The request contains malformed or mismatching credentials.',\n    [AuthErrorCode.SECOND_FACTOR_ALREADY_ENROLLED]:\n      'The second factor is already enrolled on this account.',\n    [AuthErrorCode.SECOND_FACTOR_LIMIT_EXCEEDED]:\n      'The maximum allowed number of second factors on a user has been exceeded.',\n    [AuthErrorCode.TENANT_ID_MISMATCH]:\n      \"The provided tenant ID does not match the Auth instance's tenant ID\",\n    [AuthErrorCode.TIMEOUT]: 'The operation has timed out.',\n    [AuthErrorCode.TOKEN_EXPIRED]:\n      \"The user's credential is no longer valid. The user must sign in again.\",\n    [AuthErrorCode.TOO_MANY_ATTEMPTS_TRY_LATER]:\n      'We have blocked all requests from this device due to unusual activity. ' +\n      'Try again later.',\n    [AuthErrorCode.UNAUTHORIZED_DOMAIN]:\n      'The domain of the continue URL is not whitelisted.  Please whitelist ' +\n      'the domain in the Firebase console.',\n    [AuthErrorCode.UNSUPPORTED_FIRST_FACTOR]:\n      'Enrolling a second factor or signing in with a multi-factor account requires sign-in with a supported first factor.',\n    [AuthErrorCode.UNSUPPORTED_PERSISTENCE]:\n      'The current environment does not support the specified persistence type.',\n    [AuthErrorCode.UNSUPPORTED_TENANT_OPERATION]:\n      'This operation is not supported in a multi-tenant context.',\n    [AuthErrorCode.UNVERIFIED_EMAIL]:\n      'The operation requires a verified email.',\n    [AuthErrorCode.USER_CANCELLED]:\n      'The user did not grant your application the permissions it requested.',\n    [AuthErrorCode.USER_DELETED]:\n      'There is no user record corresponding to this identifier. The user may ' +\n      'have been deleted.',\n    [AuthErrorCode.USER_DISABLED]:\n      'The user account has been disabled by an administrator.',\n    [AuthErrorCode.USER_MISMATCH]:\n      'The supplied credentials do not correspond to the previously signed in user.',\n    [AuthErrorCode.USER_SIGNED_OUT]: '',\n    [AuthErrorCode.WEAK_PASSWORD]:\n      'The password must be 6 characters long or more.',\n    [AuthErrorCode.WEB_STORAGE_UNSUPPORTED]:\n      'This browser is not supported or 3rd party cookies and data may be disabled.',\n    [AuthErrorCode.ALREADY_INITIALIZED]:\n      'initializeAuth() has already been called with ' +\n      'different options. To avoid this error, call initializeAuth() with the ' +\n      'same options as when it was originally called, or call getAuth() to return the' +\n      ' already initialized instance.',\n    [AuthErrorCode.MISSING_RECAPTCHA_TOKEN]:\n      'The reCAPTCHA token is missing when sending request to the backend.',\n    [AuthErrorCode.INVALID_RECAPTCHA_TOKEN]:\n      'The reCAPTCHA token is invalid when sending request to the backend.',\n    [AuthErrorCode.INVALID_RECAPTCHA_ACTION]:\n      'The reCAPTCHA action is invalid when sending request to the backend.',\n    [AuthErrorCode.RECAPTCHA_NOT_ENABLED]:\n      'reCAPTCHA Enterprise integration is not enabled for this project.',\n    [AuthErrorCode.MISSING_CLIENT_TYPE]:\n      'The reCAPTCHA client type is missing when sending request to the backend.',\n    [AuthErrorCode.MISSING_RECAPTCHA_VERSION]:\n      'The reCAPTCHA version is missing when sending request to the backend.',\n    [AuthErrorCode.INVALID_REQ_TYPE]: 'Invalid request parameters.',\n    [AuthErrorCode.INVALID_RECAPTCHA_VERSION]:\n      'The reCAPTCHA version is invalid when sending request to the backend.',\n    [AuthErrorCode.UNSUPPORTED_PASSWORD_POLICY_SCHEMA_VERSION]:\n      'The password policy received from the backend uses a schema version that is not supported by this version of the Firebase SDK.',\n    [AuthErrorCode.PASSWORD_DOES_NOT_MEET_REQUIREMENTS]:\n      'The password does not meet the requirements.'\n  };\n}\n\nexport interface ErrorMapRetriever extends AuthErrorMap {\n  (): ErrorMap<AuthErrorCode>;\n}\n\nfunction _prodErrorMap(): ErrorMap<AuthErrorCode> {\n  // We will include this one message in the prod error map since by the very\n  // nature of this error, developers will never be able to see the message\n  // using the debugErrorMap (which is installed during auth initialization).\n  return {\n    [AuthErrorCode.DEPENDENT_SDK_INIT_BEFORE_AUTH]:\n      'Another Firebase SDK was initialized and is trying to use Auth before Auth is ' +\n      'initialized. Please be sure to call `initializeAuth` or `getAuth` before ' +\n      'starting any other Firebase SDK.'\n  } as ErrorMap<AuthErrorCode>;\n}\n\n/**\n * A verbose error map with detailed descriptions for most error codes.\n *\n * See discussion at {@link AuthErrorMap}\n *\n * @public\n */\nexport const debugErrorMap: AuthErrorMap = _debugErrorMap;\n\n/**\n * A minimal error map with all verbose error messages stripped.\n *\n * See discussion at {@link AuthErrorMap}\n *\n * @public\n */\nexport const prodErrorMap: AuthErrorMap = _prodErrorMap;\n\nexport interface NamedErrorParams {\n  appName: AppName;\n  credential?: AuthCredential;\n  email?: string;\n  phoneNumber?: string;\n  tenantId?: string;\n  user?: User;\n  _serverResponse?: object;\n}\n\n/**\n * @internal\n */\ntype GenericAuthErrorParams = {\n  [key in Exclude<\n    AuthErrorCode,\n    | AuthErrorCode.ARGUMENT_ERROR\n    | AuthErrorCode.DEPENDENT_SDK_INIT_BEFORE_AUTH\n    | AuthErrorCode.INTERNAL_ERROR\n    | AuthErrorCode.MFA_REQUIRED\n    | AuthErrorCode.NO_AUTH_EVENT\n    | AuthErrorCode.OPERATION_NOT_SUPPORTED\n  >]: {\n    appName?: AppName;\n    email?: string;\n    phoneNumber?: string;\n    message?: string;\n  };\n};\n\n/**\n * @internal\n */\nexport interface AuthErrorParams extends GenericAuthErrorParams {\n  [AuthErrorCode.ARGUMENT_ERROR]: { appName?: AppName };\n  [AuthErrorCode.DEPENDENT_SDK_INIT_BEFORE_AUTH]: { appName?: AppName };\n  [AuthErrorCode.INTERNAL_ERROR]: { appName?: AppName };\n  [AuthErrorCode.LOGIN_BLOCKED]: {\n    appName?: AppName;\n    originalMessage?: string;\n  };\n  [AuthErrorCode.OPERATION_NOT_SUPPORTED]: { appName?: AppName };\n  [AuthErrorCode.NO_AUTH_EVENT]: { appName?: AppName };\n  [AuthErrorCode.MFA_REQUIRED]: {\n    appName: AppName;\n    _serverResponse: IdTokenMfaResponse;\n  };\n  [AuthErrorCode.INVALID_CORDOVA_CONFIGURATION]: {\n    appName: AppName;\n    missingPlugin?: string;\n  };\n}\n\nexport const _DEFAULT_AUTH_ERROR_FACTORY = new ErrorFactory<\n  AuthErrorCode,\n  AuthErrorParams\n>('auth', 'Firebase', _prodErrorMap());\n\n/**\n * A map of potential `Auth` error codes, for easier comparison with errors\n * thrown by the SDK.\n *\n * @remarks\n * Note that you can't tree-shake individual keys\n * in the map, so by using the map you might substantially increase your\n * bundle size.\n *\n * @public\n */\nexport const AUTH_ERROR_CODES_MAP_DO_NOT_USE_INTERNALLY = {\n  ADMIN_ONLY_OPERATION: 'auth/admin-restricted-operation',\n  ARGUMENT_ERROR: 'auth/argument-error',\n  APP_NOT_AUTHORIZED: 'auth/app-not-authorized',\n  APP_NOT_INSTALLED: 'auth/app-not-installed',\n  CAPTCHA_CHECK_FAILED: 'auth/captcha-check-failed',\n  CODE_EXPIRED: 'auth/code-expired',\n  CORDOVA_NOT_READY: 'auth/cordova-not-ready',\n  CORS_UNSUPPORTED: 'auth/cors-unsupported',\n  CREDENTIAL_ALREADY_IN_USE: 'auth/credential-already-in-use',\n  CREDENTIAL_MISMATCH: 'auth/custom-token-mismatch',\n  CREDENTIAL_TOO_OLD_LOGIN_AGAIN: 'auth/requires-recent-login',\n  DEPENDENT_SDK_INIT_BEFORE_AUTH: 'auth/dependent-sdk-initialized-before-auth',\n  DYNAMIC_LINK_NOT_ACTIVATED: 'auth/dynamic-link-not-activated',\n  EMAIL_CHANGE_NEEDS_VERIFICATION: 'auth/email-change-needs-verification',\n  EMAIL_EXISTS: 'auth/email-already-in-use',\n  EMULATOR_CONFIG_FAILED: 'auth/emulator-config-failed',\n  EXPIRED_OOB_CODE: 'auth/expired-action-code',\n  EXPIRED_POPUP_REQUEST: 'auth/cancelled-popup-request',\n  INTERNAL_ERROR: 'auth/internal-error',\n  INVALID_API_KEY: 'auth/invalid-api-key',\n  INVALID_APP_CREDENTIAL: 'auth/invalid-app-credential',\n  INVALID_APP_ID: 'auth/invalid-app-id',\n  INVALID_AUTH: 'auth/invalid-user-token',\n  INVALID_AUTH_EVENT: 'auth/invalid-auth-event',\n  INVALID_CERT_HASH: 'auth/invalid-cert-hash',\n  INVALID_CODE: 'auth/invalid-verification-code',\n  INVALID_CONTINUE_URI: 'auth/invalid-continue-uri',\n  INVALID_CORDOVA_CONFIGURATION: 'auth/invalid-cordova-configuration',\n  INVALID_CUSTOM_TOKEN: 'auth/invalid-custom-token',\n  INVALID_DYNAMIC_LINK_DOMAIN: 'auth/invalid-dynamic-link-domain',\n  INVALID_EMAIL: 'auth/invalid-email',\n  INVALID_EMULATOR_SCHEME: 'auth/invalid-emulator-scheme',\n  INVALID_IDP_RESPONSE: 'auth/invalid-credential',\n  INVALID_LOGIN_CREDENTIALS: 'auth/invalid-credential',\n  INVALID_MESSAGE_PAYLOAD: 'auth/invalid-message-payload',\n  INVALID_MFA_SESSION: 'auth/invalid-multi-factor-session',\n  INVALID_OAUTH_CLIENT_ID: 'auth/invalid-oauth-client-id',\n  INVALID_OAUTH_PROVIDER: 'auth/invalid-oauth-provider',\n  INVALID_OOB_CODE: 'auth/invalid-action-code',\n  INVALID_ORIGIN: 'auth/unauthorized-domain',\n  INVALID_PASSWORD: 'auth/wrong-password',\n  INVALID_PERSISTENCE: 'auth/invalid-persistence-type',\n  INVALID_PHONE_NUMBER: 'auth/invalid-phone-number',\n  INVALID_PROVIDER_ID: 'auth/invalid-provider-id',\n  INVALID_RECIPIENT_EMAIL: 'auth/invalid-recipient-email',\n  INVALID_SENDER: 'auth/invalid-sender',\n  INVALID_SESSION_INFO: 'auth/invalid-verification-id',\n  INVALID_TENANT_ID: 'auth/invalid-tenant-id',\n  MFA_INFO_NOT_FOUND: 'auth/multi-factor-info-not-found',\n  MFA_REQUIRED: 'auth/multi-factor-auth-required',\n  MISSING_ANDROID_PACKAGE_NAME: 'auth/missing-android-pkg-name',\n  MISSING_APP_CREDENTIAL: 'auth/missing-app-credential',\n  MISSING_AUTH_DOMAIN: 'auth/auth-domain-config-required',\n  MISSING_CODE: 'auth/missing-verification-code',\n  MISSING_CONTINUE_URI: 'auth/missing-continue-uri',\n  MISSING_IFRAME_START: 'auth/missing-iframe-start',\n  MISSING_IOS_BUNDLE_ID: 'auth/missing-ios-bundle-id',\n  MISSING_OR_INVALID_NONCE: 'auth/missing-or-invalid-nonce',\n  MISSING_MFA_INFO: 'auth/missing-multi-factor-info',\n  MISSING_MFA_SESSION: 'auth/missing-multi-factor-session',\n  MISSING_PHONE_NUMBER: 'auth/missing-phone-number',\n  MISSING_SESSION_INFO: 'auth/missing-verification-id',\n  MODULE_DESTROYED: 'auth/app-deleted',\n  NEED_CONFIRMATION: 'auth/account-exists-with-different-credential',\n  NETWORK_REQUEST_FAILED: 'auth/network-request-failed',\n  NULL_USER: 'auth/null-user',\n  NO_AUTH_EVENT: 'auth/no-auth-event',\n  NO_SUCH_PROVIDER: 'auth/no-such-provider',\n  OPERATION_NOT_ALLOWED: 'auth/operation-not-allowed',\n  OPERATION_NOT_SUPPORTED: 'auth/operation-not-supported-in-this-environment',\n  POPUP_BLOCKED: 'auth/popup-blocked',\n  POPUP_CLOSED_BY_USER: 'auth/popup-closed-by-user',\n  PROVIDER_ALREADY_LINKED: 'auth/provider-already-linked',\n  QUOTA_EXCEEDED: 'auth/quota-exceeded',\n  REDIRECT_CANCELLED_BY_USER: 'auth/redirect-cancelled-by-user',\n  REDIRECT_OPERATION_PENDING: 'auth/redirect-operation-pending',\n  REJECTED_CREDENTIAL: 'auth/rejected-credential',\n  SECOND_FACTOR_ALREADY_ENROLLED: 'auth/second-factor-already-in-use',\n  SECOND_FACTOR_LIMIT_EXCEEDED: 'auth/maximum-second-factor-count-exceeded',\n  TENANT_ID_MISMATCH: 'auth/tenant-id-mismatch',\n  TIMEOUT: 'auth/timeout',\n  TOKEN_EXPIRED: 'auth/user-token-expired',\n  TOO_MANY_ATTEMPTS_TRY_LATER: 'auth/too-many-requests',\n  UNAUTHORIZED_DOMAIN: 'auth/unauthorized-continue-uri',\n  UNSUPPORTED_FIRST_FACTOR: 'auth/unsupported-first-factor',\n  UNSUPPORTED_PERSISTENCE: 'auth/unsupported-persistence-type',\n  UNSUPPORTED_TENANT_OPERATION: 'auth/unsupported-tenant-operation',\n  UNVERIFIED_EMAIL: 'auth/unverified-email',\n  USER_CANCELLED: 'auth/user-cancelled',\n  USER_DELETED: 'auth/user-not-found',\n  USER_DISABLED: 'auth/user-disabled',\n  USER_MISMATCH: 'auth/user-mismatch',\n  USER_SIGNED_OUT: 'auth/user-signed-out',\n  WEAK_PASSWORD: 'auth/weak-password',\n  WEB_STORAGE_UNSUPPORTED: 'auth/web-storage-unsupported',\n  ALREADY_INITIALIZED: 'auth/already-initialized',\n  RECAPTCHA_NOT_ENABLED: 'auth/recaptcha-not-enabled',\n  MISSING_RECAPTCHA_TOKEN: 'auth/missing-recaptcha-token',\n  INVALID_RECAPTCHA_TOKEN: 'auth/invalid-recaptcha-token',\n  INVALID_RECAPTCHA_ACTION: 'auth/invalid-recaptcha-action',\n  MISSING_CLIENT_TYPE: 'auth/missing-client-type',\n  MISSING_RECAPTCHA_VERSION: 'auth/missing-recaptcha-version',\n  INVALID_RECAPTCHA_VERSION: 'auth/invalid-recaptcha-version',\n  INVALID_REQ_TYPE: 'auth/invalid-req-type'\n} as const;\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 { Logger, LogLevel } from '@firebase/logger';\nimport { SDK_VERSION } from '@firebase/app';\n\nexport { LogLevel };\n\nconst logClient = new Logger('@firebase/auth');\n\n// Helper methods are needed because variables can't be exported as read/write\nexport function _getLogLevel(): LogLevel {\n  return logClient.logLevel;\n}\n\nexport function _setLogLevel(newLevel: LogLevel): void {\n  logClient.logLevel = newLevel;\n}\n\nexport function _logDebug(msg: string, ...args: string[]): void {\n  if (logClient.logLevel <= LogLevel.DEBUG) {\n    logClient.debug(`Auth (${SDK_VERSION}): ${msg}`, ...args);\n  }\n}\n\nexport function _logWarn(msg: string, ...args: string[]): void {\n  if (logClient.logLevel <= LogLevel.WARN) {\n    logClient.warn(`Auth (${SDK_VERSION}): ${msg}`, ...args);\n  }\n}\n\nexport function _logError(msg: string, ...args: string[]): void {\n  if (logClient.logLevel <= LogLevel.ERROR) {\n    logClient.error(`Auth (${SDK_VERSION}): ${msg}`, ...args);\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 { Auth } from '../../model/public_types';\nimport { ErrorFactory, FirebaseError } from '@firebase/util';\nimport { AuthInternal } from '../../model/auth';\nimport {\n  _DEFAULT_AUTH_ERROR_FACTORY,\n  AuthErrorCode,\n  AuthErrorParams,\n  prodErrorMap,\n  ErrorMapRetriever\n} from '../errors';\nimport { _logError } from './log';\n\ntype AuthErrorListParams<K> = K extends keyof AuthErrorParams\n  ? [AuthErrorParams[K]]\n  : [];\ntype LessAppName<K extends AuthErrorCode> = Omit<AuthErrorParams[K], 'appName'>;\n\n/**\n * Unconditionally fails, throwing a developer facing INTERNAL_ERROR\n *\n * @example\n * ```javascript\n * fail(auth, AuthErrorCode.MFA_REQUIRED);  // Error: the MFA_REQUIRED error needs more params than appName\n * fail(auth, AuthErrorCode.MFA_REQUIRED, {serverResponse});  // Compiles\n * fail(AuthErrorCode.INTERNAL_ERROR);  // Compiles; internal error does not need appName\n * fail(AuthErrorCode.USER_DELETED);  // Error: USER_DELETED requires app name\n * fail(auth, AuthErrorCode.USER_DELETED);  // Compiles; USER_DELETED _only_ needs app name\n * ```\n *\n * @param appName App name for tagging the error\n * @throws FirebaseError\n */\nexport function _fail<K extends AuthErrorCode>(\n  code: K,\n  ...data: {} extends AuthErrorParams[K]\n    ? [AuthErrorParams[K]?]\n    : [AuthErrorParams[K]]\n): never;\nexport function _fail<K extends AuthErrorCode>(\n  auth: Auth,\n  code: K,\n  ...data: {} extends LessAppName<K> ? [LessAppName<K>?] : [LessAppName<K>]\n): never;\nexport function _fail<K extends AuthErrorCode>(\n  authOrCode: Auth | K,\n  ...rest: unknown[]\n): never {\n  throw createErrorInternal(authOrCode, ...rest);\n}\n\nexport function _createError<K extends AuthErrorCode>(\n  code: K,\n  ...data: {} extends AuthErrorParams[K]\n    ? [AuthErrorParams[K]?]\n    : [AuthErrorParams[K]]\n): FirebaseError;\nexport function _createError<K extends AuthErrorCode>(\n  auth: Auth,\n  code: K,\n  ...data: {} extends LessAppName<K> ? [LessAppName<K>?] : [LessAppName<K>]\n): FirebaseError;\nexport function _createError<K extends AuthErrorCode>(\n  authOrCode: Auth | K,\n  ...rest: unknown[]\n): FirebaseError {\n  return createErrorInternal(authOrCode, ...rest);\n}\n\nexport function _errorWithCustomMessage(\n  auth: Auth,\n  code: AuthErrorCode,\n  message: string\n): FirebaseError {\n  const errorMap = {\n    ...(prodErrorMap as ErrorMapRetriever)(),\n    [code]: message\n  };\n  const factory = new ErrorFactory<AuthErrorCode, AuthErrorParams>(\n    'auth',\n    'Firebase',\n    errorMap\n  );\n  return factory.create(code, {\n    appName: auth.name\n  });\n}\n\nexport function _serverAppCurrentUserOperationNotSupportedError(\n  auth: Auth\n): FirebaseError {\n  return _errorWithCustomMessage(\n    auth,\n    AuthErrorCode.OPERATION_NOT_SUPPORTED,\n    'Operations that alter the current user are not supported in conjunction with FirebaseServerApp'\n  );\n}\n\nexport function _assertInstanceOf(\n  auth: Auth,\n  object: object,\n  instance: unknown\n): void {\n  const constructorInstance = instance as { new (...args: unknown[]): unknown };\n  if (!(object instanceof constructorInstance)) {\n    if (constructorInstance.name !== object.constructor.name) {\n      _fail(auth, AuthErrorCode.ARGUMENT_ERROR);\n    }\n\n    throw _errorWithCustomMessage(\n      auth,\n      AuthErrorCode.ARGUMENT_ERROR,\n      `Type of ${object.constructor.name} does not match expected instance.` +\n        `Did you pass a reference from a different Auth SDK?`\n    );\n  }\n}\n\nfunction createErrorInternal<K extends AuthErrorCode>(\n  authOrCode: Auth | K,\n  ...rest: unknown[]\n): FirebaseError {\n  if (typeof authOrCode !== 'string') {\n    const code = rest[0] as K;\n    const fullParams = [...rest.slice(1)] as AuthErrorListParams<K>;\n    if (fullParams[0]) {\n      fullParams[0].appName = authOrCode.name;\n    }\n\n    return (authOrCode as AuthInternal)._errorFactory.create(\n      code,\n      ...fullParams\n    );\n  }\n\n  return _DEFAULT_AUTH_ERROR_FACTORY.create(\n    authOrCode,\n    ...(rest as AuthErrorListParams<K>)\n  );\n}\n\nexport function _assert<K extends AuthErrorCode>(\n  assertion: unknown,\n  code: K,\n  ...data: {} extends AuthErrorParams[K]\n    ? [AuthErrorParams[K]?]\n    : [AuthErrorParams[K]]\n): asserts assertion;\nexport function _assert<K extends AuthErrorCode>(\n  assertion: unknown,\n  auth: Auth,\n  code: K,\n  ...data: {} extends LessAppName<K> ? [LessAppName<K>?] : [LessAppName<K>]\n): asserts assertion;\nexport function _assert<K extends AuthErrorCode>(\n  assertion: unknown,\n  authOrCode: Auth | K,\n  ...rest: unknown[]\n): asserts assertion {\n  if (!assertion) {\n    throw createErrorInternal(authOrCode, ...rest);\n  }\n}\n\n// We really do want to accept literally any function type here\n// eslint-disable-next-line @typescript-eslint/ban-types\ntype TypeExpectation = Function | string | MapType;\n\ninterface MapType extends Record<string, TypeExpectation | Optional> {}\n\nclass Optional {\n  constructor(readonly type: TypeExpectation) {}\n}\n\nexport function opt(type: TypeExpectation): Optional {\n  return new Optional(type);\n}\n\n/**\n * Asserts the runtime types of arguments. The 'expected' field can be one of\n * a class, a string (representing a \"typeof\" call), or a record map of name\n * to type. Furthermore, the opt() function can be used to mark a field as\n * optional. For example:\n *\n * function foo(auth: Auth, profile: {displayName?: string}, update = false) {\n *   assertTypes(arguments, [AuthImpl, {displayName: opt('string')}, opt('boolean')]);\n * }\n *\n * opt() can be used for any type:\n * function foo(auth?: Auth) {\n *   assertTypes(arguments, [opt(AuthImpl)]);\n * }\n *\n * The string types can be or'd together, and you can use \"null\" as well (note\n * that typeof null === 'object'; this is an edge case). For example:\n *\n * function foo(profile: {displayName?: string | null}) {\n *   assertTypes(arguments, [{displayName: opt('string|null')}]);\n * }\n *\n * @param args\n * @param expected\n */\nexport function assertTypes(\n  args: Omit<IArguments, 'callee'>,\n  ...expected: Array<TypeExpectation | Optional>\n): void {\n  if (args.length > expected.length) {\n    _fail(AuthErrorCode.ARGUMENT_ERROR, {});\n  }\n\n  for (let i = 0; i < expected.length; i++) {\n    let expect = expected[i];\n    const arg = args[i];\n\n    if (expect instanceof Optional) {\n      // If the arg is undefined, then it matches \"optional\" and we can move to\n      // the next arg\n      if (typeof arg === 'undefined') {\n        continue;\n      }\n      expect = expect.type;\n    }\n\n    if (typeof expect === 'string') {\n      // Handle the edge case for null because typeof null === 'object'\n      if (expect.includes('null') && arg === null) {\n        continue;\n      }\n\n      const required = expect.split('|');\n      _assert(required.includes(typeof arg), AuthErrorCode.ARGUMENT_ERROR, {});\n    } else if (typeof expect === 'object') {\n      // Recursively check record arguments\n      const record = arg as Record<string, unknown>;\n      const map = expect as MapType;\n      const keys = Object.keys(expect);\n\n      assertTypes(\n        keys.map(k => record[k]),\n        ...keys.map(k => map[k])\n      );\n    } else {\n      _assert(arg instanceof expect, AuthErrorCode.ARGUMENT_ERROR, {});\n    }\n  }\n}\n\n/**\n * Unconditionally fails, throwing an internal error with the given message.\n *\n * @param failure type of failure encountered\n * @throws Error\n */\nexport function debugFail(failure: string): never {\n  // Log the failure in addition to throw an exception, just in case the\n  // exception is swallowed.\n  const message = `INTERNAL ASSERTION FAILED: ` + failure;\n  _logError(message);\n\n  // NOTE: We don't use FirebaseError 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 new Error(message);\n}\n\n/**\n * Fails if the given assertion condition is false, throwing an Error with the\n * given message if it did.\n *\n * @param assertion\n * @param message\n */\nexport function debugAssert(\n  assertion: unknown,\n  message: string\n): asserts assertion {\n  if (!assertion) {\n    debugFail(message);\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\nexport function _getCurrentUrl(): string {\n  return (typeof self !== 'undefined' && self.location?.href) || '';\n}\n\nexport function _isHttpOrHttps(): boolean {\n  return _getCurrentScheme() === 'http:' || _getCurrentScheme() === 'https:';\n}\n\nexport function _getCurrentScheme(): string | null {\n  return (typeof self !== 'undefined' && self.location?.protocol) || 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\nimport { isBrowserExtension } from '@firebase/util';\nimport { _isHttpOrHttps } from './location';\n\n/**\n * Determine whether the browser is working online\n */\nexport function _isOnline(): boolean {\n  if (\n    typeof navigator !== 'undefined' &&\n    navigator &&\n    'onLine' in navigator &&\n    typeof navigator.onLine === 'boolean' &&\n    // Apply only for traditional web apps and Chrome extensions.\n    // This is especially true for Cordova apps which have unreliable\n    // navigator.onLine behavior unless cordova-plugin-network-information is\n    // installed which overwrites the native navigator.onLine value and\n    // defines navigator.connection.\n    (_isHttpOrHttps() || isBrowserExtension() || 'connection' in navigator)\n  ) {\n    return navigator.onLine;\n  }\n  // If we can't determine the state, assume it is online.\n  return true;\n}\n\nexport function _getUserLanguage(): string | null {\n  if (typeof navigator === 'undefined') {\n    return null;\n  }\n  const navigatorLanguage: NavigatorLanguage = navigator;\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    // Couldn't determine language.\n    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 { isMobileCordova, isReactNative } from '@firebase/util';\nimport { _isOnline } from './navigator';\nimport { debugAssert } from './assert';\n\nexport const enum DelayMin {\n  OFFLINE = 5000\n}\n\n/**\n * A structure to help pick between a range of long and short delay durations\n * depending on the current environment. In general, the long delay is used for\n * mobile environments whereas short delays are used for desktop environments.\n */\nexport class Delay {\n  // The default value for the offline delay timeout in ms.\n\n  private readonly isMobile: boolean;\n  constructor(\n    private readonly shortDelay: number,\n    private readonly longDelay: number\n  ) {\n    // Internal error when improperly initialized.\n    debugAssert(\n      longDelay > shortDelay,\n      'Short delay should be less than long delay!'\n    );\n    this.isMobile = isMobileCordova() || isReactNative();\n  }\n\n  get(): number {\n    if (!_isOnline()) {\n      // Pick the shorter timeout.\n      return Math.min(DelayMin.OFFLINE, this.shortDelay);\n    }\n    // If running in a mobile environment, return the long delay, otherwise\n    // return the short delay.\n    // This could be improved in the future to dynamically change based on other\n    // variables instead of just reading the current environment.\n    return this.isMobile ? this.longDelay : this.shortDelay;\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 { ConfigInternal } from '../../model/auth';\nimport { debugAssert } from './assert';\n\nexport function _emulatorUrl(config: ConfigInternal, path?: string): string {\n  debugAssert(config.emulator, 'Emulator should always be set here');\n  const { url } = config.emulator;\n\n  if (!path) {\n    return url;\n  }\n\n  return `${url}${path.startsWith('/') ? path.slice(1) : path}`;\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 { debugFail } from './assert';\n\nexport class FetchProvider {\n  private static fetchImpl: typeof fetch | null;\n  private static headersImpl: typeof Headers | null;\n  private static responseImpl: typeof Response | null;\n\n  static initialize(\n    fetchImpl: typeof fetch,\n    headersImpl?: typeof Headers,\n    responseImpl?: typeof Response\n  ): void {\n    this.fetchImpl = fetchImpl;\n    if (headersImpl) {\n      this.headersImpl = headersImpl;\n    }\n    if (responseImpl) {\n      this.responseImpl = responseImpl;\n    }\n  }\n\n  static fetch(): typeof fetch {\n    if (this.fetchImpl) {\n      return this.fetchImpl;\n    }\n    if (typeof self !== 'undefined' && 'fetch' in self) {\n      return self.fetch;\n    }\n    if (typeof globalThis !== 'undefined' && globalThis.fetch) {\n      return globalThis.fetch;\n    }\n    if (typeof fetch !== 'undefined') {\n      return fetch;\n    }\n    debugFail(\n      'Could not find fetch implementation, make sure you call FetchProvider.initialize() with an appropriate polyfill'\n    );\n  }\n\n  static headers(): typeof Headers {\n    if (this.headersImpl) {\n      return this.headersImpl;\n    }\n    if (typeof self !== 'undefined' && 'Headers' in self) {\n      return self.Headers;\n    }\n    if (typeof globalThis !== 'undefined' && globalThis.Headers) {\n      return globalThis.Headers;\n    }\n    if (typeof Headers !== 'undefined') {\n      return Headers;\n    }\n    debugFail(\n      'Could not find Headers implementation, make sure you call FetchProvider.initialize() with an appropriate polyfill'\n    );\n  }\n\n  static response(): typeof Response {\n    if (this.responseImpl) {\n      return this.responseImpl;\n    }\n    if (typeof self !== 'undefined' && 'Response' in self) {\n      return self.Response;\n    }\n    if (typeof globalThis !== 'undefined' && globalThis.Response) {\n      return globalThis.Response;\n    }\n    if (typeof Response !== 'undefined') {\n      return Response;\n    }\n    debugFail(\n      'Could not find Response implementation, make sure you call FetchProvider.initialize() with an appropriate polyfill'\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 { AuthErrorCode } from '../core/errors';\n\n/**\n * Errors that can be returned by the backend\n */\nexport const enum ServerError {\n  ADMIN_ONLY_OPERATION = 'ADMIN_ONLY_OPERATION',\n  BLOCKING_FUNCTION_ERROR_RESPONSE = 'BLOCKING_FUNCTION_ERROR_RESPONSE',\n  CAPTCHA_CHECK_FAILED = 'CAPTCHA_CHECK_FAILED',\n  CORS_UNSUPPORTED = 'CORS_UNSUPPORTED',\n  CREDENTIAL_MISMATCH = 'CREDENTIAL_MISMATCH',\n  CREDENTIAL_TOO_OLD_LOGIN_AGAIN = 'CREDENTIAL_TOO_OLD_LOGIN_AGAIN',\n  DYNAMIC_LINK_NOT_ACTIVATED = 'DYNAMIC_LINK_NOT_ACTIVATED',\n  EMAIL_CHANGE_NEEDS_VERIFICATION = 'EMAIL_CHANGE_NEEDS_VERIFICATION',\n  EMAIL_EXISTS = 'EMAIL_EXISTS',\n  EMAIL_NOT_FOUND = 'EMAIL_NOT_FOUND',\n  EXPIRED_OOB_CODE = 'EXPIRED_OOB_CODE',\n  FEDERATED_USER_ID_ALREADY_LINKED = 'FEDERATED_USER_ID_ALREADY_LINKED',\n  INVALID_APP_CREDENTIAL = 'INVALID_APP_CREDENTIAL',\n  INVALID_APP_ID = 'INVALID_APP_ID',\n  INVALID_CERT_HASH = 'INVALID_CERT_HASH',\n  INVALID_CODE = 'INVALID_CODE',\n  INVALID_CONTINUE_URI = 'INVALID_CONTINUE_URI',\n  INVALID_CUSTOM_TOKEN = 'INVALID_CUSTOM_TOKEN',\n  INVALID_DYNAMIC_LINK_DOMAIN = 'INVALID_DYNAMIC_LINK_DOMAIN',\n  INVALID_EMAIL = 'INVALID_EMAIL',\n  INVALID_ID_TOKEN = 'INVALID_ID_TOKEN',\n  INVALID_IDP_RESPONSE = 'INVALID_IDP_RESPONSE',\n  INVALID_IDENTIFIER = 'INVALID_IDENTIFIER',\n  INVALID_LOGIN_CREDENTIALS = 'INVALID_LOGIN_CREDENTIALS',\n  INVALID_MESSAGE_PAYLOAD = 'INVALID_MESSAGE_PAYLOAD',\n  INVALID_MFA_PENDING_CREDENTIAL = 'INVALID_MFA_PENDING_CREDENTIAL',\n  INVALID_OAUTH_CLIENT_ID = 'INVALID_OAUTH_CLIENT_ID',\n  INVALID_OOB_CODE = 'INVALID_OOB_CODE',\n  INVALID_PASSWORD = 'INVALID_PASSWORD',\n  INVALID_PENDING_TOKEN = 'INVALID_PENDING_TOKEN',\n  INVALID_PHONE_NUMBER = 'INVALID_PHONE_NUMBER',\n  INVALID_PROVIDER_ID = 'INVALID_PROVIDER_ID',\n  INVALID_RECIPIENT_EMAIL = 'INVALID_RECIPIENT_EMAIL',\n  INVALID_SENDER = 'INVALID_SENDER',\n  INVALID_SESSION_INFO = 'INVALID_SESSION_INFO',\n  INVALID_TEMPORARY_PROOF = 'INVALID_TEMPORARY_PROOF',\n  INVALID_TENANT_ID = 'INVALID_TENANT_ID',\n  MFA_ENROLLMENT_NOT_FOUND = 'MFA_ENROLLMENT_NOT_FOUND',\n  MISSING_ANDROID_PACKAGE_NAME = 'MISSING_ANDROID_PACKAGE_NAME',\n  MISSING_APP_CREDENTIAL = 'MISSING_APP_CREDENTIAL',\n  MISSING_CODE = 'MISSING_CODE',\n  MISSING_CONTINUE_URI = 'MISSING_CONTINUE_URI',\n  MISSING_CUSTOM_TOKEN = 'MISSING_CUSTOM_TOKEN',\n  MISSING_IOS_BUNDLE_ID = 'MISSING_IOS_BUNDLE_ID',\n  MISSING_MFA_ENROLLMENT_ID = 'MISSING_MFA_ENROLLMENT_ID',\n  MISSING_MFA_PENDING_CREDENTIAL = 'MISSING_MFA_PENDING_CREDENTIAL',\n  MISSING_OOB_CODE = 'MISSING_OOB_CODE',\n  MISSING_OR_INVALID_NONCE = 'MISSING_OR_INVALID_NONCE',\n  MISSING_PASSWORD = 'MISSING_PASSWORD',\n  MISSING_REQ_TYPE = 'MISSING_REQ_TYPE',\n  MISSING_PHONE_NUMBER = 'MISSING_PHONE_NUMBER',\n  MISSING_SESSION_INFO = 'MISSING_SESSION_INFO',\n  OPERATION_NOT_ALLOWED = 'OPERATION_NOT_ALLOWED',\n  PASSWORD_LOGIN_DISABLED = 'PASSWORD_LOGIN_DISABLED',\n  QUOTA_EXCEEDED = 'QUOTA_EXCEEDED',\n  RESET_PASSWORD_EXCEED_LIMIT = 'RESET_PASSWORD_EXCEED_LIMIT',\n  REJECTED_CREDENTIAL = 'REJECTED_CREDENTIAL',\n  SECOND_FACTOR_EXISTS = 'SECOND_FACTOR_EXISTS',\n  SECOND_FACTOR_LIMIT_EXCEEDED = 'SECOND_FACTOR_LIMIT_EXCEEDED',\n  SESSION_EXPIRED = 'SESSION_EXPIRED',\n  TENANT_ID_MISMATCH = 'TENANT_ID_MISMATCH',\n  TOKEN_EXPIRED = 'TOKEN_EXPIRED',\n  TOO_MANY_ATTEMPTS_TRY_LATER = 'TOO_MANY_ATTEMPTS_TRY_LATER',\n  UNSUPPORTED_FIRST_FACTOR = 'UNSUPPORTED_FIRST_FACTOR',\n  UNSUPPORTED_TENANT_OPERATION = 'UNSUPPORTED_TENANT_OPERATION',\n  UNAUTHORIZED_DOMAIN = 'UNAUTHORIZED_DOMAIN',\n  UNVERIFIED_EMAIL = 'UNVERIFIED_EMAIL',\n  USER_CANCELLED = 'USER_CANCELLED',\n  USER_DISABLED = 'USER_DISABLED',\n  USER_NOT_FOUND = 'USER_NOT_FOUND',\n  WEAK_PASSWORD = 'WEAK_PASSWORD',\n  RECAPTCHA_NOT_ENABLED = 'RECAPTCHA_NOT_ENABLED',\n  MISSING_RECAPTCHA_TOKEN = 'MISSING_RECAPTCHA_TOKEN',\n  INVALID_RECAPTCHA_TOKEN = 'INVALID_RECAPTCHA_TOKEN',\n  INVALID_RECAPTCHA_ACTION = 'INVALID_RECAPTCHA_ACTION',\n  MISSING_CLIENT_TYPE = 'MISSING_CLIENT_TYPE',\n  MISSING_RECAPTCHA_VERSION = 'MISSING_RECAPTCHA_VERSION',\n  INVALID_RECAPTCHA_VERSION = 'INVALID_RECAPTCHA_VERSION',\n  INVALID_REQ_TYPE = 'INVALID_REQ_TYPE',\n  PASSWORD_DOES_NOT_MEET_REQUIREMENTS = 'PASSWORD_DOES_NOT_MEET_REQUIREMENTS'\n}\n\n/**\n * API Response in the event of an error\n */\nexport interface JsonError {\n  error: {\n    code: number;\n    message: string;\n    errors?: [\n      {\n        message: ServerError;\n        domain: string;\n        reason: string;\n      }\n    ];\n  };\n}\n\n/**\n * Type definition for a map from server errors to developer visible errors\n */\nexport declare type ServerErrorMap<ApiError extends string> = {\n  readonly [K in ApiError]: AuthErrorCode;\n};\n\n/**\n * Map from errors returned by the server to errors to developer visible errors\n */\nexport const SERVER_ERROR_MAP: Partial<ServerErrorMap<ServerError>> = {\n  // Custom token errors.\n  [ServerError.CREDENTIAL_MISMATCH]: AuthErrorCode.CREDENTIAL_MISMATCH,\n  // This can only happen if the SDK sends a bad request.\n  [ServerError.MISSING_CUSTOM_TOKEN]: AuthErrorCode.INTERNAL_ERROR,\n\n  // Create Auth URI errors.\n  [ServerError.INVALID_IDENTIFIER]: AuthErrorCode.INVALID_EMAIL,\n  // This can only happen if the SDK sends a bad request.\n  [ServerError.MISSING_CONTINUE_URI]: AuthErrorCode.INTERNAL_ERROR,\n\n  // Sign in with email and password errors (some apply to sign up too).\n  [ServerError.INVALID_PASSWORD]: AuthErrorCode.INVALID_PASSWORD,\n  // This can only happen if the SDK sends a bad request.\n  [ServerError.MISSING_PASSWORD]: AuthErrorCode.MISSING_PASSWORD,\n  // Thrown if Email Enumeration Protection is enabled in the project and the email or password is\n  // invalid.\n  [ServerError.INVALID_LOGIN_CREDENTIALS]: AuthErrorCode.INVALID_CREDENTIAL,\n\n  // Sign up with email and password errors.\n  [ServerError.EMAIL_EXISTS]: AuthErrorCode.EMAIL_EXISTS,\n  [ServerError.PASSWORD_LOGIN_DISABLED]: AuthErrorCode.OPERATION_NOT_ALLOWED,\n\n  // Verify assertion for sign in with credential errors:\n  [ServerError.INVALID_IDP_RESPONSE]: AuthErrorCode.INVALID_CREDENTIAL,\n  [ServerError.INVALID_PENDING_TOKEN]: AuthErrorCode.INVALID_CREDENTIAL,\n  [ServerError.FEDERATED_USER_ID_ALREADY_LINKED]:\n    AuthErrorCode.CREDENTIAL_ALREADY_IN_USE,\n\n  // This can only happen if the SDK sends a bad request.\n  [ServerError.MISSING_REQ_TYPE]: AuthErrorCode.INTERNAL_ERROR,\n\n  // Send Password reset email errors:\n  [ServerError.EMAIL_NOT_FOUND]: AuthErrorCode.USER_DELETED,\n  [ServerError.RESET_PASSWORD_EXCEED_LIMIT]:\n    AuthErrorCode.TOO_MANY_ATTEMPTS_TRY_LATER,\n\n  [ServerError.EXPIRED_OOB_CODE]: AuthErrorCode.EXPIRED_OOB_CODE,\n  [ServerError.INVALID_OOB_CODE]: AuthErrorCode.INVALID_OOB_CODE,\n  // This can only happen if the SDK sends a bad request.\n  [ServerError.MISSING_OOB_CODE]: AuthErrorCode.INTERNAL_ERROR,\n\n  // Operations that require ID token in request:\n  [ServerError.CREDENTIAL_TOO_OLD_LOGIN_AGAIN]:\n    AuthErrorCode.CREDENTIAL_TOO_OLD_LOGIN_AGAIN,\n  [ServerError.INVALID_ID_TOKEN]: AuthErrorCode.INVALID_AUTH,\n  [ServerError.TOKEN_EXPIRED]: AuthErrorCode.TOKEN_EXPIRED,\n  [ServerError.USER_NOT_FOUND]: AuthErrorCode.TOKEN_EXPIRED,\n\n  // Other errors.\n  [ServerError.TOO_MANY_ATTEMPTS_TRY_LATER]:\n    AuthErrorCode.TOO_MANY_ATTEMPTS_TRY_LATER,\n  [ServerError.PASSWORD_DOES_NOT_MEET_REQUIREMENTS]:\n    AuthErrorCode.PASSWORD_DOES_NOT_MEET_REQUIREMENTS,\n\n  // Phone Auth related errors.\n  [ServerError.INVALID_CODE]: AuthErrorCode.INVALID_CODE,\n  [ServerError.INVALID_SESSION_INFO]: AuthErrorCode.INVALID_SESSION_INFO,\n  [ServerError.INVALID_TEMPORARY_PROOF]: AuthErrorCode.INVALID_CREDENTIAL,\n  [ServerError.MISSING_SESSION_INFO]: AuthErrorCode.MISSING_SESSION_INFO,\n  [ServerError.SESSION_EXPIRED]: AuthErrorCode.CODE_EXPIRED,\n\n  // Other action code errors when additional settings passed.\n  // MISSING_CONTINUE_URI is getting mapped to INTERNAL_ERROR above.\n  // This is OK as this error will be caught by client side validation.\n  [ServerError.MISSING_ANDROID_PACKAGE_NAME]:\n    AuthErrorCode.MISSING_ANDROID_PACKAGE_NAME,\n  [ServerError.UNAUTHORIZED_DOMAIN]: AuthErrorCode.UNAUTHORIZED_DOMAIN,\n\n  // getProjectConfig errors when clientId is passed.\n  [ServerError.INVALID_OAUTH_CLIENT_ID]: AuthErrorCode.INVALID_OAUTH_CLIENT_ID,\n\n  // User actions (sign-up or deletion) disabled errors.\n  [ServerError.ADMIN_ONLY_OPERATION]: AuthErrorCode.ADMIN_ONLY_OPERATION,\n\n  // Multi factor related errors.\n  [ServerError.INVALID_MFA_PENDING_CREDENTIAL]:\n    AuthErrorCode.INVALID_MFA_SESSION,\n  [ServerError.MFA_ENROLLMENT_NOT_FOUND]: AuthErrorCode.MFA_INFO_NOT_FOUND,\n  [ServerError.MISSING_MFA_ENROLLMENT_ID]: AuthErrorCode.MISSING_MFA_INFO,\n  [ServerError.MISSING_MFA_PENDING_CREDENTIAL]:\n    AuthErrorCode.MISSING_MFA_SESSION,\n  [ServerError.SECOND_FACTOR_EXISTS]:\n    AuthErrorCode.SECOND_FACTOR_ALREADY_ENROLLED,\n  [ServerError.SECOND_FACTOR_LIMIT_EXCEEDED]:\n    AuthErrorCode.SECOND_FACTOR_LIMIT_EXCEEDED,\n\n  // Blocking functions related errors.\n  [ServerError.BLOCKING_FUNCTION_ERROR_RESPONSE]: AuthErrorCode.INTERNAL_ERROR,\n\n  // Recaptcha related errors.\n  [ServerError.RECAPTCHA_NOT_ENABLED]: AuthErrorCode.RECAPTCHA_NOT_ENABLED,\n  [ServerError.MISSING_RECAPTCHA_TOKEN]: AuthErrorCode.MISSING_RECAPTCHA_TOKEN,\n  [ServerError.INVALID_RECAPTCHA_TOKEN]: AuthErrorCode.INVALID_RECAPTCHA_TOKEN,\n  [ServerError.INVALID_RECAPTCHA_ACTION]:\n    AuthErrorCode.INVALID_RECAPTCHA_ACTION,\n  [ServerError.MISSING_CLIENT_TYPE]: AuthErrorCode.MISSING_CLIENT_TYPE,\n  [ServerError.MISSING_RECAPTCHA_VERSION]:\n    AuthErrorCode.MISSING_RECAPTCHA_VERSION,\n  [ServerError.INVALID_RECAPTCHA_VERSION]:\n    AuthErrorCode.INVALID_RECAPTCHA_VERSION,\n  [ServerError.INVALID_REQ_TYPE]: AuthErrorCode.INVALID_REQ_TYPE\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 { FirebaseError, isCloudflareWorker, querystring } from '@firebase/util';\n\nimport { AuthErrorCode, NamedErrorParams } from '../core/errors';\nimport {\n  _createError,\n  _errorWithCustomMessage,\n  _fail\n} from '../core/util/assert';\nimport { Delay } from '../core/util/delay';\nimport { _emulatorUrl } from '../core/util/emulator';\nimport { FetchProvider } from '../core/util/fetch_provider';\nimport { Auth } from '../model/public_types';\nimport { AuthInternal, ConfigInternal } from '../model/auth';\nimport { IdTokenResponse, TaggedWithTokenResponse } from '../model/id_token';\nimport { IdTokenMfaResponse } from './authentication/mfa';\nimport { SERVER_ERROR_MAP, ServerError, ServerErrorMap } from './errors';\n\nexport const enum HttpMethod {\n  POST = 'POST',\n  GET = 'GET'\n}\n\nexport const enum HttpHeader {\n  CONTENT_TYPE = 'Content-Type',\n  X_FIREBASE_LOCALE = 'X-Firebase-Locale',\n  X_CLIENT_VERSION = 'X-Client-Version',\n  X_FIREBASE_GMPID = 'X-Firebase-gmpid',\n  X_FIREBASE_CLIENT = 'X-Firebase-Client',\n  X_FIREBASE_APP_CHECK = 'X-Firebase-AppCheck'\n}\n\nexport const enum Endpoint {\n  CREATE_AUTH_URI = '/v1/accounts:createAuthUri',\n  DELETE_ACCOUNT = '/v1/accounts:delete',\n  RESET_PASSWORD = '/v1/accounts:resetPassword',\n  SIGN_UP = '/v1/accounts:signUp',\n  SIGN_IN_WITH_CUSTOM_TOKEN = '/v1/accounts:signInWithCustomToken',\n  SIGN_IN_WITH_EMAIL_LINK = '/v1/accounts:signInWithEmailLink',\n  SIGN_IN_WITH_IDP = '/v1/accounts:signInWithIdp',\n  SIGN_IN_WITH_PASSWORD = '/v1/accounts:signInWithPassword',\n  SIGN_IN_WITH_PHONE_NUMBER = '/v1/accounts:signInWithPhoneNumber',\n  SEND_VERIFICATION_CODE = '/v1/accounts:sendVerificationCode',\n  SEND_OOB_CODE = '/v1/accounts:sendOobCode',\n  SET_ACCOUNT_INFO = '/v1/accounts:update',\n  GET_ACCOUNT_INFO = '/v1/accounts:lookup',\n  GET_RECAPTCHA_PARAM = '/v1/recaptchaParams',\n  START_MFA_ENROLLMENT = '/v2/accounts/mfaEnrollment:start',\n  FINALIZE_MFA_ENROLLMENT = '/v2/accounts/mfaEnrollment:finalize',\n  START_MFA_SIGN_IN = '/v2/accounts/mfaSignIn:start',\n  FINALIZE_MFA_SIGN_IN = '/v2/accounts/mfaSignIn:finalize',\n  WITHDRAW_MFA = '/v2/accounts/mfaEnrollment:withdraw',\n  GET_PROJECT_CONFIG = '/v1/projects',\n  GET_RECAPTCHA_CONFIG = '/v2/recaptchaConfig',\n  GET_PASSWORD_POLICY = '/v2/passwordPolicy',\n  TOKEN = '/v1/token',\n  REVOKE_TOKEN = '/v2/accounts:revokeToken'\n}\n\nexport const enum RecaptchaClientType {\n  WEB = 'CLIENT_TYPE_WEB',\n  ANDROID = 'CLIENT_TYPE_ANDROID',\n  IOS = 'CLIENT_TYPE_IOS'\n}\n\nexport const enum RecaptchaVersion {\n  ENTERPRISE = 'RECAPTCHA_ENTERPRISE'\n}\n\nexport const enum RecaptchaActionName {\n  SIGN_IN_WITH_PASSWORD = 'signInWithPassword',\n  GET_OOB_CODE = 'getOobCode',\n  SIGN_UP_PASSWORD = 'signUpPassword',\n  SEND_VERIFICATION_CODE = 'sendVerificationCode',\n  MFA_SMS_ENROLLMENT = 'mfaSmsEnrollment',\n  MFA_SMS_SIGNIN = 'mfaSmsSignIn'\n}\n\nexport const enum EnforcementState {\n  ENFORCE = 'ENFORCE',\n  AUDIT = 'AUDIT',\n  OFF = 'OFF',\n  ENFORCEMENT_STATE_UNSPECIFIED = 'ENFORCEMENT_STATE_UNSPECIFIED'\n}\n\n// Providers that have reCAPTCHA Enterprise support.\nexport const enum RecaptchaAuthProvider {\n  EMAIL_PASSWORD_PROVIDER = 'EMAIL_PASSWORD_PROVIDER',\n  PHONE_PROVIDER = 'PHONE_PROVIDER'\n}\n\nexport const DEFAULT_API_TIMEOUT_MS = new Delay(30_000, 60_000);\n\nexport function _addTidIfNecessary<T extends { tenantId?: string }>(\n  auth: Auth,\n  request: T\n): T {\n  if (auth.tenantId && !request.tenantId) {\n    return {\n      ...request,\n      tenantId: auth.tenantId\n    };\n  }\n  return request;\n}\n\nexport async function _performApiRequest<T, V>(\n  auth: Auth,\n  method: HttpMethod,\n  path: Endpoint,\n  request?: T,\n  customErrorMap: Partial<ServerErrorMap<ServerError>> = {}\n): Promise<V> {\n  return _performFetchWithErrorHandling(auth, customErrorMap, async () => {\n    let body = {};\n    let params = {};\n    if (request) {\n      if (method === HttpMethod.GET) {\n        params = request;\n      } else {\n        body = {\n          body: JSON.stringify(request)\n        };\n      }\n    }\n\n    const query = querystring({\n      key: auth.config.apiKey,\n      ...params\n    }).slice(1);\n\n    const headers = await (auth as AuthInternal)._getAdditionalHeaders();\n    headers[HttpHeader.CONTENT_TYPE] = 'application/json';\n\n    if (auth.languageCode) {\n      headers[HttpHeader.X_FIREBASE_LOCALE] = auth.languageCode;\n    }\n\n    const fetchArgs: RequestInit = {\n      method,\n      headers,\n      ...body\n    };\n\n    /* Security-conscious server-side frameworks tend to have built in mitigations for referrer\n       problems\". See the Cloudflare GitHub issue #487: Error: The 'referrerPolicy' field on\n       'RequestInitializerDict' is not implemented.\"\n       https://github.com/cloudflare/next-on-pages/issues/487 */\n    if (!isCloudflareWorker()) {\n      fetchArgs.referrerPolicy = 'no-referrer';\n    }\n\n    return FetchProvider.fetch()(\n      _getFinalTarget(auth, auth.config.apiHost, path, query),\n      fetchArgs\n    );\n  });\n}\n\nexport async function _performFetchWithErrorHandling<V>(\n  auth: Auth,\n  customErrorMap: Partial<ServerErrorMap<ServerError>>,\n  fetchFn: () => Promise<Response>\n): Promise<V> {\n  (auth as AuthInternal)._canInitEmulator = false;\n  const errorMap = { ...SERVER_ERROR_MAP, ...customErrorMap };\n  try {\n    const networkTimeout = new NetworkTimeout<Response>(auth);\n    const response: Response = await Promise.race<Promise<Response>>([\n      fetchFn(),\n      networkTimeout.promise\n    ]);\n\n    // If we've reached this point, the fetch succeeded and the networkTimeout\n    // didn't throw; clear the network timeout delay so that Node won't hang\n    networkTimeout.clearNetworkTimeout();\n\n    const json = await response.json();\n    if ('needConfirmation' in json) {\n      throw _makeTaggedError(auth, AuthErrorCode.NEED_CONFIRMATION, json);\n    }\n\n    if (response.ok && !('errorMessage' in json)) {\n      return json;\n    } else {\n      const errorMessage = response.ok ? json.errorMessage : json.error.message;\n      const [serverErrorCode, serverErrorMessage] = errorMessage.split(' : ');\n      if (serverErrorCode === ServerError.FEDERATED_USER_ID_ALREADY_LINKED) {\n        throw _makeTaggedError(\n          auth,\n          AuthErrorCode.CREDENTIAL_ALREADY_IN_USE,\n          json\n        );\n      } else if (serverErrorCode === ServerError.EMAIL_EXISTS) {\n        throw _makeTaggedError(auth, AuthErrorCode.EMAIL_EXISTS, json);\n      } else if (serverErrorCode === ServerError.USER_DISABLED) {\n        throw _makeTaggedError(auth, AuthErrorCode.USER_DISABLED, json);\n      }\n      const authError =\n        errorMap[serverErrorCode as ServerError] ||\n        (serverErrorCode\n          .toLowerCase()\n          .replace(/[_\\s]+/g, '-') as unknown as AuthErrorCode);\n      if (serverErrorMessage) {\n        throw _errorWithCustomMessage(auth, authError, serverErrorMessage);\n      } else {\n        _fail(auth, authError);\n      }\n    }\n  } catch (e) {\n    if (e instanceof FirebaseError) {\n      throw e;\n    }\n    // Changing this to a different error code will log user out when there is a network error\n    // because we treat any error other than NETWORK_REQUEST_FAILED as token is invalid.\n    // https://github.com/firebase/firebase-js-sdk/blob/4fbc73610d70be4e0852e7de63a39cb7897e8546/packages/auth/src/core/auth/auth_impl.ts#L309-L316\n    _fail(auth, AuthErrorCode.NETWORK_REQUEST_FAILED, { 'message': String(e) });\n  }\n}\n\nexport async function _performSignInRequest<T, V extends IdTokenResponse>(\n  auth: Auth,\n  method: HttpMethod,\n  path: Endpoint,\n  request?: T,\n  customErrorMap: Partial<ServerErrorMap<ServerError>> = {}\n): Promise<V> {\n  const serverResponse = await _performApiRequest<T, V | IdTokenMfaResponse>(\n    auth,\n    method,\n    path,\n    request,\n    customErrorMap\n  );\n  if ('mfaPendingCredential' in serverResponse) {\n    _fail(auth, AuthErrorCode.MFA_REQUIRED, {\n      _serverResponse: serverResponse\n    });\n  }\n\n  return serverResponse as V;\n}\n\nexport function _getFinalTarget(\n  auth: Auth,\n  host: string,\n  path: string,\n  query: string\n): string {\n  const base = `${host}${path}?${query}`;\n\n  if (!(auth as AuthInternal).config.emulator) {\n    return `${auth.config.apiScheme}://${base}`;\n  }\n\n  return _emulatorUrl(auth.config as ConfigInternal, base);\n}\n\nexport function _parseEnforcementState(\n  enforcementStateStr: string\n): EnforcementState {\n  switch (enforcementStateStr) {\n    case 'ENFORCE':\n      return EnforcementState.ENFORCE;\n    case 'AUDIT':\n      return EnforcementState.AUDIT;\n    case 'OFF':\n      return EnforcementState.OFF;\n    default:\n      return EnforcementState.ENFORCEMENT_STATE_UNSPECIFIED;\n  }\n}\n\nclass NetworkTimeout<T> {\n  // Node timers and browser timers are fundamentally incompatible, but we\n  // don't care about the value here\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private timer: any | null = null;\n  readonly promise = new Promise<T>((_, reject) => {\n    this.timer = setTimeout(() => {\n      return reject(\n        _createError(this.auth, AuthErrorCode.NETWORK_REQUEST_FAILED)\n      );\n    }, DEFAULT_API_TIMEOUT_MS.get());\n  });\n\n  clearNetworkTimeout(): void {\n    clearTimeout(this.timer);\n  }\n\n  constructor(private readonly auth: Auth) {}\n}\n\ninterface PotentialResponse extends IdTokenResponse {\n  email?: string;\n  phoneNumber?: string;\n}\n\nexport function _makeTaggedError(\n  auth: Auth,\n  code: AuthErrorCode,\n  response: PotentialResponse\n): FirebaseError {\n  const errorParams: NamedErrorParams = {\n    appName: auth.name\n  };\n\n  if (response.email) {\n    errorParams.email = response.email;\n  }\n  if (response.phoneNumber) {\n    errorParams.phoneNumber = response.phoneNumber;\n  }\n\n  const error = _createError(auth, code, errorParams);\n\n  // We know customData is defined on error because errorParams is defined\n  (error.customData! as TaggedWithTokenResponse)._tokenResponse = response;\n  return error;\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 { RecaptchaParameters } from '../../model/public_types';\nimport {\n  GetRecaptchaConfigResponse,\n  RecaptchaEnforcementProviderState\n} from '../../api/authentication/recaptcha';\nimport {\n  EnforcementState,\n  RecaptchaAuthProvider,\n  _parseEnforcementState\n} from '../../api/index';\n\n// reCAPTCHA v2 interface\nexport interface Recaptcha {\n  render: (container: HTMLElement, parameters: RecaptchaParameters) => number;\n  getResponse: (id: number) => string;\n  execute: (id: number) => unknown;\n  reset: (id: number) => unknown;\n}\n\nexport function isV2(\n  grecaptcha: Recaptcha | GreCAPTCHA | undefined\n): grecaptcha is Recaptcha {\n  return (\n    grecaptcha !== undefined &&\n    (grecaptcha as Recaptcha).getResponse !== undefined\n  );\n}\n\n// reCAPTCHA Enterprise & v3 shared interface\nexport interface GreCAPTCHATopLevel extends GreCAPTCHA {\n  enterprise: GreCAPTCHA;\n}\n\n// reCAPTCHA Enterprise interface\nexport interface GreCAPTCHA {\n  ready: (callback: () => void) => void;\n  execute: (siteKey: string, options: { action: string }) => Promise<string>;\n  render: (\n    container: string | HTMLElement,\n    parameters: GreCAPTCHARenderOption\n  ) => string;\n}\n\nexport interface GreCAPTCHARenderOption {\n  sitekey: string;\n  size: 'invisible';\n}\n\nexport function isEnterprise(\n  grecaptcha: Recaptcha | GreCAPTCHA | undefined\n): grecaptcha is GreCAPTCHATopLevel {\n  return (\n    grecaptcha !== undefined &&\n    (grecaptcha as GreCAPTCHATopLevel).enterprise !== undefined\n  );\n}\n\n// TODO(chuanr): Replace this with the AuthWindow after resolving the dependency issue in Node.js env.\ndeclare global {\n  interface Window {\n    grecaptcha?: Recaptcha | GreCAPTCHATopLevel;\n  }\n}\n\nexport class RecaptchaConfig {\n  /**\n   * The reCAPTCHA site key.\n   */\n  siteKey: string = '';\n\n  /**\n   * The list of providers and their enablement status for reCAPTCHA Enterprise.\n   */\n  recaptchaEnforcementState: RecaptchaEnforcementProviderState[] = [];\n\n  constructor(response: GetRecaptchaConfigResponse) {\n    if (response.recaptchaKey === undefined) {\n      throw new Error('recaptchaKey undefined');\n    }\n    // Example response.recaptchaKey: \"projects/proj123/keys/sitekey123\"\n    this.siteKey = response.recaptchaKey.split('/')[3];\n    this.recaptchaEnforcementState = response.recaptchaEnforcementState;\n  }\n\n  /**\n   * Returns the reCAPTCHA Enterprise enforcement state for the given provider.\n   *\n   * @param providerStr - The provider whose enforcement state is to be returned.\n   * @returns The reCAPTCHA Enterprise enforcement state for the given provider.\n   */\n  getProviderEnforcementState(providerStr: string): EnforcementState | null {\n    if (\n      !this.recaptchaEnforcementState ||\n      this.recaptchaEnforcementState.length === 0\n    ) {\n      return null;\n    }\n\n    for (const recaptchaEnforcementState of this.recaptchaEnforcementState) {\n      if (\n        recaptchaEnforcementState.provider &&\n        recaptchaEnforcementState.provider === providerStr\n      ) {\n        return _parseEnforcementState(\n          recaptchaEnforcementState.enforcementState\n        );\n      }\n    }\n    return null;\n  }\n\n  /**\n   * Returns true if the reCAPTCHA Enterprise enforcement state for the provider is set to ENFORCE or AUDIT.\n   *\n   * @param providerStr - The provider whose enablement state is to be returned.\n   * @returns Whether or not reCAPTCHA Enterprise protection is enabled for the given provider.\n   */\n  isProviderEnabled(providerStr: string): boolean {\n    return (\n      this.getProviderEnforcementState(providerStr) ===\n        EnforcementState.ENFORCE ||\n      this.getProviderEnforcementState(providerStr) === EnforcementState.AUDIT\n    );\n  }\n\n  /**\n   * Returns true if reCAPTCHA Enterprise protection is enabled in at least one provider, otherwise\n   * returns false.\n   *\n   * @returns Whether or not reCAPTCHA Enterprise protection is enabled for at least one provider.\n   */\n  isAnyProviderEnabled(): boolean {\n    return (\n      this.isProviderEnabled(RecaptchaAuthProvider.EMAIL_PASSWORD_PROVIDER) ||\n      this.isProviderEnabled(RecaptchaAuthProvider.PHONE_PROVIDER)\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 {\n  Endpoint,\n  HttpMethod,\n  RecaptchaClientType,\n  RecaptchaVersion,\n  _performApiRequest,\n  _addTidIfNecessary\n} from '../index';\nimport { Auth } from '../../model/public_types';\n\ninterface GetRecaptchaParamResponse {\n  recaptchaSiteKey?: string;\n}\n\nexport async function getRecaptchaParams(auth: Auth): Promise<string> {\n  return (\n    (\n      await _performApiRequest<void, GetRecaptchaParamResponse>(\n        auth,\n        HttpMethod.GET,\n        Endpoint.GET_RECAPTCHA_PARAM\n      )\n    ).recaptchaSiteKey || ''\n  );\n}\n\n// The following functions are for reCAPTCHA enterprise integration.\ninterface GetRecaptchaConfigRequest {\n  tenantId?: string;\n  clientType?: RecaptchaClientType;\n  version?: RecaptchaVersion;\n}\n\nexport interface RecaptchaEnforcementProviderState {\n  provider: string;\n  enforcementState: string;\n}\n\nexport interface GetRecaptchaConfigResponse {\n  recaptchaKey: string;\n  recaptchaEnforcementState: RecaptchaEnforcementProviderState[];\n}\n\nexport async function getRecaptchaConfig(\n  auth: Auth,\n  request: GetRecaptchaConfigRequest\n): Promise<GetRecaptchaConfigResponse> {\n  return _performApiRequest<\n    GetRecaptchaConfigRequest,\n    GetRecaptchaConfigResponse\n  >(\n    auth,\n    HttpMethod.GET,\n    Endpoint.GET_RECAPTCHA_CONFIG,\n    _addTidIfNecessary(auth, request)\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 { Endpoint, HttpMethod, _performApiRequest } from '../index';\nimport { MfaEnrollment } from './mfa';\nimport { Auth } from '../../model/public_types';\n\nexport interface DeleteAccountRequest {\n  idToken: string;\n}\n\nexport async function deleteAccount(\n  auth: Auth,\n  request: DeleteAccountRequest\n): Promise<void> {\n  return _performApiRequest<DeleteAccountRequest, void>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.DELETE_ACCOUNT,\n    request\n  );\n}\n\nexport interface ProviderUserInfo {\n  providerId: string;\n  rawId?: string;\n  email?: string;\n  displayName?: string;\n  photoUrl?: string;\n  phoneNumber?: string;\n}\n\nexport interface DeleteLinkedAccountsRequest {\n  idToken: string;\n  deleteProvider: string[];\n}\n\nexport interface DeleteLinkedAccountsResponse {\n  providerUserInfo: ProviderUserInfo[];\n}\n\nexport async function deleteLinkedAccounts(\n  auth: Auth,\n  request: DeleteLinkedAccountsRequest\n): Promise<DeleteLinkedAccountsResponse> {\n  return _performApiRequest<\n    DeleteLinkedAccountsRequest,\n    DeleteLinkedAccountsResponse\n  >(auth, HttpMethod.POST, Endpoint.SET_ACCOUNT_INFO, request);\n}\n\nexport interface APIUserInfo {\n  localId?: string;\n  displayName?: string;\n  photoUrl?: string;\n  email?: string;\n  emailVerified?: boolean;\n  phoneNumber?: string;\n  lastLoginAt?: number;\n  createdAt?: number;\n  tenantId?: string;\n  passwordHash?: string;\n  providerUserInfo?: ProviderUserInfo[];\n  mfaInfo?: MfaEnrollment[];\n}\n\nexport interface GetAccountInfoRequest {\n  idToken: string;\n}\n\nexport interface GetAccountInfoResponse {\n  users: APIUserInfo[];\n}\n\nexport async function getAccountInfo(\n  auth: Auth,\n  request: GetAccountInfoRequest\n): Promise<GetAccountInfoResponse> {\n  return _performApiRequest<GetAccountInfoRequest, GetAccountInfoResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.GET_ACCOUNT_INFO,\n    request\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\nexport function utcTimestampToDateString(\n  utcTimestamp?: string | number\n): string | undefined {\n  if (!utcTimestamp) {\n    return undefined;\n  }\n  try {\n    // Convert to date object.\n    const date = new Date(Number(utcTimestamp));\n    // Test date is valid.\n    if (!isNaN(date.getTime())) {\n      // Convert to UTC date string.\n      return date.toUTCString();\n    }\n  } catch (e) {\n    // Do nothing. undefined will be returned.\n  }\n  return undefined;\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 { IdTokenResult, ParsedToken, User } from '../../model/public_types';\nimport { base64Decode, getModularInstance } from '@firebase/util';\n\nimport { UserInternal } from '../../model/user';\nimport { _assert } from '../util/assert';\nimport { _logError } from '../util/log';\nimport { utcTimestampToDateString } from '../util/time';\nimport { AuthErrorCode } from '../errors';\n\n/**\n * Returns a JSON Web Token (JWT) used to identify the user to a Firebase service.\n *\n * @remarks\n * Returns the current token if it has not expired or if it will not expire in the next five\n * minutes. Otherwise, this will refresh the token and return a new one.\n *\n * @param user - The user.\n * @param forceRefresh - Force refresh regardless of token expiration.\n *\n * @public\n */\nexport function getIdToken(user: User, forceRefresh = false): Promise<string> {\n  return getModularInstance(user).getIdToken(forceRefresh);\n}\n\n/**\n * Returns a deserialized JSON Web Token (JWT) used to identify the user to a Firebase service.\n *\n * @remarks\n * Returns the current token if it has not expired or if it will not expire in the next five\n * minutes. Otherwise, this will refresh the token and return a new one.\n *\n * @param user - The user.\n * @param forceRefresh - Force refresh regardless of token expiration.\n *\n * @public\n */\nexport async function getIdTokenResult(\n  user: User,\n  forceRefresh = false\n): Promise<IdTokenResult> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  const token = await userInternal.getIdToken(forceRefresh);\n  const claims = _parseToken(token);\n\n  _assert(\n    claims && claims.exp && claims.auth_time && claims.iat,\n    userInternal.auth,\n    AuthErrorCode.INTERNAL_ERROR\n  );\n  const firebase =\n    typeof claims.firebase === 'object' ? claims.firebase : undefined;\n\n  const signInProvider: string | undefined = firebase?.['sign_in_provider'];\n\n  return {\n    claims,\n    token,\n    authTime: utcTimestampToDateString(\n      secondsStringToMilliseconds(claims.auth_time)\n    )!,\n    issuedAtTime: utcTimestampToDateString(\n      secondsStringToMilliseconds(claims.iat)\n    )!,\n    expirationTime: utcTimestampToDateString(\n      secondsStringToMilliseconds(claims.exp)\n    )!,\n    signInProvider: signInProvider || null,\n    signInSecondFactor: firebase?.['sign_in_second_factor'] || null\n  };\n}\n\nfunction secondsStringToMilliseconds(seconds: string): number {\n  return Number(seconds) * 1000;\n}\n\nexport function _parseToken(token: string): ParsedToken | null {\n  const [algorithm, payload, signature] = token.split('.');\n  if (\n    algorithm === undefined ||\n    payload === undefined ||\n    signature === undefined\n  ) {\n    _logError('JWT malformed, contained fewer than 3 sections');\n    return null;\n  }\n\n  try {\n    const decoded = base64Decode(payload);\n    if (!decoded) {\n      _logError('Failed to decode base64 JWT payload');\n      return null;\n    }\n    return JSON.parse(decoded);\n  } catch (e) {\n    _logError(\n      'Caught error parsing JWT payload as JSON',\n      (e as Error)?.toString()\n    );\n    return null;\n  }\n}\n\n/**\n * Extract expiresIn TTL from a token by subtracting the expiration from the issuance.\n */\nexport function _tokenExpiresIn(token: string): number {\n  const parsedToken = _parseToken(token);\n  _assert(parsedToken, AuthErrorCode.INTERNAL_ERROR);\n  _assert(typeof parsedToken.exp !== 'undefined', AuthErrorCode.INTERNAL_ERROR);\n  _assert(typeof parsedToken.iat !== 'undefined', AuthErrorCode.INTERNAL_ERROR);\n  return Number(parsedToken.exp) - Number(parsedToken.iat);\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 { FirebaseError } from '@firebase/util';\n\nimport { UserInternal } from '../../model/user';\nimport { AuthErrorCode } from '../errors';\n\nexport async function _logoutIfInvalidated<T>(\n  user: UserInternal,\n  promise: Promise<T>,\n  bypassAuthState = false\n): Promise<T> {\n  if (bypassAuthState) {\n    return promise;\n  }\n  try {\n    return await promise;\n  } catch (e) {\n    if (e instanceof FirebaseError && isUserInvalidated(e)) {\n      if (user.auth.currentUser === user) {\n        await user.auth.signOut();\n      }\n    }\n\n    throw e;\n  }\n}\n\nfunction isUserInvalidated({ code }: FirebaseError): boolean {\n  return (\n    code === `auth/${AuthErrorCode.USER_DISABLED}` ||\n    code === `auth/${AuthErrorCode.TOKEN_EXPIRED}`\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 { FirebaseError } from '@firebase/util';\nimport { UserInternal } from '../../model/user';\nimport { AuthErrorCode } from '../errors';\n\n// Refresh the token five minutes before expiration\nexport const enum Duration {\n  OFFSET = 5 * 1000 * 60,\n  RETRY_BACKOFF_MIN = 30 * 1000,\n  RETRY_BACKOFF_MAX = 16 * 60 * 1000\n}\n\nexport class ProactiveRefresh {\n  private isRunning = false;\n\n  // Node timers and browser timers return fundamentally different types.\n  // We don't actually care what the value is but TS won't accept unknown and\n  // we can't cast properly in both environments.\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private timerId: any | null = null;\n  private errorBackoff = Duration.RETRY_BACKOFF_MIN;\n\n  constructor(private readonly user: UserInternal) {}\n\n  _start(): void {\n    if (this.isRunning) {\n      return;\n    }\n\n    this.isRunning = true;\n    this.schedule();\n  }\n\n  _stop(): void {\n    if (!this.isRunning) {\n      return;\n    }\n\n    this.isRunning = false;\n    if (this.timerId !== null) {\n      clearTimeout(this.timerId);\n    }\n  }\n\n  private getInterval(wasError: boolean): number {\n    if (wasError) {\n      const interval = this.errorBackoff;\n      this.errorBackoff = Math.min(\n        this.errorBackoff * 2,\n        Duration.RETRY_BACKOFF_MAX\n      );\n      return interval;\n    } else {\n      // Reset the error backoff\n      this.errorBackoff = Duration.RETRY_BACKOFF_MIN;\n      const expTime = this.user.stsTokenManager.expirationTime ?? 0;\n      const interval = expTime - Date.now() - Duration.OFFSET;\n\n      return Math.max(0, interval);\n    }\n  }\n\n  private schedule(wasError = false): void {\n    if (!this.isRunning) {\n      // Just in case...\n      return;\n    }\n\n    const interval = this.getInterval(wasError);\n    this.timerId = setTimeout(async () => {\n      await this.iteration();\n    }, interval);\n  }\n\n  private async iteration(): Promise<void> {\n    try {\n      await this.user.getIdToken(true);\n    } catch (e) {\n      // Only retry on network errors\n      if (\n        (e as FirebaseError)?.code ===\n        `auth/${AuthErrorCode.NETWORK_REQUEST_FAILED}`\n      ) {\n        this.schedule(/* wasError */ true);\n      }\n\n      return;\n    }\n    this.schedule();\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 { UserMetadata as UserMetadataType } from '../../model/public_types';\n\nimport { utcTimestampToDateString } from '../util/time';\n\nexport class UserMetadata implements UserMetadataType {\n  creationTime?: string;\n  lastSignInTime?: string;\n\n  constructor(\n    private createdAt?: string | number,\n    private lastLoginAt?: string | number\n  ) {\n    this._initializeTime();\n  }\n\n  private _initializeTime(): void {\n    this.lastSignInTime = utcTimestampToDateString(this.lastLoginAt);\n    this.creationTime = utcTimestampToDateString(this.createdAt);\n  }\n\n  _copy(metadata: UserMetadata): void {\n    this.createdAt = metadata.createdAt;\n    this.lastLoginAt = metadata.lastLoginAt;\n    this._initializeTime();\n  }\n\n  toJSON(): object {\n    return {\n      createdAt: this.createdAt,\n      lastLoginAt: this.lastLoginAt\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 { User, UserInfo } from '../../model/public_types';\n\nimport {\n  getAccountInfo,\n  ProviderUserInfo\n} from '../../api/account_management/account';\nimport { UserInternal } from '../../model/user';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from '../util/assert';\nimport { _logoutIfInvalidated } from './invalidation';\nimport { UserMetadata } from './user_metadata';\nimport { getModularInstance } from '@firebase/util';\n\nexport async function _reloadWithoutSaving(user: UserInternal): Promise<void> {\n  const auth = user.auth;\n  const idToken = await user.getIdToken();\n  const response = await _logoutIfInvalidated(\n    user,\n    getAccountInfo(auth, { idToken })\n  );\n\n  _assert(response?.users.length, auth, AuthErrorCode.INTERNAL_ERROR);\n\n  const coreAccount = response.users[0];\n\n  user._notifyReloadListener(coreAccount);\n\n  const newProviderData = coreAccount.providerUserInfo?.length\n    ? extractProviderData(coreAccount.providerUserInfo)\n    : [];\n\n  const providerData = mergeProviderData(user.providerData, newProviderData);\n\n  // Preserves the non-nonymous status of the stored user, even if no more\n  // credentials (federated or email/password) are linked to the user. If\n  // the user was previously anonymous, then use provider data to update.\n  // On the other hand, if it was not anonymous before, it should never be\n  // considered anonymous now.\n  const oldIsAnonymous = user.isAnonymous;\n  const newIsAnonymous =\n    !(user.email && coreAccount.passwordHash) && !providerData?.length;\n  const isAnonymous = !oldIsAnonymous ? false : newIsAnonymous;\n\n  const updates: Partial<UserInternal> = {\n    uid: coreAccount.localId,\n    displayName: coreAccount.displayName || null,\n    photoURL: coreAccount.photoUrl || null,\n    email: coreAccount.email || null,\n    emailVerified: coreAccount.emailVerified || false,\n    phoneNumber: coreAccount.phoneNumber || null,\n    tenantId: coreAccount.tenantId || null,\n    providerData,\n    metadata: new UserMetadata(coreAccount.createdAt, coreAccount.lastLoginAt),\n    isAnonymous\n  };\n\n  Object.assign(user, updates);\n}\n\n/**\n * Reloads user account data, if signed in.\n *\n * @param user - The user.\n *\n * @public\n */\nexport async function reload(user: User): Promise<void> {\n  const userInternal: UserInternal = getModularInstance(user) as UserInternal;\n  await _reloadWithoutSaving(userInternal);\n\n  // Even though the current user hasn't changed, update\n  // current user will trigger a persistence update w/ the\n  // new info.\n  await userInternal.auth._persistUserIfCurrent(userInternal);\n  userInternal.auth._notifyListenersIfCurrent(userInternal);\n}\n\nfunction mergeProviderData(\n  original: UserInfo[],\n  newData: UserInfo[]\n): UserInfo[] {\n  const deduped = original.filter(\n    o => !newData.some(n => n.providerId === o.providerId)\n  );\n  return [...deduped, ...newData];\n}\n\nexport function extractProviderData(providers: ProviderUserInfo[]): UserInfo[] {\n  return providers.map(({ providerId, ...provider }) => {\n    return {\n      providerId,\n      uid: provider.rawId || '',\n      displayName: provider.displayName || null,\n      email: provider.email || null,\n      phoneNumber: provider.phoneNumber || null,\n      photoURL: provider.photoUrl || null\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 { FinalizeMfaResponse } from '../../api/authentication/mfa';\nimport { requestStsToken } from '../../api/authentication/token';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { AuthErrorCode } from '../errors';\nimport { PersistedBlob } from '../persistence';\nimport { _assert, debugFail } from '../util/assert';\nimport { _tokenExpiresIn } from './id_token_result';\n\n/**\n * The number of milliseconds before the official expiration time of a token\n * to refresh that token, to provide a buffer for RPCs to complete.\n */\nexport const enum Buffer {\n  TOKEN_REFRESH = 30_000\n}\n\n/**\n * We need to mark this class as internal explicitly to exclude it in the public typings, because\n * it references AuthInternal which has a circular dependency with UserInternal.\n *\n * @internal\n */\nexport class StsTokenManager {\n  refreshToken: string | null = null;\n  accessToken: string | null = null;\n  expirationTime: number | null = null;\n\n  get isExpired(): boolean {\n    return (\n      !this.expirationTime ||\n      Date.now() > this.expirationTime - Buffer.TOKEN_REFRESH\n    );\n  }\n\n  updateFromServerResponse(\n    response: IdTokenResponse | FinalizeMfaResponse\n  ): void {\n    _assert(response.idToken, AuthErrorCode.INTERNAL_ERROR);\n    _assert(\n      typeof response.idToken !== 'undefined',\n      AuthErrorCode.INTERNAL_ERROR\n    );\n    _assert(\n      typeof response.refreshToken !== 'undefined',\n      AuthErrorCode.INTERNAL_ERROR\n    );\n    const expiresIn =\n      'expiresIn' in response && typeof response.expiresIn !== 'undefined'\n        ? Number(response.expiresIn)\n        : _tokenExpiresIn(response.idToken);\n    this.updateTokensAndExpiration(\n      response.idToken,\n      response.refreshToken,\n      expiresIn\n    );\n  }\n\n  updateFromIdToken(idToken: string): void {\n    _assert(idToken.length !== 0, AuthErrorCode.INTERNAL_ERROR);\n    const expiresIn = _tokenExpiresIn(idToken);\n    this.updateTokensAndExpiration(idToken, null, expiresIn);\n  }\n\n  async getToken(\n    auth: AuthInternal,\n    forceRefresh = false\n  ): Promise<string | null> {\n    if (!forceRefresh && this.accessToken && !this.isExpired) {\n      return this.accessToken;\n    }\n\n    _assert(this.refreshToken, auth, AuthErrorCode.TOKEN_EXPIRED);\n\n    if (this.refreshToken) {\n      await this.refresh(auth, this.refreshToken!);\n      return this.accessToken;\n    }\n\n    return null;\n  }\n\n  clearRefreshToken(): void {\n    this.refreshToken = null;\n  }\n\n  private async refresh(auth: AuthInternal, oldToken: string): Promise<void> {\n    const { accessToken, refreshToken, expiresIn } = await requestStsToken(\n      auth,\n      oldToken\n    );\n    this.updateTokensAndExpiration(\n      accessToken,\n      refreshToken,\n      Number(expiresIn)\n    );\n  }\n\n  private updateTokensAndExpiration(\n    accessToken: string,\n    refreshToken: string | null,\n    expiresInSec: number\n  ): void {\n    this.refreshToken = refreshToken || null;\n    this.accessToken = accessToken || null;\n    this.expirationTime = Date.now() + expiresInSec * 1000;\n  }\n\n  static fromJSON(appName: string, object: PersistedBlob): StsTokenManager {\n    const { refreshToken, accessToken, expirationTime } = object;\n\n    const manager = new StsTokenManager();\n    if (refreshToken) {\n      _assert(typeof refreshToken === 'string', AuthErrorCode.INTERNAL_ERROR, {\n        appName\n      });\n      manager.refreshToken = refreshToken;\n    }\n    if (accessToken) {\n      _assert(typeof accessToken === 'string', AuthErrorCode.INTERNAL_ERROR, {\n        appName\n      });\n      manager.accessToken = accessToken;\n    }\n    if (expirationTime) {\n      _assert(\n        typeof expirationTime === 'number',\n        AuthErrorCode.INTERNAL_ERROR,\n        {\n          appName\n        }\n      );\n      manager.expirationTime = expirationTime;\n    }\n    return manager;\n  }\n\n  toJSON(): object {\n    return {\n      refreshToken: this.refreshToken,\n      accessToken: this.accessToken,\n      expirationTime: this.expirationTime\n    };\n  }\n\n  _assign(stsTokenManager: StsTokenManager): void {\n    this.accessToken = stsTokenManager.accessToken;\n    this.refreshToken = stsTokenManager.refreshToken;\n    this.expirationTime = stsTokenManager.expirationTime;\n  }\n\n  _clone(): StsTokenManager {\n    return Object.assign(new StsTokenManager(), this.toJSON());\n  }\n\n  _performRefresh(): never {\n    return debugFail('not implemented');\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/* eslint-disable camelcase */\n\nimport { querystring } from '@firebase/util';\n\nimport {\n  _getFinalTarget,\n  _performFetchWithErrorHandling,\n  _performApiRequest,\n  _addTidIfNecessary,\n  HttpMethod,\n  HttpHeader,\n  Endpoint\n} from '../index';\nimport { FetchProvider } from '../../core/util/fetch_provider';\nimport { Auth } from '../../model/public_types';\nimport { AuthInternal } from '../../model/auth';\n\nexport const enum TokenType {\n  REFRESH_TOKEN = 'REFRESH_TOKEN',\n  ACCESS_TOKEN = 'ACCESS_TOKEN'\n}\n\n/** The server responses with snake_case; we convert to camelCase */\ninterface RequestStsTokenServerResponse {\n  access_token: string;\n  expires_in: string;\n  refresh_token: string;\n}\n\nexport interface RequestStsTokenResponse {\n  accessToken: string;\n  expiresIn: string;\n  refreshToken: string;\n}\n\nexport interface RevokeTokenRequest {\n  providerId: string;\n  tokenType: TokenType;\n  token: string;\n  idToken: string;\n  tenantId?: string;\n}\n\nexport interface RevokeTokenResponse {}\n\nexport async function requestStsToken(\n  auth: Auth,\n  refreshToken: string\n): Promise<RequestStsTokenResponse> {\n  const response =\n    await _performFetchWithErrorHandling<RequestStsTokenServerResponse>(\n      auth,\n      {},\n      async () => {\n        const body = querystring({\n          'grant_type': 'refresh_token',\n          'refresh_token': refreshToken\n        }).slice(1);\n        const { tokenApiHost, apiKey } = auth.config;\n        const url = _getFinalTarget(\n          auth,\n          tokenApiHost,\n          Endpoint.TOKEN,\n          `key=${apiKey}`\n        );\n\n        const headers = await (auth as AuthInternal)._getAdditionalHeaders();\n        headers[HttpHeader.CONTENT_TYPE] = 'application/x-www-form-urlencoded';\n\n        return FetchProvider.fetch()(url, {\n          method: HttpMethod.POST,\n          headers,\n          body\n        });\n      }\n    );\n\n  // The response comes back in snake_case. Convert to camel:\n  return {\n    accessToken: response.access_token,\n    expiresIn: response.expires_in,\n    refreshToken: response.refresh_token\n  };\n}\n\nexport async function revokeToken(\n  auth: Auth,\n  request: RevokeTokenRequest\n): Promise<RevokeTokenResponse> {\n  return _performApiRequest<RevokeTokenRequest, RevokeTokenResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.REVOKE_TOKEN,\n    _addTidIfNecessary(auth, request)\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 { IdTokenResult, UserInfo } from '../../model/public_types';\nimport { NextFn } from '@firebase/util';\nimport {\n  APIUserInfo,\n  GetAccountInfoResponse,\n  deleteAccount\n} from '../../api/account_management/account';\nimport { FinalizeMfaResponse } from '../../api/authentication/mfa';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport {\n  MutableUserInfo,\n  UserInternal,\n  UserParameters\n} from '../../model/user';\nimport { AuthErrorCode } from '../errors';\nimport { PersistedBlob } from '../persistence';\nimport {\n  _assert,\n  _serverAppCurrentUserOperationNotSupportedError\n} from '../util/assert';\nimport { getIdTokenResult } from './id_token_result';\nimport { _logoutIfInvalidated } from './invalidation';\nimport { ProactiveRefresh } from './proactive_refresh';\nimport { extractProviderData, _reloadWithoutSaving, reload } from './reload';\nimport { StsTokenManager } from './token_manager';\nimport { UserMetadata } from './user_metadata';\nimport { ProviderId } from '../../model/enums';\nimport { _isFirebaseServerApp } from '@firebase/app';\n\nfunction assertStringOrUndefined(\n  assertion: unknown,\n  appName: string\n): asserts assertion is string | undefined {\n  _assert(\n    typeof assertion === 'string' || typeof assertion === 'undefined',\n    AuthErrorCode.INTERNAL_ERROR,\n    { appName }\n  );\n}\n\nexport class UserImpl implements UserInternal {\n  // For the user object, provider is always Firebase.\n  readonly providerId = ProviderId.FIREBASE;\n  stsTokenManager: StsTokenManager;\n  // Last known accessToken so we know when it changes\n  private accessToken: string | null;\n\n  uid: string;\n  auth: AuthInternal;\n  emailVerified: boolean;\n  isAnonymous: boolean;\n  tenantId: string | null;\n  readonly metadata: UserMetadata;\n  providerData: MutableUserInfo[];\n\n  // Optional fields from UserInfo\n  displayName: string | null;\n  email: string | null;\n  phoneNumber: string | null;\n  photoURL: string | null;\n\n  _redirectEventId?: string;\n  private readonly proactiveRefresh = new ProactiveRefresh(this);\n\n  constructor({ uid, auth, stsTokenManager, ...opt }: UserParameters) {\n    this.uid = uid;\n    this.auth = auth;\n    this.stsTokenManager = stsTokenManager;\n    this.accessToken = stsTokenManager.accessToken;\n    this.displayName = opt.displayName || null;\n    this.email = opt.email || null;\n    this.emailVerified = opt.emailVerified || false;\n    this.phoneNumber = opt.phoneNumber || null;\n    this.photoURL = opt.photoURL || null;\n    this.isAnonymous = opt.isAnonymous || false;\n    this.tenantId = opt.tenantId || null;\n    this.providerData = opt.providerData ? [...opt.providerData] : [];\n    this.metadata = new UserMetadata(\n      opt.createdAt || undefined,\n      opt.lastLoginAt || undefined\n    );\n  }\n\n  async getIdToken(forceRefresh?: boolean): Promise<string> {\n    const accessToken = await _logoutIfInvalidated(\n      this,\n      this.stsTokenManager.getToken(this.auth, forceRefresh)\n    );\n    _assert(accessToken, this.auth, AuthErrorCode.INTERNAL_ERROR);\n\n    if (this.accessToken !== accessToken) {\n      this.accessToken = accessToken;\n      await this.auth._persistUserIfCurrent(this);\n      this.auth._notifyListenersIfCurrent(this);\n    }\n\n    return accessToken;\n  }\n\n  getIdTokenResult(forceRefresh?: boolean): Promise<IdTokenResult> {\n    return getIdTokenResult(this, forceRefresh);\n  }\n\n  reload(): Promise<void> {\n    return reload(this);\n  }\n\n  private reloadUserInfo: APIUserInfo | null = null;\n  private reloadListener: NextFn<APIUserInfo> | null = null;\n\n  _assign(user: UserInternal): void {\n    if (this === user) {\n      return;\n    }\n    _assert(this.uid === user.uid, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    this.displayName = user.displayName;\n    this.photoURL = user.photoURL;\n    this.email = user.email;\n    this.emailVerified = user.emailVerified;\n    this.phoneNumber = user.phoneNumber;\n    this.isAnonymous = user.isAnonymous;\n    this.tenantId = user.tenantId;\n    this.providerData = user.providerData.map(userInfo => ({ ...userInfo }));\n    this.metadata._copy(user.metadata);\n    this.stsTokenManager._assign(user.stsTokenManager);\n  }\n\n  _clone(auth: AuthInternal): UserInternal {\n    const newUser = new UserImpl({\n      ...this,\n      auth,\n      stsTokenManager: this.stsTokenManager._clone()\n    });\n    newUser.metadata._copy(this.metadata);\n    return newUser;\n  }\n\n  _onReload(callback: NextFn<APIUserInfo>): void {\n    // There should only ever be one listener, and that is a single instance of MultiFactorUser\n    _assert(!this.reloadListener, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    this.reloadListener = callback;\n    if (this.reloadUserInfo) {\n      this._notifyReloadListener(this.reloadUserInfo);\n      this.reloadUserInfo = null;\n    }\n  }\n\n  _notifyReloadListener(userInfo: APIUserInfo): void {\n    if (this.reloadListener) {\n      this.reloadListener(userInfo);\n    } else {\n      // If no listener is subscribed yet, save the result so it's available when they do subscribe\n      this.reloadUserInfo = userInfo;\n    }\n  }\n\n  _startProactiveRefresh(): void {\n    this.proactiveRefresh._start();\n  }\n\n  _stopProactiveRefresh(): void {\n    this.proactiveRefresh._stop();\n  }\n\n  async _updateTokensIfNecessary(\n    response: IdTokenResponse | FinalizeMfaResponse,\n    reload = false\n  ): Promise<void> {\n    let tokensRefreshed = false;\n    if (\n      response.idToken &&\n      response.idToken !== this.stsTokenManager.accessToken\n    ) {\n      this.stsTokenManager.updateFromServerResponse(response);\n      tokensRefreshed = true;\n    }\n\n    if (reload) {\n      await _reloadWithoutSaving(this);\n    }\n\n    await this.auth._persistUserIfCurrent(this);\n    if (tokensRefreshed) {\n      this.auth._notifyListenersIfCurrent(this);\n    }\n  }\n\n  async delete(): Promise<void> {\n    if (_isFirebaseServerApp(this.auth.app)) {\n      return Promise.reject(\n        _serverAppCurrentUserOperationNotSupportedError(this.auth)\n      );\n    }\n    const idToken = await this.getIdToken();\n    await _logoutIfInvalidated(this, deleteAccount(this.auth, { idToken }));\n    this.stsTokenManager.clearRefreshToken();\n\n    // TODO: Determine if cancellable-promises are necessary to use in this class so that delete()\n    //       cancels pending actions...\n\n    return this.auth.signOut();\n  }\n\n  toJSON(): PersistedBlob {\n    return {\n      uid: this.uid,\n      email: this.email || undefined,\n      emailVerified: this.emailVerified,\n      displayName: this.displayName || undefined,\n      isAnonymous: this.isAnonymous,\n      photoURL: this.photoURL || undefined,\n      phoneNumber: this.phoneNumber || undefined,\n      tenantId: this.tenantId || undefined,\n      providerData: this.providerData.map(userInfo => ({ ...userInfo })),\n      stsTokenManager: this.stsTokenManager.toJSON(),\n      // Redirect event ID must be maintained in case there is a pending\n      // redirect event.\n      _redirectEventId: this._redirectEventId,\n      ...this.metadata.toJSON(),\n\n      // Required for compatibility with the legacy SDK (go/firebase-auth-sdk-persistence-parsing):\n      apiKey: this.auth.config.apiKey,\n      appName: this.auth.name\n      // Missing authDomain will be tolerated by the legacy SDK.\n      // stsTokenManager.apiKey isn't actually required (despite the legacy SDK persisting it).\n    };\n  }\n\n  get refreshToken(): string {\n    return this.stsTokenManager.refreshToken || '';\n  }\n\n  static _fromJSON(auth: AuthInternal, object: PersistedBlob): UserInternal {\n    const displayName = object.displayName ?? undefined;\n    const email = object.email ?? undefined;\n    const phoneNumber = object.phoneNumber ?? undefined;\n    const photoURL = object.photoURL ?? undefined;\n    const tenantId = object.tenantId ?? undefined;\n    const _redirectEventId = object._redirectEventId ?? undefined;\n    const createdAt = object.createdAt ?? undefined;\n    const lastLoginAt = object.lastLoginAt ?? undefined;\n    const {\n      uid,\n      emailVerified,\n      isAnonymous,\n      providerData,\n      stsTokenManager: plainObjectTokenManager\n    } = object;\n\n    _assert(uid && plainObjectTokenManager, auth, AuthErrorCode.INTERNAL_ERROR);\n\n    const stsTokenManager = StsTokenManager.fromJSON(\n      this.name,\n      plainObjectTokenManager as PersistedBlob\n    );\n\n    _assert(typeof uid === 'string', auth, AuthErrorCode.INTERNAL_ERROR);\n    assertStringOrUndefined(displayName, auth.name);\n    assertStringOrUndefined(email, auth.name);\n    _assert(\n      typeof emailVerified === 'boolean',\n      auth,\n      AuthErrorCode.INTERNAL_ERROR\n    );\n    _assert(\n      typeof isAnonymous === 'boolean',\n      auth,\n      AuthErrorCode.INTERNAL_ERROR\n    );\n    assertStringOrUndefined(phoneNumber, auth.name);\n    assertStringOrUndefined(photoURL, auth.name);\n    assertStringOrUndefined(tenantId, auth.name);\n    assertStringOrUndefined(_redirectEventId, auth.name);\n    assertStringOrUndefined(createdAt, auth.name);\n    assertStringOrUndefined(lastLoginAt, auth.name);\n    const user = new UserImpl({\n      uid,\n      auth,\n      email,\n      emailVerified,\n      displayName,\n      isAnonymous,\n      photoURL,\n      phoneNumber,\n      tenantId,\n      stsTokenManager,\n      createdAt,\n      lastLoginAt\n    });\n\n    if (providerData && Array.isArray(providerData)) {\n      user.providerData = providerData.map(userInfo => ({ ...userInfo }));\n    }\n\n    if (_redirectEventId) {\n      user._redirectEventId = _redirectEventId;\n    }\n\n    return user;\n  }\n\n  /**\n   * Initialize a User from an idToken server response\n   * @param auth\n   * @param idTokenResponse\n   */\n  static async _fromIdTokenResponse(\n    auth: AuthInternal,\n    idTokenResponse: IdTokenResponse,\n    isAnonymous: boolean = false\n  ): Promise<UserInternal> {\n    const stsTokenManager = new StsTokenManager();\n    stsTokenManager.updateFromServerResponse(idTokenResponse);\n\n    // Initialize the Firebase Auth user.\n    const user = new UserImpl({\n      uid: idTokenResponse.localId,\n      auth,\n      stsTokenManager,\n      isAnonymous\n    });\n\n    // Updates the user info and data and resolves with a user instance.\n    await _reloadWithoutSaving(user);\n    return user;\n  }\n\n  /**\n   * Initialize a User from an idToken server response\n   * @param auth\n   * @param idTokenResponse\n   */\n  static async _fromGetAccountInfoResponse(\n    auth: AuthInternal,\n    response: GetAccountInfoResponse,\n    idToken: string\n  ): Promise<UserInternal> {\n    const coreAccount = response.users[0];\n    _assert(coreAccount.localId !== undefined, AuthErrorCode.INTERNAL_ERROR);\n\n    const providerData: UserInfo[] =\n      coreAccount.providerUserInfo !== undefined\n        ? extractProviderData(coreAccount.providerUserInfo)\n        : [];\n\n    const isAnonymous =\n      !(coreAccount.email && coreAccount.passwordHash) && !providerData?.length;\n\n    const stsTokenManager = new StsTokenManager();\n    stsTokenManager.updateFromIdToken(idToken);\n\n    // Initialize the Firebase Auth user.\n    const user = new UserImpl({\n      uid: coreAccount.localId,\n      auth,\n      stsTokenManager,\n      isAnonymous\n    });\n\n    // update the user with data from the GetAccountInfo response.\n    const updates: Partial<UserInternal> = {\n      uid: coreAccount.localId,\n      displayName: coreAccount.displayName || null,\n      photoURL: coreAccount.photoUrl || null,\n      email: coreAccount.email || null,\n      emailVerified: coreAccount.emailVerified || false,\n      phoneNumber: coreAccount.phoneNumber || null,\n      tenantId: coreAccount.tenantId || null,\n      providerData,\n      metadata: new UserMetadata(\n        coreAccount.createdAt,\n        coreAccount.lastLoginAt\n      ),\n      isAnonymous:\n        !(coreAccount.email && coreAccount.passwordHash) &&\n        !providerData?.length\n    };\n\n    Object.assign(user, updates);\n    return user;\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 { debugAssert } from './assert';\n\n/**\n * Our API has a lot of one-off constants that are used to do things.\n * Unfortunately we can't export these as classes instantiated directly since\n * the constructor may side effect and therefore can't be proven to be safely\n * culled. Instead, we export these classes themselves as a lowerCamelCase\n * constant, and instantiate them under the hood.\n */\nexport interface SingletonInstantiator<T> {\n  new (): T;\n}\n\nconst instanceCache: Map<unknown, unknown> = new Map();\n\nexport function _getInstance<T>(cls: unknown): T {\n  debugAssert(cls instanceof Function, 'Expected a class definition');\n  let instance = instanceCache.get(cls) as T | undefined;\n\n  if (instance) {\n    debugAssert(\n      instance instanceof cls,\n      'Instance stored in cache mismatched with class'\n    );\n    return instance;\n  }\n\n  instance = new (cls as SingletonInstantiator<T>)();\n  instanceCache.set(cls, instance);\n  return instance;\n}\n\nexport function _clearInstanceMap(): void {\n  instanceCache.clear();\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 { Persistence } from '../../model/public_types';\n\nimport {\n  PersistenceInternal,\n  PersistenceType,\n  PersistenceValue,\n  StorageEventListener\n} from '../persistence';\n\nexport class InMemoryPersistence implements PersistenceInternal {\n  static type: 'NONE' = 'NONE';\n  readonly type = PersistenceType.NONE;\n  storage: Record<string, PersistenceValue> = {};\n\n  async _isAvailable(): Promise<boolean> {\n    return true;\n  }\n\n  async _set(key: string, value: PersistenceValue): Promise<void> {\n    this.storage[key] = value;\n  }\n\n  async _get<T extends PersistenceValue>(key: string): Promise<T | null> {\n    const value = this.storage[key];\n    return value === undefined ? null : (value as T);\n  }\n\n  async _remove(key: string): Promise<void> {\n    delete this.storage[key];\n  }\n\n  _addListener(_key: string, _listener: StorageEventListener): void {\n    // Listeners are not supported for in-memory storage since it cannot be shared across windows/workers\n    return;\n  }\n\n  _removeListener(_key: string, _listener: StorageEventListener): void {\n    // Listeners are not supported for in-memory storage since it cannot be shared across windows/workers\n    return;\n  }\n}\n\n/**\n * An implementation of {@link Persistence} of type 'NONE'.\n *\n * @public\n */\nexport const inMemoryPersistence: Persistence = InMemoryPersistence;\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 { ApiKey, AppName, AuthInternal } from '../../model/auth';\nimport { UserInternal } from '../../model/user';\nimport { PersistedBlob, PersistenceInternal } from '../persistence';\nimport { UserImpl } from '../user/user_impl';\nimport { _getInstance } from '../util/instantiator';\nimport { inMemoryPersistence } from './in_memory';\n\nexport const enum KeyName {\n  AUTH_USER = 'authUser',\n  AUTH_EVENT = 'authEvent',\n  REDIRECT_USER = 'redirectUser',\n  PERSISTENCE_USER = 'persistence'\n}\nexport const enum Namespace {\n  PERSISTENCE = 'firebase'\n}\n\nexport function _persistenceKeyName(\n  key: string,\n  apiKey: ApiKey,\n  appName: AppName\n): string {\n  return `${Namespace.PERSISTENCE}:${key}:${apiKey}:${appName}`;\n}\n\nexport class PersistenceUserManager {\n  private readonly fullUserKey: string;\n  private readonly fullPersistenceKey: string;\n  private readonly boundEventHandler: () => void;\n\n  private constructor(\n    public persistence: PersistenceInternal,\n    private readonly auth: AuthInternal,\n    private readonly userKey: string\n  ) {\n    const { config, name } = this.auth;\n    this.fullUserKey = _persistenceKeyName(this.userKey, config.apiKey, name);\n    this.fullPersistenceKey = _persistenceKeyName(\n      KeyName.PERSISTENCE_USER,\n      config.apiKey,\n      name\n    );\n    this.boundEventHandler = auth._onStorageEvent.bind(auth);\n    this.persistence._addListener(this.fullUserKey, this.boundEventHandler);\n  }\n\n  setCurrentUser(user: UserInternal): Promise<void> {\n    return this.persistence._set(this.fullUserKey, user.toJSON());\n  }\n\n  async getCurrentUser(): Promise<UserInternal | null> {\n    const blob = await this.persistence._get<PersistedBlob>(this.fullUserKey);\n    return blob ? UserImpl._fromJSON(this.auth, blob) : null;\n  }\n\n  removeCurrentUser(): Promise<void> {\n    return this.persistence._remove(this.fullUserKey);\n  }\n\n  savePersistenceForRedirect(): Promise<void> {\n    return this.persistence._set(\n      this.fullPersistenceKey,\n      this.persistence.type\n    );\n  }\n\n  async setPersistence(newPersistence: PersistenceInternal): Promise<void> {\n    if (this.persistence === newPersistence) {\n      return;\n    }\n\n    const currentUser = await this.getCurrentUser();\n    await this.removeCurrentUser();\n\n    this.persistence = newPersistence;\n\n    if (currentUser) {\n      return this.setCurrentUser(currentUser);\n    }\n  }\n\n  delete(): void {\n    this.persistence._removeListener(this.fullUserKey, this.boundEventHandler);\n  }\n\n  static async create(\n    auth: AuthInternal,\n    persistenceHierarchy: PersistenceInternal[],\n    userKey = KeyName.AUTH_USER\n  ): Promise<PersistenceUserManager> {\n    if (!persistenceHierarchy.length) {\n      return new PersistenceUserManager(\n        _getInstance(inMemoryPersistence),\n        auth,\n        userKey\n      );\n    }\n\n    // Eliminate any persistences that are not available\n    const availablePersistences = (\n      await Promise.all(\n        persistenceHierarchy.map(async persistence => {\n          if (await persistence._isAvailable()) {\n            return persistence;\n          }\n          return undefined;\n        })\n      )\n    ).filter(persistence => persistence) as PersistenceInternal[];\n\n    // Fall back to the first persistence listed, or in memory if none available\n    let selectedPersistence =\n      availablePersistences[0] ||\n      _getInstance<PersistenceInternal>(inMemoryPersistence);\n\n    const key = _persistenceKeyName(userKey, auth.config.apiKey, auth.name);\n\n    // Pull out the existing user, setting the chosen persistence to that\n    // persistence if the user exists.\n    let userToMigrate: UserInternal | null = null;\n    // Note, here we check for a user in _all_ persistences, not just the\n    // ones deemed available. If we can migrate a user out of a broken\n    // persistence, we will (but only if that persistence supports migration).\n    for (const persistence of persistenceHierarchy) {\n      try {\n        const blob = await persistence._get<PersistedBlob>(key);\n        if (blob) {\n          const user = UserImpl._fromJSON(auth, blob); // throws for unparsable blob (wrong format)\n          if (persistence !== selectedPersistence) {\n            userToMigrate = user;\n          }\n          selectedPersistence = persistence;\n          break;\n        }\n      } catch {}\n    }\n\n    // If we find the user in a persistence that does support migration, use\n    // that migration path (of only persistences that support migration)\n    const migrationHierarchy = availablePersistences.filter(\n      p => p._shouldAllowMigration\n    );\n\n    // If the persistence does _not_ allow migration, just finish off here\n    if (\n      !selectedPersistence._shouldAllowMigration ||\n      !migrationHierarchy.length\n    ) {\n      return new PersistenceUserManager(selectedPersistence, auth, userKey);\n    }\n\n    selectedPersistence = migrationHierarchy[0];\n    if (userToMigrate) {\n      // This normally shouldn't throw since chosenPersistence.isAvailable() is true, but if it does\n      // we'll just let it bubble to surface the error.\n      await selectedPersistence._set(key, userToMigrate.toJSON());\n    }\n\n    // Attempt to clear the key in other persistences but ignore errors. This helps prevent issues\n    // such as users getting stuck with a previous account after signing out and refreshing the tab.\n    await Promise.all(\n      persistenceHierarchy.map(async persistence => {\n        if (persistence !== selectedPersistence) {\n          try {\n            await persistence._remove(key);\n          } catch {}\n        }\n      })\n    );\n    return new PersistenceUserManager(selectedPersistence, auth, userKey);\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 { isIE, getUA } from '@firebase/util';\n\ninterface NavigatorStandalone extends Navigator {\n  standalone?: unknown;\n}\n\ninterface Document {\n  documentMode?: number;\n}\n\n/**\n * Enums for Browser name.\n */\nexport const enum BrowserName {\n  ANDROID = 'Android',\n  BLACKBERRY = 'Blackberry',\n  EDGE = 'Edge',\n  FIREFOX = 'Firefox',\n  IE = 'IE',\n  IEMOBILE = 'IEMobile',\n  OPERA = 'Opera',\n  OTHER = 'Other',\n  CHROME = 'Chrome',\n  SAFARI = 'Safari',\n  SILK = 'Silk',\n  WEBOS = 'Webos'\n}\n\n/**\n * Determine the browser for the purposes of reporting usage to the API\n */\nexport function _getBrowserName(userAgent: string): BrowserName | string {\n  const ua = userAgent.toLowerCase();\n  if (ua.includes('opera/') || ua.includes('opr/') || ua.includes('opios/')) {\n    return BrowserName.OPERA;\n  } else if (_isIEMobile(ua)) {\n    // Windows phone IEMobile browser.\n    return BrowserName.IEMOBILE;\n  } else if (ua.includes('msie') || ua.includes('trident/')) {\n    return BrowserName.IE;\n  } else if (ua.includes('edge/')) {\n    return BrowserName.EDGE;\n  } else if (_isFirefox(ua)) {\n    return BrowserName.FIREFOX;\n  } else if (ua.includes('silk/')) {\n    return BrowserName.SILK;\n  } else if (_isBlackBerry(ua)) {\n    // Blackberry browser.\n    return BrowserName.BLACKBERRY;\n  } else if (_isWebOS(ua)) {\n    // WebOS default browser.\n    return BrowserName.WEBOS;\n  } else if (_isSafari(ua)) {\n    return BrowserName.SAFARI;\n  } else if (\n    (ua.includes('chrome/') || _isChromeIOS(ua)) &&\n    !ua.includes('edge/')\n  ) {\n    return BrowserName.CHROME;\n  } else if (_isAndroid(ua)) {\n    // Android stock browser.\n    return BrowserName.ANDROID;\n  } else {\n    // Most modern browsers have name/version at end of user agent string.\n    const re = /([a-zA-Z\\d\\.]+)\\/[a-zA-Z\\d\\.]*$/;\n    const matches = userAgent.match(re);\n    if (matches?.length === 2) {\n      return matches[1];\n    }\n  }\n  return BrowserName.OTHER;\n}\n\nexport function _isFirefox(ua = getUA()): boolean {\n  return /firefox\\//i.test(ua);\n}\n\nexport function _isSafari(userAgent = getUA()): boolean {\n  const ua = userAgent.toLowerCase();\n  return (\n    ua.includes('safari/') &&\n    !ua.includes('chrome/') &&\n    !ua.includes('crios/') &&\n    !ua.includes('android')\n  );\n}\n\nexport function _isChromeIOS(ua = getUA()): boolean {\n  return /crios\\//i.test(ua);\n}\n\nexport function _isIEMobile(ua = getUA()): boolean {\n  return /iemobile/i.test(ua);\n}\n\nexport function _isAndroid(ua = getUA()): boolean {\n  return /android/i.test(ua);\n}\n\nexport function _isBlackBerry(ua = getUA()): boolean {\n  return /blackberry/i.test(ua);\n}\n\nexport function _isWebOS(ua = getUA()): boolean {\n  return /webos/i.test(ua);\n}\n\nexport function _isIOS(ua = getUA()): boolean {\n  return (\n    /iphone|ipad|ipod/i.test(ua) ||\n    (/macintosh/i.test(ua) && /mobile/i.test(ua))\n  );\n}\n\nexport function _isIOS7Or8(ua = getUA()): boolean {\n  return (\n    /(iPad|iPhone|iPod).*OS 7_\\d/i.test(ua) ||\n    /(iPad|iPhone|iPod).*OS 8_\\d/i.test(ua)\n  );\n}\n\nexport function _isIOSStandalone(ua = getUA()): boolean {\n  return _isIOS(ua) && !!(window.navigator as NavigatorStandalone)?.standalone;\n}\n\nexport function _isIE10(): boolean {\n  return isIE() && (document as Document).documentMode === 10;\n}\n\nexport function _isMobileBrowser(ua: string = getUA()): boolean {\n  // TODO: implement getBrowserName equivalent for OS.\n  return (\n    _isIOS(ua) ||\n    _isAndroid(ua) ||\n    _isWebOS(ua) ||\n    _isBlackBerry(ua) ||\n    /windows phone/i.test(ua) ||\n    _isIEMobile(ua)\n  );\n}\n\nexport function _isIframe(): boolean {\n  try {\n    // Check that the current window is not the top window.\n    // If so, return true.\n    return !!(window && window !== window.top);\n  } catch (e) {\n    return false;\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 { SDK_VERSION } from '@firebase/app';\nimport { _getBrowserName } from './browser';\nimport { getUA } from '@firebase/util';\n\nexport const enum ClientImplementation {\n  CORE = 'JsCore'\n}\n\n/**\n * @internal\n */\nexport const enum ClientPlatform {\n  BROWSER = 'Browser',\n  NODE = 'Node',\n  REACT_NATIVE = 'ReactNative',\n  CORDOVA = 'Cordova',\n  WORKER = 'Worker',\n  WEB_EXTENSION = 'WebExtension'\n}\n\n/*\n * Determine the SDK version string\n */\nexport function _getClientVersion(\n  clientPlatform: ClientPlatform,\n  frameworks: readonly string[] = []\n): string {\n  let reportedPlatform: string;\n  switch (clientPlatform) {\n    case ClientPlatform.BROWSER:\n      // In a browser environment, report the browser name.\n      reportedPlatform = _getBrowserName(getUA());\n      break;\n    case ClientPlatform.WORKER:\n      // Technically a worker runs from a browser but we need to differentiate a\n      // worker from a browser.\n      // For example: Chrome-Worker/JsCore/4.9.1/FirebaseCore-web.\n      reportedPlatform = `${_getBrowserName(getUA())}-${clientPlatform}`;\n      break;\n    default:\n      reportedPlatform = clientPlatform;\n  }\n  const reportedFrameworks = frameworks.length\n    ? frameworks.join(',')\n    : 'FirebaseCore-web'; /* default value if no other framework is used */\n  return `${reportedPlatform}/${ClientImplementation.CORE}/${SDK_VERSION}/${reportedFrameworks}`;\n}\n","/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { AuthInternal } from '../../model/auth';\nimport { Unsubscribe, User } from '../../model/public_types';\nimport { AuthErrorCode } from '../errors';\n\ninterface MiddlewareEntry {\n  (user: User | null): Promise<void>;\n  onAbort?: () => void;\n}\n\nexport class AuthMiddlewareQueue {\n  private readonly queue: MiddlewareEntry[] = [];\n\n  constructor(private readonly auth: AuthInternal) {}\n\n  pushCallback(\n    callback: (user: User | null) => void | Promise<void>,\n    onAbort?: () => void\n  ): Unsubscribe {\n    // The callback could be sync or async. Wrap it into a\n    // function that is always async.\n    const wrappedCallback: MiddlewareEntry = (\n      user: User | null\n    ): Promise<void> =>\n      new Promise((resolve, reject) => {\n        try {\n          const result = callback(user);\n          // Either resolve with existing promise or wrap a non-promise\n          // return value into a promise.\n          resolve(result);\n        } catch (e) {\n          // Sync callback throws.\n          reject(e);\n        }\n      });\n    // Attach the onAbort if present\n    wrappedCallback.onAbort = onAbort;\n    this.queue.push(wrappedCallback);\n\n    const index = this.queue.length - 1;\n    return () => {\n      // Unsubscribe. Replace with no-op. Do not remove from array, or it will disturb\n      // indexing of other elements.\n      this.queue[index] = () => Promise.resolve();\n    };\n  }\n\n  async runMiddleware(nextUser: User | null): Promise<void> {\n    if (this.auth.currentUser === nextUser) {\n      return;\n    }\n\n    // While running the middleware, build a temporary stack of onAbort\n    // callbacks to call if one middleware callback rejects.\n\n    const onAbortStack: Array<() => void> = [];\n    try {\n      for (const beforeStateCallback of this.queue) {\n        await beforeStateCallback(nextUser);\n\n        // Only push the onAbort if the callback succeeds\n        if (beforeStateCallback.onAbort) {\n          onAbortStack.push(beforeStateCallback.onAbort);\n        }\n      }\n    } catch (e) {\n      // Run all onAbort, with separate try/catch to ignore any errors and\n      // continue\n      onAbortStack.reverse();\n      for (const onAbort of onAbortStack) {\n        try {\n          onAbort();\n        } catch (_) {\n          /* swallow error */\n        }\n      }\n\n      throw this.auth._errorFactory.create(AuthErrorCode.LOGIN_BLOCKED, {\n        originalMessage: (e as Error)?.message\n      });\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { GetPasswordPolicyResponse } from '../../api/password_policy/get_password_policy';\nimport {\n  PasswordPolicyCustomStrengthOptions,\n  PasswordPolicyInternal,\n  PasswordValidationStatusInternal\n} from '../../model/password_policy';\nimport { PasswordValidationStatus } from '../../model/public_types';\n\n// Minimum min password length enforced by the backend, even if no minimum length is set.\nconst MINIMUM_MIN_PASSWORD_LENGTH = 6;\n\n/**\n * Stores password policy requirements and provides password validation against the policy.\n *\n * @internal\n */\nexport class PasswordPolicyImpl implements PasswordPolicyInternal {\n  readonly customStrengthOptions: PasswordPolicyCustomStrengthOptions;\n  readonly allowedNonAlphanumericCharacters: string;\n  readonly enforcementState: string;\n  readonly forceUpgradeOnSignin: boolean;\n  readonly schemaVersion: number;\n\n  constructor(response: GetPasswordPolicyResponse) {\n    // Only include custom strength options defined in the response.\n    const responseOptions = response.customStrengthOptions;\n    this.customStrengthOptions = {};\n    // TODO: Remove once the backend is updated to include the minimum min password length instead of undefined when there is no minimum length set.\n    this.customStrengthOptions.minPasswordLength =\n      responseOptions.minPasswordLength ?? MINIMUM_MIN_PASSWORD_LENGTH;\n    if (responseOptions.maxPasswordLength) {\n      this.customStrengthOptions.maxPasswordLength =\n        responseOptions.maxPasswordLength;\n    }\n    if (responseOptions.containsLowercaseCharacter !== undefined) {\n      this.customStrengthOptions.containsLowercaseLetter =\n        responseOptions.containsLowercaseCharacter;\n    }\n    if (responseOptions.containsUppercaseCharacter !== undefined) {\n      this.customStrengthOptions.containsUppercaseLetter =\n        responseOptions.containsUppercaseCharacter;\n    }\n    if (responseOptions.containsNumericCharacter !== undefined) {\n      this.customStrengthOptions.containsNumericCharacter =\n        responseOptions.containsNumericCharacter;\n    }\n    if (responseOptions.containsNonAlphanumericCharacter !== undefined) {\n      this.customStrengthOptions.containsNonAlphanumericCharacter =\n        responseOptions.containsNonAlphanumericCharacter;\n    }\n\n    this.enforcementState = response.enforcementState;\n    if (this.enforcementState === 'ENFORCEMENT_STATE_UNSPECIFIED') {\n      this.enforcementState = 'OFF';\n    }\n\n    // Use an empty string if no non-alphanumeric characters are specified in the response.\n    this.allowedNonAlphanumericCharacters =\n      response.allowedNonAlphanumericCharacters?.join('') ?? '';\n\n    this.forceUpgradeOnSignin = response.forceUpgradeOnSignin ?? false;\n    this.schemaVersion = response.schemaVersion;\n  }\n\n  validatePassword(password: string): PasswordValidationStatus {\n    const status: PasswordValidationStatusInternal = {\n      isValid: true,\n      passwordPolicy: this\n    };\n\n    // Check the password length and character options.\n    this.validatePasswordLengthOptions(password, status);\n    this.validatePasswordCharacterOptions(password, status);\n\n    // Combine the status into single isValid property.\n    status.isValid &&= status.meetsMinPasswordLength ?? true;\n    status.isValid &&= status.meetsMaxPasswordLength ?? true;\n    status.isValid &&= status.containsLowercaseLetter ?? true;\n    status.isValid &&= status.containsUppercaseLetter ?? true;\n    status.isValid &&= status.containsNumericCharacter ?? true;\n    status.isValid &&= status.containsNonAlphanumericCharacter ?? true;\n\n    return status;\n  }\n\n  /**\n   * Validates that the password meets the length options for the policy.\n   *\n   * @param password Password to validate.\n   * @param status Validation status.\n   */\n  private validatePasswordLengthOptions(\n    password: string,\n    status: PasswordValidationStatusInternal\n  ): void {\n    const minPasswordLength = this.customStrengthOptions.minPasswordLength;\n    const maxPasswordLength = this.customStrengthOptions.maxPasswordLength;\n    if (minPasswordLength) {\n      status.meetsMinPasswordLength = password.length >= minPasswordLength;\n    }\n    if (maxPasswordLength) {\n      status.meetsMaxPasswordLength = password.length <= maxPasswordLength;\n    }\n  }\n\n  /**\n   * Validates that the password meets the character options for the policy.\n   *\n   * @param password Password to validate.\n   * @param status Validation status.\n   */\n  private validatePasswordCharacterOptions(\n    password: string,\n    status: PasswordValidationStatusInternal\n  ): void {\n    // Assign statuses for requirements even if the password is an empty string.\n    this.updatePasswordCharacterOptionsStatuses(\n      status,\n      /* containsLowercaseCharacter= */ false,\n      /* containsUppercaseCharacter= */ false,\n      /* containsNumericCharacter= */ false,\n      /* containsNonAlphanumericCharacter= */ false\n    );\n\n    let passwordChar;\n    for (let i = 0; i < password.length; i++) {\n      passwordChar = password.charAt(i);\n      this.updatePasswordCharacterOptionsStatuses(\n        status,\n        /* containsLowercaseCharacter= */ passwordChar >= 'a' &&\n          passwordChar <= 'z',\n        /* containsUppercaseCharacter= */ passwordChar >= 'A' &&\n          passwordChar <= 'Z',\n        /* containsNumericCharacter= */ passwordChar >= '0' &&\n          passwordChar <= '9',\n        /* containsNonAlphanumericCharacter= */ this.allowedNonAlphanumericCharacters.includes(\n          passwordChar\n        )\n      );\n    }\n  }\n\n  /**\n   * Updates the running validation status with the statuses for the character options.\n   * Expected to be called each time a character is processed to update each option status\n   * based on the current character.\n   *\n   * @param status Validation status.\n   * @param containsLowercaseCharacter Whether the character is a lowercase letter.\n   * @param containsUppercaseCharacter Whether the character is an uppercase letter.\n   * @param containsNumericCharacter Whether the character is a numeric character.\n   * @param containsNonAlphanumericCharacter Whether the character is a non-alphanumeric character.\n   */\n  private updatePasswordCharacterOptionsStatuses(\n    status: PasswordValidationStatusInternal,\n    containsLowercaseCharacter: boolean,\n    containsUppercaseCharacter: boolean,\n    containsNumericCharacter: boolean,\n    containsNonAlphanumericCharacter: boolean\n  ): void {\n    if (this.customStrengthOptions.containsLowercaseLetter) {\n      status.containsLowercaseLetter ||= containsLowercaseCharacter;\n    }\n    if (this.customStrengthOptions.containsUppercaseLetter) {\n      status.containsUppercaseLetter ||= containsUppercaseCharacter;\n    }\n    if (this.customStrengthOptions.containsNumericCharacter) {\n      status.containsNumericCharacter ||= containsNumericCharacter;\n    }\n    if (this.customStrengthOptions.containsNonAlphanumericCharacter) {\n      status.containsNonAlphanumericCharacter ||=\n        containsNonAlphanumericCharacter;\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 {\n  _isFirebaseServerApp,\n  _FirebaseService,\n  FirebaseApp\n} from '@firebase/app';\nimport { Provider } from '@firebase/component';\nimport { AppCheckInternalComponentName } from '@firebase/app-check-interop-types';\nimport {\n  Auth,\n  AuthErrorMap,\n  AuthSettings,\n  EmulatorConfig,\n  NextOrObserver,\n  Persistence,\n  PopupRedirectResolver,\n  User,\n  UserCredential,\n  CompleteFn,\n  ErrorFn,\n  NextFn,\n  Unsubscribe,\n  PasswordValidationStatus\n} from '../../model/public_types';\nimport {\n  createSubscribe,\n  ErrorFactory,\n  FirebaseError,\n  getModularInstance,\n  Observer,\n  Subscribe\n} from '@firebase/util';\n\nimport { AuthInternal, ConfigInternal } from '../../model/auth';\nimport { PopupRedirectResolverInternal } from '../../model/popup_redirect';\nimport { UserInternal } from '../../model/user';\nimport {\n  AuthErrorCode,\n  AuthErrorParams,\n  ErrorMapRetriever,\n  _DEFAULT_AUTH_ERROR_FACTORY\n} from '../errors';\nimport { PersistenceInternal } from '../persistence';\nimport {\n  KeyName,\n  PersistenceUserManager\n} from '../persistence/persistence_user_manager';\nimport { _reloadWithoutSaving } from '../user/reload';\nimport {\n  _assert,\n  _serverAppCurrentUserOperationNotSupportedError\n} from '../util/assert';\nimport { _getInstance } from '../util/instantiator';\nimport { _getUserLanguage } from '../util/navigator';\nimport { _getClientVersion } from '../util/version';\nimport { HttpHeader } from '../../api';\nimport {\n  RevokeTokenRequest,\n  TokenType,\n  revokeToken\n} from '../../api/authentication/token';\nimport { AuthMiddlewareQueue } from './middleware';\nimport { RecaptchaConfig } from '../../platform_browser/recaptcha/recaptcha';\nimport { _logWarn } from '../util/log';\nimport { _getPasswordPolicy } from '../../api/password_policy/get_password_policy';\nimport { PasswordPolicyInternal } from '../../model/password_policy';\nimport { PasswordPolicyImpl } from './password_policy_impl';\nimport { getAccountInfo } from '../../api/account_management/account';\nimport { UserImpl } from '../user/user_impl';\n\ninterface AsyncAction {\n  (): Promise<void>;\n}\n\nexport const enum DefaultConfig {\n  TOKEN_API_HOST = 'securetoken.googleapis.com',\n  API_HOST = 'identitytoolkit.googleapis.com',\n  API_SCHEME = 'https'\n}\n\nexport class AuthImpl implements AuthInternal, _FirebaseService {\n  currentUser: User | null = null;\n  emulatorConfig: EmulatorConfig | null = null;\n  private operations = Promise.resolve();\n  private persistenceManager?: PersistenceUserManager;\n  private redirectPersistenceManager?: PersistenceUserManager;\n  private authStateSubscription = new Subscription<User>(this);\n  private idTokenSubscription = new Subscription<User>(this);\n  private readonly beforeStateQueue = new AuthMiddlewareQueue(this);\n  private redirectUser: UserInternal | null = null;\n  private isProactiveRefreshEnabled = false;\n  private readonly EXPECTED_PASSWORD_POLICY_SCHEMA_VERSION: number = 1;\n\n  // Any network calls will set this to true and prevent subsequent emulator\n  // initialization\n  _canInitEmulator = true;\n  _isInitialized = false;\n  _deleted = false;\n  _initializationPromise: Promise<void> | null = null;\n  _popupRedirectResolver: PopupRedirectResolverInternal | null = null;\n  _errorFactory: ErrorFactory<AuthErrorCode, AuthErrorParams> =\n    _DEFAULT_AUTH_ERROR_FACTORY;\n  _agentRecaptchaConfig: RecaptchaConfig | null = null;\n  _tenantRecaptchaConfigs: Record<string, RecaptchaConfig> = {};\n  _projectPasswordPolicy: PasswordPolicyInternal | null = null;\n  _tenantPasswordPolicies: Record<string, PasswordPolicyInternal> = {};\n  readonly name: string;\n\n  // Tracks the last notified UID for state change listeners to prevent\n  // repeated calls to the callbacks. Undefined means it's never been\n  // called, whereas null means it's been called with a signed out user\n  private lastNotifiedUid: string | null | undefined = undefined;\n\n  languageCode: string | null = null;\n  tenantId: string | null = null;\n  settings: AuthSettings = { appVerificationDisabledForTesting: false };\n\n  constructor(\n    public readonly app: FirebaseApp,\n    private readonly heartbeatServiceProvider: Provider<'heartbeat'>,\n    private readonly appCheckServiceProvider: Provider<AppCheckInternalComponentName>,\n    public readonly config: ConfigInternal\n  ) {\n    this.name = app.name;\n    this.clientVersion = config.sdkClientVersion;\n  }\n\n  _initializeWithPersistence(\n    persistenceHierarchy: PersistenceInternal[],\n    popupRedirectResolver?: PopupRedirectResolver\n  ): Promise<void> {\n    if (popupRedirectResolver) {\n      this._popupRedirectResolver = _getInstance(popupRedirectResolver);\n    }\n\n    // Have to check for app deletion throughout initialization (after each\n    // promise resolution)\n    this._initializationPromise = this.queue(async () => {\n      if (this._deleted) {\n        return;\n      }\n\n      this.persistenceManager = await PersistenceUserManager.create(\n        this,\n        persistenceHierarchy\n      );\n\n      if (this._deleted) {\n        return;\n      }\n\n      // Initialize the resolver early if necessary (only applicable to web:\n      // this will cause the iframe to load immediately in certain cases)\n      if (this._popupRedirectResolver?._shouldInitProactively) {\n        // If this fails, don't halt auth loading\n        try {\n          await this._popupRedirectResolver._initialize(this);\n        } catch (e) {\n          /* Ignore the error */\n        }\n      }\n\n      await this.initializeCurrentUser(popupRedirectResolver);\n\n      this.lastNotifiedUid = this.currentUser?.uid || null;\n\n      if (this._deleted) {\n        return;\n      }\n\n      this._isInitialized = true;\n    });\n\n    return this._initializationPromise;\n  }\n\n  /**\n   * If the persistence is changed in another window, the user manager will let us know\n   */\n  async _onStorageEvent(): Promise<void> {\n    if (this._deleted) {\n      return;\n    }\n\n    const user = await this.assertedPersistence.getCurrentUser();\n\n    if (!this.currentUser && !user) {\n      // No change, do nothing (was signed out and remained signed out).\n      return;\n    }\n\n    // If the same user is to be synchronized.\n    if (this.currentUser && user && this.currentUser.uid === user.uid) {\n      // Data update, simply copy data changes.\n      this._currentUser._assign(user);\n      // If tokens changed from previous user tokens, this will trigger\n      // notifyAuthListeners_.\n      await this.currentUser.getIdToken();\n      return;\n    }\n\n    // Update current Auth state. Either a new login or logout.\n    // Skip blocking callbacks, they should not apply to a change in another tab.\n    await this._updateCurrentUser(user, /* skipBeforeStateCallbacks */ true);\n  }\n\n  private async initializeCurrentUserFromIdToken(\n    idToken: string\n  ): Promise<void> {\n    try {\n      const response = await getAccountInfo(this, { idToken });\n      const user = await UserImpl._fromGetAccountInfoResponse(\n        this,\n        response,\n        idToken\n      );\n      await this.directlySetCurrentUser(user);\n    } catch (err) {\n      console.warn(\n        'FirebaseServerApp could not login user with provided authIdToken: ',\n        err\n      );\n      await this.directlySetCurrentUser(null);\n    }\n  }\n\n  private async initializeCurrentUser(\n    popupRedirectResolver?: PopupRedirectResolver\n  ): Promise<void> {\n    if (_isFirebaseServerApp(this.app)) {\n      const idToken = this.app.settings.authIdToken;\n      if (idToken) {\n        // Start the auth operation in the next tick to allow a moment for the customer's app to\n        // attach an emulator, if desired.\n        return new Promise<void>(resolve => {\n          setTimeout(() =>\n            this.initializeCurrentUserFromIdToken(idToken).then(\n              resolve,\n              resolve\n            )\n          );\n        });\n      } else {\n        return this.directlySetCurrentUser(null);\n      }\n    }\n\n    // First check to see if we have a pending redirect event.\n    const previouslyStoredUser =\n      (await this.assertedPersistence.getCurrentUser()) as UserInternal | null;\n    let futureCurrentUser = previouslyStoredUser;\n    let needsTocheckMiddleware = false;\n    if (popupRedirectResolver && this.config.authDomain) {\n      await this.getOrInitRedirectPersistenceManager();\n      const redirectUserEventId = this.redirectUser?._redirectEventId;\n      const storedUserEventId = futureCurrentUser?._redirectEventId;\n      const result = await this.tryRedirectSignIn(popupRedirectResolver);\n\n      // If the stored user (i.e. the old \"currentUser\") has a redirectId that\n      // matches the redirect user, then we want to initially sign in with the\n      // new user object from result.\n      // TODO(samgho): More thoroughly test all of this\n      if (\n        (!redirectUserEventId || redirectUserEventId === storedUserEventId) &&\n        result?.user\n      ) {\n        futureCurrentUser = result.user as UserInternal;\n        needsTocheckMiddleware = true;\n      }\n    }\n\n    // If no user in persistence, there is no current user. Set to null.\n    if (!futureCurrentUser) {\n      return this.directlySetCurrentUser(null);\n    }\n\n    if (!futureCurrentUser._redirectEventId) {\n      // This isn't a redirect link operation, we can reload and bail.\n      // First though, ensure that we check the middleware is happy.\n      if (needsTocheckMiddleware) {\n        try {\n          await this.beforeStateQueue.runMiddleware(futureCurrentUser);\n        } catch (e) {\n          futureCurrentUser = previouslyStoredUser;\n          // We know this is available since the bit is only set when the\n          // resolver is available\n          this._popupRedirectResolver!._overrideRedirectResult(this, () =>\n            Promise.reject(e)\n          );\n        }\n      }\n\n      if (futureCurrentUser) {\n        return this.reloadAndSetCurrentUserOrClear(futureCurrentUser);\n      } else {\n        return this.directlySetCurrentUser(null);\n      }\n    }\n\n    _assert(this._popupRedirectResolver, this, AuthErrorCode.ARGUMENT_ERROR);\n    await this.getOrInitRedirectPersistenceManager();\n\n    // If the redirect user's event ID matches the current user's event ID,\n    // DO NOT reload the current user, otherwise they'll be cleared from storage.\n    // This is important for the reauthenticateWithRedirect() flow.\n    if (\n      this.redirectUser &&\n      this.redirectUser._redirectEventId === futureCurrentUser._redirectEventId\n    ) {\n      return this.directlySetCurrentUser(futureCurrentUser);\n    }\n\n    return this.reloadAndSetCurrentUserOrClear(futureCurrentUser);\n  }\n\n  private async tryRedirectSignIn(\n    redirectResolver: PopupRedirectResolver\n  ): Promise<UserCredential | null> {\n    // The redirect user needs to be checked (and signed in if available)\n    // during auth initialization. All of the normal sign in and link/reauth\n    // flows call back into auth and push things onto the promise queue. We\n    // need to await the result of the redirect sign in *inside the promise\n    // queue*. This presents a problem: we run into deadlock. See:\n    //    ┌> [Initialization] ─────┐\n    //    ┌> [<other queue tasks>] │\n    //    └─ [getRedirectResult] <─┘\n    //    where [] are tasks on the queue and arrows denote awaits\n    // Initialization will never complete because it's waiting on something\n    // that's waiting for initialization to complete!\n    //\n    // Instead, this method calls getRedirectResult() (stored in\n    // _completeRedirectFn) with an optional parameter that instructs all of\n    // the underlying auth operations to skip anything that mutates auth state.\n\n    let result: UserCredential | null = null;\n    try {\n      // We know this._popupRedirectResolver is set since redirectResolver\n      // is passed in. The _completeRedirectFn expects the unwrapped extern.\n      result = await this._popupRedirectResolver!._completeRedirectFn(\n        this,\n        redirectResolver,\n        true\n      );\n    } catch (e) {\n      // Swallow any errors here; the code can retrieve them in\n      // getRedirectResult().\n      await this._setRedirectUser(null);\n    }\n\n    return result;\n  }\n\n  private async reloadAndSetCurrentUserOrClear(\n    user: UserInternal\n  ): Promise<void> {\n    try {\n      await _reloadWithoutSaving(user);\n    } catch (e) {\n      if (\n        (e as FirebaseError)?.code !==\n        `auth/${AuthErrorCode.NETWORK_REQUEST_FAILED}`\n      ) {\n        // Something's wrong with the user's token. Log them out and remove\n        // them from storage\n        return this.directlySetCurrentUser(null);\n      }\n    }\n\n    return this.directlySetCurrentUser(user);\n  }\n\n  useDeviceLanguage(): void {\n    this.languageCode = _getUserLanguage();\n  }\n\n  async _delete(): Promise<void> {\n    this._deleted = true;\n  }\n\n  async updateCurrentUser(userExtern: User | null): Promise<void> {\n    if (_isFirebaseServerApp(this.app)) {\n      return Promise.reject(\n        _serverAppCurrentUserOperationNotSupportedError(this)\n      );\n    }\n    // The public updateCurrentUser method needs to make a copy of the user,\n    // and also check that the project matches\n    const user = userExtern\n      ? (getModularInstance(userExtern) as UserInternal)\n      : null;\n    if (user) {\n      _assert(\n        user.auth.config.apiKey === this.config.apiKey,\n        this,\n        AuthErrorCode.INVALID_AUTH\n      );\n    }\n    return this._updateCurrentUser(user && user._clone(this));\n  }\n\n  async _updateCurrentUser(\n    user: User | null,\n    skipBeforeStateCallbacks: boolean = false\n  ): Promise<void> {\n    if (this._deleted) {\n      return;\n    }\n    if (user) {\n      _assert(\n        this.tenantId === user.tenantId,\n        this,\n        AuthErrorCode.TENANT_ID_MISMATCH\n      );\n    }\n\n    if (!skipBeforeStateCallbacks) {\n      await this.beforeStateQueue.runMiddleware(user);\n    }\n\n    return this.queue(async () => {\n      await this.directlySetCurrentUser(user as UserInternal | null);\n      this.notifyAuthListeners();\n    });\n  }\n\n  async signOut(): Promise<void> {\n    if (_isFirebaseServerApp(this.app)) {\n      return Promise.reject(\n        _serverAppCurrentUserOperationNotSupportedError(this)\n      );\n    }\n    // Run first, to block _setRedirectUser() if any callbacks fail.\n    await this.beforeStateQueue.runMiddleware(null);\n    // Clear the redirect user when signOut is called\n    if (this.redirectPersistenceManager || this._popupRedirectResolver) {\n      await this._setRedirectUser(null);\n    }\n\n    // Prevent callbacks from being called again in _updateCurrentUser, as\n    // they were already called in the first line.\n    return this._updateCurrentUser(null, /* skipBeforeStateCallbacks */ true);\n  }\n\n  setPersistence(persistence: Persistence): Promise<void> {\n    if (_isFirebaseServerApp(this.app)) {\n      return Promise.reject(\n        _serverAppCurrentUserOperationNotSupportedError(this)\n      );\n    }\n    return this.queue(async () => {\n      await this.assertedPersistence.setPersistence(_getInstance(persistence));\n    });\n  }\n\n  _getRecaptchaConfig(): RecaptchaConfig | null {\n    if (this.tenantId == null) {\n      return this._agentRecaptchaConfig;\n    } else {\n      return this._tenantRecaptchaConfigs[this.tenantId];\n    }\n  }\n\n  async validatePassword(password: string): Promise<PasswordValidationStatus> {\n    if (!this._getPasswordPolicyInternal()) {\n      await this._updatePasswordPolicy();\n    }\n\n    // Password policy will be defined after fetching.\n    const passwordPolicy: PasswordPolicyInternal =\n      this._getPasswordPolicyInternal()!;\n\n    // Check that the policy schema version is supported by the SDK.\n    // TODO: Update this logic to use a max supported policy schema version once we have multiple schema versions.\n    if (\n      passwordPolicy.schemaVersion !==\n      this.EXPECTED_PASSWORD_POLICY_SCHEMA_VERSION\n    ) {\n      return Promise.reject(\n        this._errorFactory.create(\n          AuthErrorCode.UNSUPPORTED_PASSWORD_POLICY_SCHEMA_VERSION,\n          {}\n        )\n      );\n    }\n\n    return passwordPolicy.validatePassword(password);\n  }\n\n  _getPasswordPolicyInternal(): PasswordPolicyInternal | null {\n    if (this.tenantId === null) {\n      return this._projectPasswordPolicy;\n    } else {\n      return this._tenantPasswordPolicies[this.tenantId];\n    }\n  }\n\n  async _updatePasswordPolicy(): Promise<void> {\n    const response = await _getPasswordPolicy(this);\n\n    const passwordPolicy: PasswordPolicyInternal = new PasswordPolicyImpl(\n      response\n    );\n\n    if (this.tenantId === null) {\n      this._projectPasswordPolicy = passwordPolicy;\n    } else {\n      this._tenantPasswordPolicies[this.tenantId] = passwordPolicy;\n    }\n  }\n\n  _getPersistence(): string {\n    return this.assertedPersistence.persistence.type;\n  }\n\n  _updateErrorMap(errorMap: AuthErrorMap): void {\n    this._errorFactory = new ErrorFactory<AuthErrorCode, AuthErrorParams>(\n      'auth',\n      'Firebase',\n      (errorMap as ErrorMapRetriever)()\n    );\n  }\n\n  onAuthStateChanged(\n    nextOrObserver: NextOrObserver<User>,\n    error?: ErrorFn,\n    completed?: CompleteFn\n  ): Unsubscribe {\n    return this.registerStateListener(\n      this.authStateSubscription,\n      nextOrObserver,\n      error,\n      completed\n    );\n  }\n\n  beforeAuthStateChanged(\n    callback: (user: User | null) => void | Promise<void>,\n    onAbort?: () => void\n  ): Unsubscribe {\n    return this.beforeStateQueue.pushCallback(callback, onAbort);\n  }\n\n  onIdTokenChanged(\n    nextOrObserver: NextOrObserver<User>,\n    error?: ErrorFn,\n    completed?: CompleteFn\n  ): Unsubscribe {\n    return this.registerStateListener(\n      this.idTokenSubscription,\n      nextOrObserver,\n      error,\n      completed\n    );\n  }\n\n  authStateReady(): Promise<void> {\n    return new Promise((resolve, reject) => {\n      if (this.currentUser) {\n        resolve();\n      } else {\n        const unsubscribe = this.onAuthStateChanged(() => {\n          unsubscribe();\n          resolve();\n        }, reject);\n      }\n    });\n  }\n\n  /**\n   * Revokes the given access token. Currently only supports Apple OAuth access tokens.\n   */\n  async revokeAccessToken(token: string): Promise<void> {\n    if (this.currentUser) {\n      const idToken = await this.currentUser.getIdToken();\n      // Generalize this to accept other providers once supported.\n      const request: RevokeTokenRequest = {\n        providerId: 'apple.com',\n        tokenType: TokenType.ACCESS_TOKEN,\n        token,\n        idToken\n      };\n      if (this.tenantId != null) {\n        request.tenantId = this.tenantId;\n      }\n      await revokeToken(this, request);\n    }\n  }\n\n  toJSON(): object {\n    return {\n      apiKey: this.config.apiKey,\n      authDomain: this.config.authDomain,\n      appName: this.name,\n      currentUser: this._currentUser?.toJSON()\n    };\n  }\n\n  async _setRedirectUser(\n    user: UserInternal | null,\n    popupRedirectResolver?: PopupRedirectResolver\n  ): Promise<void> {\n    const redirectManager = await this.getOrInitRedirectPersistenceManager(\n      popupRedirectResolver\n    );\n    return user === null\n      ? redirectManager.removeCurrentUser()\n      : redirectManager.setCurrentUser(user);\n  }\n\n  private async getOrInitRedirectPersistenceManager(\n    popupRedirectResolver?: PopupRedirectResolver\n  ): Promise<PersistenceUserManager> {\n    if (!this.redirectPersistenceManager) {\n      const resolver: PopupRedirectResolverInternal | null =\n        (popupRedirectResolver && _getInstance(popupRedirectResolver)) ||\n        this._popupRedirectResolver;\n      _assert(resolver, this, AuthErrorCode.ARGUMENT_ERROR);\n      this.redirectPersistenceManager = await PersistenceUserManager.create(\n        this,\n        [_getInstance(resolver._redirectPersistence)],\n        KeyName.REDIRECT_USER\n      );\n      this.redirectUser =\n        await this.redirectPersistenceManager.getCurrentUser();\n    }\n\n    return this.redirectPersistenceManager;\n  }\n\n  async _redirectUserForId(id: string): Promise<UserInternal | null> {\n    // Make sure we've cleared any pending persistence actions if we're not in\n    // the initializer\n    if (this._isInitialized) {\n      await this.queue(async () => {});\n    }\n\n    if (this._currentUser?._redirectEventId === id) {\n      return this._currentUser;\n    }\n\n    if (this.redirectUser?._redirectEventId === id) {\n      return this.redirectUser;\n    }\n\n    return null;\n  }\n\n  async _persistUserIfCurrent(user: UserInternal): Promise<void> {\n    if (user === this.currentUser) {\n      return this.queue(async () => this.directlySetCurrentUser(user));\n    }\n  }\n\n  /** Notifies listeners only if the user is current */\n  _notifyListenersIfCurrent(user: UserInternal): void {\n    if (user === this.currentUser) {\n      this.notifyAuthListeners();\n    }\n  }\n\n  _key(): string {\n    return `${this.config.authDomain}:${this.config.apiKey}:${this.name}`;\n  }\n\n  _startProactiveRefresh(): void {\n    this.isProactiveRefreshEnabled = true;\n    if (this.currentUser) {\n      this._currentUser._startProactiveRefresh();\n    }\n  }\n\n  _stopProactiveRefresh(): void {\n    this.isProactiveRefreshEnabled = false;\n    if (this.currentUser) {\n      this._currentUser._stopProactiveRefresh();\n    }\n  }\n\n  /** Returns the current user cast as the internal type */\n  get _currentUser(): UserInternal {\n    return this.currentUser as UserInternal;\n  }\n\n  private notifyAuthListeners(): void {\n    if (!this._isInitialized) {\n      return;\n    }\n\n    this.idTokenSubscription.next(this.currentUser);\n\n    const currentUid = this.currentUser?.uid ?? null;\n    if (this.lastNotifiedUid !== currentUid) {\n      this.lastNotifiedUid = currentUid;\n      this.authStateSubscription.next(this.currentUser);\n    }\n  }\n\n  private registerStateListener(\n    subscription: Subscription<User>,\n    nextOrObserver: NextOrObserver<User>,\n    error?: ErrorFn,\n    completed?: CompleteFn\n  ): Unsubscribe {\n    if (this._deleted) {\n      return () => {};\n    }\n\n    const cb =\n      typeof nextOrObserver === 'function'\n        ? nextOrObserver\n        : nextOrObserver.next.bind(nextOrObserver);\n\n    let isUnsubscribed = false;\n\n    const promise = this._isInitialized\n      ? Promise.resolve()\n      : this._initializationPromise;\n    _assert(promise, this, AuthErrorCode.INTERNAL_ERROR);\n    // The callback needs to be called asynchronously per the spec.\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    promise.then(() => {\n      if (isUnsubscribed) {\n        return;\n      }\n      cb(this.currentUser);\n    });\n\n    if (typeof nextOrObserver === 'function') {\n      const unsubscribe = subscription.addObserver(\n        nextOrObserver,\n        error,\n        completed\n      );\n      return () => {\n        isUnsubscribed = true;\n        unsubscribe();\n      };\n    } else {\n      const unsubscribe = subscription.addObserver(nextOrObserver);\n      return () => {\n        isUnsubscribed = true;\n        unsubscribe();\n      };\n    }\n  }\n\n  /**\n   * Unprotected (from race conditions) method to set the current user. This\n   * should only be called from within a queued callback. This is necessary\n   * because the queue shouldn't rely on another queued callback.\n   */\n  private async directlySetCurrentUser(\n    user: UserInternal | null\n  ): Promise<void> {\n    if (this.currentUser && this.currentUser !== user) {\n      this._currentUser._stopProactiveRefresh();\n    }\n    if (user && this.isProactiveRefreshEnabled) {\n      user._startProactiveRefresh();\n    }\n\n    this.currentUser = user;\n\n    if (user) {\n      await this.assertedPersistence.setCurrentUser(user);\n    } else {\n      await this.assertedPersistence.removeCurrentUser();\n    }\n  }\n\n  private queue(action: AsyncAction): Promise<void> {\n    // In case something errors, the callback still should be called in order\n    // to keep the promise chain alive\n    this.operations = this.operations.then(action, action);\n    return this.operations;\n  }\n\n  private get assertedPersistence(): PersistenceUserManager {\n    _assert(this.persistenceManager, this, AuthErrorCode.INTERNAL_ERROR);\n    return this.persistenceManager;\n  }\n\n  private frameworks: string[] = [];\n  private clientVersion: string;\n  _logFramework(framework: string): void {\n    if (!framework || this.frameworks.includes(framework)) {\n      return;\n    }\n    this.frameworks.push(framework);\n\n    // Sort alphabetically so that \"FirebaseCore-web,FirebaseUI-web\" and\n    // \"FirebaseUI-web,FirebaseCore-web\" aren't viewed as different.\n    this.frameworks.sort();\n    this.clientVersion = _getClientVersion(\n      this.config.clientPlatform,\n      this._getFrameworks()\n    );\n  }\n  _getFrameworks(): readonly string[] {\n    return this.frameworks;\n  }\n  async _getAdditionalHeaders(): Promise<Record<string, string>> {\n    // Additional headers on every request\n    const headers: Record<string, string> = {\n      [HttpHeader.X_CLIENT_VERSION]: this.clientVersion\n    };\n\n    if (this.app.options.appId) {\n      headers[HttpHeader.X_FIREBASE_GMPID] = this.app.options.appId;\n    }\n\n    // If the heartbeat service exists, add the heartbeat string\n    const heartbeatsHeader = await this.heartbeatServiceProvider\n      .getImmediate({\n        optional: true\n      })\n      ?.getHeartbeatsHeader();\n    if (heartbeatsHeader) {\n      headers[HttpHeader.X_FIREBASE_CLIENT] = heartbeatsHeader;\n    }\n\n    // If the App Check service exists, add the App Check token in the headers\n    const appCheckToken = await this._getAppCheckToken();\n    if (appCheckToken) {\n      headers[HttpHeader.X_FIREBASE_APP_CHECK] = appCheckToken;\n    }\n\n    return headers;\n  }\n\n  async _getAppCheckToken(): Promise<string | undefined> {\n    const appCheckTokenResult = await this.appCheckServiceProvider\n      .getImmediate({ optional: true })\n      ?.getToken();\n    if (appCheckTokenResult?.error) {\n      // Context: appCheck.getToken() will never throw even if an error happened.\n      // In the error case, a dummy token will be returned along with an error field describing\n      // the error. In general, we shouldn't care about the error condition and just use\n      // the token (actual or dummy) to send requests.\n      _logWarn(\n        `Error while retrieving App Check token: ${appCheckTokenResult.error}`\n      );\n    }\n    return appCheckTokenResult?.token;\n  }\n}\n\n/**\n * Method to be used to cast down to our private implementation of Auth.\n * It will also handle unwrapping from the compat type if necessary\n *\n * @param auth Auth object passed in from developer\n */\nexport function _castAuth(auth: Auth): AuthInternal {\n  return getModularInstance(auth) as AuthInternal;\n}\n\n/** Helper class to wrap subscriber logic */\nclass Subscription<T> {\n  private observer: Observer<T | null> | null = null;\n  readonly addObserver: Subscribe<T | null> = createSubscribe(\n    observer => (this.observer = observer)\n  );\n\n  constructor(readonly auth: AuthInternal) {}\n\n  get next(): NextFn<T | null> {\n    _assert(this.observer, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    return this.observer.next.bind(this.observer);\n  }\n}\n","/**\n * @license\n * Copyright 2023 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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  _performApiRequest,\n  Endpoint,\n  HttpMethod,\n  _addTidIfNecessary\n} from '../index';\nimport { Auth } from '../../model/public_types';\n\n/**\n * Request object for fetching the password policy.\n */\nexport interface GetPasswordPolicyRequest {\n  tenantId?: string;\n}\n\n/**\n * Response object for fetching the password policy.\n */\nexport interface GetPasswordPolicyResponse {\n  customStrengthOptions: {\n    minPasswordLength?: number;\n    maxPasswordLength?: number;\n    containsLowercaseCharacter?: boolean;\n    containsUppercaseCharacter?: boolean;\n    containsNumericCharacter?: boolean;\n    containsNonAlphanumericCharacter?: boolean;\n  };\n  allowedNonAlphanumericCharacters?: string[];\n  enforcementState: string;\n  forceUpgradeOnSignin?: boolean;\n  schemaVersion: number;\n}\n\n/**\n * Fetches the password policy for the currently set tenant or the project if no tenant is set.\n *\n * @param auth Auth object.\n * @param request Password policy request.\n * @returns Password policy response.\n */\nexport async function _getPasswordPolicy(\n  auth: Auth,\n  request: GetPasswordPolicyRequest = {}\n): Promise<GetPasswordPolicyResponse> {\n  return _performApiRequest<\n    GetPasswordPolicyRequest,\n    GetPasswordPolicyResponse\n  >(\n    auth,\n    HttpMethod.GET,\n    Endpoint.GET_PASSWORD_POLICY,\n    _addTidIfNecessary(auth, request)\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\ninterface ExternalJSProvider {\n  loadJS(url: string): Promise<Event>;\n  recaptchaV2Script: string;\n  recaptchaEnterpriseScript: string;\n  gapiScript: string;\n}\n\nlet externalJSProvider: ExternalJSProvider = {\n  async loadJS() {\n    throw new Error('Unable to load external scripts');\n  },\n\n  recaptchaV2Script: '',\n  recaptchaEnterpriseScript: '',\n  gapiScript: ''\n};\n\nexport function _setExternalJSProvider(p: ExternalJSProvider): void {\n  externalJSProvider = p;\n}\n\nexport function _loadJS(url: string): Promise<Event> {\n  return externalJSProvider.loadJS(url);\n}\n\nexport function _recaptchaV2ScriptUrl(): string {\n  return externalJSProvider.recaptchaV2Script;\n}\n\nexport function _recaptchaEnterpriseScriptUrl(): string {\n  return externalJSProvider.recaptchaEnterpriseScript;\n}\n\nexport function _gapiScriptUrl(): string {\n  return externalJSProvider.gapiScript;\n}\n\nexport function _generateCallbackName(prefix: string): string {\n  return `__${prefix}${Math.floor(Math.random() * 1000000)}`;\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 { AuthErrorCode } from '../../core/errors';\nimport { _assert } from '../../core/util/assert';\nimport { AuthInternal } from '../../model/auth';\nimport { RecaptchaParameters } from '../../model/public_types';\nimport {\n  Recaptcha,\n  GreCAPTCHATopLevel,\n  GreCAPTCHARenderOption,\n  GreCAPTCHA\n} from './recaptcha';\n\nexport const _SOLVE_TIME_MS = 500;\nexport const _EXPIRATION_TIME_MS = 60_000;\nexport const _WIDGET_ID_START = 1_000_000_000_000;\n\nexport interface Widget {\n  getResponse: () => string | null;\n  delete: () => void;\n  execute: () => void;\n}\n\nexport class MockReCaptcha implements Recaptcha {\n  private counter = _WIDGET_ID_START;\n  _widgets = new Map<number, Widget>();\n\n  constructor(private readonly auth: AuthInternal) {}\n\n  render(\n    container: string | HTMLElement,\n    parameters?: RecaptchaParameters\n  ): number {\n    const id = this.counter;\n    this._widgets.set(\n      id,\n      new MockWidget(container, this.auth.name, parameters || {})\n    );\n    this.counter++;\n    return id;\n  }\n\n  reset(optWidgetId?: number): void {\n    const id = optWidgetId || _WIDGET_ID_START;\n    void this._widgets.get(id)?.delete();\n    this._widgets.delete(id);\n  }\n\n  getResponse(optWidgetId?: number): string {\n    const id = optWidgetId || _WIDGET_ID_START;\n    return this._widgets.get(id)?.getResponse() || '';\n  }\n\n  async execute(optWidgetId?: number | string): Promise<string> {\n    const id: number = (optWidgetId as number) || _WIDGET_ID_START;\n    void this._widgets.get(id)?.execute();\n    return '';\n  }\n}\n\nexport class MockGreCAPTCHATopLevel implements GreCAPTCHATopLevel {\n  enterprise: GreCAPTCHA = new MockGreCAPTCHA();\n  ready(callback: () => void): void {\n    callback();\n  }\n\n  execute(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _siteKey: string,\n    _options: { action: string }\n  ): Promise<string> {\n    return Promise.resolve('token');\n  }\n  render(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _container: string | HTMLElement,\n    _parameters: GreCAPTCHARenderOption\n  ): string {\n    return '';\n  }\n}\n\nexport class MockGreCAPTCHA implements GreCAPTCHA {\n  ready(callback: () => void): void {\n    callback();\n  }\n\n  execute(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _siteKey: string,\n    _options: { action: string }\n  ): Promise<string> {\n    return Promise.resolve('token');\n  }\n  render(\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _container: string | HTMLElement,\n    _parameters: GreCAPTCHARenderOption\n  ): string {\n    return '';\n  }\n}\n\nexport class MockWidget {\n  private readonly container: HTMLElement;\n  private readonly isVisible: boolean;\n  private timerId: number | null = null;\n  private deleted = false;\n  private responseToken: string | null = null;\n  private readonly clickHandler = (): void => {\n    this.execute();\n  };\n\n  constructor(\n    containerOrId: string | HTMLElement,\n    appName: string,\n    private readonly params: RecaptchaParameters\n  ) {\n    const container =\n      typeof containerOrId === 'string'\n        ? document.getElementById(containerOrId)\n        : containerOrId;\n    _assert(container, AuthErrorCode.ARGUMENT_ERROR, { appName });\n\n    this.container = container;\n    this.isVisible = this.params.size !== 'invisible';\n    if (this.isVisible) {\n      this.execute();\n    } else {\n      this.container.addEventListener('click', this.clickHandler);\n    }\n  }\n\n  getResponse(): string | null {\n    this.checkIfDeleted();\n    return this.responseToken;\n  }\n\n  delete(): void {\n    this.checkIfDeleted();\n    this.deleted = true;\n    if (this.timerId) {\n      clearTimeout(this.timerId);\n      this.timerId = null;\n    }\n    this.container.removeEventListener('click', this.clickHandler);\n  }\n\n  execute(): void {\n    this.checkIfDeleted();\n    if (this.timerId) {\n      return;\n    }\n\n    this.timerId = window.setTimeout(() => {\n      this.responseToken = generateRandomAlphaNumericString(50);\n      const { callback, 'expired-callback': expiredCallback } = this.params;\n      if (callback) {\n        try {\n          callback(this.responseToken);\n        } catch (e) {}\n      }\n\n      this.timerId = window.setTimeout(() => {\n        this.timerId = null;\n        this.responseToken = null;\n        if (expiredCallback) {\n          try {\n            expiredCallback();\n          } catch (e) {}\n        }\n\n        if (this.isVisible) {\n          this.execute();\n        }\n      }, _EXPIRATION_TIME_MS);\n    }, _SOLVE_TIME_MS);\n  }\n\n  private checkIfDeleted(): void {\n    if (this.deleted) {\n      throw new Error('reCAPTCHA mock was already deleted!');\n    }\n  }\n}\n\nfunction generateRandomAlphaNumericString(len: number): string {\n  const chars = [];\n  const allowedChars =\n    '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';\n  for (let i = 0; i < len; i++) {\n    chars.push(\n      allowedChars.charAt(Math.floor(Math.random() * allowedChars.length))\n    );\n  }\n  return chars.join('');\n}\n","/* eslint-disable @typescript-eslint/no-require-imports */\n/**\n * @license\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { isEnterprise, RecaptchaConfig } from './recaptcha';\nimport { getRecaptchaConfig } from '../../api/authentication/recaptcha';\nimport {\n  RecaptchaClientType,\n  RecaptchaVersion,\n  RecaptchaActionName,\n  RecaptchaAuthProvider,\n  EnforcementState\n} from '../../api';\n\nimport { Auth } from '../../model/public_types';\nimport { AuthInternal } from '../../model/auth';\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport * as jsHelpers from '../load_js';\nimport { AuthErrorCode } from '../../core/errors';\nimport { StartPhoneMfaEnrollmentRequest } from '../../api/account_management/mfa';\nimport { StartPhoneMfaSignInRequest } from '../../api/authentication/mfa';\nimport { MockGreCAPTCHATopLevel } from './recaptcha_mock';\n\nexport const RECAPTCHA_ENTERPRISE_VERIFIER_TYPE = 'recaptcha-enterprise';\nexport const FAKE_TOKEN = 'NO_RECAPTCHA';\n\nexport class RecaptchaEnterpriseVerifier {\n  /**\n   * Identifies the type of application verifier (e.g. \"recaptcha-enterprise\").\n   */\n  readonly type = RECAPTCHA_ENTERPRISE_VERIFIER_TYPE;\n\n  private readonly auth: AuthInternal;\n\n  /**\n   *\n   * @param authExtern - The corresponding Firebase {@link Auth} instance.\n   *\n   */\n  constructor(authExtern: Auth) {\n    this.auth = _castAuth(authExtern);\n  }\n\n  /**\n   * Executes the verification process.\n   *\n   * @returns A Promise for a token that can be used to assert the validity of a request.\n   */\n  async verify(\n    action: string = 'verify',\n    forceRefresh = false\n  ): Promise<string> {\n    async function retrieveSiteKey(auth: AuthInternal): Promise<string> {\n      if (!forceRefresh) {\n        if (auth.tenantId == null && auth._agentRecaptchaConfig != null) {\n          return auth._agentRecaptchaConfig.siteKey;\n        }\n        if (\n          auth.tenantId != null &&\n          auth._tenantRecaptchaConfigs[auth.tenantId] !== undefined\n        ) {\n          return auth._tenantRecaptchaConfigs[auth.tenantId].siteKey;\n        }\n      }\n\n      return new Promise<string>(async (resolve, reject) => {\n        getRecaptchaConfig(auth, {\n          clientType: RecaptchaClientType.WEB,\n          version: RecaptchaVersion.ENTERPRISE\n        })\n          .then(response => {\n            if (response.recaptchaKey === undefined) {\n              reject(new Error('recaptcha Enterprise site key undefined'));\n            } else {\n              const config = new RecaptchaConfig(response);\n              if (auth.tenantId == null) {\n                auth._agentRecaptchaConfig = config;\n              } else {\n                auth._tenantRecaptchaConfigs[auth.tenantId] = config;\n              }\n              return resolve(config.siteKey);\n            }\n          })\n          .catch(error => {\n            reject(error);\n          });\n      });\n    }\n\n    function retrieveRecaptchaToken(\n      siteKey: string,\n      resolve: (value: string | PromiseLike<string>) => void,\n      reject: (reason?: unknown) => void\n    ): void {\n      const grecaptcha = window.grecaptcha;\n      if (isEnterprise(grecaptcha)) {\n        grecaptcha.enterprise.ready(() => {\n          grecaptcha.enterprise\n            .execute(siteKey, { action })\n            .then(token => {\n              resolve(token);\n            })\n            .catch(() => {\n              resolve(FAKE_TOKEN);\n            });\n        });\n      } else {\n        reject(Error('No reCAPTCHA enterprise script loaded.'));\n      }\n    }\n\n    // Returns Promise for a mock token when appVerificationDisabledForTesting is true.\n    if (this.auth.settings.appVerificationDisabledForTesting) {\n      const mockRecaptcha = new MockGreCAPTCHATopLevel();\n      return mockRecaptcha.execute('siteKey', { action: 'verify' });\n    }\n\n    return new Promise<string>((resolve, reject) => {\n      retrieveSiteKey(this.auth)\n        .then(siteKey => {\n          if (!forceRefresh && isEnterprise(window.grecaptcha)) {\n            retrieveRecaptchaToken(siteKey, resolve, reject);\n          } else {\n            if (typeof window === 'undefined') {\n              reject(\n                new Error('RecaptchaVerifier is only supported in browser')\n              );\n              return;\n            }\n            let url = jsHelpers._recaptchaEnterpriseScriptUrl();\n            if (url.length !== 0) {\n              url += siteKey;\n            }\n            jsHelpers\n              ._loadJS(url)\n              .then(() => {\n                retrieveRecaptchaToken(siteKey, resolve, reject);\n              })\n              .catch(error => {\n                reject(error);\n              });\n          }\n        })\n        .catch(error => {\n          reject(error);\n        });\n    });\n  }\n}\n\nexport async function injectRecaptchaFields<T extends object>(\n  auth: AuthInternal,\n  request: T,\n  action: RecaptchaActionName,\n  isCaptchaResp = false,\n  isFakeToken = false\n): Promise<T> {\n  const verifier = new RecaptchaEnterpriseVerifier(auth);\n  let captchaResponse;\n\n  if (isFakeToken) {\n    captchaResponse = FAKE_TOKEN;\n  } else {\n    try {\n      captchaResponse = await verifier.verify(action);\n    } catch (error) {\n      captchaResponse = await verifier.verify(action, true);\n    }\n  }\n\n  const newRequest = { ...request };\n  if (\n    action === RecaptchaActionName.MFA_SMS_ENROLLMENT ||\n    action === RecaptchaActionName.MFA_SMS_SIGNIN\n  ) {\n    if ('phoneEnrollmentInfo' in newRequest) {\n      const phoneNumber = (\n        newRequest as unknown as StartPhoneMfaEnrollmentRequest\n      ).phoneEnrollmentInfo.phoneNumber;\n      const recaptchaToken = (\n        newRequest as unknown as StartPhoneMfaEnrollmentRequest\n      ).phoneEnrollmentInfo.recaptchaToken;\n\n      Object.assign(newRequest, {\n        'phoneEnrollmentInfo': {\n          phoneNumber,\n          recaptchaToken,\n          captchaResponse,\n          'clientType': RecaptchaClientType.WEB,\n          'recaptchaVersion': RecaptchaVersion.ENTERPRISE\n        }\n      });\n    } else if ('phoneSignInInfo' in newRequest) {\n      const recaptchaToken = (\n        newRequest as unknown as StartPhoneMfaSignInRequest\n      ).phoneSignInInfo.recaptchaToken;\n\n      Object.assign(newRequest, {\n        'phoneSignInInfo': {\n          recaptchaToken,\n          captchaResponse,\n          'clientType': RecaptchaClientType.WEB,\n          'recaptchaVersion': RecaptchaVersion.ENTERPRISE\n        }\n      });\n    }\n    return newRequest;\n  }\n\n  if (!isCaptchaResp) {\n    Object.assign(newRequest, { captchaResponse });\n  } else {\n    Object.assign(newRequest, { 'captchaResp': captchaResponse });\n  }\n  Object.assign(newRequest, { 'clientType': RecaptchaClientType.WEB });\n  Object.assign(newRequest, {\n    'recaptchaVersion': RecaptchaVersion.ENTERPRISE\n  });\n  return newRequest;\n}\n\ntype ActionMethod<TRequest, TResponse> = (\n  auth: AuthInternal,\n  request: TRequest\n) => Promise<TResponse>;\n\nexport async function handleRecaptchaFlow<TRequest extends object, TResponse>(\n  authInstance: AuthInternal,\n  request: TRequest,\n  actionName: RecaptchaActionName,\n  actionMethod: ActionMethod<TRequest, TResponse>,\n  recaptchaAuthProvider: RecaptchaAuthProvider\n): Promise<TResponse> {\n  if (recaptchaAuthProvider === RecaptchaAuthProvider.EMAIL_PASSWORD_PROVIDER) {\n    if (\n      authInstance\n        ._getRecaptchaConfig()\n        ?.isProviderEnabled(RecaptchaAuthProvider.EMAIL_PASSWORD_PROVIDER)\n    ) {\n      const requestWithRecaptcha = await injectRecaptchaFields(\n        authInstance,\n        request,\n        actionName,\n        actionName === RecaptchaActionName.GET_OOB_CODE\n      );\n      return actionMethod(authInstance, requestWithRecaptcha);\n    } else {\n      return actionMethod(authInstance, request).catch(async error => {\n        if (error.code === `auth/${AuthErrorCode.MISSING_RECAPTCHA_TOKEN}`) {\n          console.log(\n            `${actionName} is protected by reCAPTCHA Enterprise for this project. Automatically triggering the reCAPTCHA flow and restarting the flow.`\n          );\n          const requestWithRecaptcha = await injectRecaptchaFields(\n            authInstance,\n            request,\n            actionName,\n            actionName === RecaptchaActionName.GET_OOB_CODE\n          );\n          return actionMethod(authInstance, requestWithRecaptcha);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n    }\n  } else if (recaptchaAuthProvider === RecaptchaAuthProvider.PHONE_PROVIDER) {\n    if (\n      authInstance\n        ._getRecaptchaConfig()\n        ?.isProviderEnabled(RecaptchaAuthProvider.PHONE_PROVIDER)\n    ) {\n      const requestWithRecaptcha = await injectRecaptchaFields(\n        authInstance,\n        request,\n        actionName\n      );\n\n      return actionMethod(authInstance, requestWithRecaptcha).catch(\n        async error => {\n          if (\n            authInstance\n              ._getRecaptchaConfig()\n              ?.getProviderEnforcementState(\n                RecaptchaAuthProvider.PHONE_PROVIDER\n              ) === EnforcementState.AUDIT\n          ) {\n            // AUDIT mode\n            if (\n              error.code === `auth/${AuthErrorCode.MISSING_RECAPTCHA_TOKEN}` ||\n              error.code === `auth/${AuthErrorCode.INVALID_APP_CREDENTIAL}`\n            ) {\n              console.log(\n                `Failed to verify with reCAPTCHA Enterprise. Automatically triggering the reCAPTCHA v2 flow to complete the ${actionName} flow.`\n              );\n              // reCAPTCHA Enterprise token is missing or reCAPTCHA Enterprise token\n              // check fails.\n              // Fallback to reCAPTCHA v2 flow.\n              const requestWithRecaptchaFields = await injectRecaptchaFields(\n                authInstance,\n                request,\n                actionName,\n                false, // isCaptchaResp\n                true // isFakeToken\n              );\n              // This will call the PhoneApiCaller to fetch and inject reCAPTCHA v2 token.\n              return actionMethod(authInstance, requestWithRecaptchaFields);\n            }\n          }\n          // ENFORCE mode or AUDIT mode with any other error.\n          return Promise.reject(error);\n        }\n      );\n    } else {\n      // Do reCAPTCHA v2 flow.\n      const requestWithRecaptchaFields = await injectRecaptchaFields(\n        authInstance,\n        request,\n        actionName,\n        false, // isCaptchaResp\n        true // isFakeToken\n      );\n\n      // This will call the PhoneApiCaller to fetch and inject v2 token.\n      return actionMethod(authInstance, requestWithRecaptchaFields);\n    }\n  } else {\n    return Promise.reject(\n      recaptchaAuthProvider + ' provider is not supported.'\n    );\n  }\n}\n\nexport async function _initializeRecaptchaConfig(auth: Auth): Promise<void> {\n  const authInternal = _castAuth(auth);\n\n  const response = await getRecaptchaConfig(authInternal, {\n    clientType: RecaptchaClientType.WEB,\n    version: RecaptchaVersion.ENTERPRISE\n  });\n\n  const config = new RecaptchaConfig(response);\n  if (authInternal.tenantId == null) {\n    authInternal._agentRecaptchaConfig = config;\n  } else {\n    authInternal._tenantRecaptchaConfigs[authInternal.tenantId] = config;\n  }\n\n  if (config.isAnyProviderEnabled()) {\n    const verifier = new RecaptchaEnterpriseVerifier(authInternal);\n    void verifier.verify();\n  }\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS 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 { Auth } from '../../model/public_types';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from '../util/assert';\nimport { _castAuth } from './auth_impl';\n\n/**\n * Changes the {@link Auth} instance to communicate with the Firebase Auth Emulator, instead of production\n * Firebase Auth services.\n *\n * @remarks\n * This must be called synchronously immediately following the first call to\n * {@link initializeAuth}.  Do not use with production credentials as emulator\n * traffic is not encrypted.\n *\n *\n * @example\n * ```javascript\n * connectAuthEmulator(auth, 'http://127.0.0.1:9099', { disableWarnings: true });\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param url - The URL at which the emulator is running (eg, 'http://localhost:9099').\n * @param options - Optional. `options.disableWarnings` defaults to `false`. Set it to\n * `true` to disable the warning banner attached to the DOM.\n *\n * @public\n */\nexport function connectAuthEmulator(\n  auth: Auth,\n  url: string,\n  options?: { disableWarnings: boolean }\n): void {\n  const authInternal = _castAuth(auth);\n  _assert(\n    authInternal._canInitEmulator,\n    authInternal,\n    AuthErrorCode.EMULATOR_CONFIG_FAILED\n  );\n\n  _assert(\n    /^https?:\\/\\//.test(url),\n    authInternal,\n    AuthErrorCode.INVALID_EMULATOR_SCHEME\n  );\n\n  const disableWarnings = !!options?.disableWarnings;\n\n  const protocol = extractProtocol(url);\n  const { host, port } = extractHostAndPort(url);\n  const portStr = port === null ? '' : `:${port}`;\n\n  // Always replace path with \"/\" (even if input url had no path at all, or had a different one).\n  authInternal.config.emulator = { url: `${protocol}//${host}${portStr}/` };\n  authInternal.settings.appVerificationDisabledForTesting = true;\n  authInternal.emulatorConfig = Object.freeze({\n    host,\n    port,\n    protocol: protocol.replace(':', ''),\n    options: Object.freeze({ disableWarnings })\n  });\n\n  if (!disableWarnings) {\n    emitEmulatorWarning();\n  }\n}\n\nfunction extractProtocol(url: string): string {\n  const protocolEnd = url.indexOf(':');\n  return protocolEnd < 0 ? '' : url.substr(0, protocolEnd + 1);\n}\n\nfunction extractHostAndPort(url: string): {\n  host: string;\n  port: number | null;\n} {\n  const protocol = extractProtocol(url);\n  const authority = /(\\/\\/)?([^?#/]+)/.exec(url.substr(protocol.length)); // Between // and /, ? or #.\n  if (!authority) {\n    return { host: '', port: null };\n  }\n  const hostAndPort = authority[2].split('@').pop() || ''; // Strip out \"username:password@\".\n  const bracketedIPv6 = /^(\\[[^\\]]+\\])(:|$)/.exec(hostAndPort);\n  if (bracketedIPv6) {\n    const host = bracketedIPv6[1];\n    return { host, port: parsePort(hostAndPort.substr(host.length + 1)) };\n  } else {\n    const [host, port] = hostAndPort.split(':');\n    return { host, port: parsePort(port) };\n  }\n}\n\nfunction parsePort(portStr: string): number | null {\n  if (!portStr) {\n    return null;\n  }\n  const port = Number(portStr);\n  if (isNaN(port)) {\n    return null;\n  }\n  return port;\n}\n\nfunction emitEmulatorWarning(): void {\n  function attachBanner(): void {\n    const el = document.createElement('p');\n    const sty = el.style;\n    el.innerText =\n      'Running in emulator mode. Do not use with production credentials.';\n    sty.position = 'fixed';\n    sty.width = '100%';\n    sty.backgroundColor = '#ffffff';\n    sty.border = '.1em solid #000000';\n    sty.color = '#b50000';\n    sty.bottom = '0px';\n    sty.left = '0px';\n    sty.margin = '0px';\n    sty.zIndex = '10000';\n    sty.textAlign = 'center';\n    el.classList.add('firebase-emulator-warning');\n    document.body.appendChild(el);\n  }\n\n  if (typeof console !== 'undefined' && typeof console.info === 'function') {\n    console.info(\n      'WARNING: You are using the Auth Emulator,' +\n        ' which is intended for local testing only.  Do not use with' +\n        ' production credentials.'\n    );\n  }\n  if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n    if (document.readyState === 'loading') {\n      window.addEventListener('DOMContentLoaded', attachBanner);\n    } else {\n      attachBanner();\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 { PhoneOrOauthTokenResponse } from '../../api/authentication/mfa';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { debugFail } from '../util/assert';\n\n/**\n * Interface that represents the credentials returned by an {@link AuthProvider}.\n *\n * @remarks\n * Implementations specify the details about each auth provider's credential requirements.\n *\n * @public\n */\nexport class AuthCredential {\n  /** @internal */\n  protected constructor(\n    /**\n     * The authentication provider ID for the credential.\n     *\n     * @remarks\n     * For example, 'facebook.com', or 'google.com'.\n     */\n    readonly providerId: string,\n    /**\n     * The authentication sign in method for the credential.\n     *\n     * @remarks\n     * For example, {@link SignInMethod}.EMAIL_PASSWORD, or\n     * {@link SignInMethod}.EMAIL_LINK. This corresponds to the sign-in method\n     * identifier as returned in {@link fetchSignInMethodsForEmail}.\n     */\n    readonly signInMethod: string\n  ) {}\n\n  /**\n   * Returns a JSON-serializable representation of this object.\n   *\n   * @returns a JSON-serializable representation of this object.\n   */\n  toJSON(): object {\n    return debugFail('not implemented');\n  }\n\n  /** @internal */\n  _getIdTokenResponse(_auth: AuthInternal): Promise<PhoneOrOauthTokenResponse> {\n    return debugFail('not implemented');\n  }\n  /** @internal */\n  _linkToIdToken(\n    _auth: AuthInternal,\n    _idToken: string\n  ): Promise<IdTokenResponse> {\n    return debugFail('not implemented');\n  }\n  /** @internal */\n  _getReauthenticationResolver(_auth: AuthInternal): Promise<IdTokenResponse> {\n    return debugFail('not implemented');\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 { ActionCodeOperation, Auth } from '../../model/public_types';\n\nimport {\n  Endpoint,\n  HttpMethod,\n  _addTidIfNecessary,\n  _performApiRequest\n} from '../index';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { MfaEnrollment } from './mfa';\nimport { SignUpRequest, SignUpResponse } from '../authentication/sign_up';\n\nexport interface ResetPasswordRequest {\n  oobCode: string;\n  newPassword?: string;\n  tenantId?: string;\n}\n\nexport interface ResetPasswordResponse {\n  email: string;\n  newEmail?: string;\n  requestType?: ActionCodeOperation;\n  mfaInfo?: MfaEnrollment;\n}\n\nexport async function resetPassword(\n  auth: Auth,\n  request: ResetPasswordRequest\n): Promise<ResetPasswordResponse> {\n  return _performApiRequest<ResetPasswordRequest, ResetPasswordResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.RESET_PASSWORD,\n    _addTidIfNecessary(auth, request)\n  );\n}\nexport interface UpdateEmailPasswordRequest {\n  idToken: string;\n  returnSecureToken?: boolean;\n  email?: string;\n  password?: string;\n}\n\nexport interface UpdateEmailPasswordResponse extends IdTokenResponse {}\n\nexport async function updateEmailPassword(\n  auth: Auth,\n  request: UpdateEmailPasswordRequest\n): Promise<UpdateEmailPasswordResponse> {\n  return _performApiRequest<\n    UpdateEmailPasswordRequest,\n    UpdateEmailPasswordResponse\n  >(auth, HttpMethod.POST, Endpoint.SET_ACCOUNT_INFO, request);\n}\n\n// Used for linking an email/password account to an existing idToken. Uses the same request/response\n// format as updateEmailPassword.\nexport async function linkEmailPassword(\n  auth: Auth,\n  request: SignUpRequest\n): Promise<SignUpResponse> {\n  return _performApiRequest<SignUpRequest, SignUpResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_UP,\n    request\n  );\n}\n\nexport interface ApplyActionCodeRequest {\n  oobCode: string;\n  tenantId?: string;\n}\n\nexport interface ApplyActionCodeResponse {}\n\nexport async function applyActionCode(\n  auth: Auth,\n  request: ApplyActionCodeRequest\n): Promise<ApplyActionCodeResponse> {\n  return _performApiRequest<ApplyActionCodeRequest, ApplyActionCodeResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SET_ACCOUNT_INFO,\n    _addTidIfNecessary(auth, request)\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 { ActionCodeOperation, Auth } from '../../model/public_types';\n\nimport {\n  Endpoint,\n  HttpMethod,\n  RecaptchaClientType,\n  RecaptchaVersion,\n  _addTidIfNecessary,\n  _performApiRequest,\n  _performSignInRequest\n} from '../index';\nimport { IdToken, IdTokenResponse } from '../../model/id_token';\n\nexport interface SignInWithPasswordRequest {\n  returnSecureToken?: boolean;\n  email: string;\n  password: string;\n  tenantId?: string;\n  captchaResponse?: string;\n  clientType?: RecaptchaClientType;\n  recaptchaVersion?: RecaptchaVersion;\n}\n\nexport interface SignInWithPasswordResponse extends IdTokenResponse {\n  email: string;\n  displayName: string;\n}\n\nexport async function signInWithPassword(\n  auth: Auth,\n  request: SignInWithPasswordRequest\n): Promise<SignInWithPasswordResponse> {\n  return _performSignInRequest<\n    SignInWithPasswordRequest,\n    SignInWithPasswordResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_PASSWORD,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface GetOobCodeRequest {\n  email?: string; // Everything except VERIFY_AND_CHANGE_EMAIL\n  continueUrl?: string;\n  iOSBundleId?: string;\n  iosAppStoreId?: string;\n  androidPackageName?: string;\n  androidInstallApp?: boolean;\n  androidMinimumVersionCode?: string;\n  canHandleCodeInApp?: boolean;\n  dynamicLinkDomain?: string;\n  tenantId?: string;\n  targetProjectid?: string;\n}\n\nexport interface VerifyEmailRequest extends GetOobCodeRequest {\n  requestType: ActionCodeOperation.VERIFY_EMAIL;\n  idToken: IdToken;\n}\n\nexport interface PasswordResetRequest extends GetOobCodeRequest {\n  requestType: ActionCodeOperation.PASSWORD_RESET;\n  email: string;\n  captchaResp?: string;\n  clientType?: RecaptchaClientType;\n  recaptchaVersion?: RecaptchaVersion;\n}\n\nexport interface EmailSignInRequest extends GetOobCodeRequest {\n  requestType: ActionCodeOperation.EMAIL_SIGNIN;\n  email: string;\n  captchaResp?: string;\n  clientType?: RecaptchaClientType;\n  recaptchaVersion?: RecaptchaVersion;\n}\n\nexport interface VerifyAndChangeEmailRequest extends GetOobCodeRequest {\n  requestType: ActionCodeOperation.VERIFY_AND_CHANGE_EMAIL;\n  idToken: IdToken;\n  newEmail: string;\n}\n\ninterface GetOobCodeResponse {\n  email: string;\n}\n\nexport interface VerifyEmailResponse extends GetOobCodeResponse {}\nexport interface PasswordResetResponse extends GetOobCodeResponse {}\nexport interface EmailSignInResponse extends GetOobCodeResponse {}\nexport interface VerifyAndChangeEmailResponse extends GetOobCodeRequest {}\n\nasync function sendOobCode(\n  auth: Auth,\n  request: GetOobCodeRequest\n): Promise<GetOobCodeResponse> {\n  return _performApiRequest<GetOobCodeRequest, GetOobCodeResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SEND_OOB_CODE,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport async function sendEmailVerification(\n  auth: Auth,\n  request: VerifyEmailRequest\n): Promise<VerifyEmailResponse> {\n  return sendOobCode(auth, request);\n}\n\nexport async function sendPasswordResetEmail(\n  auth: Auth,\n  request: PasswordResetRequest\n): Promise<PasswordResetResponse> {\n  return sendOobCode(auth, request);\n}\n\nexport async function sendSignInLinkToEmail(\n  auth: Auth,\n  request: EmailSignInRequest\n): Promise<EmailSignInResponse> {\n  return sendOobCode(auth, request);\n}\n\nexport async function verifyAndChangeEmail(\n  auth: Auth,\n  request: VerifyAndChangeEmailRequest\n): Promise<VerifyAndChangeEmailResponse> {\n  return sendOobCode(auth, request);\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 { ProviderId, SignInMethod } from '../../model/enums';\n\nimport { linkEmailPassword } from '../../api/account_management/email_and_password';\nimport {\n  signInWithPassword,\n  SignInWithPasswordRequest\n} from '../../api/authentication/email_and_password';\nimport {\n  signInWithEmailLink,\n  signInWithEmailLinkForLinking\n} from '../../api/authentication/email_link';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { AuthErrorCode } from '../errors';\nimport { _fail } from '../util/assert';\nimport { AuthCredential } from './auth_credential';\nimport { handleRecaptchaFlow } from '../../platform_browser/recaptcha/recaptcha_enterprise_verifier';\nimport {\n  RecaptchaActionName,\n  RecaptchaClientType,\n  RecaptchaAuthProvider\n} from '../../api';\nimport { SignUpRequest } from '../../api/authentication/sign_up';\n/**\n * Interface that represents the credentials returned by {@link EmailAuthProvider} for\n * {@link ProviderId}.PASSWORD\n *\n * @remarks\n * Covers both {@link SignInMethod}.EMAIL_PASSWORD and\n * {@link SignInMethod}.EMAIL_LINK.\n *\n * @public\n */\nexport class EmailAuthCredential extends AuthCredential {\n  /** @internal */\n  private constructor(\n    /** @internal */\n    readonly _email: string,\n    /** @internal */\n    readonly _password: string,\n    signInMethod: SignInMethod,\n    /** @internal */\n    readonly _tenantId: string | null = null\n  ) {\n    super(ProviderId.PASSWORD, signInMethod);\n  }\n\n  /** @internal */\n  static _fromEmailAndPassword(\n    email: string,\n    password: string\n  ): EmailAuthCredential {\n    return new EmailAuthCredential(\n      email,\n      password,\n      SignInMethod.EMAIL_PASSWORD\n    );\n  }\n\n  /** @internal */\n  static _fromEmailAndCode(\n    email: string,\n    oobCode: string,\n    tenantId: string | null = null\n  ): EmailAuthCredential {\n    return new EmailAuthCredential(\n      email,\n      oobCode,\n      SignInMethod.EMAIL_LINK,\n      tenantId\n    );\n  }\n\n  /** {@inheritdoc AuthCredential.toJSON} */\n  toJSON(): object {\n    return {\n      email: this._email,\n      password: this._password,\n      signInMethod: this.signInMethod,\n      tenantId: this._tenantId\n    };\n  }\n\n  /**\n   * Static method to deserialize a JSON representation of an object into an {@link  AuthCredential}.\n   *\n   * @param json - Either `object` or the stringified representation of the object. When string is\n   * provided, `JSON.parse` would be called first.\n   *\n   * @returns If the JSON input does not represent an {@link AuthCredential}, null is returned.\n   */\n  static fromJSON(json: object | string): EmailAuthCredential | null {\n    const obj = typeof json === 'string' ? JSON.parse(json) : json;\n    if (obj?.email && obj?.password) {\n      if (obj.signInMethod === SignInMethod.EMAIL_PASSWORD) {\n        return this._fromEmailAndPassword(obj.email, obj.password);\n      } else if (obj.signInMethod === SignInMethod.EMAIL_LINK) {\n        return this._fromEmailAndCode(obj.email, obj.password, obj.tenantId);\n      }\n    }\n    return null;\n  }\n\n  /** @internal */\n  async _getIdTokenResponse(auth: AuthInternal): Promise<IdTokenResponse> {\n    switch (this.signInMethod) {\n      case SignInMethod.EMAIL_PASSWORD:\n        const request: SignInWithPasswordRequest = {\n          returnSecureToken: true,\n          email: this._email,\n          password: this._password,\n          clientType: RecaptchaClientType.WEB\n        };\n        return handleRecaptchaFlow(\n          auth,\n          request,\n          RecaptchaActionName.SIGN_IN_WITH_PASSWORD,\n          signInWithPassword,\n          RecaptchaAuthProvider.EMAIL_PASSWORD_PROVIDER\n        );\n      case SignInMethod.EMAIL_LINK:\n        return signInWithEmailLink(auth, {\n          email: this._email,\n          oobCode: this._password\n        });\n      default:\n        _fail(auth, AuthErrorCode.INTERNAL_ERROR);\n    }\n  }\n\n  /** @internal */\n  async _linkToIdToken(\n    auth: AuthInternal,\n    idToken: string\n  ): Promise<IdTokenResponse> {\n    switch (this.signInMethod) {\n      case SignInMethod.EMAIL_PASSWORD:\n        const request: SignUpRequest = {\n          idToken,\n          returnSecureToken: true,\n          email: this._email,\n          password: this._password,\n          clientType: RecaptchaClientType.WEB\n        };\n        return handleRecaptchaFlow(\n          auth,\n          request,\n          RecaptchaActionName.SIGN_UP_PASSWORD,\n          linkEmailPassword,\n          RecaptchaAuthProvider.EMAIL_PASSWORD_PROVIDER\n        );\n      case SignInMethod.EMAIL_LINK:\n        return signInWithEmailLinkForLinking(auth, {\n          idToken,\n          email: this._email,\n          oobCode: this._password\n        });\n      default:\n        _fail(auth, AuthErrorCode.INTERNAL_ERROR);\n    }\n  }\n\n  /** @internal */\n  _getReauthenticationResolver(auth: AuthInternal): Promise<IdTokenResponse> {\n    return this._getIdTokenResponse(auth);\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  _performSignInRequest,\n  Endpoint,\n  HttpMethod,\n  _addTidIfNecessary\n} from '../index';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { Auth } from '../../model/public_types';\n\nexport interface SignInWithEmailLinkRequest {\n  email: string;\n  oobCode: string;\n  tenantId?: string;\n}\n\nexport interface SignInWithEmailLinkResponse extends IdTokenResponse {\n  email: string;\n  isNewUser: boolean;\n}\n\nexport async function signInWithEmailLink(\n  auth: Auth,\n  request: SignInWithEmailLinkRequest\n): Promise<SignInWithEmailLinkResponse> {\n  return _performSignInRequest<\n    SignInWithEmailLinkRequest,\n    SignInWithEmailLinkResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_EMAIL_LINK,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface SignInWithEmailLinkForLinkingRequest\n  extends SignInWithEmailLinkRequest {\n  idToken: string;\n}\n\nexport async function signInWithEmailLinkForLinking(\n  auth: Auth,\n  request: SignInWithEmailLinkForLinkingRequest\n): Promise<SignInWithEmailLinkResponse> {\n  return _performSignInRequest<\n    SignInWithEmailLinkForLinkingRequest,\n    SignInWithEmailLinkResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_EMAIL_LINK,\n    _addTidIfNecessary(auth, request)\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  Endpoint,\n  HttpMethod,\n  _addTidIfNecessary,\n  _performSignInRequest\n} from '../index';\nimport { IdToken, IdTokenResponse } from '../../model/id_token';\nimport { Auth } from '../../model/public_types';\n\nexport interface SignInWithIdpRequest {\n  requestUri: string;\n  postBody?: string;\n  sessionId?: string;\n  tenantId?: string;\n  returnSecureToken: boolean;\n  returnIdpCredential?: boolean;\n  idToken?: IdToken;\n  autoCreate?: boolean;\n  pendingToken?: string;\n}\n\n/**\n * @internal\n */\nexport interface SignInWithIdpResponse extends IdTokenResponse {\n  oauthAccessToken?: string;\n  oauthTokenSecret?: string;\n  nonce?: string;\n  oauthIdToken?: string;\n  pendingToken?: string;\n}\n\nexport async function signInWithIdp(\n  auth: Auth,\n  request: SignInWithIdpRequest\n): Promise<SignInWithIdpResponse> {\n  return _performSignInRequest<SignInWithIdpRequest, SignInWithIdpResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_IDP,\n    _addTidIfNecessary(auth, request)\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 { querystring } from '@firebase/util';\n\nimport {\n  signInWithIdp,\n  SignInWithIdpRequest\n} from '../../api/authentication/idp';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { AuthErrorCode } from '../errors';\nimport { _fail } from '../util/assert';\nimport { AuthCredential } from './auth_credential';\n\nconst IDP_REQUEST_URI = 'http://localhost';\n\nexport interface OAuthCredentialParams {\n  // OAuth 2 uses either id token or access token\n  idToken?: string | null;\n  accessToken?: string | null;\n\n  // These fields are used with OAuth 1\n  oauthToken?: string;\n  secret?: string;\n  oauthTokenSecret?: string;\n\n  // Nonce is only set if pendingToken is not present\n  nonce?: string;\n  pendingToken?: string;\n\n  // Utilities\n  providerId: string;\n  signInMethod: string;\n}\n\n/**\n * Represents the OAuth credentials returned by an {@link OAuthProvider}.\n *\n * @remarks\n * Implementations specify the details about each auth provider's credential requirements.\n *\n * @public\n */\nexport class OAuthCredential extends AuthCredential {\n  /**\n   * The OAuth ID token associated with the credential if it belongs to an OIDC provider,\n   * such as `google.com`.\n   * @readonly\n   */\n  idToken?: string;\n  /**\n   * The OAuth access token associated with the credential if it belongs to an\n   * {@link OAuthProvider}, such as `facebook.com`, `twitter.com`, etc.\n   * @readonly\n   */\n  accessToken?: string;\n  /**\n   * The OAuth access token secret associated with the credential if it belongs to an OAuth 1.0\n   * provider, such as `twitter.com`.\n   * @readonly\n   */\n  secret?: string;\n\n  private nonce?: string;\n  private pendingToken: string | null = null;\n\n  /** @internal */\n  static _fromParams(params: OAuthCredentialParams): OAuthCredential {\n    const cred = new OAuthCredential(params.providerId, params.signInMethod);\n\n    if (params.idToken || params.accessToken) {\n      // OAuth 2 and either ID token or access token.\n      if (params.idToken) {\n        cred.idToken = params.idToken;\n      }\n\n      if (params.accessToken) {\n        cred.accessToken = params.accessToken;\n      }\n\n      // Add nonce if available and no pendingToken is present.\n      if (params.nonce && !params.pendingToken) {\n        cred.nonce = params.nonce;\n      }\n\n      if (params.pendingToken) {\n        cred.pendingToken = params.pendingToken;\n      }\n    } else if (params.oauthToken && params.oauthTokenSecret) {\n      // OAuth 1 and OAuth token with token secret\n      cred.accessToken = params.oauthToken;\n      cred.secret = params.oauthTokenSecret;\n    } else {\n      _fail(AuthErrorCode.ARGUMENT_ERROR);\n    }\n\n    return cred;\n  }\n\n  /** {@inheritdoc AuthCredential.toJSON}  */\n  toJSON(): object {\n    return {\n      idToken: this.idToken,\n      accessToken: this.accessToken,\n      secret: this.secret,\n      nonce: this.nonce,\n      pendingToken: this.pendingToken,\n      providerId: this.providerId,\n      signInMethod: this.signInMethod\n    };\n  }\n\n  /**\n   * Static method to deserialize a JSON representation of an object into an\n   * {@link  AuthCredential}.\n   *\n   * @param json - Input can be either Object or the stringified representation of the object.\n   * When string is provided, JSON.parse would be called first.\n   *\n   * @returns If the JSON input does not represent an {@link  AuthCredential}, null is returned.\n   */\n  static fromJSON(json: string | object): OAuthCredential | null {\n    const obj = typeof json === 'string' ? JSON.parse(json) : json;\n    const { providerId, signInMethod, ...rest }: OAuthCredentialParams = obj;\n    if (!providerId || !signInMethod) {\n      return null;\n    }\n\n    const cred = new OAuthCredential(providerId, signInMethod);\n    cred.idToken = rest.idToken || undefined;\n    cred.accessToken = rest.accessToken || undefined;\n    cred.secret = rest.secret;\n    cred.nonce = rest.nonce;\n    cred.pendingToken = rest.pendingToken || null;\n    return cred;\n  }\n\n  /** @internal */\n  _getIdTokenResponse(auth: AuthInternal): Promise<IdTokenResponse> {\n    const request = this.buildRequest();\n    return signInWithIdp(auth, request);\n  }\n\n  /** @internal */\n  _linkToIdToken(\n    auth: AuthInternal,\n    idToken: string\n  ): Promise<IdTokenResponse> {\n    const request = this.buildRequest();\n    request.idToken = idToken;\n    return signInWithIdp(auth, request);\n  }\n\n  /** @internal */\n  _getReauthenticationResolver(auth: AuthInternal): Promise<IdTokenResponse> {\n    const request = this.buildRequest();\n    request.autoCreate = false;\n    return signInWithIdp(auth, request);\n  }\n\n  private buildRequest(): SignInWithIdpRequest {\n    const request: SignInWithIdpRequest = {\n      requestUri: IDP_REQUEST_URI,\n      returnSecureToken: true\n    };\n\n    if (this.pendingToken) {\n      request.pendingToken = this.pendingToken;\n    } else {\n      const postBody: Record<string, string> = {};\n      if (this.idToken) {\n        postBody['id_token'] = this.idToken;\n      }\n      if (this.accessToken) {\n        postBody['access_token'] = this.accessToken;\n      }\n      if (this.secret) {\n        postBody['oauth_token_secret'] = this.secret;\n      }\n\n      postBody['providerId'] = this.providerId;\n      if (this.nonce && !this.pendingToken) {\n        postBody['nonce'] = this.nonce;\n      }\n\n      request.postBody = querystring(postBody);\n    }\n\n    return request;\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  Endpoint,\n  HttpMethod,\n  RecaptchaClientType,\n  RecaptchaVersion,\n  _addTidIfNecessary,\n  _makeTaggedError,\n  _performApiRequest,\n  _performSignInRequest\n} from '../index';\nimport { AuthErrorCode } from '../../core/errors';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { ServerError, ServerErrorMap } from '../errors';\nimport { Auth } from '../../model/public_types';\n\nexport interface SendPhoneVerificationCodeRequest {\n  phoneNumber: string;\n  // reCAPTCHA v2 token\n  recaptchaToken?: string;\n  tenantId?: string;\n  // reCAPTCHA Enterprise token\n  captchaResponse?: string;\n  clientType?: RecaptchaClientType;\n  recaptchaVersion?: RecaptchaVersion;\n}\n\nexport interface SendPhoneVerificationCodeResponse {\n  sessionInfo: string;\n}\n\nexport async function sendPhoneVerificationCode(\n  auth: Auth,\n  request: SendPhoneVerificationCodeRequest\n): Promise<SendPhoneVerificationCodeResponse> {\n  return _performApiRequest<\n    SendPhoneVerificationCodeRequest,\n    SendPhoneVerificationCodeResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SEND_VERIFICATION_CODE,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\n/**\n * @internal\n */\nexport interface SignInWithPhoneNumberRequest {\n  temporaryProof?: string;\n  phoneNumber?: string;\n  sessionInfo?: string;\n  code?: string;\n  tenantId?: string;\n}\n\nexport interface LinkWithPhoneNumberRequest\n  extends SignInWithPhoneNumberRequest {\n  idToken: string;\n}\n\n/**\n * @internal\n */\nexport interface SignInWithPhoneNumberResponse extends IdTokenResponse {\n  temporaryProof?: string;\n  phoneNumber?: string;\n}\n\nexport async function signInWithPhoneNumber(\n  auth: Auth,\n  request: SignInWithPhoneNumberRequest\n): Promise<SignInWithPhoneNumberResponse> {\n  return _performSignInRequest<\n    SignInWithPhoneNumberRequest,\n    SignInWithPhoneNumberResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_PHONE_NUMBER,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport async function linkWithPhoneNumber(\n  auth: Auth,\n  request: LinkWithPhoneNumberRequest\n): Promise<SignInWithPhoneNumberResponse> {\n  const response = await _performSignInRequest<\n    LinkWithPhoneNumberRequest,\n    SignInWithPhoneNumberResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_PHONE_NUMBER,\n    _addTidIfNecessary(auth, request)\n  );\n  if (response.temporaryProof) {\n    throw _makeTaggedError(auth, AuthErrorCode.NEED_CONFIRMATION, response);\n  }\n  return response;\n}\n\ninterface VerifyPhoneNumberForExistingRequest\n  extends SignInWithPhoneNumberRequest {\n  operation: 'REAUTH';\n}\n\nconst VERIFY_PHONE_NUMBER_FOR_EXISTING_ERROR_MAP_: Partial<\n  ServerErrorMap<ServerError>\n> = {\n  [ServerError.USER_NOT_FOUND]: AuthErrorCode.USER_DELETED\n};\n\nexport async function verifyPhoneNumberForExisting(\n  auth: Auth,\n  request: SignInWithPhoneNumberRequest\n): Promise<SignInWithPhoneNumberResponse> {\n  const apiRequest: VerifyPhoneNumberForExistingRequest = {\n    ...request,\n    operation: 'REAUTH'\n  };\n  return _performSignInRequest<\n    VerifyPhoneNumberForExistingRequest,\n    SignInWithPhoneNumberResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.SIGN_IN_WITH_PHONE_NUMBER,\n    _addTidIfNecessary(auth, apiRequest),\n    VERIFY_PHONE_NUMBER_FOR_EXISTING_ERROR_MAP_\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 { ProviderId, SignInMethod } from '../../model/enums';\n\nimport { PhoneOrOauthTokenResponse } from '../../api/authentication/mfa';\nimport {\n  linkWithPhoneNumber,\n  signInWithPhoneNumber,\n  SignInWithPhoneNumberRequest,\n  verifyPhoneNumberForExisting\n} from '../../api/authentication/sms';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { AuthCredential } from './auth_credential';\n\nexport interface PhoneAuthCredentialParameters {\n  verificationId?: string;\n  verificationCode?: string;\n  phoneNumber?: string;\n  temporaryProof?: string;\n}\n\n/**\n * Represents the credentials returned by {@link PhoneAuthProvider}.\n *\n * @public\n */\nexport class PhoneAuthCredential extends AuthCredential {\n  private constructor(private readonly params: PhoneAuthCredentialParameters) {\n    super(ProviderId.PHONE, SignInMethod.PHONE);\n  }\n\n  /** @internal */\n  static _fromVerification(\n    verificationId: string,\n    verificationCode: string\n  ): PhoneAuthCredential {\n    return new PhoneAuthCredential({ verificationId, verificationCode });\n  }\n\n  /** @internal */\n  static _fromTokenResponse(\n    phoneNumber: string,\n    temporaryProof: string\n  ): PhoneAuthCredential {\n    return new PhoneAuthCredential({ phoneNumber, temporaryProof });\n  }\n\n  /** @internal */\n  _getIdTokenResponse(auth: AuthInternal): Promise<PhoneOrOauthTokenResponse> {\n    return signInWithPhoneNumber(auth, this._makeVerificationRequest());\n  }\n\n  /** @internal */\n  _linkToIdToken(\n    auth: AuthInternal,\n    idToken: string\n  ): Promise<IdTokenResponse> {\n    return linkWithPhoneNumber(auth, {\n      idToken,\n      ...this._makeVerificationRequest()\n    });\n  }\n\n  /** @internal */\n  _getReauthenticationResolver(auth: AuthInternal): Promise<IdTokenResponse> {\n    return verifyPhoneNumberForExisting(auth, this._makeVerificationRequest());\n  }\n\n  /** @internal */\n  _makeVerificationRequest(): SignInWithPhoneNumberRequest {\n    const { temporaryProof, phoneNumber, verificationId, verificationCode } =\n      this.params;\n    if (temporaryProof && phoneNumber) {\n      return { temporaryProof, phoneNumber };\n    }\n\n    return {\n      sessionInfo: verificationId,\n      code: verificationCode\n    };\n  }\n\n  /** {@inheritdoc AuthCredential.toJSON} */\n  toJSON(): object {\n    const obj: Record<string, string> = {\n      providerId: this.providerId\n    };\n    if (this.params.phoneNumber) {\n      obj.phoneNumber = this.params.phoneNumber;\n    }\n    if (this.params.temporaryProof) {\n      obj.temporaryProof = this.params.temporaryProof;\n    }\n    if (this.params.verificationCode) {\n      obj.verificationCode = this.params.verificationCode;\n    }\n    if (this.params.verificationId) {\n      obj.verificationId = this.params.verificationId;\n    }\n\n    return obj;\n  }\n\n  /** Generates a phone credential based on a plain object or a JSON string. */\n  static fromJSON(json: object | string): PhoneAuthCredential | null {\n    if (typeof json === 'string') {\n      json = JSON.parse(json);\n    }\n\n    const { verificationId, verificationCode, phoneNumber, temporaryProof } =\n      json as { [key: string]: string };\n    if (\n      !verificationCode &&\n      !verificationId &&\n      !phoneNumber &&\n      !temporaryProof\n    ) {\n      return null;\n    }\n\n    return new PhoneAuthCredential({\n      verificationId,\n      verificationCode,\n      phoneNumber,\n      temporaryProof\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 { extractQuerystring, querystringDecode } from '@firebase/util';\nimport { ActionCodeOperation } from '../model/public_types';\nimport { AuthErrorCode } from './errors';\nimport { _assert } from './util/assert';\n\n/**\n * Enums for fields in URL query string.\n *\n * @enum {string}\n */\nconst enum QueryField {\n  API_KEY = 'apiKey',\n  CODE = 'oobCode',\n  CONTINUE_URL = 'continueUrl',\n  LANGUAGE_CODE = 'languageCode',\n  MODE = 'mode',\n  TENANT_ID = 'tenantId'\n}\n\n/**\n * Maps the mode string in action code URL to Action Code Info operation.\n *\n * @param mode\n */\nfunction parseMode(mode: string | null): ActionCodeOperation | null {\n  switch (mode) {\n    case 'recoverEmail':\n      return ActionCodeOperation.RECOVER_EMAIL;\n    case 'resetPassword':\n      return ActionCodeOperation.PASSWORD_RESET;\n    case 'signIn':\n      return ActionCodeOperation.EMAIL_SIGNIN;\n    case 'verifyEmail':\n      return ActionCodeOperation.VERIFY_EMAIL;\n    case 'verifyAndChangeEmail':\n      return ActionCodeOperation.VERIFY_AND_CHANGE_EMAIL;\n    case 'revertSecondFactorAddition':\n      return ActionCodeOperation.REVERT_SECOND_FACTOR_ADDITION;\n    default:\n      return null;\n  }\n}\n\n/**\n * Helper to parse FDL links\n *\n * @param url\n */\nfunction parseDeepLink(url: string): string {\n  const link = querystringDecode(extractQuerystring(url))['link'];\n\n  // Double link case (automatic redirect).\n  const doubleDeepLink = link\n    ? querystringDecode(extractQuerystring(link))['deep_link_id']\n    : null;\n  // iOS custom scheme links.\n  const iOSDeepLink = querystringDecode(extractQuerystring(url))[\n    'deep_link_id'\n  ];\n  const iOSDoubleDeepLink = iOSDeepLink\n    ? querystringDecode(extractQuerystring(iOSDeepLink))['link']\n    : null;\n  return iOSDoubleDeepLink || iOSDeepLink || doubleDeepLink || link || url;\n}\n\n/**\n * A utility class to parse email action URLs such as password reset, email verification,\n * email link sign in, etc.\n *\n * @public\n */\nexport class ActionCodeURL {\n  /**\n   * The API key of the email action link.\n   */\n  readonly apiKey: string;\n  /**\n   * The action code of the email action link.\n   */\n  readonly code: string;\n  /**\n   * The continue URL of the email action link. Null if not provided.\n   */\n  readonly continueUrl: string | null;\n  /**\n   * The language code of the email action link. Null if not provided.\n   */\n  readonly languageCode: string | null;\n  /**\n   * The action performed by the email action link. It returns from one of the types from\n   * {@link ActionCodeInfo}\n   */\n  readonly operation: string;\n  /**\n   * The tenant ID of the email action link. Null if the email action is from the parent project.\n   */\n  readonly tenantId: string | null;\n\n  /**\n   * @param actionLink - The link from which to extract the URL.\n   * @returns The {@link ActionCodeURL} object, or null if the link is invalid.\n   *\n   * @internal\n   */\n  constructor(actionLink: string) {\n    const searchParams = querystringDecode(extractQuerystring(actionLink));\n    const apiKey = searchParams[QueryField.API_KEY] ?? null;\n    const code = searchParams[QueryField.CODE] ?? null;\n    const operation = parseMode(searchParams[QueryField.MODE] ?? null);\n    // Validate API key, code and mode.\n    _assert(apiKey && code && operation, AuthErrorCode.ARGUMENT_ERROR);\n    this.apiKey = apiKey;\n    this.operation = operation;\n    this.code = code;\n    this.continueUrl = searchParams[QueryField.CONTINUE_URL] ?? null;\n    this.languageCode = searchParams[QueryField.LANGUAGE_CODE] ?? null;\n    this.tenantId = searchParams[QueryField.TENANT_ID] ?? null;\n  }\n\n  /**\n   * Parses the email action link string and returns an {@link ActionCodeURL} if the link is valid,\n   * otherwise returns null.\n   *\n   * @param link  - The email action link string.\n   * @returns The {@link ActionCodeURL} object, or null if the link is invalid.\n   *\n   * @public\n   */\n  static parseLink(link: string): ActionCodeURL | null {\n    const actionLink = parseDeepLink(link);\n    try {\n      return new ActionCodeURL(actionLink);\n    } catch {\n      return null;\n    }\n  }\n}\n\n/**\n * Parses the email action link string and returns an {@link ActionCodeURL} if\n * the link is valid, otherwise returns null.\n *\n * @public\n */\nexport function parseActionCodeURL(link: string): ActionCodeURL | null {\n  return ActionCodeURL.parseLink(link);\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 { ProviderId, SignInMethod } from '../../model/enums';\nimport { AuthProvider } from '../../model/public_types';\n\nimport { ActionCodeURL } from '../action_code_url';\nimport { EmailAuthCredential } from '../credentials/email';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from '../util/assert';\n\n/**\n * Provider for generating {@link EmailAuthCredential}.\n *\n * @public\n */\nexport class EmailAuthProvider implements AuthProvider {\n  /**\n   * Always set to {@link ProviderId}.PASSWORD, even for email link.\n   */\n  static readonly PROVIDER_ID: 'password' = ProviderId.PASSWORD;\n  /**\n   * Always set to {@link SignInMethod}.EMAIL_PASSWORD.\n   */\n  static readonly EMAIL_PASSWORD_SIGN_IN_METHOD: 'password' =\n    SignInMethod.EMAIL_PASSWORD;\n  /**\n   * Always set to {@link SignInMethod}.EMAIL_LINK.\n   */\n  static readonly EMAIL_LINK_SIGN_IN_METHOD: 'emailLink' =\n    SignInMethod.EMAIL_LINK;\n  /**\n   * Always set to {@link ProviderId}.PASSWORD, even for email link.\n   */\n  readonly providerId = EmailAuthProvider.PROVIDER_ID;\n\n  /**\n   * Initialize an {@link AuthCredential} using an email and password.\n   *\n   * @example\n   * ```javascript\n   * const authCredential = EmailAuthProvider.credential(email, password);\n   * const userCredential = await signInWithCredential(auth, authCredential);\n   * ```\n   *\n   * @example\n   * ```javascript\n   * const userCredential = await signInWithEmailAndPassword(auth, email, password);\n   * ```\n   *\n   * @param email - Email address.\n   * @param password - User account password.\n   * @returns The auth provider credential.\n   */\n  static credential(email: string, password: string): EmailAuthCredential {\n    return EmailAuthCredential._fromEmailAndPassword(email, password);\n  }\n\n  /**\n   * Initialize an {@link AuthCredential} using an email and an email link after a sign in with\n   * email link operation.\n   *\n   * @example\n   * ```javascript\n   * const authCredential = EmailAuthProvider.credentialWithLink(auth, email, emailLink);\n   * const userCredential = await signInWithCredential(auth, authCredential);\n   * ```\n   *\n   * @example\n   * ```javascript\n   * await sendSignInLinkToEmail(auth, email);\n   * // Obtain emailLink from user.\n   * const userCredential = await signInWithEmailLink(auth, email, emailLink);\n   * ```\n   *\n   * @param auth - The {@link Auth} instance used to verify the link.\n   * @param email - Email address.\n   * @param emailLink - Sign-in email link.\n   * @returns - The auth provider credential.\n   */\n  static credentialWithLink(\n    email: string,\n    emailLink: string\n  ): EmailAuthCredential {\n    const actionCodeUrl = ActionCodeURL.parseLink(emailLink);\n    _assert(actionCodeUrl, AuthErrorCode.ARGUMENT_ERROR);\n\n    return EmailAuthCredential._fromEmailAndCode(\n      email,\n      actionCodeUrl.code,\n      actionCodeUrl.tenantId\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 { AuthProvider } from '../../model/public_types';\n\n/**\n * Map of OAuth Custom Parameters.\n *\n * @public\n */\nexport type CustomParameters = Record<string, string>;\n\n/**\n * The base class for all Federated providers (OAuth (including OIDC), SAML).\n *\n * This class is not meant to be instantiated directly.\n *\n * @public\n */\nexport abstract class FederatedAuthProvider implements AuthProvider {\n  /** @internal */\n  defaultLanguageCode: string | null = null;\n  /** @internal */\n  private customParameters: CustomParameters = {};\n\n  /**\n   * Constructor for generic OAuth providers.\n   *\n   * @param providerId - Provider for which credentials should be generated.\n   */\n  constructor(readonly providerId: string) {}\n\n  /**\n   * Set the language gode.\n   *\n   * @param languageCode - language code\n   */\n  setDefaultLanguage(languageCode: string | null): void {\n    this.defaultLanguageCode = languageCode;\n  }\n\n  /**\n   * Sets the OAuth custom parameters to pass in an OAuth request for popup and redirect sign-in\n   * operations.\n   *\n   * @remarks\n   * For a detailed list, check the reserved required OAuth 2.0 parameters such as `client_id`,\n   * `redirect_uri`, `scope`, `response_type`, and `state` are not allowed and will be ignored.\n   *\n   * @param customOAuthParameters - The custom OAuth parameters to pass in the OAuth request.\n   */\n  setCustomParameters(customOAuthParameters: CustomParameters): AuthProvider {\n    this.customParameters = customOAuthParameters;\n    return this;\n  }\n\n  /**\n   * Retrieve the current list of {@link CustomParameters}.\n   */\n  getCustomParameters(): CustomParameters {\n    return this.customParameters;\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 { AuthProvider, UserCredential } from '../../model/public_types';\n\nimport { _assert } from '../util/assert';\nimport { AuthErrorCode } from '../errors';\n\nimport { OAuthCredential, OAuthCredentialParams } from '../credentials/oauth';\nimport { UserCredentialInternal } from '../../model/user';\nimport { FirebaseError } from '@firebase/util';\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { SignInWithIdpResponse } from '../../../internal';\nimport { FederatedAuthProvider } from './federated';\n\n/**\n * Defines the options for initializing an {@link OAuthCredential}.\n *\n * @remarks\n * For ID tokens with nonce claim, the raw nonce has to also be provided.\n *\n * @public\n */\nexport interface OAuthCredentialOptions {\n  /**\n   * The OAuth ID token used to initialize the {@link OAuthCredential}.\n   */\n  idToken?: string;\n  /**\n   * The OAuth access token used to initialize the {@link OAuthCredential}.\n   */\n  accessToken?: string;\n  /**\n   * The raw nonce associated with the ID token.\n   *\n   * @remarks\n   * It is required when an ID token with a nonce field is provided. The SHA-256 hash of the\n   * raw nonce must match the nonce field in the ID token.\n   */\n  rawNonce?: string;\n}\n\n/**\n * Common code to all OAuth providers. This is separate from the\n * {@link OAuthProvider} so that child providers (like\n * {@link GoogleAuthProvider}) don't inherit the `credential` instance method.\n * Instead, they rely on a static `credential` method.\n */\nexport abstract class BaseOAuthProvider\n  extends FederatedAuthProvider\n  implements AuthProvider\n{\n  /** @internal */\n  private scopes: string[] = [];\n\n  /**\n   * Add an OAuth scope to the credential.\n   *\n   * @param scope - Provider OAuth scope to add.\n   */\n  addScope(scope: string): AuthProvider {\n    // If not already added, add scope to list.\n    if (!this.scopes.includes(scope)) {\n      this.scopes.push(scope);\n    }\n    return this;\n  }\n\n  /**\n   * Retrieve the current list of OAuth scopes.\n   */\n  getScopes(): string[] {\n    return [...this.scopes];\n  }\n}\n\n/**\n * Provider for generating generic {@link OAuthCredential}.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new OAuthProvider('google.com');\n * // Start a sign in process for an unauthenticated user.\n * provider.addScope('profile');\n * provider.addScope('email');\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a OAuth Access Token for the provider.\n *   const credential = provider.credentialFromResult(auth, result);\n *   const token = credential.accessToken;\n * }\n * ```\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new OAuthProvider('google.com');\n * provider.addScope('profile');\n * provider.addScope('email');\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a OAuth Access Token for the provider.\n * const credential = provider.credentialFromResult(auth, result);\n * const token = credential.accessToken;\n * ```\n * @public\n */\nexport class OAuthProvider extends BaseOAuthProvider {\n  /**\n   * Creates an {@link OAuthCredential} from a JSON string or a plain object.\n   * @param json - A plain object or a JSON string\n   */\n  static credentialFromJSON(json: object | string): OAuthCredential {\n    const obj = typeof json === 'string' ? JSON.parse(json) : json;\n    _assert(\n      'providerId' in obj && 'signInMethod' in obj,\n      AuthErrorCode.ARGUMENT_ERROR\n    );\n    return OAuthCredential._fromParams(obj);\n  }\n\n  /**\n   * Creates a {@link OAuthCredential} from a generic OAuth provider's access token or ID token.\n   *\n   * @remarks\n   * The raw nonce is required when an ID token with a nonce field is provided. The SHA-256 hash of\n   * the raw nonce must match the nonce field in the ID token.\n   *\n   * @example\n   * ```javascript\n   * // `googleUser` from the onsuccess Google Sign In callback.\n   * // Initialize a generate OAuth provider with a `google.com` providerId.\n   * const provider = new OAuthProvider('google.com');\n   * const credential = provider.credential({\n   *   idToken: googleUser.getAuthResponse().id_token,\n   * });\n   * const result = await signInWithCredential(credential);\n   * ```\n   *\n   * @param params - Either the options object containing the ID token, access token and raw nonce\n   * or the ID token string.\n   */\n  credential(params: OAuthCredentialOptions): OAuthCredential {\n    return this._credential({ ...params, nonce: params.rawNonce });\n  }\n\n  /** An internal credential method that accepts more permissive options */\n  private _credential(\n    params: Omit<OAuthCredentialParams, 'signInMethod' | 'providerId'>\n  ): OAuthCredential {\n    _assert(params.idToken || params.accessToken, AuthErrorCode.ARGUMENT_ERROR);\n    // For OAuthCredential, sign in method is same as providerId.\n    return OAuthCredential._fromParams({\n      ...params,\n      providerId: this.providerId,\n      signInMethod: this.providerId\n    });\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link UserCredential}.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): OAuthCredential | null {\n    return OAuthProvider.oauthCredentialFromTaggedObject(\n      userCredential as UserCredentialInternal\n    );\n  }\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link AuthError} which was\n   * thrown during a sign-in, link, or reauthenticate operation.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromError(error: FirebaseError): OAuthCredential | null {\n    return OAuthProvider.oauthCredentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static oauthCredentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): OAuthCredential | null {\n    if (!tokenResponse) {\n      return null;\n    }\n\n    const {\n      oauthIdToken,\n      oauthAccessToken,\n      oauthTokenSecret,\n      pendingToken,\n      nonce,\n      providerId\n    } = tokenResponse as SignInWithIdpResponse;\n    if (\n      !oauthAccessToken &&\n      !oauthTokenSecret &&\n      !oauthIdToken &&\n      !pendingToken\n    ) {\n      return null;\n    }\n\n    if (!providerId) {\n      return null;\n    }\n\n    try {\n      return new OAuthProvider(providerId)._credential({\n        idToken: oauthIdToken,\n        accessToken: oauthAccessToken,\n        nonce,\n        pendingToken\n      });\n    } catch (e) {\n      return null;\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 { UserCredential } from '../../model/public_types';\nimport { FirebaseError } from '@firebase/util';\n\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { UserCredentialInternal } from '../../model/user';\nimport { OAuthCredential } from '../credentials/oauth';\nimport { BaseOAuthProvider } from './oauth';\nimport { ProviderId, SignInMethod } from '../../model/enums';\n\n/**\n * Provider for generating an {@link OAuthCredential} for {@link ProviderId}.FACEBOOK.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new FacebookAuthProvider();\n * // Start a sign in process for an unauthenticated user.\n * provider.addScope('user_birthday');\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a Facebook Access Token.\n *   const credential = FacebookAuthProvider.credentialFromResult(result);\n *   const token = credential.accessToken;\n * }\n * ```\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new FacebookAuthProvider();\n * provider.addScope('user_birthday');\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a Facebook Access Token.\n * const credential = FacebookAuthProvider.credentialFromResult(result);\n * const token = credential.accessToken;\n * ```\n *\n * @public\n */\nexport class FacebookAuthProvider extends BaseOAuthProvider {\n  /** Always set to {@link SignInMethod}.FACEBOOK. */\n  static readonly FACEBOOK_SIGN_IN_METHOD: 'facebook.com' =\n    SignInMethod.FACEBOOK;\n  /** Always set to {@link ProviderId}.FACEBOOK. */\n  static readonly PROVIDER_ID: 'facebook.com' = ProviderId.FACEBOOK;\n\n  constructor() {\n    super(ProviderId.FACEBOOK);\n  }\n\n  /**\n   * Creates a credential for Facebook.\n   *\n   * @example\n   * ```javascript\n   * // `event` from the Facebook auth.authResponseChange callback.\n   * const credential = FacebookAuthProvider.credential(event.authResponse.accessToken);\n   * const result = await signInWithCredential(credential);\n   * ```\n   *\n   * @param accessToken - Facebook access token.\n   */\n  static credential(accessToken: string): OAuthCredential {\n    return OAuthCredential._fromParams({\n      providerId: FacebookAuthProvider.PROVIDER_ID,\n      signInMethod: FacebookAuthProvider.FACEBOOK_SIGN_IN_METHOD,\n      accessToken\n    });\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link UserCredential}.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): OAuthCredential | null {\n    return FacebookAuthProvider.credentialFromTaggedObject(\n      userCredential as UserCredentialInternal\n    );\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link AuthError} which was\n   * thrown during a sign-in, link, or reauthenticate operation.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromError(error: FirebaseError): OAuthCredential | null {\n    return FacebookAuthProvider.credentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static credentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): OAuthCredential | null {\n    if (!tokenResponse || !('oauthAccessToken' in tokenResponse)) {\n      return null;\n    }\n\n    if (!tokenResponse.oauthAccessToken) {\n      return null;\n    }\n\n    try {\n      return FacebookAuthProvider.credential(tokenResponse.oauthAccessToken);\n    } catch {\n      return null;\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 { UserCredential } from '../../model/public_types';\nimport { FirebaseError } from '@firebase/util';\n\nimport { SignInWithIdpResponse } from '../../api/authentication/idp';\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { UserCredentialInternal } from '../../model/user';\nimport { OAuthCredential } from '../credentials/oauth';\nimport { BaseOAuthProvider } from './oauth';\nimport { ProviderId, SignInMethod } from '../../model/enums';\n\n/**\n * Provider for generating an {@link OAuthCredential} for {@link ProviderId}.GOOGLE.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new GoogleAuthProvider();\n * // Start a sign in process for an unauthenticated user.\n * provider.addScope('profile');\n * provider.addScope('email');\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a Google Access Token.\n *   const credential = GoogleAuthProvider.credentialFromResult(result);\n *   const token = credential.accessToken;\n * }\n * ```\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new GoogleAuthProvider();\n * provider.addScope('profile');\n * provider.addScope('email');\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a Google Access Token.\n * const credential = GoogleAuthProvider.credentialFromResult(result);\n * const token = credential.accessToken;\n * ```\n *\n * @public\n */\nexport class GoogleAuthProvider extends BaseOAuthProvider {\n  /** Always set to {@link SignInMethod}.GOOGLE. */\n  static readonly GOOGLE_SIGN_IN_METHOD: 'google.com' = SignInMethod.GOOGLE;\n  /** Always set to {@link ProviderId}.GOOGLE. */\n  static readonly PROVIDER_ID: 'google.com' = ProviderId.GOOGLE;\n\n  constructor() {\n    super(ProviderId.GOOGLE);\n    this.addScope('profile');\n  }\n\n  /**\n   * Creates a credential for Google. At least one of ID token and access token is required.\n   *\n   * @example\n   * ```javascript\n   * // \\`googleUser\\` from the onsuccess Google Sign In callback.\n   * const credential = GoogleAuthProvider.credential(googleUser.getAuthResponse().id_token);\n   * const result = await signInWithCredential(credential);\n   * ```\n   *\n   * @param idToken - Google ID token.\n   * @param accessToken - Google access token.\n   */\n  static credential(\n    idToken?: string | null,\n    accessToken?: string | null\n  ): OAuthCredential {\n    return OAuthCredential._fromParams({\n      providerId: GoogleAuthProvider.PROVIDER_ID,\n      signInMethod: GoogleAuthProvider.GOOGLE_SIGN_IN_METHOD,\n      idToken,\n      accessToken\n    });\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link UserCredential}.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): OAuthCredential | null {\n    return GoogleAuthProvider.credentialFromTaggedObject(\n      userCredential as UserCredentialInternal\n    );\n  }\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link AuthError} which was\n   * thrown during a sign-in, link, or reauthenticate operation.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromError(error: FirebaseError): OAuthCredential | null {\n    return GoogleAuthProvider.credentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static credentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): OAuthCredential | null {\n    if (!tokenResponse) {\n      return null;\n    }\n\n    const { oauthIdToken, oauthAccessToken } =\n      tokenResponse as SignInWithIdpResponse;\n    if (!oauthIdToken && !oauthAccessToken) {\n      // This could be an oauth 1 credential or a phone credential\n      return null;\n    }\n\n    try {\n      return GoogleAuthProvider.credential(oauthIdToken, oauthAccessToken);\n    } catch {\n      return null;\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 { UserCredential } from '../../model/public_types';\nimport { FirebaseError } from '@firebase/util';\n\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { UserCredentialInternal } from '../../model/user';\nimport { OAuthCredential } from '../credentials/oauth';\nimport { BaseOAuthProvider } from './oauth';\nimport { ProviderId, SignInMethod } from '../../model/enums';\n\n/**\n * Provider for generating an {@link OAuthCredential} for {@link ProviderId}.GITHUB.\n *\n * @remarks\n * GitHub requires an OAuth 2.0 redirect, so you can either handle the redirect directly, or use\n * the {@link signInWithPopup} handler:\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new GithubAuthProvider();\n * // Start a sign in process for an unauthenticated user.\n * provider.addScope('repo');\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a GitHub Access Token.\n *   const credential = GithubAuthProvider.credentialFromResult(result);\n *   const token = credential.accessToken;\n * }\n * ```\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new GithubAuthProvider();\n * provider.addScope('repo');\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a GitHub Access Token.\n * const credential = GithubAuthProvider.credentialFromResult(result);\n * const token = credential.accessToken;\n * ```\n * @public\n */\nexport class GithubAuthProvider extends BaseOAuthProvider {\n  /** Always set to {@link SignInMethod}.GITHUB. */\n  static readonly GITHUB_SIGN_IN_METHOD: 'github.com' = SignInMethod.GITHUB;\n  /** Always set to {@link ProviderId}.GITHUB. */\n  static readonly PROVIDER_ID: 'github.com' = ProviderId.GITHUB;\n\n  constructor() {\n    super(ProviderId.GITHUB);\n  }\n\n  /**\n   * Creates a credential for GitHub.\n   *\n   * @param accessToken - GitHub access token.\n   */\n  static credential(accessToken: string): OAuthCredential {\n    return OAuthCredential._fromParams({\n      providerId: GithubAuthProvider.PROVIDER_ID,\n      signInMethod: GithubAuthProvider.GITHUB_SIGN_IN_METHOD,\n      accessToken\n    });\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link UserCredential}.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): OAuthCredential | null {\n    return GithubAuthProvider.credentialFromTaggedObject(\n      userCredential as UserCredentialInternal\n    );\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link AuthError} which was\n   * thrown during a sign-in, link, or reauthenticate operation.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromError(error: FirebaseError): OAuthCredential | null {\n    return GithubAuthProvider.credentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static credentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): OAuthCredential | null {\n    if (!tokenResponse || !('oauthAccessToken' in tokenResponse)) {\n      return null;\n    }\n\n    if (!tokenResponse.oauthAccessToken) {\n      return null;\n    }\n\n    try {\n      return GithubAuthProvider.credential(tokenResponse.oauthAccessToken);\n    } catch {\n      return null;\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/**\n * @license\n * Copyright 2020 Twitter LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { UserCredential } from '../../model/public_types';\nimport { FirebaseError } from '@firebase/util';\n\nimport { SignInWithIdpResponse } from '../../api/authentication/idp';\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { UserCredentialInternal } from '../../model/user';\nimport { OAuthCredential } from '../credentials/oauth';\nimport { BaseOAuthProvider } from './oauth';\nimport { ProviderId, SignInMethod } from '../../model/enums';\n\n/**\n * Provider for generating an {@link OAuthCredential} for {@link ProviderId}.TWITTER.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new TwitterAuthProvider();\n * // Start a sign in process for an unauthenticated user.\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a Twitter Access Token and Secret.\n *   const credential = TwitterAuthProvider.credentialFromResult(result);\n *   const token = credential.accessToken;\n *   const secret = credential.secret;\n * }\n * ```\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new TwitterAuthProvider();\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a Twitter Access Token and Secret.\n * const credential = TwitterAuthProvider.credentialFromResult(result);\n * const token = credential.accessToken;\n * const secret = credential.secret;\n * ```\n *\n * @public\n */\nexport class TwitterAuthProvider extends BaseOAuthProvider {\n  /** Always set to {@link SignInMethod}.TWITTER. */\n  static readonly TWITTER_SIGN_IN_METHOD: 'twitter.com' = SignInMethod.TWITTER;\n  /** Always set to {@link ProviderId}.TWITTER. */\n  static readonly PROVIDER_ID: 'twitter.com' = ProviderId.TWITTER;\n\n  constructor() {\n    super(ProviderId.TWITTER);\n  }\n\n  /**\n   * Creates a credential for Twitter.\n   *\n   * @param token - Twitter access token.\n   * @param secret - Twitter secret.\n   */\n  static credential(token: string, secret: string): OAuthCredential {\n    return OAuthCredential._fromParams({\n      providerId: TwitterAuthProvider.PROVIDER_ID,\n      signInMethod: TwitterAuthProvider.TWITTER_SIGN_IN_METHOD,\n      oauthToken: token,\n      oauthTokenSecret: secret\n    });\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link UserCredential}.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): OAuthCredential | null {\n    return TwitterAuthProvider.credentialFromTaggedObject(\n      userCredential as UserCredentialInternal\n    );\n  }\n\n  /**\n   * Used to extract the underlying {@link OAuthCredential} from a {@link AuthError} which was\n   * thrown during a sign-in, link, or reauthenticate operation.\n   *\n   * @param userCredential - The user credential.\n   */\n  static credentialFromError(error: FirebaseError): OAuthCredential | null {\n    return TwitterAuthProvider.credentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static credentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): OAuthCredential | null {\n    if (!tokenResponse) {\n      return null;\n    }\n    const { oauthAccessToken, oauthTokenSecret } =\n      tokenResponse as SignInWithIdpResponse;\n    if (!oauthAccessToken || !oauthTokenSecret) {\n      return null;\n    }\n\n    try {\n      return TwitterAuthProvider.credential(oauthAccessToken, oauthTokenSecret);\n    } catch {\n      return null;\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 { PhoneOrOauthTokenResponse } from '../../api/authentication/mfa';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { UserInternal, UserCredentialInternal } from '../../model/user';\nimport { UserImpl } from './user_impl';\nimport { AuthInternal } from '../../model/auth';\nimport { OperationType, ProviderId } from '../../model/enums';\n\ninterface UserCredentialParams {\n  readonly user: UserInternal;\n  readonly providerId: ProviderId | string | null;\n  readonly _tokenResponse?: PhoneOrOauthTokenResponse;\n  readonly operationType: OperationType;\n}\n\nexport class UserCredentialImpl\n  implements UserCredentialInternal, UserCredentialParams\n{\n  readonly user: UserInternal;\n  readonly providerId: ProviderId | string | null;\n  readonly _tokenResponse: PhoneOrOauthTokenResponse | undefined;\n  readonly operationType: OperationType;\n\n  constructor(params: UserCredentialParams) {\n    this.user = params.user;\n    this.providerId = params.providerId;\n    this._tokenResponse = params._tokenResponse;\n    this.operationType = params.operationType;\n  }\n\n  static async _fromIdTokenResponse(\n    auth: AuthInternal,\n    operationType: OperationType,\n    idTokenResponse: IdTokenResponse,\n    isAnonymous: boolean = false\n  ): Promise<UserCredentialInternal> {\n    const user = await UserImpl._fromIdTokenResponse(\n      auth,\n      idTokenResponse,\n      isAnonymous\n    );\n    const providerId = providerIdForResponse(idTokenResponse);\n    const userCred = new UserCredentialImpl({\n      user,\n      providerId,\n      _tokenResponse: idTokenResponse,\n      operationType\n    });\n    return userCred;\n  }\n\n  static async _forOperation(\n    user: UserInternal,\n    operationType: OperationType,\n    response: PhoneOrOauthTokenResponse\n  ): Promise<UserCredentialImpl> {\n    await user._updateTokensIfNecessary(response, /* reload */ true);\n    const providerId = providerIdForResponse(response);\n    return new UserCredentialImpl({\n      user,\n      providerId,\n      _tokenResponse: response,\n      operationType\n    });\n  }\n}\n\nfunction providerIdForResponse(\n  response: IdTokenResponse\n): ProviderId | string | null {\n  if (response.providerId) {\n    return response.providerId;\n  }\n\n  if ('phoneNumber' in response) {\n    return ProviderId.PHONE;\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\nimport { MultiFactorError as MultiFactorErrorPublic } from '../model/public_types';\nimport { FirebaseError } from '@firebase/util';\nimport { AuthInternal } from '../model/auth';\nimport { IdTokenResponse } from '../model/id_token';\nimport { AuthErrorCode } from '../core/errors';\nimport { UserInternal } from '../model/user';\nimport { AuthCredential } from '../core/credentials';\nimport { IdTokenMfaResponse } from '../api/authentication/mfa';\nimport { OperationType } from '../model/enums';\n\nexport type MultiFactorErrorData = MultiFactorErrorPublic['customData'] & {\n  _serverResponse: IdTokenMfaResponse;\n};\n\nexport class MultiFactorError\n  extends FirebaseError\n  implements MultiFactorErrorPublic\n{\n  readonly customData: MultiFactorErrorData;\n\n  private constructor(\n    auth: AuthInternal,\n    error: FirebaseError,\n    readonly operationType: OperationType,\n    readonly user?: UserInternal\n  ) {\n    super(error.code, error.message);\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, MultiFactorError.prototype);\n    this.customData = {\n      appName: auth.name,\n      tenantId: auth.tenantId ?? undefined,\n      _serverResponse: error.customData!._serverResponse as IdTokenMfaResponse,\n      operationType\n    };\n  }\n\n  static _fromErrorAndOperation(\n    auth: AuthInternal,\n    error: FirebaseError,\n    operationType: OperationType,\n    user?: UserInternal\n  ): MultiFactorError {\n    return new MultiFactorError(auth, error, operationType, user);\n  }\n}\n\nexport function _processCredentialSavingMfaContextIfNecessary(\n  auth: AuthInternal,\n  operationType: OperationType,\n  credential: AuthCredential,\n  user?: UserInternal\n): Promise<IdTokenResponse> {\n  const idTokenProvider =\n    operationType === OperationType.REAUTHENTICATE\n      ? credential._getReauthenticationResolver(auth)\n      : credential._getIdTokenResponse(auth);\n\n  return idTokenProvider.catch(error => {\n    if (error.code === `auth/${AuthErrorCode.MFA_REQUIRED}`) {\n      throw MultiFactorError._fromErrorAndOperation(\n        auth,\n        error,\n        operationType,\n        user\n      );\n    }\n\n    throw error;\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 { User } from '../../model/public_types';\n\nimport { deleteLinkedAccounts } from '../../api/account_management/account';\nimport { UserInternal, UserCredentialInternal } from '../../model/user';\nimport { AuthCredential } from '../credentials';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from '../util/assert';\nimport { providerDataAsNames } from '../util/providers';\nimport { _logoutIfInvalidated } from './invalidation';\nimport { _reloadWithoutSaving } from './reload';\nimport { UserCredentialImpl } from './user_credential_impl';\nimport { getModularInstance } from '@firebase/util';\nimport { OperationType, ProviderId } from '../../model/enums';\n\n/**\n * Unlinks a provider from a user account.\n *\n * @param user - The user.\n * @param providerId - The provider to unlink.\n *\n * @public\n */\nexport async function unlink(user: User, providerId: string): Promise<User> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  await _assertLinkedStatus(true, userInternal, providerId);\n  const { providerUserInfo } = await deleteLinkedAccounts(userInternal.auth, {\n    idToken: await userInternal.getIdToken(),\n    deleteProvider: [providerId]\n  });\n\n  const providersLeft = providerDataAsNames(providerUserInfo || []);\n\n  userInternal.providerData = userInternal.providerData.filter(pd =>\n    providersLeft.has(pd.providerId)\n  );\n  if (!providersLeft.has(ProviderId.PHONE)) {\n    userInternal.phoneNumber = null;\n  }\n\n  await userInternal.auth._persistUserIfCurrent(userInternal);\n  return userInternal;\n}\n\nexport async function _link(\n  user: UserInternal,\n  credential: AuthCredential,\n  bypassAuthState = false\n): Promise<UserCredentialInternal> {\n  const response = await _logoutIfInvalidated(\n    user,\n    credential._linkToIdToken(user.auth, await user.getIdToken()),\n    bypassAuthState\n  );\n  return UserCredentialImpl._forOperation(user, OperationType.LINK, response);\n}\n\nexport async function _assertLinkedStatus(\n  expected: boolean,\n  user: UserInternal,\n  provider: string\n): Promise<void> {\n  await _reloadWithoutSaving(user);\n  const providerIds = providerDataAsNames(user.providerData);\n\n  const code =\n    expected === false\n      ? AuthErrorCode.PROVIDER_ALREADY_LINKED\n      : AuthErrorCode.NO_SUCH_PROVIDER;\n  _assert(providerIds.has(provider) === expected, user.auth, code);\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 { _processCredentialSavingMfaContextIfNecessary } from '../../mfa/mfa_error';\nimport { OperationType } from '../../model/enums';\nimport { UserInternal } from '../../model/user';\nimport { AuthCredential } from '../credentials';\nimport { AuthErrorCode } from '../errors';\nimport { _assert, _fail } from '../util/assert';\nimport { _parseToken } from './id_token_result';\nimport { _logoutIfInvalidated } from './invalidation';\nimport { UserCredentialImpl } from './user_credential_impl';\nimport { _isFirebaseServerApp } from '@firebase/app';\nimport { _serverAppCurrentUserOperationNotSupportedError } from '../../core/util/assert';\n\nexport async function _reauthenticate(\n  user: UserInternal,\n  credential: AuthCredential,\n  bypassAuthState = false\n): Promise<UserCredentialImpl> {\n  const { auth } = user;\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(auth)\n    );\n  }\n  const operationType = OperationType.REAUTHENTICATE;\n\n  try {\n    const response = await _logoutIfInvalidated(\n      user,\n      _processCredentialSavingMfaContextIfNecessary(\n        auth,\n        operationType,\n        credential,\n        user\n      ),\n      bypassAuthState\n    );\n    _assert(response.idToken, auth, AuthErrorCode.INTERNAL_ERROR);\n    const parsed = _parseToken(response.idToken);\n    _assert(parsed, auth, AuthErrorCode.INTERNAL_ERROR);\n\n    const { sub: localId } = parsed;\n    _assert(user.uid === localId, auth, AuthErrorCode.USER_MISMATCH);\n\n    return UserCredentialImpl._forOperation(user, operationType, response);\n  } catch (e) {\n    // Convert user deleted error into user mismatch\n    if ((e as FirebaseError)?.code === `auth/${AuthErrorCode.USER_DELETED}`) {\n      _fail(auth, AuthErrorCode.USER_MISMATCH);\n    }\n    throw 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\nimport { UserCredential, Auth, User } from '../../model/public_types';\n\nimport { _processCredentialSavingMfaContextIfNecessary } from '../../mfa/mfa_error';\nimport { AuthInternal } from '../../model/auth';\nimport { UserInternal } from '../../model/user';\nimport { AuthCredential } from '../credentials';\nimport { _assertLinkedStatus, _link } from '../user/link_unlink';\nimport { _reauthenticate } from '../user/reauthenticate';\nimport { UserCredentialImpl } from '../user/user_credential_impl';\nimport { _castAuth } from '../auth/auth_impl';\nimport { getModularInstance } from '@firebase/util';\nimport { OperationType } from '../../model/enums';\nimport { _isFirebaseServerApp } from '@firebase/app';\nimport { _serverAppCurrentUserOperationNotSupportedError } from '../../core/util/assert';\n\nexport async function _signInWithCredential(\n  auth: AuthInternal,\n  credential: AuthCredential,\n  bypassAuthState = false\n): Promise<UserCredential> {\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(auth)\n    );\n  }\n  const operationType = OperationType.SIGN_IN;\n  const response = await _processCredentialSavingMfaContextIfNecessary(\n    auth,\n    operationType,\n    credential\n  );\n  const userCredential = await UserCredentialImpl._fromIdTokenResponse(\n    auth,\n    operationType,\n    response\n  );\n\n  if (!bypassAuthState) {\n    await auth._updateCurrentUser(userCredential.user);\n  }\n  return userCredential;\n}\n\n/**\n * Asynchronously signs in with the given credentials.\n *\n * @remarks\n * An {@link AuthProvider} can be used to generate the credential.\n *\n * This method is not supported by {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @param auth - The {@link Auth} instance.\n * @param credential - The auth credential.\n *\n * @public\n */\nexport async function signInWithCredential(\n  auth: Auth,\n  credential: AuthCredential\n): Promise<UserCredential> {\n  return _signInWithCredential(_castAuth(auth), credential);\n}\n\n/**\n * Links the user account with the given credentials.\n *\n * @remarks\n * An {@link AuthProvider} can be used to generate the credential.\n *\n * @param user - The user.\n * @param credential - The auth credential.\n *\n * @public\n */\nexport async function linkWithCredential(\n  user: User,\n  credential: AuthCredential\n): Promise<UserCredential> {\n  const userInternal = getModularInstance(user) as UserInternal;\n\n  await _assertLinkedStatus(false, userInternal, credential.providerId);\n\n  return _link(userInternal, credential);\n}\n\n/**\n * Re-authenticates a user using a fresh credential.\n *\n * @remarks\n * Use before operations such as {@link updatePassword} that require tokens from recent sign-in\n * attempts. This method can be used to recover from a `CREDENTIAL_TOO_OLD_LOGIN_AGAIN` error\n * or a `TOKEN_EXPIRED` error.\n *\n * This method is not supported on any {@link User} signed in by {@link Auth} instances\n * created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @param user - The user.\n * @param credential - The auth credential.\n *\n * @public\n */\nexport async function reauthenticateWithCredential(\n  user: User,\n  credential: AuthCredential\n): Promise<UserCredential> {\n  return _reauthenticate(getModularInstance(user) as UserInternal, credential);\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  Endpoint,\n  HttpMethod,\n  RecaptchaClientType,\n  RecaptchaVersion,\n  _addTidIfNecessary,\n  _performApiRequest\n} from '../index';\nimport { SignInWithPhoneNumberRequest } from '../authentication/sms';\nimport { FinalizeMfaResponse } from '../authentication/mfa';\nimport { AuthInternal } from '../../model/auth';\n\n/**\n * MFA Info as returned by the API.\n */\ninterface BaseMfaEnrollment {\n  mfaEnrollmentId: string;\n  enrolledAt: number;\n  displayName?: string;\n}\n\n/**\n * An MFA provided by SMS verification.\n */\nexport interface PhoneMfaEnrollment extends BaseMfaEnrollment {\n  phoneInfo: string;\n}\n\n/**\n * An MFA provided by TOTP (Time-based One Time Password).\n */\nexport interface TotpMfaEnrollment extends BaseMfaEnrollment {}\n\n/**\n * MfaEnrollment can be any subtype of BaseMfaEnrollment, currently only PhoneMfaEnrollment and TotpMfaEnrollment are supported.\n */\nexport type MfaEnrollment = PhoneMfaEnrollment | TotpMfaEnrollment;\n\nexport interface StartPhoneMfaEnrollmentRequest {\n  idToken: string;\n  phoneEnrollmentInfo: {\n    phoneNumber: string;\n    // reCAPTCHA v2 token\n    recaptchaToken?: string;\n    // reCAPTCHA Enterprise token\n    captchaResponse?: string;\n    clientType?: RecaptchaClientType;\n    recaptchaVersion?: RecaptchaVersion;\n  };\n  tenantId?: string;\n}\n\nexport interface StartPhoneMfaEnrollmentResponse {\n  phoneSessionInfo: {\n    sessionInfo: string;\n  };\n}\n\nexport function startEnrollPhoneMfa(\n  auth: AuthInternal,\n  request: StartPhoneMfaEnrollmentRequest\n): Promise<StartPhoneMfaEnrollmentResponse> {\n  return _performApiRequest<\n    StartPhoneMfaEnrollmentRequest,\n    StartPhoneMfaEnrollmentResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.START_MFA_ENROLLMENT,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface FinalizePhoneMfaEnrollmentRequest {\n  idToken: string;\n  phoneVerificationInfo: SignInWithPhoneNumberRequest;\n  displayName?: string | null;\n  tenantId?: string;\n}\n\nexport interface FinalizePhoneMfaEnrollmentResponse\n  extends FinalizeMfaResponse {}\n\nexport function finalizeEnrollPhoneMfa(\n  auth: AuthInternal,\n  request: FinalizePhoneMfaEnrollmentRequest\n): Promise<FinalizePhoneMfaEnrollmentResponse> {\n  return _performApiRequest<\n    FinalizePhoneMfaEnrollmentRequest,\n    FinalizePhoneMfaEnrollmentResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.FINALIZE_MFA_ENROLLMENT,\n    _addTidIfNecessary(auth, request)\n  );\n}\nexport interface StartTotpMfaEnrollmentRequest {\n  idToken: string;\n  totpEnrollmentInfo: {};\n  tenantId?: string;\n}\n\nexport interface StartTotpMfaEnrollmentResponse {\n  totpSessionInfo: {\n    sharedSecretKey: string;\n    verificationCodeLength: number;\n    hashingAlgorithm: string;\n    periodSec: number;\n    sessionInfo: string;\n    finalizeEnrollmentTime: number;\n  };\n}\n\nexport function startEnrollTotpMfa(\n  auth: AuthInternal,\n  request: StartTotpMfaEnrollmentRequest\n): Promise<StartTotpMfaEnrollmentResponse> {\n  return _performApiRequest<\n    StartTotpMfaEnrollmentRequest,\n    StartTotpMfaEnrollmentResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.START_MFA_ENROLLMENT,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface TotpVerificationInfo {\n  sessionInfo: string;\n  verificationCode: string;\n}\nexport interface FinalizeTotpMfaEnrollmentRequest {\n  idToken: string;\n  totpVerificationInfo: TotpVerificationInfo;\n  displayName?: string | null;\n  tenantId?: string;\n}\n\nexport interface FinalizeTotpMfaEnrollmentResponse\n  extends FinalizeMfaResponse {}\n\nexport function finalizeEnrollTotpMfa(\n  auth: AuthInternal,\n  request: FinalizeTotpMfaEnrollmentRequest\n): Promise<FinalizeTotpMfaEnrollmentResponse> {\n  return _performApiRequest<\n    FinalizeTotpMfaEnrollmentRequest,\n    FinalizeTotpMfaEnrollmentResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.FINALIZE_MFA_ENROLLMENT,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface WithdrawMfaRequest {\n  idToken: string;\n  mfaEnrollmentId: string;\n  tenantId?: string;\n}\n\nexport interface WithdrawMfaResponse extends FinalizeMfaResponse {}\n\nexport function withdrawMfa(\n  auth: AuthInternal,\n  request: WithdrawMfaRequest\n): Promise<WithdrawMfaResponse> {\n  return _performApiRequest<WithdrawMfaRequest, WithdrawMfaResponse>(\n    auth,\n    HttpMethod.POST,\n    Endpoint.WITHDRAW_MFA,\n    _addTidIfNecessary(auth, request)\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 */\nimport {\n  MultiFactorAssertion,\n  MultiFactorInfo,\n  MultiFactorSession,\n  MultiFactorUser,\n  User\n} from '../model/public_types';\n\nimport { withdrawMfa } from '../api/account_management/mfa';\nimport { _logoutIfInvalidated } from '../core/user/invalidation';\nimport { UserInternal } from '../model/user';\nimport { MultiFactorAssertionImpl } from './mfa_assertion';\nimport { MultiFactorInfoImpl } from './mfa_info';\nimport { MultiFactorSessionImpl } from './mfa_session';\nimport { getModularInstance } from '@firebase/util';\n\nexport class MultiFactorUserImpl implements MultiFactorUser {\n  enrolledFactors: MultiFactorInfo[] = [];\n\n  private constructor(readonly user: UserInternal) {\n    user._onReload(userInfo => {\n      if (userInfo.mfaInfo) {\n        this.enrolledFactors = userInfo.mfaInfo.map(enrollment =>\n          MultiFactorInfoImpl._fromServerResponse(user.auth, enrollment)\n        );\n      }\n    });\n  }\n\n  static _fromUser(user: UserInternal): MultiFactorUserImpl {\n    return new MultiFactorUserImpl(user);\n  }\n\n  async getSession(): Promise<MultiFactorSession> {\n    return MultiFactorSessionImpl._fromIdtoken(\n      await this.user.getIdToken(),\n      this.user\n    );\n  }\n\n  async enroll(\n    assertionExtern: MultiFactorAssertion,\n    displayName?: string | null\n  ): Promise<void> {\n    const assertion = assertionExtern as MultiFactorAssertionImpl;\n    const session = (await this.getSession()) as MultiFactorSessionImpl;\n    const finalizeMfaResponse = await _logoutIfInvalidated(\n      this.user,\n      assertion._process(this.user.auth, session, displayName)\n    );\n    // New tokens will be issued after enrollment of the new second factors.\n    // They need to be updated on the user.\n    await this.user._updateTokensIfNecessary(finalizeMfaResponse);\n    // The user needs to be reloaded to get the new multi-factor information\n    // from server. USER_RELOADED event will be triggered and `enrolledFactors`\n    // will be updated.\n    return this.user.reload();\n  }\n\n  async unenroll(infoOrUid: MultiFactorInfo | string): Promise<void> {\n    const mfaEnrollmentId =\n      typeof infoOrUid === 'string' ? infoOrUid : infoOrUid.uid;\n    const idToken = await this.user.getIdToken();\n    try {\n      const idTokenResponse = await _logoutIfInvalidated(\n        this.user,\n        withdrawMfa(this.user.auth, {\n          idToken,\n          mfaEnrollmentId\n        })\n      );\n      // Remove the second factor from the user's list.\n      this.enrolledFactors = this.enrolledFactors.filter(\n        ({ uid }) => uid !== mfaEnrollmentId\n      );\n      // Depending on whether the backend decided to revoke the user's session,\n      // the tokenResponse may be empty. If the tokens were not updated (and they\n      // are now invalid), reloading the user will discover this and invalidate\n      // the user's state accordingly.\n      await this.user._updateTokensIfNecessary(idTokenResponse);\n      await this.user.reload();\n    } catch (e) {\n      throw e;\n    }\n  }\n}\n\nconst multiFactorUserCache = new WeakMap<User, MultiFactorUser>();\n\n/**\n * The {@link MultiFactorUser} corresponding to the user.\n *\n * @remarks\n * This is used to access all multi-factor properties and operations related to the user.\n *\n * @param user - The user.\n *\n * @public\n */\nexport function multiFactor(user: User): MultiFactorUser {\n  const userModular = getModularInstance(user);\n  if (!multiFactorUserCache.has(userModular)) {\n    multiFactorUserCache.set(\n      userModular,\n      MultiFactorUserImpl._fromUser(userModular as UserInternal)\n    );\n  }\n  return multiFactorUserCache.get(userModular)!;\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 { Persistence } from '../../model/public_types';\n\nexport const enum PersistenceType {\n  SESSION = 'SESSION',\n  LOCAL = 'LOCAL',\n  NONE = 'NONE'\n}\n\nexport type PersistedBlob = Record<string, unknown>;\n\nexport interface Instantiator<T> {\n  (blob: PersistedBlob): T;\n}\n\nexport type PersistenceValue = PersistedBlob | string;\n\nexport const STORAGE_AVAILABLE_KEY = '__sak';\n\nexport interface StorageEventListener {\n  (value: PersistenceValue | null): void;\n}\n\nexport interface PersistenceInternal extends Persistence {\n  type: PersistenceType;\n  _isAvailable(): Promise<boolean>;\n  _set(key: string, value: PersistenceValue): Promise<void>;\n  _get<T extends PersistenceValue>(key: string): Promise<T | null>;\n  _remove(key: string): Promise<void>;\n  _addListener(key: string, listener: StorageEventListener): void;\n  _removeListener(key: string, listener: StorageEventListener): void;\n  // Should this persistence allow migration up the chosen hierarchy?\n  _shouldAllowMigration?: boolean;\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  PersistenceValue,\n  STORAGE_AVAILABLE_KEY,\n  PersistenceType\n} from '../../core/persistence';\n\n// There are two different browser persistence types: local and session.\n// Both have the same implementation but use a different underlying storage\n// object.\n\nexport abstract class BrowserPersistenceClass {\n  protected constructor(\n    protected readonly storageRetriever: () => Storage,\n    readonly type: PersistenceType\n  ) {}\n\n  _isAvailable(): Promise<boolean> {\n    try {\n      if (!this.storage) {\n        return Promise.resolve(false);\n      }\n      this.storage.setItem(STORAGE_AVAILABLE_KEY, '1');\n      this.storage.removeItem(STORAGE_AVAILABLE_KEY);\n      return Promise.resolve(true);\n    } catch {\n      return Promise.resolve(false);\n    }\n  }\n\n  _set(key: string, value: PersistenceValue): Promise<void> {\n    this.storage.setItem(key, JSON.stringify(value));\n    return Promise.resolve();\n  }\n\n  _get<T extends PersistenceValue>(key: string): Promise<T | null> {\n    const json = this.storage.getItem(key);\n    return Promise.resolve(json ? JSON.parse(json) : null);\n  }\n\n  _remove(key: string): Promise<void> {\n    this.storage.removeItem(key);\n    return Promise.resolve();\n  }\n\n  protected get storage(): Storage {\n    return this.storageRetriever();\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 { Persistence } from '../../model/public_types';\n\nimport { _isMobileBrowser, _isIE10 } from '../../core/util/browser';\nimport {\n  PersistenceInternal as InternalPersistence,\n  PersistenceType,\n  PersistenceValue,\n  StorageEventListener\n} from '../../core/persistence';\nimport { BrowserPersistenceClass } from './browser';\n\n// The polling period in case events are not supported\nexport const _POLLING_INTERVAL_MS = 1000;\n\n// The IE 10 localStorage cross tab synchronization delay in milliseconds\nconst IE10_LOCAL_STORAGE_SYNC_DELAY = 10;\n\nclass BrowserLocalPersistence\n  extends BrowserPersistenceClass\n  implements InternalPersistence\n{\n  static type: 'LOCAL' = 'LOCAL';\n\n  constructor() {\n    super(() => window.localStorage, PersistenceType.LOCAL);\n  }\n\n  private readonly boundEventHandler = (\n    event: StorageEvent,\n    poll?: boolean\n  ): void => this.onStorageEvent(event, poll);\n  private readonly listeners: Record<string, Set<StorageEventListener>> = {};\n  private readonly localCache: Record<string, string | null> = {};\n  // setTimeout return value is platform specific\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private pollTimer: any | null = null;\n\n  // Whether to use polling instead of depending on window events\n  private readonly fallbackToPolling = _isMobileBrowser();\n  readonly _shouldAllowMigration = true;\n\n  private forAllChangedKeys(\n    cb: (key: string, oldValue: string | null, newValue: string | null) => void\n  ): void {\n    // Check all keys with listeners on them.\n    for (const key of Object.keys(this.listeners)) {\n      // Get value from localStorage.\n      const newValue = this.storage.getItem(key);\n      const oldValue = this.localCache[key];\n      // If local map value does not match, trigger listener with storage event.\n      // Differentiate this simulated event from the real storage event.\n      if (newValue !== oldValue) {\n        cb(key, oldValue, newValue);\n      }\n    }\n  }\n\n  private onStorageEvent(event: StorageEvent, poll = false): void {\n    // Key would be null in some situations, like when localStorage is cleared\n    if (!event.key) {\n      this.forAllChangedKeys(\n        (key: string, _oldValue: string | null, newValue: string | null) => {\n          this.notifyListeners(key, newValue);\n        }\n      );\n      return;\n    }\n\n    const key = event.key;\n\n    // Check the mechanism how this event was detected.\n    // The first event will dictate the mechanism to be used.\n    if (poll) {\n      // Environment detects storage changes via polling.\n      // Remove storage event listener to prevent possible event duplication.\n      this.detachListener();\n    } else {\n      // Environment detects storage changes via storage event listener.\n      // Remove polling listener to prevent possible event duplication.\n      this.stopPolling();\n    }\n\n    const triggerListeners = (): void => {\n      // Keep local map up to date in case storage event is triggered before\n      // poll.\n      const storedValue = this.storage.getItem(key);\n      if (!poll && this.localCache[key] === storedValue) {\n        // Real storage event which has already been detected, do nothing.\n        // This seems to trigger in some IE browsers for some reason.\n        return;\n      }\n      this.notifyListeners(key, storedValue);\n    };\n\n    const storedValue = this.storage.getItem(key);\n    if (\n      _isIE10() &&\n      storedValue !== event.newValue &&\n      event.newValue !== event.oldValue\n    ) {\n      // IE 10 has this weird bug where a storage event would trigger with the\n      // correct key, oldValue and newValue but localStorage.getItem(key) does\n      // not yield the updated value until a few milliseconds. This ensures\n      // this recovers from that situation.\n      setTimeout(triggerListeners, IE10_LOCAL_STORAGE_SYNC_DELAY);\n    } else {\n      triggerListeners();\n    }\n  }\n\n  private notifyListeners(key: string, value: string | null): void {\n    this.localCache[key] = value;\n    const listeners = this.listeners[key];\n    if (listeners) {\n      for (const listener of Array.from(listeners)) {\n        listener(value ? JSON.parse(value) : value);\n      }\n    }\n  }\n\n  private startPolling(): void {\n    this.stopPolling();\n\n    this.pollTimer = setInterval(() => {\n      this.forAllChangedKeys(\n        (key: string, oldValue: string | null, newValue: string | null) => {\n          this.onStorageEvent(\n            new StorageEvent('storage', {\n              key,\n              oldValue,\n              newValue\n            }),\n            /* poll */ true\n          );\n        }\n      );\n    }, _POLLING_INTERVAL_MS);\n  }\n\n  private stopPolling(): void {\n    if (this.pollTimer) {\n      clearInterval(this.pollTimer);\n      this.pollTimer = null;\n    }\n  }\n\n  private attachListener(): void {\n    window.addEventListener('storage', this.boundEventHandler);\n  }\n\n  private detachListener(): void {\n    window.removeEventListener('storage', this.boundEventHandler);\n  }\n\n  _addListener(key: string, listener: StorageEventListener): void {\n    if (Object.keys(this.listeners).length === 0) {\n      // Whether browser can detect storage event when it had already been pushed to the background.\n      // This may happen in some mobile browsers. A localStorage change in the foreground window\n      // will not be detected in the background window via the storage event.\n      // This was detected in iOS 7.x mobile browsers\n      if (this.fallbackToPolling) {\n        this.startPolling();\n      } else {\n        this.attachListener();\n      }\n    }\n    if (!this.listeners[key]) {\n      this.listeners[key] = new Set();\n      // Populate the cache to avoid spuriously triggering on first poll.\n      this.localCache[key] = this.storage.getItem(key);\n    }\n    this.listeners[key].add(listener);\n  }\n\n  _removeListener(key: string, listener: StorageEventListener): void {\n    if (this.listeners[key]) {\n      this.listeners[key].delete(listener);\n\n      if (this.listeners[key].size === 0) {\n        delete this.listeners[key];\n      }\n    }\n\n    if (Object.keys(this.listeners).length === 0) {\n      this.detachListener();\n      this.stopPolling();\n    }\n  }\n\n  // Update local cache on base operations:\n\n  async _set(key: string, value: PersistenceValue): Promise<void> {\n    await super._set(key, value);\n    this.localCache[key] = JSON.stringify(value);\n  }\n\n  async _get<T extends PersistenceValue>(key: string): Promise<T | null> {\n    const value = await super._get<T>(key);\n    this.localCache[key] = JSON.stringify(value);\n    return value;\n  }\n\n  async _remove(key: string): Promise<void> {\n    await super._remove(key);\n    delete this.localCache[key];\n  }\n}\n\n/**\n * An implementation of {@link Persistence} of type `LOCAL` using `localStorage`\n * for the underlying storage.\n *\n * @public\n */\nexport const browserLocalPersistence: Persistence = BrowserLocalPersistence;\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 { Persistence } from '../../model/public_types';\n\nimport {\n  PersistenceInternal as InternalPersistence,\n  PersistenceType,\n  StorageEventListener\n} from '../../core/persistence';\nimport { BrowserPersistenceClass } from './browser';\n\nclass BrowserSessionPersistence\n  extends BrowserPersistenceClass\n  implements InternalPersistence\n{\n  static type: 'SESSION' = 'SESSION';\n\n  constructor() {\n    super(() => window.sessionStorage, PersistenceType.SESSION);\n  }\n\n  _addListener(_key: string, _listener: StorageEventListener): void {\n    // Listeners are not supported for session storage since it cannot be shared across windows\n    return;\n  }\n\n  _removeListener(_key: string, _listener: StorageEventListener): void {\n    // Listeners are not supported for session storage since it cannot be shared across windows\n    return;\n  }\n}\n\n/**\n * An implementation of {@link Persistence} of `SESSION` using `sessionStorage`\n * for the underlying storage.\n *\n * @public\n */\nexport const browserSessionPersistence: Persistence = BrowserSessionPersistence;\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  ReceiverHandler,\n  _EventType,\n  _ReceiverResponse,\n  SenderMessageEvent,\n  _Status,\n  _SenderRequest\n} from './index';\nimport { _allSettled } from './promise';\n\n/**\n * Interface class for receiving messages.\n *\n */\nexport class Receiver {\n  private static readonly receivers: Receiver[] = [];\n  private readonly boundEventHandler: EventListener;\n\n  private readonly handlersMap: {\n    // TypeScript doesn't have existential types :(\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    [eventType: string]: Set<ReceiverHandler<any, any>>;\n  } = {};\n\n  constructor(private readonly eventTarget: EventTarget) {\n    this.boundEventHandler = this.handleEvent.bind(this);\n  }\n\n  /**\n   * Obtain an instance of a Receiver for a given event target, if none exists it will be created.\n   *\n   * @param eventTarget - An event target (such as window or self) through which the underlying\n   * messages will be received.\n   */\n  static _getInstance(eventTarget: EventTarget): Receiver {\n    // The results are stored in an array since objects can't be keys for other\n    // objects. In addition, setting a unique property on an event target as a\n    // hash map key may not be allowed due to CORS restrictions.\n    const existingInstance = this.receivers.find(receiver =>\n      receiver.isListeningto(eventTarget)\n    );\n    if (existingInstance) {\n      return existingInstance;\n    }\n    const newInstance = new Receiver(eventTarget);\n    this.receivers.push(newInstance);\n    return newInstance;\n  }\n\n  private isListeningto(eventTarget: EventTarget): boolean {\n    return this.eventTarget === eventTarget;\n  }\n\n  /**\n   * Fans out a MessageEvent to the appropriate listeners.\n   *\n   * @remarks\n   * Sends an {@link Status.ACK} upon receipt and a {@link Status.DONE} once all handlers have\n   * finished processing.\n   *\n   * @param event - The MessageEvent.\n   *\n   */\n  private async handleEvent<\n    T extends _ReceiverResponse,\n    S extends _SenderRequest\n  >(event: Event): Promise<void> {\n    const messageEvent = event as MessageEvent<SenderMessageEvent<S>>;\n    const { eventId, eventType, data } = messageEvent.data;\n\n    const handlers: Set<ReceiverHandler<T, S>> | undefined =\n      this.handlersMap[eventType];\n    if (!handlers?.size) {\n      return;\n    }\n\n    messageEvent.ports[0].postMessage({\n      status: _Status.ACK,\n      eventId,\n      eventType\n    });\n\n    const promises = Array.from(handlers).map(async handler =>\n      handler(messageEvent.origin, data)\n    );\n    const response = await _allSettled(promises);\n    messageEvent.ports[0].postMessage({\n      status: _Status.DONE,\n      eventId,\n      eventType,\n      response\n    });\n  }\n\n  /**\n   * Subscribe an event handler for a particular event.\n   *\n   * @param eventType - Event name to subscribe to.\n   * @param eventHandler - The event handler which should receive the events.\n   *\n   */\n  _subscribe<T extends _ReceiverResponse, S extends _SenderRequest>(\n    eventType: _EventType,\n    eventHandler: ReceiverHandler<T, S>\n  ): void {\n    if (Object.keys(this.handlersMap).length === 0) {\n      this.eventTarget.addEventListener('message', this.boundEventHandler);\n    }\n\n    if (!this.handlersMap[eventType]) {\n      this.handlersMap[eventType] = new Set();\n    }\n\n    this.handlersMap[eventType].add(eventHandler);\n  }\n\n  /**\n   * Unsubscribe an event handler from a particular event.\n   *\n   * @param eventType - Event name to unsubscribe from.\n   * @param eventHandler - Optional event handler, if none provided, unsubscribe all handlers on this event.\n   *\n   */\n  _unsubscribe<T extends _ReceiverResponse, S extends _SenderRequest>(\n    eventType: _EventType,\n    eventHandler?: ReceiverHandler<T, S>\n  ): void {\n    if (this.handlersMap[eventType] && eventHandler) {\n      this.handlersMap[eventType].delete(eventHandler);\n    }\n    if (!eventHandler || this.handlersMap[eventType].size === 0) {\n      delete this.handlersMap[eventType];\n    }\n\n    if (Object.keys(this.handlersMap).length === 0) {\n      this.eventTarget.removeEventListener('message', this.boundEventHandler);\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/** TODO: remove this once tslib has a polyfill for Promise.allSettled */\ninterface PromiseFulfilledResult<T> {\n  fulfilled: true;\n  value: T;\n}\n\ninterface PromiseRejectedResult {\n  fulfilled: false;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  reason: any;\n}\n\nexport type PromiseSettledResult<T> =\n  | PromiseFulfilledResult<T>\n  | PromiseRejectedResult;\n\n/**\n * Shim for Promise.allSettled, note the slightly different format of `fulfilled` vs `status`.\n *\n * @param promises - Array of promises to wait on.\n */\nexport function _allSettled<T>(\n  promises: Array<Promise<T>>\n): Promise<Array<PromiseSettledResult<T>>> {\n  return Promise.all(\n    promises.map(async promise => {\n      try {\n        const value = await promise;\n        return {\n          fulfilled: true,\n          value\n        } as PromiseFulfilledResult<T>;\n      } catch (reason) {\n        return {\n          fulfilled: false,\n          reason\n        } as PromiseRejectedResult;\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\nexport function _generateEventId(prefix = '', digits = 10): string {\n  let random = '';\n  for (let i = 0; i < digits; i++) {\n    random += Math.floor(Math.random() * 10);\n  }\n  return prefix + random;\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 { _generateEventId } from '../../core/util/event_id';\nimport {\n  _SenderRequest,\n  _EventType,\n  ReceiverMessageEvent,\n  _MessageError,\n  SenderMessageEvent,\n  _Status,\n  _ReceiverMessageResponse,\n  _ReceiverResponse,\n  _TimeoutDuration\n} from './index';\n\ninterface MessageHandler {\n  messageChannel: MessageChannel;\n  onMessage: EventListenerOrEventListenerObject;\n}\n\n/**\n * Interface for sending messages and waiting for a completion response.\n *\n */\nexport class Sender {\n  private readonly handlers = new Set<MessageHandler>();\n\n  constructor(private readonly target: ServiceWorker) {}\n\n  /**\n   * Unsubscribe the handler and remove it from our tracking Set.\n   *\n   * @param handler - The handler to unsubscribe.\n   */\n  private removeMessageHandler(handler: MessageHandler): void {\n    if (handler.messageChannel) {\n      handler.messageChannel.port1.removeEventListener(\n        'message',\n        handler.onMessage\n      );\n      handler.messageChannel.port1.close();\n    }\n    this.handlers.delete(handler);\n  }\n\n  /**\n   * Send a message to the Receiver located at {@link target}.\n   *\n   * @remarks\n   * We'll first wait a bit for an ACK , if we get one we will wait significantly longer until the\n   * receiver has had a chance to fully process the event.\n   *\n   * @param eventType - Type of event to send.\n   * @param data - The payload of the event.\n   * @param timeout - Timeout for waiting on an ACK from the receiver.\n   *\n   * @returns An array of settled promises from all the handlers that were listening on the receiver.\n   */\n  async _send<T extends _ReceiverResponse, S extends _SenderRequest>(\n    eventType: _EventType,\n    data: S,\n    timeout = _TimeoutDuration.ACK\n  ): Promise<_ReceiverMessageResponse<T>> {\n    const messageChannel =\n      typeof MessageChannel !== 'undefined' ? new MessageChannel() : null;\n    if (!messageChannel) {\n      throw new Error(_MessageError.CONNECTION_UNAVAILABLE);\n    }\n    // Node timers and browser timers return fundamentally different types.\n    // We don't actually care what the value is but TS won't accept unknown and\n    // we can't cast properly in both environments.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    let completionTimer: any;\n    let handler: MessageHandler;\n    return new Promise<_ReceiverMessageResponse<T>>((resolve, reject) => {\n      const eventId = _generateEventId('', 20);\n      messageChannel.port1.start();\n      const ackTimer = setTimeout(() => {\n        reject(new Error(_MessageError.UNSUPPORTED_EVENT));\n      }, timeout);\n      handler = {\n        messageChannel,\n        onMessage(event: Event): void {\n          const messageEvent = event as MessageEvent<ReceiverMessageEvent<T>>;\n          if (messageEvent.data.eventId !== eventId) {\n            return;\n          }\n          switch (messageEvent.data.status) {\n            case _Status.ACK:\n              // The receiver should ACK first.\n              clearTimeout(ackTimer);\n              completionTimer = setTimeout(() => {\n                reject(new Error(_MessageError.TIMEOUT));\n              }, _TimeoutDuration.COMPLETION);\n              break;\n            case _Status.DONE:\n              // Once the receiver's handlers are finished we will get the results.\n              clearTimeout(completionTimer);\n              resolve(messageEvent.data.response);\n              break;\n            default:\n              clearTimeout(ackTimer);\n              clearTimeout(completionTimer);\n              reject(new Error(_MessageError.INVALID_RESPONSE));\n              break;\n          }\n        }\n      };\n      this.handlers.add(handler);\n      messageChannel.port1.addEventListener('message', handler.onMessage);\n      this.target.postMessage(\n        {\n          eventType,\n          eventId,\n          data\n        } as SenderMessageEvent<S>,\n        [messageChannel.port2]\n      );\n    }).finally(() => {\n      if (handler) {\n        this.removeMessageHandler(handler);\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\nimport { Recaptcha, GreCAPTCHATopLevel } from './recaptcha/recaptcha';\n\n/**\n * A specialized window type that melds the normal window type plus the\n * various bits we need. The three different blocks that are &'d together\n * cant be defined in the same block together.\n */\nexport type AuthWindow = {\n  // Standard window types\n  [T in keyof Window]: Window[T];\n} & {\n  // Any known / named properties we want to add\n  grecaptcha?: Recaptcha | GreCAPTCHATopLevel;\n  /* eslint-disable-next-line @typescript-eslint/no-explicit-any */\n  ___jsl?: Record<string, any>;\n  gapi?: typeof gapi;\n} & {\n  // A final catch-all for callbacks (which will have random names) that\n  // we will stick on the window.\n  [callback: string]: (...args: unknown[]) => void;\n};\n\n/**\n * Lazy accessor for window, since the compat layer won't tree shake this out,\n * we need to make sure not to mess with window unless we have to\n */\nexport function _window(): AuthWindow {\n  return window as unknown as AuthWindow;\n}\n\nexport function _setWindowLocation(url: string): void {\n  _window().location.href = url;\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 { _window } from '../auth_window';\n\nexport function _isWorker(): boolean {\n  return (\n    typeof _window()['WorkerGlobalScope'] !== 'undefined' &&\n    typeof _window()['importScripts'] === 'function'\n  );\n}\n\nexport async function _getActiveServiceWorker(): Promise<ServiceWorker | null> {\n  if (!navigator?.serviceWorker) {\n    return null;\n  }\n  try {\n    const registration = await navigator.serviceWorker.ready;\n    return registration.active;\n  } catch {\n    return null;\n  }\n}\n\nexport function _getServiceWorkerController(): ServiceWorker | null {\n  return navigator?.serviceWorker?.controller || null;\n}\n\nexport function _getWorkerGlobalScope(): ServiceWorker | null {\n  return _isWorker() ? (self as unknown as ServiceWorker) : null;\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 { Persistence } from '../../model/public_types';\nimport {\n  PersistedBlob,\n  PersistenceInternal as InternalPersistence,\n  PersistenceType,\n  PersistenceValue,\n  StorageEventListener,\n  STORAGE_AVAILABLE_KEY\n} from '../../core/persistence/';\nimport {\n  _EventType,\n  _PingResponse,\n  KeyChangedResponse,\n  KeyChangedRequest,\n  PingRequest,\n  _TimeoutDuration\n} from '../messagechannel/index';\nimport { Receiver } from '../messagechannel/receiver';\nimport { Sender } from '../messagechannel/sender';\nimport {\n  _isWorker,\n  _getActiveServiceWorker,\n  _getServiceWorkerController,\n  _getWorkerGlobalScope\n} from '../util/worker';\n\nexport const DB_NAME = 'firebaseLocalStorageDb';\nconst DB_VERSION = 1;\nconst DB_OBJECTSTORE_NAME = 'firebaseLocalStorage';\nconst DB_DATA_KEYPATH = 'fbase_key';\n\ninterface DBObject {\n  [DB_DATA_KEYPATH]: string;\n  value: PersistedBlob;\n}\n\n/**\n * Promise wrapper for IDBRequest\n *\n * Unfortunately we can't cleanly extend Promise<T> since promises are not callable in ES6\n *\n */\nclass DBPromise<T> {\n  constructor(private readonly request: IDBRequest) {}\n\n  toPromise(): Promise<T> {\n    return new Promise<T>((resolve, reject) => {\n      this.request.addEventListener('success', () => {\n        resolve(this.request.result);\n      });\n      this.request.addEventListener('error', () => {\n        reject(this.request.error);\n      });\n    });\n  }\n}\n\nfunction getObjectStore(db: IDBDatabase, isReadWrite: boolean): IDBObjectStore {\n  return db\n    .transaction([DB_OBJECTSTORE_NAME], isReadWrite ? 'readwrite' : 'readonly')\n    .objectStore(DB_OBJECTSTORE_NAME);\n}\n\nexport async function _clearDatabase(db: IDBDatabase): Promise<void> {\n  const objectStore = getObjectStore(db, true);\n  return new DBPromise<void>(objectStore.clear()).toPromise();\n}\n\nexport function _deleteDatabase(): Promise<void> {\n  const request = indexedDB.deleteDatabase(DB_NAME);\n  return new DBPromise<void>(request).toPromise();\n}\n\nexport function _openDatabase(): Promise<IDBDatabase> {\n  const request = indexedDB.open(DB_NAME, DB_VERSION);\n  return new Promise((resolve, reject) => {\n    request.addEventListener('error', () => {\n      reject(request.error);\n    });\n\n    request.addEventListener('upgradeneeded', () => {\n      const db = request.result;\n\n      try {\n        db.createObjectStore(DB_OBJECTSTORE_NAME, { keyPath: DB_DATA_KEYPATH });\n      } catch (e) {\n        reject(e);\n      }\n    });\n\n    request.addEventListener('success', async () => {\n      const db: IDBDatabase = request.result;\n      // Strange bug that occurs in Firefox when multiple tabs are opened at the\n      // same time. The only way to recover seems to be deleting the database\n      // and re-initializing it.\n      // https://github.com/firebase/firebase-js-sdk/issues/634\n\n      if (!db.objectStoreNames.contains(DB_OBJECTSTORE_NAME)) {\n        // Need to close the database or else you get a `blocked` event\n        db.close();\n        await _deleteDatabase();\n        resolve(await _openDatabase());\n      } else {\n        resolve(db);\n      }\n    });\n  });\n}\n\nexport async function _putObject(\n  db: IDBDatabase,\n  key: string,\n  value: PersistenceValue | string\n): Promise<void> {\n  const request = getObjectStore(db, true).put({\n    [DB_DATA_KEYPATH]: key,\n    value\n  });\n  return new DBPromise<void>(request).toPromise();\n}\n\nasync function getObject(\n  db: IDBDatabase,\n  key: string\n): Promise<PersistedBlob | null> {\n  const request = getObjectStore(db, false).get(key);\n  const data = await new DBPromise<DBObject | undefined>(request).toPromise();\n  return data === undefined ? null : data.value;\n}\n\nexport function _deleteObject(db: IDBDatabase, key: string): Promise<void> {\n  const request = getObjectStore(db, true).delete(key);\n  return new DBPromise<void>(request).toPromise();\n}\n\nexport const _POLLING_INTERVAL_MS = 800;\nexport const _TRANSACTION_RETRY_COUNT = 3;\n\nclass IndexedDBLocalPersistence implements InternalPersistence {\n  static type: 'LOCAL' = 'LOCAL';\n\n  type = PersistenceType.LOCAL;\n  db?: IDBDatabase;\n  readonly _shouldAllowMigration = true;\n\n  private readonly listeners: Record<string, Set<StorageEventListener>> = {};\n  private readonly localCache: Record<string, PersistenceValue | null> = {};\n  // setTimeout return value is platform specific\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private pollTimer: any | null = null;\n  private pendingWrites = 0;\n\n  private receiver: Receiver | null = null;\n  private sender: Sender | null = null;\n  private serviceWorkerReceiverAvailable = false;\n  private activeServiceWorker: ServiceWorker | null = null;\n  // Visible for testing only\n  readonly _workerInitializationPromise: Promise<void>;\n\n  constructor() {\n    // Fire & forget the service worker registration as it may never resolve\n    this._workerInitializationPromise =\n      this.initializeServiceWorkerMessaging().then(\n        () => {},\n        () => {}\n      );\n  }\n\n  async _openDb(): Promise<IDBDatabase> {\n    if (this.db) {\n      return this.db;\n    }\n    this.db = await _openDatabase();\n    return this.db;\n  }\n\n  async _withRetries<T>(op: (db: IDBDatabase) => Promise<T>): Promise<T> {\n    let numAttempts = 0;\n\n    while (true) {\n      try {\n        const db = await this._openDb();\n        return await op(db);\n      } catch (e) {\n        if (numAttempts++ > _TRANSACTION_RETRY_COUNT) {\n          throw e;\n        }\n        if (this.db) {\n          this.db.close();\n          this.db = undefined;\n        }\n        // TODO: consider adding exponential backoff\n      }\n    }\n  }\n\n  /**\n   * IndexedDB events do not propagate from the main window to the worker context.  We rely on a\n   * postMessage interface to send these events to the worker ourselves.\n   */\n  private async initializeServiceWorkerMessaging(): Promise<void> {\n    return _isWorker() ? this.initializeReceiver() : this.initializeSender();\n  }\n\n  /**\n   * As the worker we should listen to events from the main window.\n   */\n  private async initializeReceiver(): Promise<void> {\n    this.receiver = Receiver._getInstance(_getWorkerGlobalScope()!);\n    // Refresh from persistence if we receive a KeyChanged message.\n    this.receiver._subscribe(\n      _EventType.KEY_CHANGED,\n      async (_origin: string, data: KeyChangedRequest) => {\n        const keys = await this._poll();\n        return {\n          keyProcessed: keys.includes(data.key)\n        };\n      }\n    );\n    // Let the sender know that we are listening so they give us more timeout.\n    this.receiver._subscribe(\n      _EventType.PING,\n      async (_origin: string, _data: PingRequest) => {\n        return [_EventType.KEY_CHANGED];\n      }\n    );\n  }\n\n  /**\n   * As the main window, we should let the worker know when keys change (set and remove).\n   *\n   * @remarks\n   * {@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/ready | ServiceWorkerContainer.ready}\n   * may not resolve.\n   */\n  private async initializeSender(): Promise<void> {\n    // Check to see if there's an active service worker.\n    this.activeServiceWorker = await _getActiveServiceWorker();\n    if (!this.activeServiceWorker) {\n      return;\n    }\n    this.sender = new Sender(this.activeServiceWorker);\n    // Ping the service worker to check what events they can handle.\n    const results = await this.sender._send<_PingResponse, PingRequest>(\n      _EventType.PING,\n      {},\n      _TimeoutDuration.LONG_ACK\n    );\n    if (!results) {\n      return;\n    }\n    if (\n      results[0]?.fulfilled &&\n      results[0]?.value.includes(_EventType.KEY_CHANGED)\n    ) {\n      this.serviceWorkerReceiverAvailable = true;\n    }\n  }\n\n  /**\n   * Let the worker know about a changed key, the exact key doesn't technically matter since the\n   * worker will just trigger a full sync anyway.\n   *\n   * @remarks\n   * For now, we only support one service worker per page.\n   *\n   * @param key - Storage key which changed.\n   */\n  private async notifyServiceWorker(key: string): Promise<void> {\n    if (\n      !this.sender ||\n      !this.activeServiceWorker ||\n      _getServiceWorkerController() !== this.activeServiceWorker\n    ) {\n      return;\n    }\n    try {\n      await this.sender._send<KeyChangedResponse, KeyChangedRequest>(\n        _EventType.KEY_CHANGED,\n        { key },\n        // Use long timeout if receiver has previously responded to a ping from us.\n        this.serviceWorkerReceiverAvailable\n          ? _TimeoutDuration.LONG_ACK\n          : _TimeoutDuration.ACK\n      );\n    } catch {\n      // This is a best effort approach. Ignore errors.\n    }\n  }\n\n  async _isAvailable(): Promise<boolean> {\n    try {\n      if (!indexedDB) {\n        return false;\n      }\n      const db = await _openDatabase();\n      await _putObject(db, STORAGE_AVAILABLE_KEY, '1');\n      await _deleteObject(db, STORAGE_AVAILABLE_KEY);\n      return true;\n    } catch {}\n    return false;\n  }\n\n  private async _withPendingWrite(write: () => Promise<void>): Promise<void> {\n    this.pendingWrites++;\n    try {\n      await write();\n    } finally {\n      this.pendingWrites--;\n    }\n  }\n\n  async _set(key: string, value: PersistenceValue): Promise<void> {\n    return this._withPendingWrite(async () => {\n      await this._withRetries((db: IDBDatabase) => _putObject(db, key, value));\n      this.localCache[key] = value;\n      return this.notifyServiceWorker(key);\n    });\n  }\n\n  async _get<T extends PersistenceValue>(key: string): Promise<T | null> {\n    const obj = (await this._withRetries((db: IDBDatabase) =>\n      getObject(db, key)\n    )) as T;\n    this.localCache[key] = obj;\n    return obj;\n  }\n\n  async _remove(key: string): Promise<void> {\n    return this._withPendingWrite(async () => {\n      await this._withRetries((db: IDBDatabase) => _deleteObject(db, key));\n      delete this.localCache[key];\n      return this.notifyServiceWorker(key);\n    });\n  }\n\n  private async _poll(): Promise<string[]> {\n    // TODO: check if we need to fallback if getAll is not supported\n    const result = await this._withRetries((db: IDBDatabase) => {\n      const getAllRequest = getObjectStore(db, false).getAll();\n      return new DBPromise<DBObject[] | null>(getAllRequest).toPromise();\n    });\n\n    if (!result) {\n      return [];\n    }\n\n    // If we have pending writes in progress abort, we'll get picked up on the next poll\n    if (this.pendingWrites !== 0) {\n      return [];\n    }\n\n    const keys = [];\n    const keysInResult = new Set();\n    if (result.length !== 0) {\n      for (const { fbase_key: key, value } of result) {\n        keysInResult.add(key);\n        if (JSON.stringify(this.localCache[key]) !== JSON.stringify(value)) {\n          this.notifyListeners(key, value as PersistenceValue);\n          keys.push(key);\n        }\n      }\n    }\n\n    for (const localKey of Object.keys(this.localCache)) {\n      if (this.localCache[localKey] && !keysInResult.has(localKey)) {\n        // Deleted\n        this.notifyListeners(localKey, null);\n        keys.push(localKey);\n      }\n    }\n    return keys;\n  }\n\n  private notifyListeners(\n    key: string,\n    newValue: PersistenceValue | null\n  ): void {\n    this.localCache[key] = newValue;\n    const listeners = this.listeners[key];\n    if (listeners) {\n      for (const listener of Array.from(listeners)) {\n        listener(newValue);\n      }\n    }\n  }\n\n  private startPolling(): void {\n    this.stopPolling();\n\n    this.pollTimer = setInterval(\n      async () => this._poll(),\n      _POLLING_INTERVAL_MS\n    );\n  }\n\n  private stopPolling(): void {\n    if (this.pollTimer) {\n      clearInterval(this.pollTimer);\n      this.pollTimer = null;\n    }\n  }\n\n  _addListener(key: string, listener: StorageEventListener): void {\n    if (Object.keys(this.listeners).length === 0) {\n      this.startPolling();\n    }\n    if (!this.listeners[key]) {\n      this.listeners[key] = new Set();\n      // Populate the cache to avoid spuriously triggering on first poll.\n      void this._get(key); // This can happen in the background async and we can return immediately.\n    }\n    this.listeners[key].add(listener);\n  }\n\n  _removeListener(key: string, listener: StorageEventListener): void {\n    if (this.listeners[key]) {\n      this.listeners[key].delete(listener);\n\n      if (this.listeners[key].size === 0) {\n        delete this.listeners[key];\n      }\n    }\n\n    if (Object.keys(this.listeners).length === 0) {\n      this.stopPolling();\n    }\n  }\n}\n\n/**\n * An implementation of {@link Persistence} of type `LOCAL` using `indexedDB`\n * for the underlying storage.\n *\n * @public\n */\nexport const indexedDBLocalPersistence: Persistence = IndexedDBLocalPersistence;\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  _performApiRequest,\n  Endpoint,\n  HttpMethod,\n  RecaptchaClientType,\n  RecaptchaVersion,\n  _addTidIfNecessary\n} from '../index';\nimport { Auth } from '../../model/public_types';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { MfaEnrollment } from '../account_management/mfa';\nimport { SignInWithIdpResponse } from './idp';\nimport {\n  SignInWithPhoneNumberRequest,\n  SignInWithPhoneNumberResponse\n} from './sms';\n\nexport interface FinalizeMfaResponse {\n  idToken: string;\n  refreshToken: string;\n}\n\n/**\n * @internal\n */\nexport interface IdTokenMfaResponse extends IdTokenResponse {\n  mfaPendingCredential?: string;\n  mfaInfo?: MfaEnrollment[];\n}\n\nexport interface StartPhoneMfaSignInRequest {\n  mfaPendingCredential: string;\n  mfaEnrollmentId: string;\n  phoneSignInInfo: {\n    // reCAPTCHA v2 token\n    recaptchaToken?: string;\n    // reCAPTCHA Enterprise token\n    captchaResponse?: string;\n    clientType?: RecaptchaClientType;\n    recaptchaVersion?: RecaptchaVersion;\n  };\n  tenantId?: string;\n}\n\nexport interface StartPhoneMfaSignInResponse {\n  phoneResponseInfo: {\n    sessionInfo: string;\n  };\n}\n\nexport function startSignInPhoneMfa(\n  auth: Auth,\n  request: StartPhoneMfaSignInRequest\n): Promise<StartPhoneMfaSignInResponse> {\n  return _performApiRequest<\n    StartPhoneMfaSignInRequest,\n    StartPhoneMfaSignInResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.START_MFA_SIGN_IN,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport interface FinalizePhoneMfaSignInRequest {\n  mfaPendingCredential: string;\n  phoneVerificationInfo: SignInWithPhoneNumberRequest;\n  tenantId?: string;\n}\n\n// TOTP MFA Sign in only has a finalize phase. Phone MFA has a start phase to initiate sending an\n// SMS and a finalize phase to complete sign in. With TOTP, the user already has the OTP in the\n// TOTP/Authenticator app.\nexport interface FinalizeTotpMfaSignInRequest {\n  mfaPendingCredential: string;\n  totpVerificationInfo: { verificationCode: string };\n  tenantId?: string;\n  mfaEnrollmentId: string;\n}\n\nexport interface FinalizePhoneMfaSignInResponse extends FinalizeMfaResponse {}\n\nexport interface FinalizeTotpMfaSignInResponse extends FinalizeMfaResponse {}\n\nexport function finalizeSignInPhoneMfa(\n  auth: Auth,\n  request: FinalizePhoneMfaSignInRequest\n): Promise<FinalizePhoneMfaSignInResponse> {\n  return _performApiRequest<\n    FinalizePhoneMfaSignInRequest,\n    FinalizePhoneMfaSignInResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.FINALIZE_MFA_SIGN_IN,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\nexport function finalizeSignInTotpMfa(\n  auth: Auth,\n  request: FinalizeTotpMfaSignInRequest\n): Promise<FinalizeTotpMfaSignInResponse> {\n  return _performApiRequest<\n    FinalizeTotpMfaSignInRequest,\n    FinalizeTotpMfaSignInResponse\n  >(\n    auth,\n    HttpMethod.POST,\n    Endpoint.FINALIZE_MFA_SIGN_IN,\n    _addTidIfNecessary(auth, request)\n  );\n}\n\n/**\n * @internal\n */\nexport type PhoneOrOauthTokenResponse =\n  | SignInWithPhoneNumberResponse\n  | SignInWithIdpResponse\n  | IdTokenResponse;\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 { querystring } from '@firebase/util';\n\nimport { AuthErrorCode } from '../../core/errors';\nimport { _assert, _createError } from '../../core/util/assert';\nimport { Delay } from '../../core/util/delay';\nimport { AuthInternal } from '../../model/auth';\nimport { _window } from '../auth_window';\nimport * as jsHelpers from '../load_js';\nimport { Recaptcha, isV2 } from './recaptcha';\nimport { MockReCaptcha } from './recaptcha_mock';\n\n// ReCaptcha will load using the same callback, so the callback function needs\n// to be kept around\nexport const _JSLOAD_CALLBACK = jsHelpers._generateCallbackName('rcb');\nconst NETWORK_TIMEOUT_DELAY = new Delay(30000, 60000);\n\n/**\n * We need to mark this interface as internal explicitly to exclude it in the public typings, because\n * it references AuthInternal which has a circular dependency with UserInternal.\n *\n * @internal\n */\nexport interface ReCaptchaLoader {\n  load(auth: AuthInternal, hl?: string): Promise<Recaptcha>;\n  clearedOneInstance(): void;\n}\n\n/**\n * Loader for the GReCaptcha library. There should only ever be one of this.\n */\nexport class ReCaptchaLoaderImpl implements ReCaptchaLoader {\n  private hostLanguage = '';\n  private counter = 0;\n  /**\n   * Check for `render()` method. `window.grecaptcha` will exist if the Enterprise\n   * version of the ReCAPTCHA script was loaded by someone else (e.g. App Check) but\n   * `window.grecaptcha.render()` will not. Another load will add it.\n   */\n  private readonly librarySeparatelyLoaded = !!_window().grecaptcha?.render;\n\n  load(auth: AuthInternal, hl = ''): Promise<Recaptcha> {\n    _assert(isHostLanguageValid(hl), auth, AuthErrorCode.ARGUMENT_ERROR);\n\n    if (this.shouldResolveImmediately(hl) && isV2(_window().grecaptcha)) {\n      return Promise.resolve(_window().grecaptcha! as Recaptcha);\n    }\n    return new Promise<Recaptcha>((resolve, reject) => {\n      const networkTimeout = _window().setTimeout(() => {\n        reject(_createError(auth, AuthErrorCode.NETWORK_REQUEST_FAILED));\n      }, NETWORK_TIMEOUT_DELAY.get());\n\n      _window()[_JSLOAD_CALLBACK] = () => {\n        _window().clearTimeout(networkTimeout);\n        delete _window()[_JSLOAD_CALLBACK];\n\n        const recaptcha = _window().grecaptcha as Recaptcha;\n\n        if (!recaptcha || !isV2(recaptcha)) {\n          reject(_createError(auth, AuthErrorCode.INTERNAL_ERROR));\n          return;\n        }\n\n        // Wrap the recaptcha render function so that we know if the developer has\n        // called it separately\n        const render = recaptcha.render;\n        recaptcha.render = (container, params) => {\n          const widgetId = render(container, params);\n          this.counter++;\n          return widgetId;\n        };\n\n        this.hostLanguage = hl;\n        resolve(recaptcha);\n      };\n\n      const url = `${jsHelpers._recaptchaV2ScriptUrl()}?${querystring({\n        onload: _JSLOAD_CALLBACK,\n        render: 'explicit',\n        hl\n      })}`;\n\n      jsHelpers._loadJS(url).catch(() => {\n        clearTimeout(networkTimeout);\n        reject(_createError(auth, AuthErrorCode.INTERNAL_ERROR));\n      });\n    });\n  }\n\n  clearedOneInstance(): void {\n    this.counter--;\n  }\n\n  private shouldResolveImmediately(hl: string): boolean {\n    // We can resolve immediately if:\n    //   • grecaptcha is already defined AND (\n    //     1. the requested language codes are the same OR\n    //     2. there exists already a ReCaptcha on the page\n    //     3. the library was already loaded by the app\n    // In cases (2) and (3), we _can't_ reload as it would break the recaptchas\n    // that are already in the page\n    return (\n      !!_window().grecaptcha?.render &&\n      (hl === this.hostLanguage ||\n        this.counter > 0 ||\n        this.librarySeparatelyLoaded)\n    );\n  }\n}\n\nfunction isHostLanguageValid(hl: string): boolean {\n  return hl.length <= 6 && /^\\s*[a-zA-Z0-9\\-]*\\s*$/.test(hl);\n}\n\nexport class MockReCaptchaLoaderImpl implements ReCaptchaLoader {\n  async load(auth: AuthInternal): Promise<Recaptcha> {\n    return new MockReCaptcha(auth);\n  }\n\n  clearedOneInstance(): void {}\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 { Auth, RecaptchaParameters } from '../../model/public_types';\nimport { getRecaptchaParams } from '../../api/authentication/recaptcha';\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport { AuthErrorCode } from '../../core/errors';\nimport { _assert } from '../../core/util/assert';\nimport { _isHttpOrHttps } from '../../core/util/location';\nimport { ApplicationVerifierInternal } from '../../model/application_verifier';\nimport { AuthInternal } from '../../model/auth';\nimport { _window } from '../auth_window';\nimport { _isWorker } from '../util/worker';\nimport { Recaptcha } from './recaptcha';\nimport {\n  MockReCaptchaLoaderImpl,\n  ReCaptchaLoader,\n  ReCaptchaLoaderImpl\n} from './recaptcha_loader';\n\nexport const RECAPTCHA_VERIFIER_TYPE = 'recaptcha';\n\nconst DEFAULT_PARAMS: RecaptchaParameters = {\n  theme: 'light',\n  type: 'image'\n};\n\ntype TokenCallback = (token: string) => void;\n\n/**\n * An {@link https://www.google.com/recaptcha/ | reCAPTCHA}-based application verifier.\n *\n * @remarks\n * `RecaptchaVerifier` does not work in a Node.js environment.\n *\n * @public\n */\nexport class RecaptchaVerifier implements ApplicationVerifierInternal {\n  /**\n   * The application verifier type.\n   *\n   * @remarks\n   * For a reCAPTCHA verifier, this is 'recaptcha'.\n   */\n  readonly type = RECAPTCHA_VERIFIER_TYPE;\n  private destroyed = false;\n  private widgetId: number | null = null;\n  private readonly container: HTMLElement;\n  private readonly isInvisible: boolean;\n  private readonly tokenChangeListeners = new Set<TokenCallback>();\n  private renderPromise: Promise<number> | null = null;\n  private readonly auth: AuthInternal;\n\n  /** @internal */\n  readonly _recaptchaLoader: ReCaptchaLoader;\n  private recaptcha: Recaptcha | null = null;\n\n  /**\n   * @param authExtern - The corresponding Firebase {@link Auth} instance.\n   *\n   * @param containerOrId - The reCAPTCHA container parameter.\n   *\n   * @remarks\n   * This has different meaning depending on whether the reCAPTCHA is hidden or visible. For a\n   * visible reCAPTCHA the container must be empty. If a string is used, it has to correspond to\n   * an element ID. The corresponding element must also must be in the DOM at the time of\n   * initialization.\n   *\n   * @param parameters - The optional reCAPTCHA parameters.\n   *\n   * @remarks\n   * Check the reCAPTCHA docs for a comprehensive list. All parameters are accepted except for\n   * the sitekey. Firebase Auth backend provisions a reCAPTCHA for each project and will\n   * configure this upon rendering. For an invisible reCAPTCHA, a size key must have the value\n   * 'invisible'.\n   */\n  constructor(\n    authExtern: Auth,\n    containerOrId: HTMLElement | string,\n    private readonly parameters: RecaptchaParameters = {\n      ...DEFAULT_PARAMS\n    }\n  ) {\n    this.auth = _castAuth(authExtern);\n    this.isInvisible = this.parameters.size === 'invisible';\n    _assert(\n      typeof document !== 'undefined',\n      this.auth,\n      AuthErrorCode.OPERATION_NOT_SUPPORTED\n    );\n    const container =\n      typeof containerOrId === 'string'\n        ? document.getElementById(containerOrId)\n        : containerOrId;\n    _assert(container, this.auth, AuthErrorCode.ARGUMENT_ERROR);\n\n    this.container = container;\n    this.parameters.callback = this.makeTokenCallback(this.parameters.callback);\n\n    this._recaptchaLoader = this.auth.settings.appVerificationDisabledForTesting\n      ? new MockReCaptchaLoaderImpl()\n      : new ReCaptchaLoaderImpl();\n\n    this.validateStartingState();\n    // TODO: Figure out if sdk version is needed\n  }\n\n  /**\n   * Waits for the user to solve the reCAPTCHA and resolves with the reCAPTCHA token.\n   *\n   * @returns A Promise for the reCAPTCHA token.\n   */\n  async verify(): Promise<string> {\n    this.assertNotDestroyed();\n    const id = await this.render();\n    const recaptcha = this.getAssertedRecaptcha();\n\n    const response = recaptcha.getResponse(id);\n    if (response) {\n      return response;\n    }\n\n    return new Promise<string>(resolve => {\n      const tokenChange = (token: string): void => {\n        if (!token) {\n          return; // Ignore token expirations.\n        }\n        this.tokenChangeListeners.delete(tokenChange);\n        resolve(token);\n      };\n\n      this.tokenChangeListeners.add(tokenChange);\n      if (this.isInvisible) {\n        recaptcha.execute(id);\n      }\n    });\n  }\n\n  /**\n   * Renders the reCAPTCHA widget on the page.\n   *\n   * @returns A Promise that resolves with the reCAPTCHA widget ID.\n   */\n  render(): Promise<number> {\n    try {\n      this.assertNotDestroyed();\n    } catch (e) {\n      // This method returns a promise. Since it's not async (we want to return the\n      // _same_ promise if rendering is still occurring), the API surface should\n      // reject with the error rather than just throw\n      return Promise.reject(e);\n    }\n\n    if (this.renderPromise) {\n      return this.renderPromise;\n    }\n\n    this.renderPromise = this.makeRenderPromise().catch(e => {\n      this.renderPromise = null;\n      throw e;\n    });\n\n    return this.renderPromise;\n  }\n\n  /** @internal */\n  _reset(): void {\n    this.assertNotDestroyed();\n    if (this.widgetId !== null) {\n      this.getAssertedRecaptcha().reset(this.widgetId);\n    }\n  }\n\n  /**\n   * Clears the reCAPTCHA widget from the page and destroys the instance.\n   */\n  clear(): void {\n    this.assertNotDestroyed();\n    this.destroyed = true;\n    this._recaptchaLoader.clearedOneInstance();\n    if (!this.isInvisible) {\n      this.container.childNodes.forEach(node => {\n        this.container.removeChild(node);\n      });\n    }\n  }\n\n  private validateStartingState(): void {\n    _assert(!this.parameters.sitekey, this.auth, AuthErrorCode.ARGUMENT_ERROR);\n    _assert(\n      this.isInvisible || !this.container.hasChildNodes(),\n      this.auth,\n      AuthErrorCode.ARGUMENT_ERROR\n    );\n    _assert(\n      typeof document !== 'undefined',\n      this.auth,\n      AuthErrorCode.OPERATION_NOT_SUPPORTED\n    );\n  }\n\n  private makeTokenCallback(\n    existing: TokenCallback | string | undefined\n  ): TokenCallback {\n    return token => {\n      this.tokenChangeListeners.forEach(listener => listener(token));\n      if (typeof existing === 'function') {\n        existing(token);\n      } else if (typeof existing === 'string') {\n        const globalFunc = _window()[existing];\n        if (typeof globalFunc === 'function') {\n          globalFunc(token);\n        }\n      }\n    };\n  }\n\n  private assertNotDestroyed(): void {\n    _assert(!this.destroyed, this.auth, AuthErrorCode.INTERNAL_ERROR);\n  }\n\n  private async makeRenderPromise(): Promise<number> {\n    await this.init();\n    if (!this.widgetId) {\n      let container = this.container;\n      if (!this.isInvisible) {\n        const guaranteedEmpty = document.createElement('div');\n        container.appendChild(guaranteedEmpty);\n        container = guaranteedEmpty;\n      }\n\n      this.widgetId = this.getAssertedRecaptcha().render(\n        container,\n        this.parameters\n      );\n    }\n\n    return this.widgetId;\n  }\n\n  private async init(): Promise<void> {\n    _assert(\n      _isHttpOrHttps() && !_isWorker(),\n      this.auth,\n      AuthErrorCode.INTERNAL_ERROR\n    );\n\n    await domReady();\n    this.recaptcha = await this._recaptchaLoader.load(\n      this.auth,\n      this.auth.languageCode || undefined\n    );\n\n    const siteKey = await getRecaptchaParams(this.auth);\n    _assert(siteKey, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    this.parameters.sitekey = siteKey;\n  }\n\n  private getAssertedRecaptcha(): Recaptcha {\n    _assert(this.recaptcha, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    return this.recaptcha;\n  }\n}\n\nfunction domReady(): Promise<void> {\n  let resolver: (() => void) | null = null;\n  return new Promise<void>(resolve => {\n    if (document.readyState === 'complete') {\n      resolve();\n      return;\n    }\n\n    // Document not ready, wait for load before resolving.\n    // Save resolver, so we can remove listener in case it was externally\n    // cancelled.\n    resolver = () => resolve();\n    window.addEventListener('load', resolver);\n  }).catch(e => {\n    if (resolver) {\n      window.removeEventListener('load', resolver);\n    }\n\n    throw 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\nimport {\n  ApplicationVerifier,\n  Auth,\n  ConfirmationResult,\n  PhoneInfoOptions,\n  User,\n  UserCredential\n} from '../../model/public_types';\n\nimport {\n  startEnrollPhoneMfa,\n  StartPhoneMfaEnrollmentRequest,\n  StartPhoneMfaEnrollmentResponse\n} from '../../api/account_management/mfa';\nimport {\n  startSignInPhoneMfa,\n  StartPhoneMfaSignInRequest,\n  StartPhoneMfaSignInResponse\n} from '../../api/authentication/mfa';\nimport {\n  sendPhoneVerificationCode,\n  SendPhoneVerificationCodeRequest,\n  SendPhoneVerificationCodeResponse\n} from '../../api/authentication/sms';\nimport {\n  RecaptchaActionName,\n  RecaptchaClientType,\n  RecaptchaAuthProvider\n} from '../../api';\nimport { ApplicationVerifierInternal } from '../../model/application_verifier';\nimport { PhoneAuthCredential } from '../../core/credentials/phone';\nimport { AuthErrorCode } from '../../core/errors';\nimport { _assertLinkedStatus, _link } from '../../core/user/link_unlink';\nimport {\n  _assert,\n  _serverAppCurrentUserOperationNotSupportedError\n} from '../../core/util/assert';\nimport { AuthInternal } from '../../model/auth';\nimport {\n  linkWithCredential,\n  reauthenticateWithCredential,\n  signInWithCredential\n} from '../../core/strategies/credential';\nimport {\n  MultiFactorSessionImpl,\n  MultiFactorSessionType\n} from '../../mfa/mfa_session';\nimport { UserInternal } from '../../model/user';\nimport { RECAPTCHA_VERIFIER_TYPE } from '../recaptcha/recaptcha_verifier';\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport { getModularInstance } from '@firebase/util';\nimport { ProviderId } from '../../model/enums';\nimport {\n  FAKE_TOKEN,\n  handleRecaptchaFlow,\n  _initializeRecaptchaConfig\n} from '../recaptcha/recaptcha_enterprise_verifier';\nimport { _isFirebaseServerApp } from '@firebase/app';\n\ninterface OnConfirmationCallback {\n  (credential: PhoneAuthCredential): Promise<UserCredential>;\n}\n\nclass ConfirmationResultImpl implements ConfirmationResult {\n  constructor(\n    readonly verificationId: string,\n    private readonly onConfirmation: OnConfirmationCallback\n  ) {}\n\n  confirm(verificationCode: string): Promise<UserCredential> {\n    const authCredential = PhoneAuthCredential._fromVerification(\n      this.verificationId,\n      verificationCode\n    );\n    return this.onConfirmation(authCredential);\n  }\n}\n\n/**\n * Asynchronously signs in using a phone number.\n *\n * @remarks\n * This method sends a code via SMS to the given\n * phone number, and returns a {@link ConfirmationResult}. After the user\n * provides the code sent to their phone, call {@link ConfirmationResult.confirm}\n * with the code to sign the user in.\n *\n * For abuse prevention, this method requires a {@link ApplicationVerifier}.\n * This SDK includes an implementation based on reCAPTCHA v2, {@link RecaptchaVerifier}.\n * This function can work on other platforms that do not support the\n * {@link RecaptchaVerifier} (like React Native), but you need to use a\n * third-party {@link ApplicationVerifier} implementation.\n *\n * If you've enabled project-level reCAPTCHA Enterprise bot protection in\n * Enforce mode, you can omit the {@link ApplicationVerifier}.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // 'recaptcha-container' is the ID of an element in the DOM.\n * const applicationVerifier = new firebase.auth.RecaptchaVerifier('recaptcha-container');\n * const confirmationResult = await signInWithPhoneNumber(auth, phoneNumber, applicationVerifier);\n * // Obtain a verificationCode from the user.\n * const credential = await confirmationResult.confirm(verificationCode);\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param phoneNumber - The user's phone number in E.164 format (e.g. +16505550101).\n * @param appVerifier - The {@link ApplicationVerifier}.\n *\n * @public\n */\nexport async function signInWithPhoneNumber(\n  auth: Auth,\n  phoneNumber: string,\n  appVerifier?: ApplicationVerifier\n): Promise<ConfirmationResult> {\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(auth)\n    );\n  }\n  const authInternal = _castAuth(auth);\n  const verificationId = await _verifyPhoneNumber(\n    authInternal,\n    phoneNumber,\n    getModularInstance(appVerifier as ApplicationVerifierInternal)\n  );\n  return new ConfirmationResultImpl(verificationId, cred =>\n    signInWithCredential(authInternal, cred)\n  );\n}\n\n/**\n * Links the user account with the given phone number.\n *\n * @remarks\n * This method does not work in a Node.js environment.\n *\n * @param user - The user.\n * @param phoneNumber - The user's phone number in E.164 format (e.g. +16505550101).\n * @param appVerifier - The {@link ApplicationVerifier}.\n *\n * @public\n */\nexport async function linkWithPhoneNumber(\n  user: User,\n  phoneNumber: string,\n  appVerifier?: ApplicationVerifier\n): Promise<ConfirmationResult> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  await _assertLinkedStatus(false, userInternal, ProviderId.PHONE);\n  const verificationId = await _verifyPhoneNumber(\n    userInternal.auth,\n    phoneNumber,\n    getModularInstance(appVerifier as ApplicationVerifierInternal)\n  );\n  return new ConfirmationResultImpl(verificationId, cred =>\n    linkWithCredential(userInternal, cred)\n  );\n}\n\n/**\n * Re-authenticates a user using a fresh phone credential.\n *\n * @remarks\n * Use before operations such as {@link updatePassword} that require tokens from recent sign-in attempts.\n *\n * This method does not work in a Node.js environment or on any {@link User} signed in by\n * {@link Auth} instances created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @param user - The user.\n * @param phoneNumber - The user's phone number in E.164 format (e.g. +16505550101).\n * @param appVerifier - The {@link ApplicationVerifier}.\n *\n * @public\n */\nexport async function reauthenticateWithPhoneNumber(\n  user: User,\n  phoneNumber: string,\n  appVerifier?: ApplicationVerifier\n): Promise<ConfirmationResult> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  if (_isFirebaseServerApp(userInternal.auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(userInternal.auth)\n    );\n  }\n  const verificationId = await _verifyPhoneNumber(\n    userInternal.auth,\n    phoneNumber,\n    getModularInstance(appVerifier as ApplicationVerifierInternal)\n  );\n  return new ConfirmationResultImpl(verificationId, cred =>\n    reauthenticateWithCredential(userInternal, cred)\n  );\n}\n\ntype PhoneApiCaller<TRequest, TResponse> = (\n  auth: AuthInternal,\n  request: TRequest\n) => Promise<TResponse>;\n\n/**\n * Returns a verification ID to be used in conjunction with the SMS code that is sent.\n *\n */\nexport async function _verifyPhoneNumber(\n  auth: AuthInternal,\n  options: PhoneInfoOptions | string,\n  verifier?: ApplicationVerifierInternal\n): Promise<string> {\n  if (!auth._getRecaptchaConfig()) {\n    try {\n      await _initializeRecaptchaConfig(auth);\n    } catch (error) {\n      // If an error occurs while fetching the config, there is no way to know the enablement state\n      // of Phone provider, so we proceed with recaptcha V2 verification.\n      // The error is likely \"recaptchaKey undefined\", as reCAPTCHA Enterprise is not\n      // enabled for any provider.\n      console.log(\n        'Failed to initialize reCAPTCHA Enterprise config. Triggering the reCAPTCHA v2 verification.'\n      );\n    }\n  }\n\n  try {\n    let phoneInfoOptions: PhoneInfoOptions;\n\n    if (typeof options === 'string') {\n      phoneInfoOptions = {\n        phoneNumber: options\n      };\n    } else {\n      phoneInfoOptions = options;\n    }\n\n    if ('session' in phoneInfoOptions) {\n      const session = phoneInfoOptions.session as MultiFactorSessionImpl;\n\n      if ('phoneNumber' in phoneInfoOptions) {\n        _assert(\n          session.type === MultiFactorSessionType.ENROLL,\n          auth,\n          AuthErrorCode.INTERNAL_ERROR\n        );\n\n        const startPhoneMfaEnrollmentRequest: StartPhoneMfaEnrollmentRequest = {\n          idToken: session.credential,\n          phoneEnrollmentInfo: {\n            phoneNumber: phoneInfoOptions.phoneNumber,\n            clientType: RecaptchaClientType.WEB\n          }\n        };\n\n        const startEnrollPhoneMfaActionCallback: PhoneApiCaller<\n          StartPhoneMfaEnrollmentRequest,\n          StartPhoneMfaEnrollmentResponse\n        > = async (\n          authInstance: AuthInternal,\n          request: StartPhoneMfaEnrollmentRequest\n        ) => {\n          // If reCAPTCHA Enterprise token is FAKE_TOKEN, fetch reCAPTCHA v2 token and inject into request.\n          if (request.phoneEnrollmentInfo.captchaResponse === FAKE_TOKEN) {\n            _assert(\n              verifier?.type === RECAPTCHA_VERIFIER_TYPE,\n              authInstance,\n              AuthErrorCode.ARGUMENT_ERROR\n            );\n\n            const requestWithRecaptchaV2 = await injectRecaptchaV2Token(\n              authInstance,\n              request,\n              verifier\n            );\n            return startEnrollPhoneMfa(authInstance, requestWithRecaptchaV2);\n          }\n          return startEnrollPhoneMfa(authInstance, request);\n        };\n\n        const startPhoneMfaEnrollmentResponse: Promise<StartPhoneMfaEnrollmentResponse> =\n          handleRecaptchaFlow(\n            auth,\n            startPhoneMfaEnrollmentRequest,\n            RecaptchaActionName.MFA_SMS_ENROLLMENT,\n            startEnrollPhoneMfaActionCallback,\n            RecaptchaAuthProvider.PHONE_PROVIDER\n          );\n\n        const response = await startPhoneMfaEnrollmentResponse.catch(error => {\n          return Promise.reject(error);\n        });\n\n        return response.phoneSessionInfo.sessionInfo;\n      } else {\n        _assert(\n          session.type === MultiFactorSessionType.SIGN_IN,\n          auth,\n          AuthErrorCode.INTERNAL_ERROR\n        );\n        const mfaEnrollmentId =\n          phoneInfoOptions.multiFactorHint?.uid ||\n          phoneInfoOptions.multiFactorUid;\n        _assert(mfaEnrollmentId, auth, AuthErrorCode.MISSING_MFA_INFO);\n\n        const startPhoneMfaSignInRequest: StartPhoneMfaSignInRequest = {\n          mfaPendingCredential: session.credential,\n          mfaEnrollmentId,\n          phoneSignInInfo: {\n            clientType: RecaptchaClientType.WEB\n          }\n        };\n\n        const startSignInPhoneMfaActionCallback: PhoneApiCaller<\n          StartPhoneMfaSignInRequest,\n          StartPhoneMfaSignInResponse\n        > = async (\n          authInstance: AuthInternal,\n          request: StartPhoneMfaSignInRequest\n        ) => {\n          // If reCAPTCHA Enterprise token is FAKE_TOKEN, fetch reCAPTCHA v2 token and inject into request.\n          if (request.phoneSignInInfo.captchaResponse === FAKE_TOKEN) {\n            _assert(\n              verifier?.type === RECAPTCHA_VERIFIER_TYPE,\n              authInstance,\n              AuthErrorCode.ARGUMENT_ERROR\n            );\n\n            const requestWithRecaptchaV2 = await injectRecaptchaV2Token(\n              authInstance,\n              request,\n              verifier\n            );\n            return startSignInPhoneMfa(authInstance, requestWithRecaptchaV2);\n          }\n          return startSignInPhoneMfa(authInstance, request);\n        };\n\n        const startPhoneMfaSignInResponse: Promise<StartPhoneMfaSignInResponse> =\n          handleRecaptchaFlow(\n            auth,\n            startPhoneMfaSignInRequest,\n            RecaptchaActionName.MFA_SMS_SIGNIN,\n            startSignInPhoneMfaActionCallback,\n            RecaptchaAuthProvider.PHONE_PROVIDER\n          );\n\n        const response = await startPhoneMfaSignInResponse.catch(error => {\n          return Promise.reject(error);\n        });\n\n        return response.phoneResponseInfo.sessionInfo;\n      }\n    } else {\n      const sendPhoneVerificationCodeRequest: SendPhoneVerificationCodeRequest =\n        {\n          phoneNumber: phoneInfoOptions.phoneNumber,\n          clientType: RecaptchaClientType.WEB\n        };\n\n      const sendPhoneVerificationCodeActionCallback: PhoneApiCaller<\n        SendPhoneVerificationCodeRequest,\n        SendPhoneVerificationCodeResponse\n      > = async (\n        authInstance: AuthInternal,\n        request: SendPhoneVerificationCodeRequest\n      ) => {\n        // If reCAPTCHA Enterprise token is FAKE_TOKEN, fetch reCAPTCHA v2 token and inject into request.\n        if (request.captchaResponse === FAKE_TOKEN) {\n          _assert(\n            verifier?.type === RECAPTCHA_VERIFIER_TYPE,\n            authInstance,\n            AuthErrorCode.ARGUMENT_ERROR\n          );\n\n          const requestWithRecaptchaV2 = await injectRecaptchaV2Token(\n            authInstance,\n            request,\n            verifier\n          );\n          return sendPhoneVerificationCode(\n            authInstance,\n            requestWithRecaptchaV2\n          );\n        }\n        return sendPhoneVerificationCode(authInstance, request);\n      };\n\n      const sendPhoneVerificationCodeResponse: Promise<SendPhoneVerificationCodeResponse> =\n        handleRecaptchaFlow(\n          auth,\n          sendPhoneVerificationCodeRequest,\n          RecaptchaActionName.SEND_VERIFICATION_CODE,\n          sendPhoneVerificationCodeActionCallback,\n          RecaptchaAuthProvider.PHONE_PROVIDER\n        );\n\n      const response = await sendPhoneVerificationCodeResponse.catch(error => {\n        return Promise.reject(error);\n      });\n\n      return response.sessionInfo;\n    }\n  } finally {\n    verifier?._reset();\n  }\n}\n\n/**\n * Updates the user's phone number.\n *\n * @remarks\n * This method does not work in a Node.js environment or on any {@link User} signed in by\n * {@link Auth} instances created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```\n * // 'recaptcha-container' is the ID of an element in the DOM.\n * const applicationVerifier = new RecaptchaVerifier('recaptcha-container');\n * const provider = new PhoneAuthProvider(auth);\n * const verificationId = await provider.verifyPhoneNumber('+16505550101', applicationVerifier);\n * // Obtain the verificationCode from the user.\n * const phoneCredential = PhoneAuthProvider.credential(verificationId, verificationCode);\n * await updatePhoneNumber(user, phoneCredential);\n * ```\n *\n * @param user - The user.\n * @param credential - A credential authenticating the new phone number.\n *\n * @public\n */\nexport async function updatePhoneNumber(\n  user: User,\n  credential: PhoneAuthCredential\n): Promise<void> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  if (_isFirebaseServerApp(userInternal.auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(userInternal.auth)\n    );\n  }\n  await _link(userInternal, credential);\n}\n\n// Helper function that fetches and injects a reCAPTCHA v2 token into the request.\nexport async function injectRecaptchaV2Token<T extends object>(\n  auth: AuthInternal,\n  request: T,\n  recaptchaV2Verifier: ApplicationVerifierInternal\n): Promise<T> {\n  _assert(\n    recaptchaV2Verifier.type === RECAPTCHA_VERIFIER_TYPE,\n    auth,\n    AuthErrorCode.ARGUMENT_ERROR\n  );\n\n  const recaptchaV2Token = await recaptchaV2Verifier.verify();\n\n  _assert(\n    typeof recaptchaV2Token === 'string',\n    auth,\n    AuthErrorCode.ARGUMENT_ERROR\n  );\n\n  const newRequest = { ...request };\n\n  if ('phoneEnrollmentInfo' in newRequest) {\n    const phoneNumber = (\n      newRequest as unknown as StartPhoneMfaEnrollmentRequest\n    ).phoneEnrollmentInfo.phoneNumber;\n    const captchaResponse = (\n      newRequest as unknown as StartPhoneMfaEnrollmentRequest\n    ).phoneEnrollmentInfo.captchaResponse;\n    const clientType = (newRequest as unknown as StartPhoneMfaEnrollmentRequest)\n      .phoneEnrollmentInfo.clientType;\n    const recaptchaVersion = (\n      newRequest as unknown as StartPhoneMfaEnrollmentRequest\n    ).phoneEnrollmentInfo.recaptchaVersion;\n\n    Object.assign(newRequest, {\n      'phoneEnrollmentInfo': {\n        phoneNumber,\n        recaptchaToken: recaptchaV2Token,\n        captchaResponse,\n        clientType,\n        recaptchaVersion\n      }\n    });\n\n    return newRequest;\n  } else if ('phoneSignInInfo' in newRequest) {\n    const captchaResponse = (\n      newRequest as unknown as StartPhoneMfaSignInRequest\n    ).phoneSignInInfo.captchaResponse;\n    const clientType = (newRequest as unknown as StartPhoneMfaSignInRequest)\n      .phoneSignInInfo.clientType;\n    const recaptchaVersion = (\n      newRequest as unknown as StartPhoneMfaSignInRequest\n    ).phoneSignInInfo.recaptchaVersion;\n\n    Object.assign(newRequest, {\n      'phoneSignInInfo': {\n        recaptchaToken: recaptchaV2Token,\n        captchaResponse,\n        clientType,\n        recaptchaVersion\n      }\n    });\n\n    return newRequest;\n  } else {\n    Object.assign(newRequest, { 'recaptchaToken': recaptchaV2Token });\n    return newRequest;\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  Auth,\n  PhoneInfoOptions,\n  ApplicationVerifier,\n  UserCredential\n} from '../../model/public_types';\n\nimport { SignInWithPhoneNumberResponse } from '../../api/authentication/sms';\nimport { ApplicationVerifierInternal as ApplicationVerifierInternal } from '../../model/application_verifier';\nimport { AuthInternal as AuthInternal } from '../../model/auth';\nimport { UserCredentialInternal as UserCredentialInternal } from '../../model/user';\nimport { PhoneAuthCredential } from '../../core/credentials/phone';\nimport { _verifyPhoneNumber } from '../strategies/phone';\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport { AuthCredential } from '../../core';\nimport { FirebaseError, getModularInstance } from '@firebase/util';\nimport { TaggedWithTokenResponse } from '../../model/id_token';\nimport { ProviderId, SignInMethod } from '../../model/enums';\n\n/**\n * Provider for generating an {@link PhoneAuthCredential}.\n *\n * @remarks\n * `PhoneAuthProvider` does not work in a Node.js environment.\n *\n * @example\n * ```javascript\n * // 'recaptcha-container' is the ID of an element in the DOM.\n * const applicationVerifier = new RecaptchaVerifier('recaptcha-container');\n * const provider = new PhoneAuthProvider(auth);\n * const verificationId = await provider.verifyPhoneNumber('+16505550101', applicationVerifier);\n * // Obtain the verificationCode from the user.\n * const phoneCredential = PhoneAuthProvider.credential(verificationId, verificationCode);\n * const userCredential = await signInWithCredential(auth, phoneCredential);\n * ```\n *\n * @public\n */\nexport class PhoneAuthProvider {\n  /** Always set to {@link ProviderId}.PHONE. */\n  static readonly PROVIDER_ID: 'phone' = ProviderId.PHONE;\n  /** Always set to {@link SignInMethod}.PHONE. */\n  static readonly PHONE_SIGN_IN_METHOD: 'phone' = SignInMethod.PHONE;\n\n  /** Always set to {@link ProviderId}.PHONE. */\n  readonly providerId = PhoneAuthProvider.PROVIDER_ID;\n  private readonly auth: AuthInternal;\n\n  /**\n   * @param auth - The Firebase {@link Auth} instance in which sign-ins should occur.\n   *\n   */\n  constructor(auth: Auth) {\n    this.auth = _castAuth(auth);\n  }\n\n  /**\n   *\n   * Starts a phone number authentication flow by sending a verification code to the given phone\n   * number.\n   *\n   * @example\n   * ```javascript\n   * const provider = new PhoneAuthProvider(auth);\n   * const verificationId = await provider.verifyPhoneNumber(phoneNumber, applicationVerifier);\n   * // Obtain verificationCode from the user.\n   * const authCredential = PhoneAuthProvider.credential(verificationId, verificationCode);\n   * const userCredential = await signInWithCredential(auth, authCredential);\n   * ```\n   *\n   * @example\n   * An alternative flow is provided using the `signInWithPhoneNumber` method.\n   * ```javascript\n   * const confirmationResult = signInWithPhoneNumber(auth, phoneNumber, applicationVerifier);\n   * // Obtain verificationCode from the user.\n   * const userCredential = confirmationResult.confirm(verificationCode);\n   * ```\n   *\n   * @param phoneInfoOptions - The user's {@link PhoneInfoOptions}. The phone number should be in\n   * E.164 format (e.g. +16505550101).\n   * @param applicationVerifier - An {@link ApplicationVerifier}, which prevents\n   * requests from unauthorized clients. This SDK includes an implementation\n   * based on reCAPTCHA v2, {@link RecaptchaVerifier}. If you've enabled\n   * reCAPTCHA Enterprise bot protection in Enforce mode, this parameter is\n   * optional; in all other configurations, the parameter is required.\n   *\n   * @returns A Promise for a verification ID that can be passed to\n   * {@link PhoneAuthProvider.credential} to identify this flow.\n   */\n  verifyPhoneNumber(\n    phoneOptions: PhoneInfoOptions | string,\n    applicationVerifier?: ApplicationVerifier\n  ): Promise<string> {\n    return _verifyPhoneNumber(\n      this.auth,\n      phoneOptions,\n      getModularInstance(applicationVerifier as ApplicationVerifierInternal)\n    );\n  }\n\n  /**\n   * Creates a phone auth credential, given the verification ID from\n   * {@link PhoneAuthProvider.verifyPhoneNumber} and the code that was sent to the user's\n   * mobile device.\n   *\n   * @example\n   * ```javascript\n   * const provider = new PhoneAuthProvider(auth);\n   * const verificationId = provider.verifyPhoneNumber(phoneNumber, applicationVerifier);\n   * // Obtain verificationCode from the user.\n   * const authCredential = PhoneAuthProvider.credential(verificationId, verificationCode);\n   * const userCredential = signInWithCredential(auth, authCredential);\n   * ```\n   *\n   * @example\n   * An alternative flow is provided using the `signInWithPhoneNumber` method.\n   * ```javascript\n   * const confirmationResult = await signInWithPhoneNumber(auth, phoneNumber, applicationVerifier);\n   * // Obtain verificationCode from the user.\n   * const userCredential = await confirmationResult.confirm(verificationCode);\n   * ```\n   *\n   * @param verificationId - The verification ID returned from {@link PhoneAuthProvider.verifyPhoneNumber}.\n   * @param verificationCode - The verification code sent to the user's mobile device.\n   *\n   * @returns The auth provider credential.\n   */\n  static credential(\n    verificationId: string,\n    verificationCode: string\n  ): PhoneAuthCredential {\n    return PhoneAuthCredential._fromVerification(\n      verificationId,\n      verificationCode\n    );\n  }\n\n  /**\n   * Generates an {@link AuthCredential} from a {@link UserCredential}.\n   * @param userCredential - The user credential.\n   */\n  static credentialFromResult(\n    userCredential: UserCredential\n  ): AuthCredential | null {\n    const credential = userCredential as UserCredentialInternal;\n    return PhoneAuthProvider.credentialFromTaggedObject(credential);\n  }\n\n  /**\n   * Returns an {@link AuthCredential} when passed an error.\n   *\n   * @remarks\n   *\n   * This method works for errors like\n   * `auth/account-exists-with-different-credentials`. This is useful for\n   * recovering when attempting to set a user's phone number but the number\n   * in question is already tied to another account. For example, the following\n   * code tries to update the current user's phone number, and if that\n   * fails, links the user with the account associated with that number:\n   *\n   * ```js\n   * const provider = new PhoneAuthProvider(auth);\n   * const verificationId = await provider.verifyPhoneNumber(number, verifier);\n   * try {\n   *   const code = ''; // Prompt the user for the verification code\n   *   await updatePhoneNumber(\n   *       auth.currentUser,\n   *       PhoneAuthProvider.credential(verificationId, code));\n   * } catch (e) {\n   *   if ((e as FirebaseError)?.code === 'auth/account-exists-with-different-credential') {\n   *     const cred = PhoneAuthProvider.credentialFromError(e);\n   *     await linkWithCredential(auth.currentUser, cred);\n   *   }\n   * }\n   *\n   * // At this point, auth.currentUser.phoneNumber === number.\n   * ```\n   *\n   * @param error - The error to generate a credential from.\n   */\n  static credentialFromError(error: FirebaseError): AuthCredential | null {\n    return PhoneAuthProvider.credentialFromTaggedObject(\n      (error.customData || {}) as TaggedWithTokenResponse\n    );\n  }\n\n  private static credentialFromTaggedObject({\n    _tokenResponse: tokenResponse\n  }: TaggedWithTokenResponse): AuthCredential | null {\n    if (!tokenResponse) {\n      return null;\n    }\n    const { phoneNumber, temporaryProof } =\n      tokenResponse as SignInWithPhoneNumberResponse;\n    if (phoneNumber && temporaryProof) {\n      return PhoneAuthCredential._fromTokenResponse(\n        phoneNumber,\n        temporaryProof\n      );\n    }\n    return null;\n  }\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { PopupRedirectResolver } from '../../model/public_types';\nimport { AuthInternal } from '../../model/auth';\nimport { PopupRedirectResolverInternal } from '../../model/popup_redirect';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from './assert';\nimport { _getInstance } from './instantiator';\n\n/**\n * Chooses a popup/redirect resolver to use. This prefers the override (which\n * is directly passed in), and falls back to the property set on the auth\n * object. If neither are available, this function errors w/ an argument error.\n */\nexport function _withDefaultResolver(\n  auth: AuthInternal,\n  resolverOverride: PopupRedirectResolver | undefined\n): PopupRedirectResolverInternal {\n  if (resolverOverride) {\n    return _getInstance(resolverOverride);\n  }\n\n  _assert(auth._popupRedirectResolver, auth, AuthErrorCode.ARGUMENT_ERROR);\n\n  return auth._popupRedirectResolver;\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  signInWithIdp,\n  SignInWithIdpRequest\n} from '../../api/authentication/idp';\nimport { PhoneOrOauthTokenResponse } from '../../api/authentication/mfa';\nimport { AuthInternal } from '../../model/auth';\nimport { IdTokenResponse } from '../../model/id_token';\nimport { UserInternal, UserCredentialInternal } from '../../model/user';\nimport { AuthCredential } from '../credentials';\nimport { _link as _linkUser } from '../user/link_unlink';\nimport { _reauthenticate } from '../user/reauthenticate';\nimport { _assert } from '../util/assert';\nimport { _signInWithCredential } from './credential';\nimport { AuthErrorCode } from '../errors';\nimport { ProviderId } from '../../model/enums';\n\nexport interface IdpTaskParams {\n  auth: AuthInternal;\n  requestUri: string;\n  sessionId?: string;\n  tenantId?: string;\n  postBody?: string;\n  pendingToken?: string;\n  user?: UserInternal;\n  bypassAuthState?: boolean;\n}\n\nexport type IdpTask = (\n  params: IdpTaskParams\n) => Promise<UserCredentialInternal>;\n\nclass IdpCredential extends AuthCredential {\n  constructor(readonly params: IdpTaskParams) {\n    super(ProviderId.CUSTOM, ProviderId.CUSTOM);\n  }\n\n  _getIdTokenResponse(auth: AuthInternal): Promise<PhoneOrOauthTokenResponse> {\n    return signInWithIdp(auth, this._buildIdpRequest());\n  }\n\n  _linkToIdToken(\n    auth: AuthInternal,\n    idToken: string\n  ): Promise<IdTokenResponse> {\n    return signInWithIdp(auth, this._buildIdpRequest(idToken));\n  }\n\n  _getReauthenticationResolver(auth: AuthInternal): Promise<IdTokenResponse> {\n    return signInWithIdp(auth, this._buildIdpRequest());\n  }\n\n  private _buildIdpRequest(idToken?: string): SignInWithIdpRequest {\n    const request: SignInWithIdpRequest = {\n      requestUri: this.params.requestUri,\n      sessionId: this.params.sessionId,\n      postBody: this.params.postBody,\n      tenantId: this.params.tenantId,\n      pendingToken: this.params.pendingToken,\n      returnSecureToken: true,\n      returnIdpCredential: true\n    };\n\n    if (idToken) {\n      request.idToken = idToken;\n    }\n\n    return request;\n  }\n}\n\nexport function _signIn(\n  params: IdpTaskParams\n): Promise<UserCredentialInternal> {\n  return _signInWithCredential(\n    params.auth,\n    new IdpCredential(params),\n    params.bypassAuthState\n  ) as Promise<UserCredentialInternal>;\n}\n\nexport function _reauth(\n  params: IdpTaskParams\n): Promise<UserCredentialInternal> {\n  const { auth, user } = params;\n  _assert(user, auth, AuthErrorCode.INTERNAL_ERROR);\n  return _reauthenticate(\n    user,\n    new IdpCredential(params),\n    params.bypassAuthState\n  );\n}\n\nexport async function _link(\n  params: IdpTaskParams\n): Promise<UserCredentialInternal> {\n  const { auth, user } = params;\n  _assert(user, auth, AuthErrorCode.INTERNAL_ERROR);\n  return _linkUser(user, new IdpCredential(params), params.bypassAuthState);\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 { FirebaseError } from '@firebase/util';\n\nimport {\n  AuthEvent,\n  AuthEventConsumer,\n  AuthEventType,\n  EventManager,\n  PopupRedirectResolverInternal\n} from '../../model/popup_redirect';\nimport { UserInternal, UserCredentialInternal } from '../../model/user';\nimport { AuthErrorCode } from '../errors';\nimport { debugAssert, _fail } from '../util/assert';\nimport {\n  _link,\n  _reauth,\n  _signIn,\n  IdpTask,\n  IdpTaskParams\n} from '../strategies/idp';\nimport { AuthInternal } from '../../model/auth';\n\ninterface PendingPromise {\n  resolve: (cred: UserCredentialInternal | null) => void;\n  reject: (error: Error) => void;\n}\n\n/**\n * Popup event manager. Handles the popup's entire lifecycle; listens to auth\n * events\n */\nexport abstract class AbstractPopupRedirectOperation\n  implements AuthEventConsumer\n{\n  private pendingPromise: PendingPromise | null = null;\n  private eventManager: EventManager | null = null;\n  readonly filter: AuthEventType[];\n\n  abstract eventId: string | null;\n\n  constructor(\n    protected readonly auth: AuthInternal,\n    filter: AuthEventType | AuthEventType[],\n    protected readonly resolver: PopupRedirectResolverInternal,\n    protected user?: UserInternal,\n    protected readonly bypassAuthState = false\n  ) {\n    this.filter = Array.isArray(filter) ? filter : [filter];\n  }\n\n  abstract onExecution(): Promise<void>;\n\n  execute(): Promise<UserCredentialInternal | null> {\n    return new Promise<UserCredentialInternal | null>(\n      async (resolve, reject) => {\n        this.pendingPromise = { resolve, reject };\n\n        try {\n          this.eventManager = await this.resolver._initialize(this.auth);\n          await this.onExecution();\n          this.eventManager.registerConsumer(this);\n        } catch (e) {\n          this.reject(e as Error);\n        }\n      }\n    );\n  }\n\n  async onAuthEvent(event: AuthEvent): Promise<void> {\n    const { urlResponse, sessionId, postBody, tenantId, error, type } = event;\n    if (error) {\n      this.reject(error);\n      return;\n    }\n\n    const params: IdpTaskParams = {\n      auth: this.auth,\n      requestUri: urlResponse!,\n      sessionId: sessionId!,\n      tenantId: tenantId || undefined,\n      postBody: postBody || undefined,\n      user: this.user,\n      bypassAuthState: this.bypassAuthState\n    };\n\n    try {\n      this.resolve(await this.getIdpTask(type)(params));\n    } catch (e) {\n      this.reject(e as Error);\n    }\n  }\n\n  onError(error: FirebaseError): void {\n    this.reject(error);\n  }\n\n  private getIdpTask(type: AuthEventType): IdpTask {\n    switch (type) {\n      case AuthEventType.SIGN_IN_VIA_POPUP:\n      case AuthEventType.SIGN_IN_VIA_REDIRECT:\n        return _signIn;\n      case AuthEventType.LINK_VIA_POPUP:\n      case AuthEventType.LINK_VIA_REDIRECT:\n        return _link;\n      case AuthEventType.REAUTH_VIA_POPUP:\n      case AuthEventType.REAUTH_VIA_REDIRECT:\n        return _reauth;\n      default:\n        _fail(this.auth, AuthErrorCode.INTERNAL_ERROR);\n    }\n  }\n\n  protected resolve(cred: UserCredentialInternal | null): void {\n    debugAssert(this.pendingPromise, 'Pending promise was never set');\n    this.pendingPromise.resolve(cred);\n    this.unregisterAndCleanUp();\n  }\n\n  protected reject(error: Error): void {\n    debugAssert(this.pendingPromise, 'Pending promise was never set');\n    this.pendingPromise.reject(error);\n    this.unregisterAndCleanUp();\n  }\n\n  private unregisterAndCleanUp(): void {\n    if (this.eventManager) {\n      this.eventManager.unregisterConsumer(this);\n    }\n\n    this.pendingPromise = null;\n    this.cleanUp();\n  }\n\n  abstract cleanUp(): void;\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  Auth,\n  AuthProvider,\n  PopupRedirectResolver,\n  User,\n  UserCredential\n} from '../../model/public_types';\n\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport { AuthErrorCode } from '../../core/errors';\nimport {\n  _assert,\n  debugAssert,\n  _createError,\n  _assertInstanceOf\n} from '../../core/util/assert';\nimport { Delay } from '../../core/util/delay';\nimport { _generateEventId } from '../../core/util/event_id';\nimport { AuthInternal } from '../../model/auth';\nimport {\n  AuthEventType,\n  PopupRedirectResolverInternal\n} from '../../model/popup_redirect';\nimport { UserInternal } from '../../model/user';\nimport { _withDefaultResolver } from '../../core/util/resolver';\nimport { AuthPopup } from '../util/popup';\nimport { AbstractPopupRedirectOperation } from '../../core/strategies/abstract_popup_redirect_operation';\nimport { FederatedAuthProvider } from '../../core/providers/federated';\nimport { getModularInstance } from '@firebase/util';\nimport { _isFirebaseServerApp } from '@firebase/app';\n\n/*\n * The event timeout is the same on mobile and desktop, no need for Delay. Set this to 8s since\n * blocking functions can take upto 7s to complete sign in, as documented in:\n * https://cloud.google.com/identity-platform/docs/blocking-functions#understanding_blocking_functions\n * https://firebase.google.com/docs/auth/extend-with-blocking-functions#understanding_blocking_functions\n */\nexport const enum _Timeout {\n  AUTH_EVENT = 8000\n}\nexport const _POLL_WINDOW_CLOSE_TIMEOUT = new Delay(2000, 10000);\n\n/**\n * Authenticates a Firebase client using a popup-based OAuth authentication flow.\n *\n * @remarks\n * If succeeds, returns the signed in user along with the provider's credential. If sign in was\n * unsuccessful, returns an error object containing additional information about the error.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new FacebookAuthProvider();\n * const result = await signInWithPopup(auth, provider);\n *\n * // The signed-in user info.\n * const user = result.user;\n * // This gives you a Facebook Access Token.\n * const credential = provider.credentialFromResult(auth, result);\n * const token = credential.accessToken;\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport async function signInWithPopup(\n  auth: Auth,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<UserCredential> {\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _createError(auth, AuthErrorCode.OPERATION_NOT_SUPPORTED)\n    );\n  }\n  const authInternal = _castAuth(auth);\n  _assertInstanceOf(auth, provider, FederatedAuthProvider);\n  const resolverInternal = _withDefaultResolver(authInternal, resolver);\n  const action = new PopupOperation(\n    authInternal,\n    AuthEventType.SIGN_IN_VIA_POPUP,\n    provider,\n    resolverInternal\n  );\n  return action.executeNotNull();\n}\n\n/**\n * Reauthenticates the current user with the specified {@link OAuthProvider} using a pop-up based\n * OAuth flow.\n *\n * @remarks\n * If the reauthentication is successful, the returned result will contain the user and the\n * provider's credential.\n *\n * This method does not work in a Node.js environment or on any {@link User} signed in by\n * {@link Auth} instances created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using a popup.\n * const provider = new FacebookAuthProvider();\n * const result = await signInWithPopup(auth, provider);\n * // Reauthenticate using a popup.\n * await reauthenticateWithPopup(result.user, provider);\n * ```\n *\n * @param user - The user.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport async function reauthenticateWithPopup(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<UserCredential> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  if (_isFirebaseServerApp(userInternal.auth.app)) {\n    return Promise.reject(\n      _createError(userInternal.auth, AuthErrorCode.OPERATION_NOT_SUPPORTED)\n    );\n  }\n  _assertInstanceOf(userInternal.auth, provider, FederatedAuthProvider);\n  const resolverInternal = _withDefaultResolver(userInternal.auth, resolver);\n  const action = new PopupOperation(\n    userInternal.auth,\n    AuthEventType.REAUTH_VIA_POPUP,\n    provider,\n    resolverInternal,\n    userInternal\n  );\n  return action.executeNotNull();\n}\n\n/**\n * Links the authenticated provider to the user account using a pop-up based OAuth flow.\n *\n * @remarks\n * If the linking is successful, the returned result will contain the user and the provider's credential.\n *\n * This method does not work in a Node.js environment.\n *\n * @example\n * ```javascript\n * // Sign in using some other provider.\n * const result = await signInWithEmailAndPassword(auth, email, password);\n * // Link using a popup.\n * const provider = new FacebookAuthProvider();\n * await linkWithPopup(result.user, provider);\n * ```\n *\n * @param user - The user.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport async function linkWithPopup(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<UserCredential> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  _assertInstanceOf(userInternal.auth, provider, FederatedAuthProvider);\n  const resolverInternal = _withDefaultResolver(userInternal.auth, resolver);\n\n  const action = new PopupOperation(\n    userInternal.auth,\n    AuthEventType.LINK_VIA_POPUP,\n    provider,\n    resolverInternal,\n    userInternal\n  );\n  return action.executeNotNull();\n}\n\n/**\n * Popup event manager. Handles the popup's entire lifecycle; listens to auth\n * events\n *\n */\nclass PopupOperation extends AbstractPopupRedirectOperation {\n  // Only one popup is ever shown at once. The lifecycle of the current popup\n  // can be managed / cancelled by the constructor.\n  private static currentPopupAction: PopupOperation | null = null;\n  private authWindow: AuthPopup | null = null;\n  private pollId: number | null = null;\n\n  constructor(\n    auth: AuthInternal,\n    filter: AuthEventType,\n    private readonly provider: AuthProvider,\n    resolver: PopupRedirectResolverInternal,\n    user?: UserInternal\n  ) {\n    super(auth, filter, resolver, user);\n    if (PopupOperation.currentPopupAction) {\n      PopupOperation.currentPopupAction.cancel();\n    }\n\n    PopupOperation.currentPopupAction = this;\n  }\n\n  async executeNotNull(): Promise<UserCredential> {\n    const result = await this.execute();\n    _assert(result, this.auth, AuthErrorCode.INTERNAL_ERROR);\n    return result;\n  }\n\n  async onExecution(): Promise<void> {\n    debugAssert(\n      this.filter.length === 1,\n      'Popup operations only handle one event'\n    );\n    const eventId = _generateEventId();\n    this.authWindow = await this.resolver._openPopup(\n      this.auth,\n      this.provider,\n      this.filter[0], // There's always one, see constructor\n      eventId\n    );\n    this.authWindow.associatedEvent = eventId;\n\n    // Check for web storage support and origin validation _after_ the popup is\n    // loaded. These operations are slow (~1 second or so) Rather than\n    // waiting on them before opening the window, optimistically open the popup\n    // and check for storage support at the same time. If storage support is\n    // not available, this will cause the whole thing to reject properly. It\n    // will also close the popup, but since the promise has already rejected,\n    // the popup closed by user poll will reject into the void.\n    this.resolver._originValidation(this.auth).catch(e => {\n      this.reject(e);\n    });\n\n    this.resolver._isIframeWebStorageSupported(this.auth, isSupported => {\n      if (!isSupported) {\n        this.reject(\n          _createError(this.auth, AuthErrorCode.WEB_STORAGE_UNSUPPORTED)\n        );\n      }\n    });\n\n    // Handle user closure. Notice this does *not* use await\n    this.pollUserCancellation();\n  }\n\n  get eventId(): string | null {\n    return this.authWindow?.associatedEvent || null;\n  }\n\n  cancel(): void {\n    this.reject(_createError(this.auth, AuthErrorCode.EXPIRED_POPUP_REQUEST));\n  }\n\n  cleanUp(): void {\n    if (this.authWindow) {\n      this.authWindow.close();\n    }\n\n    if (this.pollId) {\n      window.clearTimeout(this.pollId);\n    }\n\n    this.authWindow = null;\n    this.pollId = null;\n    PopupOperation.currentPopupAction = null;\n  }\n\n  private pollUserCancellation(): void {\n    const poll = (): void => {\n      if (this.authWindow?.window?.closed) {\n        // Make sure that there is sufficient time for whatever action to\n        // complete. The window could have closed but the sign in network\n        // call could still be in flight. This is specifically true for\n        // Firefox or if the opener is in an iframe, in which case the oauth\n        // helper closes the popup.\n        this.pollId = window.setTimeout(() => {\n          this.pollId = null;\n          this.reject(\n            _createError(this.auth, AuthErrorCode.POPUP_CLOSED_BY_USER)\n          );\n        }, _Timeout.AUTH_EVENT);\n        return;\n      }\n\n      this.pollId = window.setTimeout(poll, _POLL_WINDOW_CLOSE_TIMEOUT.get());\n    };\n\n    poll();\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 { AuthInternal } from '../../model/auth';\nimport {\n  AuthEvent,\n  AuthEventType,\n  PopupRedirectResolverInternal\n} from '../../model/popup_redirect';\nimport { UserCredentialInternal } from '../../model/user';\nimport { PersistenceInternal } from '../persistence';\nimport { _persistenceKeyName } from '../persistence/persistence_user_manager';\nimport { _getInstance } from '../util/instantiator';\nimport { AbstractPopupRedirectOperation } from './abstract_popup_redirect_operation';\n\nconst PENDING_REDIRECT_KEY = 'pendingRedirect';\n\n// We only get one redirect outcome for any one auth, so just store it\n// in here.\nconst redirectOutcomeMap: Map<\n  string,\n  () => Promise<UserCredentialInternal | null>\n> = new Map();\n\nexport class RedirectAction extends AbstractPopupRedirectOperation {\n  eventId = null;\n\n  constructor(\n    auth: AuthInternal,\n    resolver: PopupRedirectResolverInternal,\n    bypassAuthState = false\n  ) {\n    super(\n      auth,\n      [\n        AuthEventType.SIGN_IN_VIA_REDIRECT,\n        AuthEventType.LINK_VIA_REDIRECT,\n        AuthEventType.REAUTH_VIA_REDIRECT,\n        AuthEventType.UNKNOWN\n      ],\n      resolver,\n      undefined,\n      bypassAuthState\n    );\n  }\n\n  /**\n   * Override the execute function; if we already have a redirect result, then\n   * just return it.\n   */\n  async execute(): Promise<UserCredentialInternal | null> {\n    let readyOutcome = redirectOutcomeMap.get(this.auth._key());\n    if (!readyOutcome) {\n      try {\n        const hasPendingRedirect = await _getAndClearPendingRedirectStatus(\n          this.resolver,\n          this.auth\n        );\n        const result = hasPendingRedirect ? await super.execute() : null;\n        readyOutcome = () => Promise.resolve(result);\n      } catch (e) {\n        readyOutcome = () => Promise.reject(e);\n      }\n\n      redirectOutcomeMap.set(this.auth._key(), readyOutcome);\n    }\n\n    // If we're not bypassing auth state, the ready outcome should be set to\n    // null.\n    if (!this.bypassAuthState) {\n      redirectOutcomeMap.set(this.auth._key(), () => Promise.resolve(null));\n    }\n\n    return readyOutcome();\n  }\n\n  async onAuthEvent(event: AuthEvent): Promise<void> {\n    if (event.type === AuthEventType.SIGN_IN_VIA_REDIRECT) {\n      return super.onAuthEvent(event);\n    } else if (event.type === AuthEventType.UNKNOWN) {\n      // This is a sentinel value indicating there's no pending redirect\n      this.resolve(null);\n      return;\n    }\n\n    if (event.eventId) {\n      const user = await this.auth._redirectUserForId(event.eventId);\n      if (user) {\n        this.user = user;\n        return super.onAuthEvent(event);\n      } else {\n        this.resolve(null);\n      }\n    }\n  }\n\n  async onExecution(): Promise<void> {}\n\n  cleanUp(): void {}\n}\n\nexport async function _getAndClearPendingRedirectStatus(\n  resolver: PopupRedirectResolverInternal,\n  auth: AuthInternal\n): Promise<boolean> {\n  const key = pendingRedirectKey(auth);\n  const persistence = resolverPersistence(resolver);\n  if (!(await persistence._isAvailable())) {\n    return false;\n  }\n  const hasPendingRedirect = (await persistence._get(key)) === 'true';\n  await persistence._remove(key);\n  return hasPendingRedirect;\n}\n\nexport async function _setPendingRedirectStatus(\n  resolver: PopupRedirectResolverInternal,\n  auth: AuthInternal\n): Promise<void> {\n  return resolverPersistence(resolver)._set(pendingRedirectKey(auth), 'true');\n}\n\nexport function _clearRedirectOutcomes(): void {\n  redirectOutcomeMap.clear();\n}\n\nexport function _overrideRedirectResult(\n  auth: AuthInternal,\n  result: () => Promise<UserCredentialInternal | null>\n): void {\n  redirectOutcomeMap.set(auth._key(), result);\n}\n\nfunction resolverPersistence(\n  resolver: PopupRedirectResolverInternal\n): PersistenceInternal {\n  return _getInstance(resolver._redirectPersistence);\n}\n\nfunction pendingRedirectKey(auth: AuthInternal): string {\n  return _persistenceKeyName(\n    PENDING_REDIRECT_KEY,\n    auth.config.apiKey,\n    auth.name\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  Auth,\n  AuthProvider,\n  PopupRedirectResolver,\n  User,\n  UserCredential\n} from '../../model/public_types';\n\nimport { _castAuth } from '../../core/auth/auth_impl';\nimport { _assertLinkedStatus } from '../../core/user/link_unlink';\nimport {\n  _assertInstanceOf,\n  _serverAppCurrentUserOperationNotSupportedError\n} from '../../core/util/assert';\nimport { _generateEventId } from '../../core/util/event_id';\nimport { AuthEventType } from '../../model/popup_redirect';\nimport { UserInternal } from '../../model/user';\nimport { _withDefaultResolver } from '../../core/util/resolver';\nimport {\n  RedirectAction,\n  _setPendingRedirectStatus\n} from '../../core/strategies/redirect';\nimport { FederatedAuthProvider } from '../../core/providers/federated';\nimport { getModularInstance } from '@firebase/util';\nimport { _isFirebaseServerApp } from '@firebase/app';\n\n/**\n * Authenticates a Firebase client using a full-page redirect flow.\n *\n * @remarks\n * To handle the results and errors for this operation, refer to {@link getRedirectResult}.\n * Follow the {@link https://firebase.google.com/docs/auth/web/redirect-best-practices\n * | best practices} when using {@link signInWithRedirect}.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new FacebookAuthProvider();\n * // You can add additional scopes to the provider:\n * provider.addScope('user_birthday');\n * // Start a sign in process for an unauthenticated user.\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a Facebook Access Token.\n *   const credential = provider.credentialFromResult(auth, result);\n *   const token = credential.accessToken;\n * }\n * // As this API can be used for sign-in, linking and reauthentication,\n * // check the operationType to determine what triggered this redirect\n * // operation.\n * const operationType = result.operationType;\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport function signInWithRedirect(\n  auth: Auth,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<never> {\n  return _signInWithRedirect(auth, provider, resolver) as Promise<never>;\n}\n\nexport async function _signInWithRedirect(\n  auth: Auth,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<void | never> {\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(auth)\n    );\n  }\n  const authInternal = _castAuth(auth);\n  _assertInstanceOf(auth, provider, FederatedAuthProvider);\n  // Wait for auth initialization to complete, this will process pending redirects and clear the\n  // PENDING_REDIRECT_KEY in persistence. This should be completed before starting a new\n  // redirect and creating a PENDING_REDIRECT_KEY entry.\n  await authInternal._initializationPromise;\n  const resolverInternal = _withDefaultResolver(authInternal, resolver);\n  await _setPendingRedirectStatus(resolverInternal, authInternal);\n\n  return resolverInternal._openRedirect(\n    authInternal,\n    provider,\n    AuthEventType.SIGN_IN_VIA_REDIRECT\n  );\n}\n\n/**\n * Reauthenticates the current user with the specified {@link OAuthProvider} using a full-page redirect flow.\n * @remarks\n * To handle the results and errors for this operation, refer to {@link getRedirectResult}.\n * Follow the {@link https://firebase.google.com/docs/auth/web/redirect-best-practices\n * | best practices} when using {@link reauthenticateWithRedirect}.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances\n * created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new FacebookAuthProvider();\n * const result = await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * // Reauthenticate using a redirect.\n * await reauthenticateWithRedirect(result.user, provider);\n * // This will again trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * ```\n *\n * @param user - The user.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport function reauthenticateWithRedirect(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<never> {\n  return _reauthenticateWithRedirect(\n    user,\n    provider,\n    resolver\n  ) as Promise<never>;\n}\nexport async function _reauthenticateWithRedirect(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<void | never> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  _assertInstanceOf(userInternal.auth, provider, FederatedAuthProvider);\n  if (_isFirebaseServerApp(userInternal.auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(userInternal.auth)\n    );\n  }\n  // Wait for auth initialization to complete, this will process pending redirects and clear the\n  // PENDING_REDIRECT_KEY in persistence. This should be completed before starting a new\n  // redirect and creating a PENDING_REDIRECT_KEY entry.\n  await userInternal.auth._initializationPromise;\n  // Allow the resolver to error before persisting the redirect user\n  const resolverInternal = _withDefaultResolver(userInternal.auth, resolver);\n  await _setPendingRedirectStatus(resolverInternal, userInternal.auth);\n\n  const eventId = await prepareUserForRedirect(userInternal);\n  return resolverInternal._openRedirect(\n    userInternal.auth,\n    provider,\n    AuthEventType.REAUTH_VIA_REDIRECT,\n    eventId\n  );\n}\n\n/**\n * Links the {@link OAuthProvider} to the user account using a full-page redirect flow.\n * @remarks\n * To handle the results and errors for this operation, refer to {@link getRedirectResult}.\n * Follow the {@link https://firebase.google.com/docs/auth/web/redirect-best-practices\n * | best practices} when using {@link linkWithRedirect}.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances\n * created with a {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using some other provider.\n * const result = await signInWithEmailAndPassword(auth, email, password);\n * // Link using a redirect.\n * const provider = new FacebookAuthProvider();\n * await linkWithRedirect(result.user, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * ```\n *\n * @param user - The user.\n * @param provider - The provider to authenticate. The provider has to be an {@link OAuthProvider}.\n * Non-OAuth providers like {@link EmailAuthProvider} will throw an error.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport function linkWithRedirect(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<never> {\n  return _linkWithRedirect(user, provider, resolver) as Promise<never>;\n}\nexport async function _linkWithRedirect(\n  user: User,\n  provider: AuthProvider,\n  resolver?: PopupRedirectResolver\n): Promise<void | never> {\n  const userInternal = getModularInstance(user) as UserInternal;\n  _assertInstanceOf(userInternal.auth, provider, FederatedAuthProvider);\n  // Wait for auth initialization to complete, this will process pending redirects and clear the\n  // PENDING_REDIRECT_KEY in persistence. This should be completed before starting a new\n  // redirect and creating a PENDING_REDIRECT_KEY entry.\n  await userInternal.auth._initializationPromise;\n  // Allow the resolver to error before persisting the redirect user\n  const resolverInternal = _withDefaultResolver(userInternal.auth, resolver);\n  await _assertLinkedStatus(false, userInternal, provider.providerId);\n  await _setPendingRedirectStatus(resolverInternal, userInternal.auth);\n\n  const eventId = await prepareUserForRedirect(userInternal);\n  return resolverInternal._openRedirect(\n    userInternal.auth,\n    provider,\n    AuthEventType.LINK_VIA_REDIRECT,\n    eventId\n  );\n}\n\n/**\n * Returns a {@link UserCredential} from the redirect-based sign-in flow.\n *\n * @remarks\n * If sign-in succeeded, returns the signed in user. If sign-in was unsuccessful, fails with an\n * error. If no redirect operation was called, returns `null`.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * // Sign in using a redirect.\n * const provider = new FacebookAuthProvider();\n * // You can add additional scopes to the provider:\n * provider.addScope('user_birthday');\n * // Start a sign in process for an unauthenticated user.\n * await signInWithRedirect(auth, provider);\n * // This will trigger a full page redirect away from your app\n *\n * // After returning from the redirect when your app initializes you can obtain the result\n * const result = await getRedirectResult(auth);\n * if (result) {\n *   // This is the signed-in user\n *   const user = result.user;\n *   // This gives you a Facebook Access Token.\n *   const credential = provider.credentialFromResult(auth, result);\n *   const token = credential.accessToken;\n * }\n * // As this API can be used for sign-in, linking and reauthentication,\n * // check the operationType to determine what triggered this redirect\n * // operation.\n * const operationType = result.operationType;\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param resolver - An instance of {@link PopupRedirectResolver}, optional\n * if already supplied to {@link initializeAuth} or provided by {@link getAuth}.\n *\n * @public\n */\nexport async function getRedirectResult(\n  auth: Auth,\n  resolver?: PopupRedirectResolver\n): Promise<UserCredential | null> {\n  await _castAuth(auth)._initializationPromise;\n  return _getRedirectResult(auth, resolver, false);\n}\n\nexport async function _getRedirectResult(\n  auth: Auth,\n  resolverExtern?: PopupRedirectResolver,\n  bypassAuthState = false\n): Promise<UserCredential | null> {\n  if (_isFirebaseServerApp(auth.app)) {\n    return Promise.reject(\n      _serverAppCurrentUserOperationNotSupportedError(auth)\n    );\n  }\n  const authInternal = _castAuth(auth);\n  const resolver = _withDefaultResolver(authInternal, resolverExtern);\n  const action = new RedirectAction(authInternal, resolver, bypassAuthState);\n  const result = await action.execute();\n\n  if (result && !bypassAuthState) {\n    delete result.user._redirectEventId;\n    await authInternal._persistUserIfCurrent(result.user as UserInternal);\n    await authInternal._setRedirectUser(null, resolverExtern);\n  }\n\n  return result;\n}\n\nasync function prepareUserForRedirect(user: UserInternal): Promise<string> {\n  const eventId = _generateEventId(`${user.uid}:::`);\n  user._redirectEventId = eventId;\n  await user.auth._setRedirectUser(user);\n  await user.auth._persistUserIfCurrent(user);\n  return eventId;\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  AuthEvent,\n  AuthEventConsumer,\n  AuthEventType,\n  EventManager\n} from '../../model/popup_redirect';\nimport { AuthErrorCode } from '../errors';\nimport { AuthInternal } from '../../model/auth';\nimport { _createError } from '../util/assert';\n\n// The amount of time to store the UIDs of seen events; this is\n// set to 10 min by default\nconst EVENT_DUPLICATION_CACHE_DURATION_MS = 10 * 60 * 1000;\n\nexport class AuthEventManager implements EventManager {\n  private readonly cachedEventUids: Set<string> = new Set();\n  private readonly consumers: Set<AuthEventConsumer> = new Set();\n  protected queuedRedirectEvent: AuthEvent | null = null;\n  protected hasHandledPotentialRedirect = false;\n  private lastProcessedEventTime = Date.now();\n\n  constructor(private readonly auth: AuthInternal) {}\n\n  registerConsumer(authEventConsumer: AuthEventConsumer): void {\n    this.consumers.add(authEventConsumer);\n\n    if (\n      this.queuedRedirectEvent &&\n      this.isEventForConsumer(this.queuedRedirectEvent, authEventConsumer)\n    ) {\n      this.sendToConsumer(this.queuedRedirectEvent, authEventConsumer);\n      this.saveEventToCache(this.queuedRedirectEvent);\n      this.queuedRedirectEvent = null;\n    }\n  }\n\n  unregisterConsumer(authEventConsumer: AuthEventConsumer): void {\n    this.consumers.delete(authEventConsumer);\n  }\n\n  onEvent(event: AuthEvent): boolean {\n    // Check if the event has already been handled\n    if (this.hasEventBeenHandled(event)) {\n      return false;\n    }\n\n    let handled = false;\n    this.consumers.forEach(consumer => {\n      if (this.isEventForConsumer(event, consumer)) {\n        handled = true;\n        this.sendToConsumer(event, consumer);\n        this.saveEventToCache(event);\n      }\n    });\n\n    if (this.hasHandledPotentialRedirect || !isRedirectEvent(event)) {\n      // If we've already seen a redirect before, or this is a popup event,\n      // bail now\n      return handled;\n    }\n\n    this.hasHandledPotentialRedirect = true;\n\n    // If the redirect wasn't handled, hang on to it\n    if (!handled) {\n      this.queuedRedirectEvent = event;\n      handled = true;\n    }\n\n    return handled;\n  }\n\n  private sendToConsumer(event: AuthEvent, consumer: AuthEventConsumer): void {\n    if (event.error && !isNullRedirectEvent(event)) {\n      const code =\n        (event.error.code?.split('auth/')[1] as AuthErrorCode) ||\n        AuthErrorCode.INTERNAL_ERROR;\n      consumer.onError(_createError(this.auth, code));\n    } else {\n      consumer.onAuthEvent(event);\n    }\n  }\n\n  private isEventForConsumer(\n    event: AuthEvent,\n    consumer: AuthEventConsumer\n  ): boolean {\n    const eventIdMatches =\n      consumer.eventId === null ||\n      (!!event.eventId && event.eventId === consumer.eventId);\n    return consumer.filter.includes(event.type) && eventIdMatches;\n  }\n\n  private hasEventBeenHandled(event: AuthEvent): boolean {\n    if (\n      Date.now() - this.lastProcessedEventTime >=\n      EVENT_DUPLICATION_CACHE_DURATION_MS\n    ) {\n      this.cachedEventUids.clear();\n    }\n\n    return this.cachedEventUids.has(eventUid(event));\n  }\n\n  private saveEventToCache(event: AuthEvent): void {\n    this.cachedEventUids.add(eventUid(event));\n    this.lastProcessedEventTime = Date.now();\n  }\n}\n\nfunction eventUid(e: AuthEvent): string {\n  return [e.type, e.eventId, e.sessionId, e.tenantId].filter(v => v).join('-');\n}\n\nfunction isNullRedirectEvent({ type, error }: AuthEvent): boolean {\n  return (\n    type === AuthEventType.UNKNOWN &&\n    error?.code === `auth/${AuthErrorCode.NO_AUTH_EVENT}`\n  );\n}\n\nfunction isRedirectEvent(event: AuthEvent): boolean {\n  switch (event.type) {\n    case AuthEventType.SIGN_IN_VIA_REDIRECT:\n    case AuthEventType.LINK_VIA_REDIRECT:\n    case AuthEventType.REAUTH_VIA_REDIRECT:\n      return true;\n    case AuthEventType.UNKNOWN:\n      return isNullRedirectEvent(event);\n    default:\n      return false;\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 { _getProjectConfig } from '../../api/project_config/get_project_config';\nimport { AuthInternal } from '../../model/auth';\nimport { AuthErrorCode } from '../errors';\nimport { _fail } from './assert';\nimport { _getCurrentUrl } from './location';\n\nconst IP_ADDRESS_REGEX = /^\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}$/;\nconst HTTP_REGEX = /^https?/;\n\nexport async function _validateOrigin(auth: AuthInternal): Promise<void> {\n  // Skip origin validation if we are in an emulated environment\n  if (auth.config.emulator) {\n    return;\n  }\n\n  const { authorizedDomains } = await _getProjectConfig(auth);\n\n  for (const domain of authorizedDomains) {\n    try {\n      if (matchDomain(domain)) {\n        return;\n      }\n    } catch {\n      // Do nothing if there's a URL error; just continue searching\n    }\n  }\n\n  // In the old SDK, this error also provides helpful messages.\n  _fail(auth, AuthErrorCode.INVALID_ORIGIN);\n}\n\nfunction matchDomain(expected: string): boolean {\n  const currentUrl = _getCurrentUrl();\n  const { protocol, hostname } = new URL(currentUrl);\n  if (expected.startsWith('chrome-extension://')) {\n    const ceUrl = new URL(expected);\n\n    if (ceUrl.hostname === '' && hostname === '') {\n      // For some reason we're not parsing chrome URLs properly\n      return (\n        protocol === 'chrome-extension:' &&\n        expected.replace('chrome-extension://', '') ===\n          currentUrl.replace('chrome-extension://', '')\n      );\n    }\n\n    return protocol === 'chrome-extension:' && ceUrl.hostname === hostname;\n  }\n\n  if (!HTTP_REGEX.test(protocol)) {\n    return false;\n  }\n\n  if (IP_ADDRESS_REGEX.test(expected)) {\n    // The domain has to be exactly equal to the pattern, as an IP domain will\n    // only contain the IP, no extra character.\n    return hostname === expected;\n  }\n\n  // Dots in pattern should be escaped.\n  const escapedDomainPattern = expected.replace(/\\./g, '\\\\.');\n  // Non ip address domains.\n  // domain.com = *.domain.com OR domain.com\n  const re = new RegExp(\n    '^(.+\\\\.' + escapedDomainPattern + '|' + escapedDomainPattern + ')$',\n    'i'\n  );\n  return re.test(hostname);\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 { _performApiRequest, Endpoint, HttpMethod } from '../index';\nimport { Auth } from '../../model/public_types';\n\nexport interface GetProjectConfigRequest {\n  androidPackageName?: string;\n  iosBundleId?: string;\n}\n\nexport interface GetProjectConfigResponse {\n  authorizedDomains: string[];\n}\n\nexport async function _getProjectConfig(\n  auth: Auth,\n  request: GetProjectConfigRequest = {}\n): Promise<GetProjectConfigResponse> {\n  return _performApiRequest<GetProjectConfigRequest, GetProjectConfigResponse>(\n    auth,\n    HttpMethod.GET,\n    Endpoint.GET_PROJECT_CONFIG,\n    request\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 { AuthErrorCode } from '../../core/errors';\nimport { _createError } from '../../core/util/assert';\nimport { Delay } from '../../core/util/delay';\nimport { AuthInternal } from '../../model/auth';\nimport { _window } from '../auth_window';\nimport * as js from '../load_js';\n\nconst NETWORK_TIMEOUT = new Delay(30000, 60000);\n\n/**\n * Reset unloaded GApi modules. If gapi.load fails due to a network error,\n * it will stop working after a retrial. This is a hack to fix this issue.\n */\nfunction resetUnloadedGapiModules(): void {\n  // Clear last failed gapi.load state to force next gapi.load to first\n  // load the failed gapi.iframes module.\n  // Get gapix.beacon context.\n  const beacon = _window().___jsl;\n  // Get current hint.\n  if (beacon?.H) {\n    // Get gapi hint.\n    for (const hint of Object.keys(beacon.H)) {\n      // Requested modules.\n      beacon.H[hint].r = beacon.H[hint].r || [];\n      // Loaded modules.\n      beacon.H[hint].L = beacon.H[hint].L || [];\n      // Set requested modules to a copy of the loaded modules.\n      beacon.H[hint].r = [...beacon.H[hint].L];\n      // Clear pending callbacks.\n      if (beacon.CP) {\n        for (let i = 0; i < beacon.CP.length; i++) {\n          // Remove all failed pending callbacks.\n          beacon.CP[i] = null;\n        }\n      }\n    }\n  }\n}\n\nfunction loadGapi(auth: AuthInternal): Promise<gapi.iframes.Context> {\n  return new Promise<gapi.iframes.Context>((resolve, reject) => {\n    // Function to run when gapi.load is ready.\n    function loadGapiIframe(): void {\n      // The developer may have tried to previously run gapi.load and failed.\n      // Run this to fix that.\n      resetUnloadedGapiModules();\n      gapi.load('gapi.iframes', {\n        callback: () => {\n          resolve(gapi.iframes.getContext());\n        },\n        ontimeout: () => {\n          // The above reset may be sufficient, but having this reset after\n          // failure ensures that if the developer calls gapi.load after the\n          // connection is re-established and before another attempt to embed\n          // the iframe, it would work and would not be broken because of our\n          // failed attempt.\n          // Timeout when gapi.iframes.Iframe not loaded.\n          resetUnloadedGapiModules();\n          reject(_createError(auth, AuthErrorCode.NETWORK_REQUEST_FAILED));\n        },\n        timeout: NETWORK_TIMEOUT.get()\n      });\n    }\n\n    if (_window().gapi?.iframes?.Iframe) {\n      // If gapi.iframes.Iframe available, resolve.\n      resolve(gapi.iframes.getContext());\n    } else if (!!_window().gapi?.load) {\n      // Gapi loader ready, load gapi.iframes.\n      loadGapiIframe();\n    } else {\n      // Create a new iframe callback when this is called so as not to overwrite\n      // any previous defined callback. This happens if this method is called\n      // multiple times in parallel and could result in the later callback\n      // overwriting the previous one. This would end up with a iframe\n      // timeout.\n      const cbName = js._generateCallbackName('iframefcb');\n      // GApi loader not available, dynamically load platform.js.\n      _window()[cbName] = () => {\n        // GApi loader should be ready.\n        if (!!gapi.load) {\n          loadGapiIframe();\n        } else {\n          // Gapi loader failed, throw error.\n          reject(_createError(auth, AuthErrorCode.NETWORK_REQUEST_FAILED));\n        }\n      };\n      // Load GApi loader.\n      return js\n        ._loadJS(`${js._gapiScriptUrl()}?onload=${cbName}`)\n        .catch(e => reject(e));\n    }\n  }).catch(error => {\n    // Reset cached promise to allow for retrial.\n    cachedGApiLoader = null;\n    throw error;\n  });\n}\n\nlet cachedGApiLoader: Promise<gapi.iframes.Context> | null = null;\nexport function _loadGapi(auth: AuthInternal): Promise<gapi.iframes.Context> {\n  cachedGApiLoader = cachedGApiLoader || loadGapi(auth);\n  return cachedGApiLoader;\n}\n\nexport function _resetLoader(): void {\n  cachedGApiLoader = 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\nimport { SDK_VERSION } from '@firebase/app';\nimport { querystring } from '@firebase/util';\nimport { DefaultConfig } from '../../../internal';\n\nimport { AuthErrorCode } from '../../core/errors';\nimport { _assert, _createError } from '../../core/util/assert';\nimport { Delay } from '../../core/util/delay';\nimport { _emulatorUrl } from '../../core/util/emulator';\nimport { AuthInternal } from '../../model/auth';\nimport { _window } from '../auth_window';\nimport * as gapiLoader from './gapi';\n\nconst PING_TIMEOUT = new Delay(5000, 15000);\nconst IFRAME_PATH = '__/auth/iframe';\nconst EMULATED_IFRAME_PATH = 'emulator/auth/iframe';\n\nconst IFRAME_ATTRIBUTES = {\n  style: {\n    position: 'absolute',\n    top: '-100px',\n    width: '1px',\n    height: '1px'\n  },\n  'aria-hidden': 'true',\n  tabindex: '-1'\n};\n\n// Map from apiHost to endpoint ID for passing into iframe. In current SDK, apiHost can be set to\n// anything (not from a list of endpoints with IDs as in legacy), so this is the closest we can get.\nconst EID_FROM_APIHOST = new Map([\n  [DefaultConfig.API_HOST, 'p'], // production\n  ['staging-identitytoolkit.sandbox.googleapis.com', 's'], // staging\n  ['test-identitytoolkit.sandbox.googleapis.com', 't'] // test\n]);\n\nfunction getIframeUrl(auth: AuthInternal): string {\n  const config = auth.config;\n  _assert(config.authDomain, auth, AuthErrorCode.MISSING_AUTH_DOMAIN);\n  const url = config.emulator\n    ? _emulatorUrl(config, EMULATED_IFRAME_PATH)\n    : `https://${auth.config.authDomain}/${IFRAME_PATH}`;\n\n  const params: Record<string, string> = {\n    apiKey: config.apiKey,\n    appName: auth.name,\n    v: SDK_VERSION\n  };\n  const eid = EID_FROM_APIHOST.get(auth.config.apiHost);\n  if (eid) {\n    params.eid = eid;\n  }\n  const frameworks = auth._getFrameworks();\n  if (frameworks.length) {\n    params.fw = frameworks.join(',');\n  }\n  return `${url}?${querystring(params).slice(1)}`;\n}\n\nexport async function _openIframe(\n  auth: AuthInternal\n): Promise<gapi.iframes.Iframe> {\n  const context = await gapiLoader._loadGapi(auth);\n  const gapi = _window().gapi;\n  _assert(gapi, auth, AuthErrorCode.INTERNAL_ERROR);\n  return context.open(\n    {\n      where: document.body,\n      url: getIframeUrl(auth),\n      messageHandlersFilter: gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER,\n      attributes: IFRAME_ATTRIBUTES,\n      dontclear: true\n    },\n    (iframe: gapi.iframes.Iframe) =>\n      new Promise(async (resolve, reject) => {\n        await iframe.restyle({\n          // Prevent iframe from closing on mouse out.\n          setHideOnLeave: false\n        });\n\n        const networkError = _createError(\n          auth,\n          AuthErrorCode.NETWORK_REQUEST_FAILED\n        );\n        // Confirm iframe is correctly loaded.\n        // To fallback on failure, set a timeout.\n        const networkErrorTimer = _window().setTimeout(() => {\n          reject(networkError);\n        }, PING_TIMEOUT.get());\n        // Clear timer and resolve pending iframe ready promise.\n        function clearTimerAndResolve(): void {\n          _window().clearTimeout(networkErrorTimer);\n          resolve(iframe);\n        }\n        // This returns an IThenable. However the reject part does not call\n        // when the iframe is not loaded.\n        iframe.ping(clearTimerAndResolve).then(clearTimerAndResolve, () => {\n          reject(networkError);\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\nimport { getUA } from '@firebase/util';\n\nimport { AuthErrorCode } from '../../core/errors';\nimport { _assert } from '../../core/util/assert';\nimport {\n  _isChromeIOS,\n  _isFirefox,\n  _isIOSStandalone\n} from '../../core/util/browser';\nimport { AuthInternal } from '../../model/auth';\n\nconst BASE_POPUP_OPTIONS = {\n  location: 'yes',\n  resizable: 'yes',\n  statusbar: 'yes',\n  toolbar: 'no'\n};\n\nconst DEFAULT_WIDTH = 500;\nconst DEFAULT_HEIGHT = 600;\nconst TARGET_BLANK = '_blank';\n\nconst FIREFOX_EMPTY_URL = 'http://localhost';\n\nexport class AuthPopup {\n  associatedEvent: string | null = null;\n\n  constructor(readonly window: Window | null) {}\n\n  close(): void {\n    if (this.window) {\n      try {\n        this.window.close();\n      } catch (e) {}\n    }\n  }\n}\n\nexport function _open(\n  auth: AuthInternal,\n  url?: string,\n  name?: string,\n  width = DEFAULT_WIDTH,\n  height = DEFAULT_HEIGHT\n): AuthPopup {\n  const top = Math.max((window.screen.availHeight - height) / 2, 0).toString();\n  const left = Math.max((window.screen.availWidth - width) / 2, 0).toString();\n  let target = '';\n\n  const options: { [key: string]: string } = {\n    ...BASE_POPUP_OPTIONS,\n    width: width.toString(),\n    height: height.toString(),\n    top,\n    left\n  };\n\n  // Chrome iOS 7 and 8 is returning an undefined popup win when target is\n  // specified, even though the popup is not necessarily blocked.\n  const ua = getUA().toLowerCase();\n\n  if (name) {\n    target = _isChromeIOS(ua) ? TARGET_BLANK : name;\n  }\n\n  if (_isFirefox(ua)) {\n    // Firefox complains when invalid URLs are popped out. Hacky way to bypass.\n    url = url || FIREFOX_EMPTY_URL;\n    // Firefox disables by default scrolling on popup windows, which can create\n    // issues when the user has many Google accounts, for instance.\n    options.scrollbars = 'yes';\n  }\n\n  const optionsString = Object.entries(options).reduce(\n    (accum, [key, value]) => `${accum}${key}=${value},`,\n    ''\n  );\n\n  if (_isIOSStandalone(ua) && target !== '_self') {\n    openAsNewWindowIOS(url || '', target);\n    return new AuthPopup(null);\n  }\n\n  // about:blank getting sanitized causing browsers like IE/Edge to display\n  // brief error message before redirecting to handler.\n  const newWin = window.open(url || '', target, optionsString);\n  _assert(newWin, auth, AuthErrorCode.POPUP_BLOCKED);\n\n  // Flaky on IE edge, encapsulate with a try and catch.\n  try {\n    newWin.focus();\n  } catch (e) {}\n\n  return new AuthPopup(newWin);\n}\n\nfunction openAsNewWindowIOS(url: string, target: string): void {\n  const el = document.createElement('a');\n  el.href = url;\n  el.target = target;\n  const click = document.createEvent('MouseEvent');\n  click.initMouseEvent(\n    'click',\n    true,\n    true,\n    window,\n    1,\n    0,\n    0,\n    0,\n    0,\n    false,\n    false,\n    false,\n    false,\n    1,\n    null\n  );\n  el.dispatchEvent(click);\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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 { SDK_VERSION } from '@firebase/app';\nimport { AuthProvider } from '../../model/public_types';\nimport { ApiKey, AppName, AuthInternal } from '../../model/auth';\nimport { AuthEventType } from '../../model/popup_redirect';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from './assert';\nimport { isEmpty, querystring } from '@firebase/util';\nimport { _emulatorUrl } from './emulator';\nimport { FederatedAuthProvider } from '../providers/federated';\nimport { BaseOAuthProvider } from '../providers/oauth';\n\n/**\n * URL for Authentication widget which will initiate the OAuth handshake\n *\n * @internal\n */\nconst WIDGET_PATH = '__/auth/handler';\n\n/**\n * URL for emulated environment\n *\n * @internal\n */\nconst EMULATOR_WIDGET_PATH = 'emulator/auth/handler';\n\n/**\n * Fragment name for the App Check token that gets passed to the widget\n *\n * @internal\n */\nconst FIREBASE_APP_CHECK_FRAGMENT_ID = encodeURIComponent('fac');\n\n// eslint-disable-next-line @typescript-eslint/consistent-type-definitions\ntype WidgetParams = {\n  apiKey: ApiKey;\n  appName: AppName;\n  authType: AuthEventType;\n  redirectUrl?: string;\n  v: string;\n  providerId?: string;\n  scopes?: string;\n  customParameters?: string;\n  eventId?: string;\n  tid?: string;\n} & { [key: string]: string | undefined };\n\nexport async function _getRedirectUrl(\n  auth: AuthInternal,\n  provider: AuthProvider,\n  authType: AuthEventType,\n  redirectUrl?: string,\n  eventId?: string,\n  additionalParams?: Record<string, string>\n): Promise<string> {\n  _assert(auth.config.authDomain, auth, AuthErrorCode.MISSING_AUTH_DOMAIN);\n  _assert(auth.config.apiKey, auth, AuthErrorCode.INVALID_API_KEY);\n\n  const params: WidgetParams = {\n    apiKey: auth.config.apiKey,\n    appName: auth.name,\n    authType,\n    redirectUrl,\n    v: SDK_VERSION,\n    eventId\n  };\n\n  if (provider instanceof FederatedAuthProvider) {\n    provider.setDefaultLanguage(auth.languageCode);\n    params.providerId = provider.providerId || '';\n    if (!isEmpty(provider.getCustomParameters())) {\n      params.customParameters = JSON.stringify(provider.getCustomParameters());\n    }\n\n    // TODO set additionalParams from the provider as well?\n    for (const [key, value] of Object.entries(additionalParams || {})) {\n      params[key] = value;\n    }\n  }\n\n  if (provider instanceof BaseOAuthProvider) {\n    const scopes = provider.getScopes().filter(scope => scope !== '');\n    if (scopes.length > 0) {\n      params.scopes = scopes.join(',');\n    }\n  }\n\n  if (auth.tenantId) {\n    params.tid = auth.tenantId;\n  }\n\n  // TODO: maybe set eid as endpointId\n  // TODO: maybe set fw as Frameworks.join(\",\")\n\n  const paramsDict = params as Record<string, string | number>;\n  for (const key of Object.keys(paramsDict)) {\n    if (paramsDict[key] === undefined) {\n      delete paramsDict[key];\n    }\n  }\n\n  // Sets the App Check token to pass to the widget\n  const appCheckToken = await auth._getAppCheckToken();\n  const appCheckTokenFragment = appCheckToken\n    ? `#${FIREBASE_APP_CHECK_FRAGMENT_ID}=${encodeURIComponent(appCheckToken)}`\n    : '';\n\n  // Start at index 1 to skip the leading '&' in the query string\n  return `${getHandlerBase(auth)}?${querystring(paramsDict).slice(\n    1\n  )}${appCheckTokenFragment}`;\n}\n\nfunction getHandlerBase({ config }: AuthInternal): string {\n  if (!config.emulator) {\n    return `https://${config.authDomain}/${WIDGET_PATH}`;\n  }\n\n  return _emulatorUrl(config, EMULATOR_WIDGET_PATH);\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 { AuthProvider, PopupRedirectResolver } from '../model/public_types';\n\nimport { AuthEventManager } from '../core/auth/auth_event_manager';\nimport { AuthErrorCode } from '../core/errors';\nimport { _assert, debugAssert, _fail } from '../core/util/assert';\nimport { _generateEventId } from '../core/util/event_id';\nimport { _getCurrentUrl } from '../core/util/location';\nimport { _validateOrigin } from '../core/util/validate_origin';\nimport { AuthInternal } from '../model/auth';\nimport {\n  AuthEventType,\n  EventManager,\n  GapiAuthEvent,\n  GapiOutcome,\n  PopupRedirectResolverInternal\n} from '../model/popup_redirect';\nimport { _setWindowLocation } from './auth_window';\nimport { _openIframe } from './iframe/iframe';\nimport { browserSessionPersistence } from './persistence/session_storage';\nimport { _open, AuthPopup } from './util/popup';\nimport { _getRedirectResult } from './strategies/redirect';\nimport { _getRedirectUrl } from '../core/util/handler';\nimport { _isIOS, _isMobileBrowser, _isSafari } from '../core/util/browser';\nimport { _overrideRedirectResult } from '../core/strategies/redirect';\n\n/**\n * The special web storage event\n *\n */\nconst WEB_STORAGE_SUPPORT_KEY = 'webStorageSupport';\n\ninterface WebStorageSupportMessage extends gapi.iframes.Message {\n  [index: number]: Record<string, boolean>;\n}\n\ninterface ManagerOrPromise {\n  manager?: EventManager;\n  promise?: Promise<EventManager>;\n}\n\nclass BrowserPopupRedirectResolver implements PopupRedirectResolverInternal {\n  private readonly eventManagers: Record<string, ManagerOrPromise> = {};\n  private readonly iframes: Record<string, gapi.iframes.Iframe> = {};\n  private readonly originValidationPromises: Record<string, Promise<void>> = {};\n\n  readonly _redirectPersistence = browserSessionPersistence;\n\n  // Wrapping in async even though we don't await anywhere in order\n  // to make sure errors are raised as promise rejections\n  async _openPopup(\n    auth: AuthInternal,\n    provider: AuthProvider,\n    authType: AuthEventType,\n    eventId?: string\n  ): Promise<AuthPopup> {\n    debugAssert(\n      this.eventManagers[auth._key()]?.manager,\n      '_initialize() not called before _openPopup()'\n    );\n\n    const url = await _getRedirectUrl(\n      auth,\n      provider,\n      authType,\n      _getCurrentUrl(),\n      eventId\n    );\n    return _open(auth, url, _generateEventId());\n  }\n\n  async _openRedirect(\n    auth: AuthInternal,\n    provider: AuthProvider,\n    authType: AuthEventType,\n    eventId?: string\n  ): Promise<never> {\n    await this._originValidation(auth);\n    const url = await _getRedirectUrl(\n      auth,\n      provider,\n      authType,\n      _getCurrentUrl(),\n      eventId\n    );\n    _setWindowLocation(url);\n    return new Promise(() => {});\n  }\n\n  _initialize(auth: AuthInternal): Promise<EventManager> {\n    const key = auth._key();\n    if (this.eventManagers[key]) {\n      const { manager, promise } = this.eventManagers[key];\n      if (manager) {\n        return Promise.resolve(manager);\n      } else {\n        debugAssert(promise, 'If manager is not set, promise should be');\n        return promise;\n      }\n    }\n\n    const promise = this.initAndGetManager(auth);\n    this.eventManagers[key] = { promise };\n\n    // If the promise is rejected, the key should be removed so that the\n    // operation can be retried later.\n    promise.catch(() => {\n      delete this.eventManagers[key];\n    });\n\n    return promise;\n  }\n\n  private async initAndGetManager(auth: AuthInternal): Promise<EventManager> {\n    const iframe = await _openIframe(auth);\n    const manager = new AuthEventManager(auth);\n    iframe.register<GapiAuthEvent>(\n      'authEvent',\n      (iframeEvent: GapiAuthEvent | null) => {\n        _assert(iframeEvent?.authEvent, auth, AuthErrorCode.INVALID_AUTH_EVENT);\n        // TODO: Consider splitting redirect and popup events earlier on\n\n        const handled = manager.onEvent(iframeEvent.authEvent);\n        return { status: handled ? GapiOutcome.ACK : GapiOutcome.ERROR };\n      },\n      gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER\n    );\n\n    this.eventManagers[auth._key()] = { manager };\n    this.iframes[auth._key()] = iframe;\n    return manager;\n  }\n\n  _isIframeWebStorageSupported(\n    auth: AuthInternal,\n    cb: (supported: boolean) => unknown\n  ): void {\n    const iframe = this.iframes[auth._key()];\n    iframe.send<gapi.iframes.Message, WebStorageSupportMessage>(\n      WEB_STORAGE_SUPPORT_KEY,\n      { type: WEB_STORAGE_SUPPORT_KEY },\n      result => {\n        const isSupported = result?.[0]?.[WEB_STORAGE_SUPPORT_KEY];\n        if (isSupported !== undefined) {\n          cb(!!isSupported);\n        }\n\n        _fail(auth, AuthErrorCode.INTERNAL_ERROR);\n      },\n      gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER\n    );\n  }\n\n  _originValidation(auth: AuthInternal): Promise<void> {\n    const key = auth._key();\n    if (!this.originValidationPromises[key]) {\n      this.originValidationPromises[key] = _validateOrigin(auth);\n    }\n\n    return this.originValidationPromises[key];\n  }\n\n  get _shouldInitProactively(): boolean {\n    // Mobile browsers and Safari need to optimistically initialize\n    return _isMobileBrowser() || _isSafari() || _isIOS();\n  }\n\n  _completeRedirectFn = _getRedirectResult;\n\n  _overrideRedirectResult = _overrideRedirectResult;\n}\n\n/**\n * An implementation of {@link PopupRedirectResolver} suitable for browser\n * based applications.\n *\n * @remarks\n * This method does not work in a Node.js environment.\n *\n * @public\n */\nexport const browserPopupRedirectResolver: PopupRedirectResolver =\n  BrowserPopupRedirectResolver;\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 { Unsubscribe } from '@firebase/util';\nimport { FirebaseAuthInternal } from '@firebase/auth-interop-types';\n\nimport { AuthInternal } from '../../model/auth';\nimport { UserInternal } from '../../model/user';\nimport { _assert } from '../util/assert';\nimport { AuthErrorCode } from '../errors';\n\ninterface TokenListener {\n  (tok: string | null): unknown;\n}\n\nexport class AuthInterop implements FirebaseAuthInternal {\n  private readonly internalListeners: Map<TokenListener, Unsubscribe> =\n    new Map();\n\n  constructor(private readonly auth: AuthInternal) {}\n\n  getUid(): string | null {\n    this.assertAuthConfigured();\n    return this.auth.currentUser?.uid || null;\n  }\n\n  async getToken(\n    forceRefresh?: boolean\n  ): Promise<{ accessToken: string } | null> {\n    this.assertAuthConfigured();\n    await this.auth._initializationPromise;\n    if (!this.auth.currentUser) {\n      return null;\n    }\n\n    const accessToken = await this.auth.currentUser.getIdToken(forceRefresh);\n    return { accessToken };\n  }\n\n  addAuthTokenListener(listener: TokenListener): void {\n    this.assertAuthConfigured();\n    if (this.internalListeners.has(listener)) {\n      return;\n    }\n\n    const unsubscribe = this.auth.onIdTokenChanged(user => {\n      listener(\n        (user as UserInternal | null)?.stsTokenManager.accessToken || null\n      );\n    });\n    this.internalListeners.set(listener, unsubscribe);\n    this.updateProactiveRefresh();\n  }\n\n  removeAuthTokenListener(listener: TokenListener): void {\n    this.assertAuthConfigured();\n    const unsubscribe = this.internalListeners.get(listener);\n    if (!unsubscribe) {\n      return;\n    }\n\n    this.internalListeners.delete(listener);\n    unsubscribe();\n    this.updateProactiveRefresh();\n  }\n\n  private assertAuthConfigured(): void {\n    _assert(\n      this.auth._initializationPromise,\n      AuthErrorCode.DEPENDENT_SDK_INIT_BEFORE_AUTH\n    );\n  }\n\n  private updateProactiveRefresh(): void {\n    if (this.internalListeners.size > 0) {\n      this.auth._startProactiveRefresh();\n    } else {\n      this.auth._stopProactiveRefresh();\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF 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, getApp, _getProvider } from '@firebase/app';\n\nimport {\n  initializeAuth,\n  beforeAuthStateChanged,\n  onIdTokenChanged,\n  connectAuthEmulator\n} from '..';\nimport { registerAuth } from '../core/auth/register';\nimport { ClientPlatform } from '../core/util/version';\nimport { browserLocalPersistence } from './persistence/local_storage';\nimport { browserSessionPersistence } from './persistence/session_storage';\nimport { indexedDBLocalPersistence } from './persistence/indexed_db';\nimport { browserPopupRedirectResolver } from './popup_redirect';\nimport { Auth, User } from '../model/public_types';\nimport { getDefaultEmulatorHost, getExperimentalSetting } from '@firebase/util';\nimport { _setExternalJSProvider } from './load_js';\nimport { _createError } from '../core/util/assert';\nimport { AuthErrorCode } from '../core/errors';\n\nconst DEFAULT_ID_TOKEN_MAX_AGE = 5 * 60;\nconst authIdTokenMaxAge =\n  getExperimentalSetting('authIdTokenMaxAge') || DEFAULT_ID_TOKEN_MAX_AGE;\n\nlet lastPostedIdToken: string | undefined | null = null;\n\nconst mintCookieFactory = (url: string) => async (user: User | null) => {\n  const idTokenResult = user && (await user.getIdTokenResult());\n  const idTokenAge =\n    idTokenResult &&\n    (new Date().getTime() - Date.parse(idTokenResult.issuedAtTime)) / 1_000;\n  if (idTokenAge && idTokenAge > authIdTokenMaxAge) {\n    return;\n  }\n  // Specifically trip null => undefined when logged out, to delete any existing cookie\n  const idToken = idTokenResult?.token;\n  if (lastPostedIdToken === idToken) {\n    return;\n  }\n  lastPostedIdToken = idToken;\n  await fetch(url, {\n    method: idToken ? 'POST' : 'DELETE',\n    headers: idToken\n      ? {\n          'Authorization': `Bearer ${idToken}`\n        }\n      : {}\n  });\n};\n\n/**\n * Returns the Auth instance associated with the provided {@link @firebase/app#FirebaseApp}.\n * If no instance exists, initializes an Auth instance with platform-specific default dependencies.\n *\n * @param app - The Firebase App.\n *\n * @public\n */\nexport function getAuth(app: FirebaseApp = getApp()): Auth {\n  const provider = _getProvider(app, 'auth');\n\n  if (provider.isInitialized()) {\n    return provider.getImmediate();\n  }\n\n  const auth = initializeAuth(app, {\n    popupRedirectResolver: browserPopupRedirectResolver,\n    persistence: [\n      indexedDBLocalPersistence,\n      browserLocalPersistence,\n      browserSessionPersistence\n    ]\n  });\n\n  const authTokenSyncPath = getExperimentalSetting('authTokenSyncURL');\n  // Only do the Cookie exchange in a secure context\n  if (\n    authTokenSyncPath &&\n    typeof isSecureContext === 'boolean' &&\n    isSecureContext\n  ) {\n    // Don't allow urls (XSS possibility), only paths on the same domain\n    const authTokenSyncUrl = new URL(authTokenSyncPath, location.origin);\n    if (location.origin === authTokenSyncUrl.origin) {\n      const mintCookie = mintCookieFactory(authTokenSyncUrl.toString());\n      beforeAuthStateChanged(auth, mintCookie, () =>\n        mintCookie(auth.currentUser)\n      );\n      onIdTokenChanged(auth, user => mintCookie(user));\n    }\n  }\n\n  const authEmulatorHost = getDefaultEmulatorHost('auth');\n  if (authEmulatorHost) {\n    connectAuthEmulator(auth, `http://${authEmulatorHost}`);\n  }\n\n  return auth;\n}\n\nfunction getScriptParentElement(): HTMLDocument | HTMLHeadElement {\n  return document.getElementsByTagName('head')?.[0] ?? document;\n}\n\n_setExternalJSProvider({\n  loadJS(url: string): Promise<Event> {\n    // TODO: consider adding timeout support & cancellation\n    return new Promise((resolve, reject) => {\n      const el = document.createElement('script');\n      el.setAttribute('src', url);\n      el.onload = resolve;\n      el.onerror = e => {\n        const error = _createError(AuthErrorCode.INTERNAL_ERROR);\n        error.customData = e as unknown as Record<string, unknown>;\n        reject(error);\n      };\n      el.type = 'text/javascript';\n      el.charset = 'UTF-8';\n      getScriptParentElement().appendChild(el);\n    });\n  },\n\n  gapiScript: 'https://apis.google.com/js/api.js',\n  recaptchaV2Script: 'https://www.google.com/recaptcha/api.js',\n  recaptchaEnterpriseScript:\n    'https://www.google.com/recaptcha/enterprise.js?render='\n});\n\nregisterAuth(ClientPlatform.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\nimport { _getProvider, FirebaseApp } from '@firebase/app';\nimport { deepEqual } from '@firebase/util';\nimport { Auth, Dependencies } from '../../model/public_types';\n\nimport { AuthErrorCode } from '../errors';\nimport { PersistenceInternal } from '../persistence';\nimport { _fail } from '../util/assert';\nimport { _getInstance } from '../util/instantiator';\nimport { AuthImpl } from './auth_impl';\n\n/**\n * Initializes an {@link Auth} instance with fine-grained control over\n * {@link Dependencies}.\n *\n * @remarks\n *\n * This function allows more control over the {@link Auth} instance than\n * {@link getAuth}. `getAuth` uses platform-specific defaults to supply\n * the {@link Dependencies}. In general, `getAuth` is the easiest way to\n * initialize Auth and works for most use cases. Use `initializeAuth` if you\n * need control over which persistence layer is used, or to minimize bundle\n * size if you're not using either `signInWithPopup` or `signInWithRedirect`.\n *\n * For example, if your app only uses anonymous accounts and you only want\n * accounts saved for the current session, initialize `Auth` with:\n *\n * ```js\n * const auth = initializeAuth(app, {\n *   persistence: browserSessionPersistence,\n *   popupRedirectResolver: undefined,\n * });\n * ```\n *\n * @public\n */\nexport function initializeAuth(app: FirebaseApp, deps?: Dependencies): Auth {\n  const provider = _getProvider(app, 'auth');\n\n  if (provider.isInitialized()) {\n    const auth = provider.getImmediate() as AuthImpl;\n    const initialOptions = provider.getOptions() as Dependencies;\n    if (deepEqual(initialOptions, deps ?? {})) {\n      return auth;\n    } else {\n      _fail(auth, AuthErrorCode.ALREADY_INITIALIZED);\n    }\n  }\n\n  const auth = provider.initialize({ options: deps }) as AuthImpl;\n\n  return auth;\n}\n\nexport function _initializeAuthInstance(\n  auth: AuthImpl,\n  deps?: Dependencies\n): void {\n  const persistence = deps?.persistence || [];\n  const hierarchy = (\n    Array.isArray(persistence) ? persistence : [persistence]\n  ).map<PersistenceInternal>(_getInstance);\n  if (deps?.errorMap) {\n    auth._updateErrorMap(deps.errorMap);\n  }\n\n  // This promise is intended to float; auth initialization happens in the\n  // background, meanwhile the auth object may be used by the app.\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  auth._initializeWithPersistence(hierarchy, deps?.popupRedirectResolver);\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 { getModularInstance } from '@firebase/util';\nimport {\n  Auth,\n  NextOrObserver,\n  Persistence,\n  User,\n  CompleteFn,\n  ErrorFn,\n  Unsubscribe,\n  PasswordValidationStatus\n} from '../model/public_types';\nimport { _initializeRecaptchaConfig } from '../platform_browser/recaptcha/recaptcha_enterprise_verifier';\nimport { _castAuth } from '../core/auth/auth_impl';\n\nexport {\n  debugErrorMap,\n  prodErrorMap,\n  AUTH_ERROR_CODES_MAP_DO_NOT_USE_INTERNALLY as AuthErrorCodes\n} from './errors';\n\n// Non-optional auth methods.\n/**\n * Changes the type of persistence on the {@link Auth} instance for the currently saved\n * `Auth` session and applies this type of persistence for future sign-in requests, including\n * sign-in with redirect requests.\n *\n * @remarks\n * This makes it easy for a user signing in to specify whether their session should be\n * remembered or not. It also makes it easier to never persist the `Auth` state for applications\n * that are shared by other users or have sensitive data.\n *\n * This method does not work in a Node.js environment or with {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @example\n * ```javascript\n * setPersistence(auth, browserSessionPersistence);\n * ```\n *\n * @param auth - The {@link Auth} instance.\n * @param persistence - The {@link Persistence} to use.\n * @returns A `Promise` that resolves once the persistence change has completed\n *\n * @public\n */\nexport function setPersistence(\n  auth: Auth,\n  persistence: Persistence\n): Promise<void> {\n  return getModularInstance(auth).setPersistence(persistence);\n}\n\n/**\n * Loads the reCAPTCHA configuration into the `Auth` instance.\n *\n * @remarks\n * This will load the reCAPTCHA config, which indicates whether the reCAPTCHA\n * verification flow should be triggered for each auth provider, into the\n * current Auth session.\n *\n * If initializeRecaptchaConfig() is not invoked, the auth flow will always start\n * without reCAPTCHA verification. If the provider is configured to require reCAPTCHA\n * verification, the SDK will transparently load the reCAPTCHA config and restart the\n * auth flows.\n *\n * Thus, by calling this optional method, you will reduce the latency of future auth flows.\n * Loading the reCAPTCHA config early will also enhance the signal collected by reCAPTCHA.\n *\n * This method does not work in a Node.js environment.\n *\n * @example\n * ```javascript\n * initializeRecaptchaConfig(auth);\n * ```\n *\n * @param auth - The {@link Auth} instance.\n *\n * @public\n */\nexport function initializeRecaptchaConfig(auth: Auth): Promise<void> {\n  return _initializeRecaptchaConfig(auth);\n}\n\n/**\n * Validates the password against the password policy configured for the project or tenant.\n *\n * @remarks\n * If no tenant ID is set on the `Auth` instance, then this method will use the password\n * policy configured for the project. Otherwise, this method will use the policy configured\n * for the tenant. If a password policy has not been configured, then the default policy\n * configured for all projects will be used.\n *\n * If an auth flow fails because a submitted password does not meet the password policy\n * requirements and this method has previously been called, then this method will use the\n * most recent policy available when called again.\n *\n * @example\n * ```javascript\n * validatePassword(auth, 'some-password');\n * ```\n *\n * @param auth The {@link Auth} instance.\n * @param password The password to validate.\n *\n * @public\n */\nexport async function validatePassword(\n  auth: Auth,\n  password: string\n): Promise<PasswordValidationStatus> {\n  const authInternal = _castAuth(auth);\n  return authInternal.validatePassword(password);\n}\n\n/**\n * Adds an observer for changes to the signed-in user's ID token.\n *\n * @remarks\n * This includes sign-in, sign-out, and token refresh events.\n * This will not be triggered automatically upon ID token expiration. Use {@link User.getIdToken} to refresh the ID token.\n *\n * @param auth - The {@link Auth} instance.\n * @param nextOrObserver - callback triggered on change.\n * @param error - Deprecated. This callback is never triggered. Errors\n * on signing in/out can be caught in promises returned from\n * sign-in/sign-out functions.\n * @param completed - Deprecated. This callback is never triggered.\n *\n * @public\n */\nexport function onIdTokenChanged(\n  auth: Auth,\n  nextOrObserver: NextOrObserver<User>,\n  error?: ErrorFn,\n  completed?: CompleteFn\n): Unsubscribe {\n  return getModularInstance(auth).onIdTokenChanged(\n    nextOrObserver,\n    error,\n    completed\n  );\n}\n/**\n * Adds a blocking callback that runs before an auth state change\n * sets a new user.\n *\n * @param auth - The {@link Auth} instance.\n * @param callback - callback triggered before new user value is set.\n *   If this throws, it blocks the user from being set.\n * @param onAbort - callback triggered if a later `beforeAuthStateChanged()`\n *   callback throws, allowing you to undo any side effects.\n */\nexport function beforeAuthStateChanged(\n  auth: Auth,\n  callback: (user: User | null) => void | Promise<void>,\n  onAbort?: () => void\n): Unsubscribe {\n  return getModularInstance(auth).beforeAuthStateChanged(callback, onAbort);\n}\n/**\n * Adds an observer for changes to the user's sign-in state.\n *\n * @remarks\n * To keep the old behavior, see {@link onIdTokenChanged}.\n *\n * @param auth - The {@link Auth} instance.\n * @param nextOrObserver - callback triggered on change.\n * @param error - Deprecated. This callback is never triggered. Errors\n * on signing in/out can be caught in promises returned from\n * sign-in/sign-out functions.\n * @param completed - Deprecated. This callback is never triggered.\n *\n * @public\n */\nexport function onAuthStateChanged(\n  auth: Auth,\n  nextOrObserver: NextOrObserver<User>,\n  error?: ErrorFn,\n  completed?: CompleteFn\n): Unsubscribe {\n  return getModularInstance(auth).onAuthStateChanged(\n    nextOrObserver,\n    error,\n    completed\n  );\n}\n/**\n * Sets the current language to the default device/browser preference.\n *\n * @param auth - The {@link Auth} instance.\n *\n * @public\n */\nexport function useDeviceLanguage(auth: Auth): void {\n  getModularInstance(auth).useDeviceLanguage();\n}\n/**\n * Asynchronously sets the provided user as {@link Auth.currentUser} on the\n * {@link Auth} instance.\n *\n * @remarks\n * A new instance copy of the user provided will be made and set as currentUser.\n *\n * This will trigger {@link onAuthStateChanged} and {@link onIdTokenChanged} listeners\n * like other sign in methods.\n *\n * The operation fails with an error if the user to be updated belongs to a different Firebase\n * project.\n *\n * This method is not supported by {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @param auth - The {@link Auth} instance.\n * @param user - The new {@link User}.\n *\n * @public\n */\nexport function updateCurrentUser(\n  auth: Auth,\n  user: User | null\n): Promise<void> {\n  return getModularInstance(auth).updateCurrentUser(user);\n}\n/**\n * Signs out the current user.\n *\n * @remarks\n * This method is not supported by {@link Auth} instances created with a\n * {@link @firebase/app#FirebaseServerApp}.\n *\n * @param auth - The {@link Auth} instance.\n *\n * @public\n */\nexport function signOut(auth: Auth): Promise<void> {\n  return getModularInstance(auth).signOut();\n}\n\n/**\n * Revokes the given access token. Currently only supports Apple OAuth access tokens.\n *\n * @param auth - The {@link Auth} instance.\n * @param token - The Apple OAuth access token.\n *\n * @public\n */\nexport function revokeAccessToken(auth: Auth, token: string): Promise<void> {\n  const authInternal = _castAuth(auth);\n  return authInternal.revokeAccessToken(token);\n}\n\nexport { initializeAuth } from './auth/initialize';\nexport { connectAuthEmulator } from './auth/emulator';\n\n// credentials\nexport { AuthCredential } from './credentials';\nexport { EmailAuthCredential } from './credentials/email';\nexport { OAuthCredential } from './credentials/oauth';\nexport { PhoneAuthCredential } from './credentials/phone';\n\n// persistence\nexport { inMemoryPersistence } from './persistence/in_memory';\n\n// providers\nexport { EmailAuthProvider } from './providers/email';\nexport { FacebookAuthProvider } from './providers/facebook';\nexport { CustomParameters } from './providers/federated';\nexport { GoogleAuthProvider } from './providers/google';\nexport { GithubAuthProvider } from './providers/github';\nexport { OAuthProvider, OAuthCredentialOptions } from './providers/oauth';\nexport { SAMLAuthProvider } from './providers/saml';\nexport { TwitterAuthProvider } from './providers/twitter';\n\n// strategies\nexport { signInAnonymously } from './strategies/anonymous';\nexport {\n  signInWithCredential,\n  linkWithCredential,\n  reauthenticateWithCredential\n} from './strategies/credential';\nexport { signInWithCustomToken } from './strategies/custom_token';\nexport {\n  sendPasswordResetEmail,\n  confirmPasswordReset,\n  applyActionCode,\n  checkActionCode,\n  verifyPasswordResetCode,\n  createUserWithEmailAndPassword,\n  signInWithEmailAndPassword\n} from './strategies/email_and_password';\nexport {\n  sendSignInLinkToEmail,\n  isSignInWithEmailLink,\n  signInWithEmailLink\n} from './strategies/email_link';\nexport {\n  fetchSignInMethodsForEmail,\n  sendEmailVerification,\n  verifyBeforeUpdateEmail\n} from './strategies/email';\n\n// core\nexport { ActionCodeURL, parseActionCodeURL } from './action_code_url';\n\n// user\nexport {\n  updateProfile,\n  updateEmail,\n  updatePassword\n} from './user/account_info';\nexport { getIdToken, getIdTokenResult } from './user/id_token_result';\nexport { unlink } from './user/link_unlink';\nexport { getAdditionalUserInfo } from './user/additional_user_info';\n\n// Non-optional user methods.\nexport { reload } from './user/reload';\n/**\n * Deletes and signs out the user.\n *\n * @remarks\n * Important: this is a security-sensitive operation that requires the user to have recently\n * signed in. If this requirement isn't met, ask the user to authenticate again and then call\n * {@link reauthenticateWithCredential}.\n *\n * @param user - The user.\n *\n * @public\n */\nexport async function deleteUser(user: User): Promise<void> {\n  return getModularInstance(user).delete();\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 { _registerComponent, registerVersion } from '@firebase/app';\nimport {\n  Component,\n  ComponentType,\n  InstantiationMode\n} from '@firebase/component';\n\nimport { name, version } from '../../../package.json';\nimport { AuthErrorCode } from '../errors';\nimport { _assert } from '../util/assert';\nimport { _getClientVersion, ClientPlatform } from '../util/version';\nimport { _castAuth, AuthImpl, DefaultConfig } from './auth_impl';\nimport { AuthInterop } from './firebase_internal';\nimport { ConfigInternal } from '../../model/auth';\nimport { Dependencies } from '../../model/public_types';\nimport { _initializeAuthInstance } from './initialize';\n\nexport const enum _ComponentName {\n  AUTH = 'auth',\n  AUTH_INTERNAL = 'auth-internal'\n}\n\nfunction getVersionForPlatform(\n  clientPlatform: ClientPlatform\n): string | undefined {\n  switch (clientPlatform) {\n    case ClientPlatform.NODE:\n      return 'node';\n    case ClientPlatform.REACT_NATIVE:\n      return 'rn';\n    case ClientPlatform.WORKER:\n      return 'webworker';\n    case ClientPlatform.CORDOVA:\n      return 'cordova';\n    case ClientPlatform.WEB_EXTENSION:\n      return 'web-extension';\n    default:\n      return undefined;\n  }\n}\n\n/** @internal */\nexport function registerAuth(clientPlatform: ClientPlatform): void {\n  _registerComponent(\n    new Component(\n      _ComponentName.AUTH,\n      (container, { options: deps }: { options?: Dependencies }) => {\n        const app = container.getProvider('app').getImmediate()!;\n        const heartbeatServiceProvider =\n          container.getProvider<'heartbeat'>('heartbeat');\n        const appCheckServiceProvider =\n          container.getProvider<'app-check-internal'>('app-check-internal');\n        const { apiKey, authDomain } = app.options;\n\n        _assert(\n          apiKey && !apiKey.includes(':'),\n          AuthErrorCode.INVALID_API_KEY,\n          { appName: app.name }\n        );\n\n        const config: ConfigInternal = {\n          apiKey,\n          authDomain,\n          clientPlatform,\n          apiHost: DefaultConfig.API_HOST,\n          tokenApiHost: DefaultConfig.TOKEN_API_HOST,\n          apiScheme: DefaultConfig.API_SCHEME,\n          sdkClientVersion: _getClientVersion(clientPlatform)\n        };\n\n        const authInstance = new AuthImpl(\n          app,\n          heartbeatServiceProvider,\n          appCheckServiceProvider,\n          config\n        );\n        _initializeAuthInstance(authInstance, deps);\n\n        return authInstance;\n      },\n      ComponentType.PUBLIC\n    )\n      /**\n       * Auth can only be initialized by explicitly calling getAuth() or initializeAuth()\n       * For why we do this, See go/firebase-next-auth-init\n       */\n      .setInstantiationMode(InstantiationMode.EXPLICIT)\n      /**\n       * Because all firebase products that depend on auth depend on auth-internal directly,\n       * we need to initialize auth-internal after auth is initialized to make it available to other firebase products.\n       */\n      .setInstanceCreatedCallback(\n        (container, _instanceIdentifier, _instance) => {\n          const authInternalProvider = container.getProvider(\n            _ComponentName.AUTH_INTERNAL\n          );\n          authInternalProvider.initialize();\n        }\n      )\n  );\n\n  _registerComponent(\n    new Component(\n      _ComponentName.AUTH_INTERNAL,\n      container => {\n        const auth = _castAuth(\n          container.getProvider(_ComponentName.AUTH).getImmediate()!\n        );\n        return (auth => new AuthInterop(auth))(auth);\n      },\n      ComponentType.PRIVATE\n    ).setInstantiationMode(InstantiationMode.EXPLICIT)\n  );\n\n  registerVersion(name, version, getVersionForPlatform(clientPlatform));\n  // BUILD_TARGET will be replaced by values like esm2017, cjs2017, etc during the compilation\n  registerVersion(name, version, '__BUILD_TARGET__');\n}\n","import React, { useState } from \"react\";\nimport {\n  getAuth,\n  signInWithPopup,\n  GoogleAuthProvider,\n  signOut,\n} from \"firebase/auth\";\n\nconst AuthButton = () => {\n  const [user, setUser] = useState(null);\n  const auth = getAuth();\n\n  const handleSignIn = async () => {\n    const provider = new GoogleAuthProvider();\n    try {\n      const result = await signInWithPopup(auth, provider);\n      const user = result.user;\n      setUser(user);\n      console.log(\"Signed in as:\", user.displayName);\n    } catch (error) {\n      console.error(\"Sign-in failed:\", error.message);\n    }\n  };\n\n  const handleSignOut = async () => {\n    try {\n      await signOut(auth);\n      setUser(null);\n      console.log(\"Signed out successfully\");\n    } catch (error) {\n      console.error(\"Sign-out failed:\", error.message);\n    }\n  };\n\n  return (\n    <div>\n      {user ? (\n        <div>\n          <p>Bienvenido, {user.displayName}</p>\n          <button onClick={handleSignOut}>Salir</button>\n        </div>\n      ) : (\n        <button onClick={handleSignIn}>Acceder con Google</button>\n      )}\n    </div>\n  );\n};\n\nexport default AuthButton;\n","import React from \"react\";\nimport AuthButton from \"./AuthButton\";\n\nconst Header = () => (\n  <header className=\"site-header\">\n    <div\n      className=\"container\"\n      style={{\n        display: \"flex\",\n        justifyContent: \"space-between\",\n        flexDirection: \"row\",\n      }}\n    >\n      <div className=\"logo\">\n        <img src=\"/assets/logo.png\" alt=\"Villanos eSports Logo\" />\n      </div>\n      <div className=\"auth-section\">\n        <AuthButton />\n      </div>\n    </div>\n  </header>\n);\n\nexport default Header;\n","import React from \"react\";\n\nconst HeroSection = () => (\n  <section id=\"inicio\" className=\"hero\">\n    <div className=\"container\">\n      <h2>Impulsando los esports en México</h2>\n      <p>\n        Somos Villanos eSports, una organización que ama los videojuegos y las\n        competencias. Nos ubicamos en Pachuca de Soto, Hidalgo y tenemos\n        influencia en todo Latinoamérica.\n      </p>\n    </div>\n  </section>\n);\n\nexport default HeroSection;\n","import React from \"react\";\nconst AboutSection = () => (\n  <section id=\"about\" className=\"about\">\n    <div className=\"container\">\n      <h2>Villanos eSports</h2>\n      <p>\n        Villanos eSports fue fundada en 2022 con el objetivo de brindar\n        estabilidad a los equipos de nuestra región y representar los esports de\n        manera significativa en Latinoamérica. Nuestro objetivo es hacer de los\n        esports una carrera profesional para nuestros jugadores.\n      </p>\n      {/*\n    <h3>Valores</h3>\n    <ul>\n      <li>Juego limpio</li>\n      <li>Espíritu competitivo</li>\n      <li>Fomentar la confianza en nuestros jugadores</li>\n    </ul>\n    */}\n    </div>\n  </section>\n);\nexport default AboutSection;\n","import React, { useState, useEffect } from \"react\";\nimport db from \"../firebaseConfig\";\nimport { collection, getDocs } from \"firebase/firestore\";\n\nconst TeamsSection = () => {\n  const [teams, setTeams] = useState([]);\n\n  useEffect(() => {\n    const fetchTeams = async () => {\n      const querySnapshot = await getDocs(collection(db, \"teams\"));\n      const data = querySnapshot.docs.map((doc) => ({\n        id: doc.id,\n        ...doc.data(),\n      }));\n      setTeams(data);\n    };\n\n    fetchTeams();\n  }, []);\n\n  return (\n    <section id=\"teams\" className=\"teams\">\n      <div className=\"container\">\n        <h2>Equipos</h2>\n        {teams.length === 0 ? (\n          <p className=\"no-data-message\">\n            No hay equipos para mostrar en este momento.\n          </p>\n        ) : (\n          <div className=\"team-cards\">\n            {teams.map((team) => (\n              <div key={team.id} className=\"team-card\">\n                <img\n                  src={team.logo || \"/assets/logo.png\"}\n                  alt={`${team.name} Logo`}\n                  className=\"team-logo\"\n                />\n                <h3>{team.name}</h3>\n                <p>{team.description}</p>\n              </div>\n            ))}\n          </div>\n        )}\n      </div>\n    </section>\n  );\n};\n\nexport default TeamsSection;\n","import React, { useState } from \"react\";\n\nconst ContactSection = () => {\n  return (\n    <section id=\"contact\" className=\"contact\">\n      <div className=\"container\">\n        <h2>Contacto</h2>\n        <p>\n          Si tienes alguna pregunta o quieres colaborar con nosotros, no dudes\n          en contactarnos:\n        </p>\n        {/* Button to open mail to contact@villanosesports.com */}\n        <a\n          href=\"mailto:contacto@villanosesports.com\"\n          className=\"btn btn-primary\"\n        >\n          Enviar Correo\n        </a>\n      </div>\n    </section>\n  );\n};\n\nexport default ContactSection;\n","import React from \"react\";\n\nconst PromoteAppSection = () => (\n  <section id=\"turo\" className=\"promote-app\">\n    <div className=\"container\">\n      <img\n        src={\"/assets/turo.jpg\"}\n        alt=\"Turo App Banner\"\n        className=\"app-banner\"\n      />\n      <h2>Turo</h2>\n      <p>\n        Descubre una experiencia única con nuestra app Turo, diseñada para\n        ayudarte a dominar el juego. ¡Disponible ahora en tu tienda favorita!\n      </p>\n      <div className=\"store-buttons\">\n        <a\n          href=\"https://apps.apple.com/mx/app/turo/id6475321740?l=en-GB\"\n          target=\"_blank\"\n          rel=\"noreferrer\"\n        >\n          <img src={\"/assets/apple.svg\"} alt=\"Download on the App Store\" />\n        </a>\n        <a\n          href=\"https://play.google.com/store/apps/details?id=com.villanosesports.turo\"\n          target=\"_blank\"\n          rel=\"noreferrer\"\n        >\n          <img src={\"/assets/google.svg\"} alt=\"Get it on Google Play\" />\n        </a>\n      </div>\n    </div>\n  </section>\n);\n\nexport default PromoteAppSection;\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","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 = Object.create(null);\n  return function (arg) {\n    if (cache[arg] === undefined) cache[arg] = fn(arg);\n    return cache[arg];\n  };\n}\n\nexport { memoize as default };\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar isPropValid = /* #__PURE__ */memoize(function (prop) {\n  return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n  /* o */\n  && prop.charCodeAt(1) === 110\n  /* n */\n  && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport { isPropValid as default };\n","// @flow\nimport type { Interpolation } from '../types';\n\nexport default (\n  strings: Array<string>,\n  interpolations: Array<Interpolation>\n): Array<Interpolation> => {\n  const result = [strings[0]];\n\n  for (let i = 0, len = interpolations.length; i < len; i += 1) {\n    result.push(interpolations[i], strings[i + 1]);\n  }\n\n  return result;\n};\n","// @flow\nimport { typeOf } from 'react-is';\n\nexport default (x: any): boolean =>\n  x !== null &&\n  typeof x === 'object' &&\n  (x.toString ? x.toString() : Object.prototype.toString.call(x)) === '[object Object]' &&\n  !typeOf(x);\n","// @flow\nexport const EMPTY_ARRAY = Object.freeze([]);\nexport const EMPTY_OBJECT = Object.freeze({});\n","// @flow\nexport default function isFunction(test: any): boolean %checks {\n  return typeof test === 'function';\n}\n","// @flow\nimport type { IStyledComponent } from '../types';\n\nexport default function getComponentName(\n  target: $PropertyType<IStyledComponent, 'target'>\n): string {\n  return (\n    (process.env.NODE_ENV !== 'production' ? typeof target === 'string' && target : false) ||\n    // $FlowFixMe\n    target.displayName ||\n    // $FlowFixMe\n    target.name ||\n    'Component'\n  );\n}\n","// @flow\nexport default function isStyledComponent(target: any): boolean %checks {\n  return target && typeof target.styledComponentId === 'string';\n}\n","// @flow\n\ndeclare var SC_DISABLE_SPEEDY: ?boolean;\ndeclare var __VERSION__: string;\n\nexport const SC_ATTR: string =\n  (typeof process !== 'undefined' &&\n    typeof process.env !== 'undefined' &&\n    (process.env.REACT_APP_SC_ATTR || process.env.SC_ATTR)) ||\n  'data-styled';\n\nexport const SC_ATTR_ACTIVE = 'active';\nexport const SC_ATTR_VERSION = 'data-styled-version';\nexport const SC_VERSION = __VERSION__;\nexport const SPLITTER = '/*!sc*/\\n';\n\nexport const IS_BROWSER = typeof window !== 'undefined' && 'HTMLElement' in window;\n\nexport const DISABLE_SPEEDY = Boolean(\n  typeof SC_DISABLE_SPEEDY === 'boolean'\n    ? SC_DISABLE_SPEEDY\n    : typeof process !== 'undefined' && typeof process.env !== 'undefined'\n    ? typeof process.env.REACT_APP_SC_DISABLE_SPEEDY !== 'undefined' &&\n      process.env.REACT_APP_SC_DISABLE_SPEEDY !== ''\n      ? process.env.REACT_APP_SC_DISABLE_SPEEDY === 'false'\n        ? false\n        : process.env.REACT_APP_SC_DISABLE_SPEEDY\n      : typeof process.env.SC_DISABLE_SPEEDY !== 'undefined' && process.env.SC_DISABLE_SPEEDY !== ''\n      ? process.env.SC_DISABLE_SPEEDY === 'false'\n        ? false\n        : process.env.SC_DISABLE_SPEEDY\n      : process.env.NODE_ENV !== 'production'\n    : false\n);\n\n// Shared empty execution context when generating static styles\nexport const STATIC_EXECUTION_CONTEXT = {};\n","// @flow\nimport errorMap from './errors';\n\nconst ERRORS = process.env.NODE_ENV !== 'production' ? errorMap : {};\n\n/**\n * super basic version of sprintf\n */\nfunction format(...args) {\n  let a = args[0];\n  const b = [];\n\n  for (let c = 1, len = args.length; c < len; c += 1) {\n    b.push(args[c]);\n  }\n\n  b.forEach(d => {\n    a = a.replace(/%[a-z]/, d);\n  });\n\n  return a;\n}\n\n/**\n * Create an error file out of errors.md for development and a simple web link to the full errors\n * in production mode.\n */\nexport default function throwStyledComponentsError(\n  code: string | number,\n  ...interpolations: Array<any>\n) {\n  if (process.env.NODE_ENV === 'production') {\n    throw new Error(\n      `An error occurred. See https://git.io/JUIaE#${code} for more information.${\n        interpolations.length > 0 ? ` Args: ${interpolations.join(', ')}` : ''\n      }`\n    );\n  } else {\n    throw new Error(format(ERRORS[code], ...interpolations).trim());\n  }\n}\n","// @flow\n/* eslint-disable no-use-before-define */\n\nimport type { GroupedTag, Tag } from './types';\nimport { SPLITTER } from '../constants';\nimport throwStyledError from '../utils/error';\n\n/** Create a GroupedTag with an underlying Tag implementation */\nexport const makeGroupedTag = (tag: Tag): GroupedTag => {\n  return new DefaultGroupedTag(tag);\n};\n\nconst BASE_SIZE = 1 << 9;\n\nclass DefaultGroupedTag implements GroupedTag {\n  groupSizes: Uint32Array;\n\n  length: number;\n\n  tag: Tag;\n\n  constructor(tag: Tag) {\n    this.groupSizes = new Uint32Array(BASE_SIZE);\n    this.length = BASE_SIZE;\n    this.tag = tag;\n  }\n\n  indexOfGroup(group: number): number {\n    let index = 0;\n    for (let i = 0; i < group; i++) {\n      index += this.groupSizes[i];\n    }\n\n    return index;\n  }\n\n  insertRules(group: number, rules: string[]): void {\n    if (group >= this.groupSizes.length) {\n      const oldBuffer = this.groupSizes;\n      const oldSize = oldBuffer.length;\n\n      let newSize = oldSize;\n      while (group >= newSize) {\n        newSize <<= 1;\n        if (newSize < 0) {\n          throwStyledError(16, `${group}`);\n        }\n      }\n\n      this.groupSizes = new Uint32Array(newSize);\n      this.groupSizes.set(oldBuffer);\n      this.length = newSize;\n\n      for (let i = oldSize; i < newSize; i++) {\n        this.groupSizes[i] = 0;\n      }\n    }\n\n    let ruleIndex = this.indexOfGroup(group + 1);\n    for (let i = 0, l = rules.length; i < l; i++) {\n      if (this.tag.insertRule(ruleIndex, rules[i])) {\n        this.groupSizes[group]++;\n        ruleIndex++;\n      }\n    }\n  }\n\n  clearGroup(group: number): void {\n    if (group < this.length) {\n      const length = this.groupSizes[group];\n      const startIndex = this.indexOfGroup(group);\n      const endIndex = startIndex + length;\n\n      this.groupSizes[group] = 0;\n\n      for (let i = startIndex; i < endIndex; i++) {\n        this.tag.deleteRule(startIndex);\n      }\n    }\n  }\n\n  getGroup(group: number): string {\n    let css = '';\n    if (group >= this.length || this.groupSizes[group] === 0) {\n      return css;\n    }\n\n    const length = this.groupSizes[group];\n    const startIndex = this.indexOfGroup(group);\n    const endIndex = startIndex + length;\n\n    for (let i = startIndex; i < endIndex; i++) {\n      css += `${this.tag.getRule(i)}${SPLITTER}`;\n    }\n\n    return css;\n  }\n}\n","// @flow\n\nimport throwStyledError from '../utils/error';\n\nconst MAX_SMI = 1 << 31 - 1;\n\nlet groupIDRegister: Map<string, number> = new Map();\nlet reverseRegister: Map<number, string> = new Map();\nlet nextFreeGroup = 1;\n\nexport const resetGroupIds = () => {\n  groupIDRegister = new Map();\n  reverseRegister = new Map();\n  nextFreeGroup = 1;\n};\n\nexport const getGroupForId = (id: string): number => {\n  if (groupIDRegister.has(id)) {\n    return (groupIDRegister.get(id): any);\n  }\n\n  while (reverseRegister.has(nextFreeGroup)) {\n    nextFreeGroup++;\n  }\n\n  const group = nextFreeGroup++;\n\n  if (\n    process.env.NODE_ENV !== 'production' &&\n    ((group | 0) < 0 || group > MAX_SMI)\n  ) {\n    throwStyledError(16, `${group}`);\n  }\n\n  groupIDRegister.set(id, group);\n  reverseRegister.set(group, id);\n  return group;\n};\n\nexport const getIdForGroup = (group: number): void | string => {\n  return reverseRegister.get(group);\n};\n\nexport const setGroupForId = (id: string, group: number) => {\n  if (group >= nextFreeGroup) {\n    nextFreeGroup = group + 1;\n  }\n\n  groupIDRegister.set(id, group);\n  reverseRegister.set(group, id);\n};\n","// @flow\n\nimport { SPLITTER, SC_ATTR, SC_ATTR_ACTIVE, SC_ATTR_VERSION, SC_VERSION } from '../constants';\nimport { getIdForGroup, setGroupForId } from './GroupIDAllocator';\nimport type { Sheet } from './types';\n\nconst SELECTOR = `style[${SC_ATTR}][${SC_ATTR_VERSION}=\"${SC_VERSION}\"]`;\nconst MARKER_RE = new RegExp(`^${SC_ATTR}\\\\.g(\\\\d+)\\\\[id=\"([\\\\w\\\\d-]+)\"\\\\].*?\"([^\"]*)`);\n\nexport const outputSheet = (sheet: Sheet) => {\n  const tag = sheet.getTag();\n  const { length } = tag;\n\n  let css = '';\n  for (let group = 0; group < length; group++) {\n    const id = getIdForGroup(group);\n    if (id === undefined) continue;\n\n    const names = sheet.names.get(id);\n    const rules = tag.getGroup(group);\n    if (!names || !rules || !names.size) continue;\n\n    const selector = `${SC_ATTR}.g${group}[id=\"${id}\"]`;\n\n    let content = '';\n    if (names !== undefined) {\n      names.forEach(name => {\n        if (name.length > 0) {\n          content += `${name},`;\n        }\n      });\n    }\n\n    // NOTE: It's easier to collect rules and have the marker\n    // after the actual rules to simplify the rehydration\n    css += `${rules}${selector}{content:\"${content}\"}${SPLITTER}`;\n  }\n\n  return css;\n};\n\nconst rehydrateNamesFromContent = (sheet: Sheet, id: string, content: string) => {\n  const names = content.split(',');\n  let name;\n\n  for (let i = 0, l = names.length; i < l; i++) {\n    // eslint-disable-next-line\n    if ((name = names[i])) {\n      sheet.registerName(id, name);\n    }\n  }\n};\n\nconst rehydrateSheetFromTag = (sheet: Sheet, style: HTMLStyleElement) => {\n  const parts = (style.textContent || '').split(SPLITTER);\n  const rules: string[] = [];\n\n  for (let i = 0, l = parts.length; i < l; i++) {\n    const part = parts[i].trim();\n    if (!part) continue;\n\n    const marker = part.match(MARKER_RE);\n\n    if (marker) {\n      const group = parseInt(marker[1], 10) | 0;\n      const id = marker[2];\n\n      if (group !== 0) {\n        // Rehydrate componentId to group index mapping\n        setGroupForId(id, group);\n        // Rehydrate names and rules\n        // looks like: data-styled.g11[id=\"idA\"]{content:\"nameA,\"}\n        rehydrateNamesFromContent(sheet, id, marker[3]);\n        sheet.getTag().insertRules(group, rules);\n      }\n\n      rules.length = 0;\n    } else {\n      rules.push(part);\n    }\n  }\n};\n\nexport const rehydrateSheet = (sheet: Sheet) => {\n  const nodes = document.querySelectorAll(SELECTOR);\n\n  for (let i = 0, l = nodes.length; i < l; i++) {\n    const node = ((nodes[i]: any): HTMLStyleElement);\n    if (node && node.getAttribute(SC_ATTR) !== SC_ATTR_ACTIVE) {\n      rehydrateSheetFromTag(sheet, node);\n\n      if (node.parentNode) {\n        node.parentNode.removeChild(node);\n      }\n    }\n  }\n};\n","// @flow\n/* eslint-disable camelcase, no-undef */\n\ndeclare var __webpack_nonce__: string;\n\nconst getNonce = () => {\n  return typeof __webpack_nonce__ !== 'undefined' ? __webpack_nonce__ : null;\n};\n\nexport default getNonce;\n","// @flow\n\nimport { SC_ATTR, SC_ATTR_ACTIVE, SC_ATTR_VERSION, SC_VERSION } from '../constants';\nimport getNonce from '../utils/nonce';\nimport throwStyledError from '../utils/error';\n\nconst ELEMENT_TYPE = 1; /* Node.ELEMENT_TYPE */\n\n/** Find last style element if any inside target */\nconst findLastStyleTag = (target: HTMLElement): void | HTMLStyleElement => {\n  const { childNodes } = target;\n\n  for (let i = childNodes.length; i >= 0; i--) {\n    const child = ((childNodes[i]: any): ?HTMLElement);\n    if (child && child.nodeType === ELEMENT_TYPE && child.hasAttribute(SC_ATTR)) {\n      return ((child: any): HTMLStyleElement);\n    }\n  }\n\n  return undefined;\n};\n\n/** Create a style element inside `target` or <head> after the last */\nexport const makeStyleTag = (target?: HTMLElement): HTMLStyleElement => {\n  const head = ((document.head: any): HTMLElement);\n  const parent = target || head;\n  const style = document.createElement('style');\n  const prevStyle = findLastStyleTag(parent);\n  const nextSibling = prevStyle !== undefined ? prevStyle.nextSibling : null;\n\n  style.setAttribute(SC_ATTR, SC_ATTR_ACTIVE);\n  style.setAttribute(SC_ATTR_VERSION, SC_VERSION);\n\n  const nonce = getNonce();\n\n  if (nonce) style.setAttribute('nonce', nonce);\n\n  parent.insertBefore(style, nextSibling);\n\n  return style;\n};\n\n/** Get the CSSStyleSheet instance for a given style element */\nexport const getSheet = (tag: HTMLStyleElement): CSSStyleSheet => {\n  if (tag.sheet) {\n    return ((tag.sheet: any): CSSStyleSheet);\n  }\n\n  // Avoid Firefox quirk where the style element might not have a sheet property\n  const { styleSheets } = document;\n  for (let i = 0, l = styleSheets.length; i < l; i++) {\n    const sheet = styleSheets[i];\n    if (sheet.ownerNode === tag) {\n      return ((sheet: any): CSSStyleSheet);\n    }\n  }\n\n  throwStyledError(17);\n  return (undefined: any);\n};\n","// @flow\n/* eslint-disable no-use-before-define */\n\nimport { makeStyleTag, getSheet } from './dom';\nimport type { SheetOptions, Tag } from './types';\n\n/** Create a CSSStyleSheet-like tag depending on the environment */\nexport const makeTag = ({ isServer, useCSSOMInjection, target }: SheetOptions): Tag => {\n  if (isServer) {\n    return new VirtualTag(target);\n  } else if (useCSSOMInjection) {\n    return new CSSOMTag(target);\n  } else {\n    return new TextTag(target);\n  }\n};\n\nexport class CSSOMTag implements Tag {\n  element: HTMLStyleElement;\n\n  sheet: CSSStyleSheet;\n\n  length: number;\n\n  constructor(target?: HTMLElement) {\n    const element = (this.element = makeStyleTag(target));\n\n    // Avoid Edge bug where empty style elements don't create sheets\n    element.appendChild(document.createTextNode(''));\n\n    this.sheet = getSheet(element);\n    this.length = 0;\n  }\n\n  insertRule(index: number, rule: string): boolean {\n    try {\n      this.sheet.insertRule(rule, index);\n      this.length++;\n      return true;\n    } catch (_error) {\n      return false;\n    }\n  }\n\n  deleteRule(index: number): void {\n    this.sheet.deleteRule(index);\n    this.length--;\n  }\n\n  getRule(index: number): string {\n    const rule = this.sheet.cssRules[index];\n    // Avoid IE11 quirk where cssText is inaccessible on some invalid rules\n    if (rule !== undefined && typeof rule.cssText === 'string') {\n      return rule.cssText;\n    } else {\n      return '';\n    }\n  }\n}\n\n/** A Tag that emulates the CSSStyleSheet API but uses text nodes */\nexport class TextTag implements Tag {\n  element: HTMLStyleElement;\n\n  nodes: NodeList<Node>;\n\n  length: number;\n\n  constructor(target?: HTMLElement) {\n    const element = (this.element = makeStyleTag(target));\n    this.nodes = element.childNodes;\n    this.length = 0;\n  }\n\n  insertRule(index: number, rule: string): boolean {\n    if (index <= this.length && index >= 0) {\n      const node = document.createTextNode(rule);\n      const refNode = this.nodes[index];\n      this.element.insertBefore(node, refNode || null);\n      this.length++;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  deleteRule(index: number): void {\n    this.element.removeChild(this.nodes[index]);\n    this.length--;\n  }\n\n  getRule(index: number): string {\n    if (index < this.length) {\n      return this.nodes[index].textContent;\n    } else {\n      return '';\n    }\n  }\n}\n\n/** A completely virtual (server-side) Tag that doesn't manipulate the DOM */\nexport class VirtualTag implements Tag {\n  rules: string[];\n\n  length: number;\n\n  constructor(_target?: HTMLElement) {\n    this.rules = [];\n    this.length = 0;\n  }\n\n  insertRule(index: number, rule: string): boolean {\n    if (index <= this.length) {\n      this.rules.splice(index, 0, rule);\n      this.length++;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  deleteRule(index: number): void {\n    this.rules.splice(index, 1);\n    this.length--;\n  }\n\n  getRule(index: number): string {\n    if (index < this.length) {\n      return this.rules[index];\n    } else {\n      return '';\n    }\n  }\n}\n","// @flow\nimport { DISABLE_SPEEDY, IS_BROWSER } from '../constants';\nimport { EMPTY_OBJECT } from '../utils/empties';\nimport { makeGroupedTag } from './GroupedTag';\nimport { getGroupForId } from './GroupIDAllocator';\nimport { outputSheet, rehydrateSheet } from './Rehydration';\nimport { makeTag } from './Tag';\nimport type { GroupedTag, Sheet, SheetOptions } from './types';\n\nlet SHOULD_REHYDRATE = IS_BROWSER;\n\ntype SheetConstructorArgs = {\n  isServer?: boolean,\n  useCSSOMInjection?: boolean,\n  target?: HTMLElement,\n};\n\ntype GlobalStylesAllocationMap = { [key: string]: number };\ntype NamesAllocationMap = Map<string, Set<string>>;\n\nconst defaultOptions: SheetOptions = {\n  isServer: !IS_BROWSER,\n  useCSSOMInjection: !DISABLE_SPEEDY,\n};\n\n/** Contains the main stylesheet logic for stringification and caching */\nexport default class StyleSheet implements Sheet {\n  gs: GlobalStylesAllocationMap;\n\n  names: NamesAllocationMap;\n\n  options: SheetOptions;\n\n  server: boolean;\n\n  tag: void | GroupedTag;\n\n  /** Register a group ID to give it an index */\n  static registerId(id: string): number {\n    return getGroupForId(id);\n  }\n\n  constructor(\n    options: SheetConstructorArgs = EMPTY_OBJECT,\n    globalStyles?: GlobalStylesAllocationMap = {},\n    names?: NamesAllocationMap\n  ) {\n    this.options = {\n      ...defaultOptions,\n      ...options,\n    };\n\n    this.gs = globalStyles;\n    this.names = new Map(names);\n    this.server = !!options.isServer;\n\n    // We rehydrate only once and use the sheet that is created first\n    if (!this.server && IS_BROWSER && SHOULD_REHYDRATE) {\n      SHOULD_REHYDRATE = false;\n      rehydrateSheet(this);\n    }\n  }\n\n  reconstructWithOptions(options: SheetConstructorArgs, withNames?: boolean = true) {\n    return new StyleSheet(\n      { ...this.options, ...options },\n      this.gs,\n      (withNames && this.names) || undefined\n    );\n  }\n\n  allocateGSInstance(id: string) {\n    return (this.gs[id] = (this.gs[id] || 0) + 1);\n  }\n\n  /** Lazily initialises a GroupedTag for when it's actually needed */\n  getTag(): GroupedTag {\n    return this.tag || (this.tag = makeGroupedTag(makeTag(this.options)));\n  }\n\n  /** Check whether a name is known for caching */\n  hasNameForId(id: string, name: string): boolean {\n    return this.names.has(id) && (this.names.get(id): any).has(name);\n  }\n\n  /** Mark a group's name as known for caching */\n  registerName(id: string, name: string) {\n    getGroupForId(id);\n\n    if (!this.names.has(id)) {\n      const groupNames = new Set();\n      groupNames.add(name);\n      this.names.set(id, groupNames);\n    } else {\n      (this.names.get(id): any).add(name);\n    }\n  }\n\n  /** Insert new rules which also marks the name as known */\n  insertRules(id: string, name: string, rules: string[]) {\n    this.registerName(id, name);\n    this.getTag().insertRules(getGroupForId(id), rules);\n  }\n\n  /** Clears all cached names for a given group ID */\n  clearNames(id: string) {\n    if (this.names.has(id)) {\n      (this.names.get(id): any).clear();\n    }\n  }\n\n  /** Clears all rules for a given group ID */\n  clearRules(id: string) {\n    this.getTag().clearGroup(getGroupForId(id));\n    this.clearNames(id);\n  }\n\n  /** Clears the entire tag which deletes all rules but not its names */\n  clearTag() {\n    // NOTE: This does not clear the names, since it's only used during SSR\n    // so that we can continuously output only new rules\n    this.tag = undefined;\n  }\n\n  /** Outputs the current sheet as a CSS string with markers for SSR */\n  toString(): string {\n    return outputSheet(this);\n  }\n}\n","// @flow\n/* eslint-disable no-bitwise */\n\nconst AD_REPLACER_R = /(a)(d)/gi;\n\n/* This is the \"capacity\" of our alphabet i.e. 2x26 for all letters plus their capitalised\n * counterparts */\nconst charsLength = 52;\n\n/* start at 75 for 'a' until 'z' (25) and then start at 65 for capitalised letters */\nconst getAlphabeticChar = (code: number): string =>\n  String.fromCharCode(code + (code > 25 ? 39 : 97));\n\n/* input a number, usually a hash and convert it to base-52 */\nexport default function generateAlphabeticName(code: number): string {\n  let name = '';\n  let x;\n\n  /* get a char and divide by alphabet-length */\n  for (x = Math.abs(code); x > charsLength; x = (x / charsLength) | 0) {\n    name = getAlphabeticChar(x % charsLength) + name;\n  }\n\n  return (getAlphabeticChar(x % charsLength) + name).replace(AD_REPLACER_R, '$1-$2');\n}\n","// @flow\n/* eslint-disable */\n\nexport const SEED = 5381;\n\n// When we have separate strings it's useful to run a progressive\n// version of djb2 where we pretend that we're still looping over\n// the same string\nexport const phash = (h: number, x: string): number => {\n  let i = x.length;\n\n  while (i) {\n    h = (h * 33) ^ x.charCodeAt(--i);\n  }\n\n  return h;\n};\n\n// This is a djb2 hashing function\nexport const hash = (x: string): number => {\n  return phash(SEED, x);\n};\n","// @flow\nimport isFunction from './isFunction';\nimport isStyledComponent from './isStyledComponent';\nimport type { RuleSet } from '../types';\n\nexport default function isStaticRules(rules: RuleSet): boolean {\n  for (let i = 0; i < rules.length; i += 1) {\n    const rule = rules[i];\n\n    if (isFunction(rule) && !isStyledComponent(rule)) {\n      // functions are allowed to be static if they're just being\n      // used to get the classname of a nested styled component\n      return false;\n    }\n  }\n\n  return true;\n}\n","// @flow\nimport { SC_VERSION } from '../constants';\nimport StyleSheet from '../sheet';\nimport type { RuleSet, Stringifier } from '../types';\nimport flatten from '../utils/flatten';\nimport generateName from '../utils/generateAlphabeticName';\nimport { hash, phash } from '../utils/hash';\nimport isStaticRules from '../utils/isStaticRules';\n\nconst SEED = hash(SC_VERSION);\n\n/**\n * ComponentStyle is all the CSS-specific stuff, not the React-specific stuff.\n */\nexport default class ComponentStyle {\n  baseHash: number;\n\n  baseStyle: ?ComponentStyle;\n\n  componentId: string;\n\n  isStatic: boolean;\n\n  rules: RuleSet;\n\n  staticRulesId: string;\n\n  constructor(rules: RuleSet, componentId: string, baseStyle?: ComponentStyle) {\n    this.rules = rules;\n    this.staticRulesId = '';\n    this.isStatic = process.env.NODE_ENV === 'production' &&\n      (baseStyle === undefined || baseStyle.isStatic) &&\n      isStaticRules(rules);\n    this.componentId = componentId;\n\n    // SC_VERSION gives us isolation between multiple runtimes on the page at once\n    // this is improved further with use of the babel plugin \"namespace\" feature\n    this.baseHash = phash(SEED, componentId);\n\n    this.baseStyle = baseStyle;\n\n    // NOTE: This registers the componentId, which ensures a consistent order\n    // for this component's styles compared to others\n    StyleSheet.registerId(componentId);\n  }\n\n  /*\n   * Flattens a rule set into valid CSS\n   * Hashes it, wraps the whole chunk in a .hash1234 {}\n   * Returns the hash to be injected on render()\n   * */\n  generateAndInjectStyles(executionContext: Object, styleSheet: StyleSheet, stylis: Stringifier) {\n    const { componentId } = this;\n\n    const names = [];\n\n    if (this.baseStyle) {\n      names.push(this.baseStyle.generateAndInjectStyles(executionContext, styleSheet, stylis));\n    }\n\n    // force dynamic classnames if user-supplied stylis plugins are in use\n    if (this.isStatic && !stylis.hash) {\n      if (this.staticRulesId && styleSheet.hasNameForId(componentId, this.staticRulesId)) {\n        names.push(this.staticRulesId);\n      } else {\n        const cssStatic = flatten(this.rules, executionContext, styleSheet, stylis).join('');\n        const name = generateName(phash(this.baseHash, cssStatic) >>> 0);\n\n        if (!styleSheet.hasNameForId(componentId, name)) {\n          const cssStaticFormatted = stylis(cssStatic, `.${name}`, undefined, componentId);\n\n          styleSheet.insertRules(componentId, name, cssStaticFormatted);\n        }\n\n        names.push(name);\n        this.staticRulesId = name;\n      }\n    } else {\n      const { length } = this.rules;\n      let dynamicHash = phash(this.baseHash, stylis.hash);\n      let css = '';\n\n      for (let i = 0; i < length; i++) {\n        const partRule = this.rules[i];\n\n        if (typeof partRule === 'string') {\n          css += partRule;\n\n          if (process.env.NODE_ENV !== 'production') dynamicHash = phash(dynamicHash, partRule + i);\n        } else if (partRule) {\n          const partChunk = flatten(partRule, executionContext, styleSheet, stylis);\n          const partString = Array.isArray(partChunk) ? partChunk.join('') : partChunk;\n          dynamicHash = phash(dynamicHash, partString + i);\n          css += partString;\n        }\n      }\n\n      if (css) {\n        const name = generateName(dynamicHash >>> 0);\n\n        if (!styleSheet.hasNameForId(componentId, name)) {\n          const cssFormatted = stylis(css, `.${name}`, undefined, componentId);\n          styleSheet.insertRules(componentId, name, cssFormatted);\n        }\n\n        names.push(name);\n      }\n    }\n\n    return names.join(' ');\n  }\n}\n","import Stylis from '@emotion/stylis';\nimport { type Stringifier } from '../types';\nimport { EMPTY_ARRAY, EMPTY_OBJECT } from './empties';\nimport throwStyledError from './error';\nimport { phash, SEED } from './hash';\nimport insertRulePlugin from './stylisPluginInsertRule';\n\nconst COMMENT_REGEX = /^\\s*\\/\\/.*$/gm;\nconst COMPLEX_SELECTOR_PREFIX = [':', '[', '.', '#'];\n\ntype StylisInstanceConstructorArgs = {\n  options?: Object,\n  plugins?: Array<Function>,\n};\n\nexport default function createStylisInstance({\n  options = EMPTY_OBJECT,\n  plugins = EMPTY_ARRAY,\n}: StylisInstanceConstructorArgs = EMPTY_OBJECT) {\n  const stylis = new Stylis(options);\n\n  // Wrap `insertRulePlugin to build a list of rules,\n  // and then make our own plugin to return the rules. This\n  // makes it easier to hook into the existing SSR architecture\n\n  let parsingRules = [];\n\n  // eslint-disable-next-line consistent-return\n  const returnRulesPlugin = context => {\n    if (context === -2) {\n      const parsedRules = parsingRules;\n      parsingRules = [];\n      return parsedRules;\n    }\n  };\n\n  const parseRulesPlugin = insertRulePlugin(rule => {\n    parsingRules.push(rule);\n  });\n\n  let _componentId: string;\n  let _selector: string;\n  let _selectorRegexp: RegExp;\n  let _consecutiveSelfRefRegExp: RegExp;\n\n  const selfReferenceReplacer = (match, offset, string) => {\n    if (\n      // do not replace the first occurrence if it is complex (has a modifier)\n      (offset === 0 ? COMPLEX_SELECTOR_PREFIX.indexOf(string[_selector.length]) === -1 : true) &&\n      // no consecutive self refs (.b.b); that is a precedence boost and treated differently\n      !string.match(_consecutiveSelfRefRegExp)\n    ) {\n      return `.${_componentId}`;\n    }\n\n    return match;\n  };\n\n  /**\n   * When writing a style like\n   *\n   * & + & {\n   *   color: red;\n   * }\n   *\n   * The second ampersand should be a reference to the static component class. stylis\n   * has no knowledge of static class so we have to intelligently replace the base selector.\n   *\n   * https://github.com/thysultan/stylis.js/tree/v3.5.4#plugins <- more info about the context phase values\n   * \"2\" means this plugin is taking effect at the very end after all other processing is complete\n   */\n  const selfReferenceReplacementPlugin = (context, _, selectors) => {\n    if (context === 2 && selectors.length && selectors[0].lastIndexOf(_selector) > 0) {\n      // eslint-disable-next-line no-param-reassign\n      selectors[0] = selectors[0].replace(_selectorRegexp, selfReferenceReplacer);\n    }\n  };\n\n  stylis.use([...plugins, selfReferenceReplacementPlugin, parseRulesPlugin, returnRulesPlugin]);\n\n  function stringifyRules(css, selector, prefix, componentId = '&'): Stringifier {\n    const flatCSS = css.replace(COMMENT_REGEX, '');\n    const cssStr = selector && prefix ? `${prefix} ${selector} { ${flatCSS} }` : flatCSS;\n\n    // stylis has no concept of state to be passed to plugins\n    // but since JS is single-threaded, we can rely on that to ensure\n    // these properties stay in sync with the current stylis run\n    _componentId = componentId;\n    _selector = selector;\n    _selectorRegexp = new RegExp(`\\\\${_selector}\\\\b`, 'g');\n    _consecutiveSelfRefRegExp = new RegExp(`(\\\\${_selector}\\\\b){2,}`);\n\n    return stylis(prefix || !selector ? '' : selector, cssStr);\n  }\n\n  stringifyRules.hash = plugins.length\n    ? plugins\n        .reduce((acc, plugin) => {\n          if (!plugin.name) {\n            throwStyledError(15);\n          }\n\n          return phash(acc, plugin.name);\n        }, SEED)\n        .toString()\n    : '';\n\n  return stringifyRules;\n}\n","/**\n * MIT License\n *\n * Copyright (c) 2016 Sultan Tarimo\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy of\n * this software and associated documentation files (the \"Software\"),\n * to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n * sell copies of the Software and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * 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 MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\n * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR\n * IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n/* eslint-disable */\n\nexport default function(insertRule) {\n  const delimiter = '/*|*/';\n  const needle = `${delimiter}}`;\n\n  function toSheet(block) {\n    if (block) {\n      try {\n        insertRule(`${block}}`);\n      } catch (e) {}\n    }\n  }\n\n  return function ruleSheet(\n    context,\n    content,\n    selectors,\n    parents,\n    line,\n    column,\n    length,\n    ns,\n    depth,\n    at\n  ) {\n    switch (context) {\n      // property\n      case 1:\n        // @import\n        if (depth === 0 && content.charCodeAt(0) === 64) return insertRule(`${content};`), '';\n        break;\n      // selector\n      case 2:\n        if (ns === 0) return content + delimiter;\n        break;\n      // at-rule\n      case 3:\n        switch (ns) {\n          // @font-face, @page\n          case 102:\n          case 112:\n            return insertRule(selectors[0] + content), '';\n          default:\n            return content + (at === 0 ? delimiter : '');\n        }\n      case -2:\n        content.split(needle).forEach(toSheet);\n    }\n  };\n}\n","// @flow\nimport React, { type Context, type Node, useContext, useEffect, useMemo, useState } from 'react';\nimport shallowequal from 'shallowequal';\nimport StyleSheet from '../sheet';\nimport type { Stringifier } from '../types';\nimport createStylisInstance from '../utils/stylis';\n\ntype Props = {\n  children?: Node,\n  disableCSSOMInjection?: boolean,\n  disableVendorPrefixes?: boolean,\n  sheet?: StyleSheet,\n  stylisPlugins?: Array<Function>,\n  target?: HTMLElement,\n};\n\nexport const StyleSheetContext: Context<StyleSheet | void> = React.createContext();\nexport const StyleSheetConsumer = StyleSheetContext.Consumer;\nexport const StylisContext: Context<Stringifier | void> = React.createContext();\nexport const StylisConsumer = StylisContext.Consumer;\n\nexport const masterSheet: StyleSheet = new StyleSheet();\nexport const masterStylis: Stringifier = createStylisInstance();\n\nexport function useStyleSheet(): StyleSheet {\n  return useContext(StyleSheetContext) || masterSheet;\n}\n\nexport function useStylis(): Stringifier {\n  return useContext(StylisContext) || masterStylis;\n}\n\nexport default function StyleSheetManager(props: Props) {\n  const [plugins, setPlugins] = useState(props.stylisPlugins);\n  const contextStyleSheet = useStyleSheet();\n\n  const styleSheet = useMemo(() => {\n    let sheet = contextStyleSheet;\n\n    if (props.sheet) {\n      // eslint-disable-next-line prefer-destructuring\n      sheet = props.sheet;\n    } else if (props.target) {\n      sheet = sheet.reconstructWithOptions({ target: props.target }, false);\n    }\n\n    if (props.disableCSSOMInjection) {\n      sheet = sheet.reconstructWithOptions({ useCSSOMInjection: false });\n    }\n\n    return sheet;\n  }, [props.disableCSSOMInjection, props.sheet, props.target]);\n\n  const stylis = useMemo(\n    () =>\n      createStylisInstance({\n        options: { prefix: !props.disableVendorPrefixes },\n        plugins,\n      }),\n    [props.disableVendorPrefixes, plugins]\n  );\n\n  useEffect(() => {\n    if (!shallowequal(plugins, props.stylisPlugins)) setPlugins(props.stylisPlugins);\n  }, [props.stylisPlugins]);\n\n  return (\n    <StyleSheetContext.Provider value={styleSheet}>\n      <StylisContext.Provider value={stylis}>\n        {process.env.NODE_ENV !== 'production'\n          ? React.Children.only(props.children)\n          : props.children}\n      </StylisContext.Provider>\n    </StyleSheetContext.Provider>\n  );\n}\n","// @flow\nimport StyleSheet from '../sheet';\nimport { type Stringifier } from '../types';\nimport throwStyledError from '../utils/error';\nimport { masterStylis } from './StyleSheetManager';\n\nexport default class Keyframes {\n  id: string;\n\n  name: string;\n\n  rules: string;\n\n  constructor(name: string, rules: string) {\n    this.name = name;\n    this.id = `sc-keyframes-${name}`;\n    this.rules = rules;\n  }\n\n  inject = (styleSheet: StyleSheet, stylisInstance: Stringifier = masterStylis) => {\n    const resolvedName = this.name + stylisInstance.hash;\n\n    if (!styleSheet.hasNameForId(this.id, resolvedName)) {\n      styleSheet.insertRules(\n        this.id,\n        resolvedName,\n        stylisInstance(this.rules, resolvedName, '@keyframes')\n      );\n    }\n  };\n\n  toString = () => {\n    return throwStyledError(12, String(this.name));\n  };\n\n  getName(stylisInstance: Stringifier = masterStylis) {\n    return this.name + stylisInstance.hash;\n  }\n}\n","// @flow\n\n/**\n * inlined version of\n * https://github.com/facebook/fbjs/blob/master/packages/fbjs/src/core/hyphenateStyleName.js\n */\n\nconst uppercaseCheck = /([A-Z])/;\nconst uppercasePattern = /([A-Z])/g;\nconst msPattern = /^ms-/;\nconst prefixAndLowerCase = (char: string): string => `-${char.toLowerCase()}`;\n\n/**\n * Hyphenates a camelcased CSS property name, for example:\n *\n *   > hyphenateStyleName('backgroundColor')\n *   < \"background-color\"\n *   > hyphenateStyleName('MozTransition')\n *   < \"-moz-transition\"\n *   > hyphenateStyleName('msTransition')\n *   < \"-ms-transition\"\n *\n * As Modernizr suggests (http://modernizr.com/docs/#prefixed), an `ms` prefix\n * is converted to `-ms-`.\n *\n * @param {string} string\n * @return {string}\n */\nexport default function hyphenateStyleName(string: string): string {\n  return uppercaseCheck.test(string)\n  ? string\n    .replace(uppercasePattern, prefixAndLowerCase)\n    .replace(msPattern, '-ms-')\n  : string;\n}\n","// @flow\nimport { isElement } from 'react-is';\nimport getComponentName from './getComponentName';\nimport isFunction from './isFunction';\nimport isStatelessFunction from './isStatelessFunction';\nimport isPlainObject from './isPlainObject';\nimport isStyledComponent from './isStyledComponent';\nimport Keyframes from '../models/Keyframes';\nimport hyphenate from './hyphenateStyleName';\nimport addUnitIfNeeded from './addUnitIfNeeded';\nimport { type Stringifier } from '../types';\n\n/**\n * It's falsish not falsy because 0 is allowed.\n */\nconst isFalsish = chunk => chunk === undefined || chunk === null || chunk === false || chunk === '';\n\nexport const objToCssArray = (obj: Object, prevKey?: string): Array<string | Function> => {\n  const rules = [];\n\n  for (const key in obj) {\n    if (!obj.hasOwnProperty(key) || isFalsish(obj[key])) continue;\n\n    if ((Array.isArray(obj[key]) && obj[key].isCss) || isFunction(obj[key])) {\n      rules.push(`${hyphenate(key)}:`, obj[key], ';');\n    } else if (isPlainObject(obj[key])) {\n      rules.push(...objToCssArray(obj[key], key));\n    } else {\n      rules.push(`${hyphenate(key)}: ${addUnitIfNeeded(key, obj[key])};`);\n    }\n  }\n\n  return prevKey ? [`${prevKey} {`, ...rules, '}'] : rules;\n};\n\nexport default function flatten(\n  chunk: any,\n  executionContext: ?Object,\n  styleSheet: ?Object,\n  stylisInstance: ?Stringifier\n): any {\n  if (Array.isArray(chunk)) {\n    const ruleSet = [];\n\n    for (let i = 0, len = chunk.length, result; i < len; i += 1) {\n      result = flatten(chunk[i], executionContext, styleSheet, stylisInstance);\n\n      if (result === '') continue;\n      else if (Array.isArray(result)) ruleSet.push(...result);\n      else ruleSet.push(result);\n    }\n\n    return ruleSet;\n  }\n\n  if (isFalsish(chunk)) {\n    return '';\n  }\n\n  /* Handle other components */\n  if (isStyledComponent(chunk)) {\n    return `.${chunk.styledComponentId}`;\n  }\n\n  /* Either execute or defer the function */\n  if (isFunction(chunk)) {\n    if (isStatelessFunction(chunk) && executionContext) {\n      const result = chunk(executionContext);\n\n      if (process.env.NODE_ENV !== 'production' && isElement(result)) {\n        // eslint-disable-next-line no-console\n        console.warn(\n          `${getComponentName(\n            chunk\n          )} is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.`\n        );\n      }\n\n      return flatten(result, executionContext, styleSheet, stylisInstance);\n    } else return chunk;\n  }\n\n  if (chunk instanceof Keyframes) {\n    if (styleSheet) {\n      chunk.inject(styleSheet, stylisInstance);\n      return chunk.getName(stylisInstance);\n    } else return chunk;\n  }\n\n  /* Handle objects */\n  return isPlainObject(chunk) ? objToCssArray(chunk) : chunk.toString();\n}\n","// @flow\nexport default function isStatelessFunction(test: any): boolean {\n  return (\n    typeof test === 'function'\n    && !(\n      test.prototype\n      && test.prototype.isReactComponent\n    )\n  );\n}\n","// @flow\nimport unitless from '@emotion/unitless';\n\n// Taken from https://github.com/facebook/react/blob/b87aabdfe1b7461e7331abb3601d9e6bb27544bc/packages/react-dom/src/shared/dangerousStyleValue.js\nexport default function addUnitIfNeeded(name: string, value: any): any {\n  // https://github.com/amilajack/eslint-plugin-flowtype-errors/issues/133\n  // $FlowFixMe\n  if (value == null || typeof value === 'boolean' || value === '') {\n    return '';\n  }\n\n  if (typeof value === 'number' && value !== 0 && !(name in unitless) && !name.startsWith('--')) {\n    return `${value}px`; // Presumes implicit 'px' suffix for unitless numbers except for CSS variables\n  }\n\n  return String(value).trim();\n}\n","// @flow\nimport interleave from '../utils/interleave';\nimport isPlainObject from '../utils/isPlainObject';\nimport { EMPTY_ARRAY } from '../utils/empties';\nimport isFunction from '../utils/isFunction';\nimport flatten from '../utils/flatten';\nimport type { Interpolation, RuleSet, Styles } from '../types';\n\n/**\n * Used when flattening object styles to determine if we should\n * expand an array of styles.\n */\nconst addTag = arg => {\n  if (Array.isArray(arg)) {\n    // eslint-disable-next-line no-param-reassign\n    arg.isCss = true;\n  }\n  return arg;\n};\n\nexport default function css(styles: Styles, ...interpolations: Array<Interpolation>): RuleSet {\n  if (isFunction(styles) || isPlainObject(styles)) {\n    // $FlowFixMe\n    return addTag(flatten(interleave(EMPTY_ARRAY, [styles, ...interpolations])));\n  }\n\n  if (interpolations.length === 0 && styles.length === 1 && typeof styles[0] === 'string') {\n    // $FlowFixMe\n    return styles;\n  }\n\n  // $FlowFixMe\n  return addTag(flatten(interleave(styles, interpolations)));\n}\n","// @flow\n\nimport { useRef } from 'react';\n\nconst invalidHookCallRe = /invalid hook call/i;\nconst seen = new Set();\n\nexport const checkDynamicCreation = (displayName: string, componentId?: string) => {\n  if (process.env.NODE_ENV !== 'production') {\n    const parsedIdString = componentId ? ` with the id of \"${componentId}\"` : '';\n    const message =\n      `The component ${displayName}${parsedIdString} has been created dynamically.\\n` +\n      \"You may see this warning because you've called styled inside another component.\\n\" +\n      'To resolve this only create new StyledComponents outside of any render method and function component.';\n\n    // If a hook is called outside of a component:\n    // React 17 and earlier throw an error\n    // React 18 and above use console.error\n\n    const originalConsoleError = console.error // eslint-disable-line no-console\n    try {\n      let didNotCallInvalidHook = true\n      /* $FlowIgnore[cannot-write] */\n      console.error = (consoleErrorMessage, ...consoleErrorArgs) => { // eslint-disable-line no-console\n      // The error here is expected, since we're expecting anything that uses `checkDynamicCreation` to\n      // be called outside of a React component.\n        if (invalidHookCallRe.test(consoleErrorMessage)) {\n          didNotCallInvalidHook = false\n          // This shouldn't happen, but resets `warningSeen` if we had this error happen intermittently\n          seen.delete(message);\n        } else {\n          originalConsoleError(consoleErrorMessage, ...consoleErrorArgs);\n        }\n      }\n      // We purposefully call `useRef` outside of a component and expect it to throw\n      // If it doesn't, then we're inside another component.\n      // eslint-disable-next-line react-hooks/rules-of-hooks\n      useRef();\n\n      if (didNotCallInvalidHook && !seen.has(message)) {\n        // eslint-disable-next-line no-console\n        console.warn(message);\n        seen.add(message);\n      }\n    } catch (error) {\n      // The error here is expected, since we're expecting anything that uses `checkDynamicCreation` to\n      // be called outside of a React component.\n      if (invalidHookCallRe.test(error.message)) {\n        // This shouldn't happen, but resets `warningSeen` if we had this error happen intermittently\n        seen.delete(message);\n      }\n    } finally {\n      /* $FlowIgnore[cannot-write] */\n      console.error = originalConsoleError; // eslint-disable-line no-console\n    }\n  }\n};\n","// @flow\nimport { EMPTY_OBJECT } from './empties';\n\ntype Props = {\n  theme?: any,\n};\n\nexport default (props: Props, providedTheme: any, defaultProps: any = EMPTY_OBJECT) => {\n  return (props.theme !== defaultProps.theme && props.theme) || providedTheme || defaultProps.theme;\n};\n","// @flow\n\n// Source: https://www.w3.org/TR/cssom-1/#serialize-an-identifier\n// Control characters and non-letter first symbols are not supported\nconst escapeRegex = /[!\"#$%&'()*+,./:;<=>?@[\\\\\\]^`{|}~-]+/g;\n\nconst dashesAtEnds = /(^-|-$)/g;\n\n/**\n * TODO: Explore using CSS.escape when it becomes more available\n * in evergreen browsers.\n */\nexport default function escape(str: string): string {\n  return (\n    str\n      // Replace all possible CSS selectors\n      .replace(escapeRegex, '-')\n\n      // Remove extraneous hyphens at the start and end\n      .replace(dashesAtEnds, '')\n  );\n}\n","// @flow\n/* eslint-disable */\nimport generateAlphabeticName from './generateAlphabeticName';\nimport { hash } from './hash';\n\nexport default (str: string): string => {\n  return generateAlphabeticName(hash(str) >>> 0);\n};\n","// @flow\nimport type { IStyledComponent } from '../types';\n\nexport default function isTag(target: $PropertyType<IStyledComponent, 'target'>): boolean %checks {\n  return (\n    typeof target === 'string' &&\n    (process.env.NODE_ENV !== 'production'\n      ? target.charAt(0) === target.charAt(0).toLowerCase()\n      : true)\n  );\n}\n","/* eslint-disable */\n/**\n  mixin-deep; https://github.com/jonschlinkert/mixin-deep\n  Inlined such that it will be consistently transpiled to an IE-compatible syntax.\n\n  The MIT License (MIT)\n\n  Copyright (c) 2014-present, Jon Schlinkert.\n\n  Permission is hereby granted, free of charge, to any person obtaining a copy\n  of this software and associated documentation files (the \"Software\"), to deal\n  in the Software without restriction, including without limitation the rights\n  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n  copies of the Software, and to permit persons to whom the Software is\n  furnished to do so, subject to the following conditions:\n\n  The above copyright notice and this permission notice shall be included in\n  all copies or substantial portions of the Software.\n\n  THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n  THE SOFTWARE.\n*/\n\nconst isObject = val => {\n  return (\n    typeof val === 'function' || (typeof val === 'object' && val !== null && !Array.isArray(val))\n  );\n};\n\nconst isValidKey = key => {\n  return key !== '__proto__' && key !== 'constructor' && key !== 'prototype';\n};\n\nfunction mixin(target, val, key) {\n  const obj = target[key];\n  if (isObject(val) && isObject(obj)) {\n    mixinDeep(obj, val);\n  } else {\n    target[key] = val;\n  }\n}\n\nexport default function mixinDeep(target, ...rest) {\n  for (const obj of rest) {\n    if (isObject(obj)) {\n      for (const key in obj) {\n        if (isValidKey(key)) {\n          mixin(target, obj[key], key);\n        }\n      }\n    }\n  }\n\n  return target;\n}\n","// @flow\nimport React, { useContext, useMemo, type Element, type Context } from 'react';\nimport throwStyledError from '../utils/error';\nimport isFunction from '../utils/isFunction';\n\nexport type Theme = { [key: string]: mixed };\n\ntype ThemeArgument = Theme | ((outerTheme?: Theme) => Theme);\n\ntype Props = {\n  children?: Element<any>,\n  theme: ThemeArgument,\n};\n\nexport const ThemeContext: Context<Theme | void> = React.createContext();\n\nexport const ThemeConsumer = ThemeContext.Consumer;\n\nfunction mergeTheme(theme: ThemeArgument, outerTheme?: Theme): Theme {\n  if (!theme) {\n    return throwStyledError(14);\n  }\n\n  if (isFunction(theme)) {\n    const mergedTheme = theme(outerTheme);\n\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      (mergedTheme === null || Array.isArray(mergedTheme) || typeof mergedTheme !== 'object')\n    ) {\n      return throwStyledError(7);\n    }\n\n    return mergedTheme;\n  }\n\n  if (Array.isArray(theme) || typeof theme !== 'object') {\n    return throwStyledError(8);\n  }\n\n  return outerTheme ? { ...outerTheme, ...theme } : theme;\n}\n\n/**\n * Provide a theme to an entire react component tree via context\n */\nexport default function ThemeProvider(props: Props) {\n  const outerTheme = useContext(ThemeContext);\n  const themeContext = useMemo(() => mergeTheme(props.theme, outerTheme), [\n    props.theme,\n    outerTheme,\n  ]);\n\n  if (!props.children) {\n    return null;\n  }\n\n  return <ThemeContext.Provider value={themeContext}>{props.children}</ThemeContext.Provider>;\n}\n","// @flow\nimport validAttr from '@emotion/is-prop-valid';\nimport hoist from 'hoist-non-react-statics';\nimport React, { createElement, type Ref, useContext } from 'react';\nimport { SC_VERSION } from '../constants';\nimport type {\n  Attrs,\n  IStyledComponent,\n  IStyledStatics,\n  RuleSet,\n  ShouldForwardProp,\n  Target,\n} from '../types';\nimport { checkDynamicCreation } from '../utils/checkDynamicCreation';\nimport createWarnTooManyClasses from '../utils/createWarnTooManyClasses';\nimport determineTheme from '../utils/determineTheme';\nimport { EMPTY_ARRAY, EMPTY_OBJECT } from '../utils/empties';\nimport escape from '../utils/escape';\nimport generateComponentId from '../utils/generateComponentId';\nimport generateDisplayName from '../utils/generateDisplayName';\nimport getComponentName from '../utils/getComponentName';\nimport isFunction from '../utils/isFunction';\nimport isStyledComponent from '../utils/isStyledComponent';\nimport isTag from '../utils/isTag';\nimport joinStrings from '../utils/joinStrings';\nimport merge from '../utils/mixinDeep';\nimport ComponentStyle from './ComponentStyle';\nimport { useStyleSheet, useStylis } from './StyleSheetManager';\nimport { ThemeContext } from './ThemeProvider';\n\nconst identifiers = {};\n\n/* We depend on components having unique IDs */\nfunction generateId(displayName?: string, parentComponentId?: string) {\n  const name = typeof displayName !== 'string' ? 'sc' : escape(displayName);\n  // Ensure that no displayName can lead to duplicate componentIds\n  identifiers[name] = (identifiers[name] || 0) + 1;\n\n  const componentId = `${name}-${generateComponentId(\n    // SC_VERSION gives us isolation between multiple runtimes on the page at once\n    // this is improved further with use of the babel plugin \"namespace\" feature\n    SC_VERSION + name + identifiers[name]\n  )}`;\n\n  return parentComponentId ? `${parentComponentId}-${componentId}` : componentId;\n}\n\nfunction useResolvedAttrs<Config>(theme: any = EMPTY_OBJECT, props: Config, attrs: Attrs) {\n  // NOTE: can't memoize this\n  // returns [context, resolvedAttrs]\n  // where resolvedAttrs is only the things injected by the attrs themselves\n  const context = { ...props, theme };\n  const resolvedAttrs = {};\n\n  attrs.forEach(attrDef => {\n    let resolvedAttrDef = attrDef;\n    let key;\n\n    if (isFunction(resolvedAttrDef)) {\n      resolvedAttrDef = resolvedAttrDef(context);\n    }\n\n    /* eslint-disable guard-for-in */\n    for (key in resolvedAttrDef) {\n      context[key] = resolvedAttrs[key] =\n        key === 'className'\n          ? joinStrings(resolvedAttrs[key], resolvedAttrDef[key])\n          : resolvedAttrDef[key];\n    }\n    /* eslint-enable guard-for-in */\n  });\n\n  return [context, resolvedAttrs];\n}\n\nfunction useInjectedStyle<T>(\n  componentStyle: ComponentStyle,\n  isStatic: boolean,\n  resolvedAttrs: T,\n  warnTooManyClasses?: $Call<typeof createWarnTooManyClasses, string, string>\n) {\n  const styleSheet = useStyleSheet();\n  const stylis = useStylis();\n\n  const className = isStatic\n    ? componentStyle.generateAndInjectStyles(EMPTY_OBJECT, styleSheet, stylis)\n    : componentStyle.generateAndInjectStyles(resolvedAttrs, styleSheet, stylis);\n\n  if (process.env.NODE_ENV !== 'production' && !isStatic && warnTooManyClasses) {\n    warnTooManyClasses(className);\n  }\n\n  return className;\n}\n\nfunction useStyledComponentImpl(\n  forwardedComponent: IStyledComponent,\n  props: Object,\n  forwardedRef: Ref<any>,\n  isStatic: boolean\n) {\n  const {\n    attrs: componentAttrs,\n    componentStyle,\n    defaultProps,\n    foldedComponentIds,\n    shouldForwardProp,\n    styledComponentId,\n    target,\n  } = forwardedComponent;\n\n  // NOTE: the non-hooks version only subscribes to this when !componentStyle.isStatic,\n  // but that'd be against the rules-of-hooks. We could be naughty and do it anyway as it\n  // should be an immutable value, but behave for now.\n  const theme = determineTheme(props, useContext(ThemeContext), defaultProps);\n\n  const [context, attrs] = useResolvedAttrs(theme || EMPTY_OBJECT, props, componentAttrs);\n\n  const generatedClassName = useInjectedStyle(\n    componentStyle,\n    isStatic,\n    context,\n    process.env.NODE_ENV !== 'production' ? forwardedComponent.warnTooManyClasses : undefined\n  );\n\n  const refToForward = forwardedRef;\n\n  const elementToBeCreated: Target = attrs.$as || props.$as || attrs.as || props.as || target;\n\n  const isTargetTag = isTag(elementToBeCreated);\n  const computedProps = attrs !== props ? { ...props, ...attrs } : props;\n  const propsForElement = {};\n\n  // eslint-disable-next-line guard-for-in\n  for (const key in computedProps) {\n    if (key[0] === '$' || key === 'as') continue;\n    else if (key === 'forwardedAs') {\n      propsForElement.as = computedProps[key];\n    } else if (\n      shouldForwardProp\n        ? shouldForwardProp(key, validAttr, elementToBeCreated)\n        : isTargetTag\n        ? validAttr(key)\n        : true\n    ) {\n      // Don't pass through non HTML tags through to HTML elements\n      propsForElement[key] = computedProps[key];\n    }\n  }\n\n  if (props.style && attrs.style !== props.style) {\n    propsForElement.style = { ...props.style, ...attrs.style };\n  }\n\n  propsForElement.className = Array.prototype\n    .concat(\n      foldedComponentIds,\n      styledComponentId,\n      generatedClassName !== styledComponentId ? generatedClassName : null,\n      props.className,\n      attrs.className\n    )\n    .filter(Boolean)\n    .join(' ');\n\n  propsForElement.ref = refToForward;\n\n  return createElement(elementToBeCreated, propsForElement);\n}\n\nexport default function createStyledComponent(\n  target: $PropertyType<IStyledComponent, 'target'>,\n  options: {\n    attrs?: Attrs,\n    componentId: string,\n    displayName?: string,\n    parentComponentId?: string,\n    shouldForwardProp?: ShouldForwardProp,\n  },\n  rules: RuleSet\n) {\n  const isTargetStyledComp = isStyledComponent(target);\n  const isCompositeComponent = !isTag(target);\n\n  const {\n    attrs = EMPTY_ARRAY,\n    componentId = generateId(options.displayName, options.parentComponentId),\n    displayName = generateDisplayName(target),\n  } = options;\n\n  const styledComponentId =\n    options.displayName && options.componentId\n      ? `${escape(options.displayName)}-${options.componentId}`\n      : options.componentId || componentId;\n\n  // fold the underlying StyledComponent attrs up (implicit extend)\n  const finalAttrs =\n    isTargetStyledComp && ((target: any): IStyledComponent).attrs\n      ? Array.prototype.concat(((target: any): IStyledComponent).attrs, attrs).filter(Boolean)\n      : attrs;\n\n  // eslint-disable-next-line prefer-destructuring\n  let shouldForwardProp = options.shouldForwardProp;\n\n  if (isTargetStyledComp && target.shouldForwardProp) {\n    if (options.shouldForwardProp) {\n      // compose nested shouldForwardProp calls\n      shouldForwardProp = (prop, filterFn, elementToBeCreated) =>\n        ((((target: any): IStyledComponent).shouldForwardProp: any): ShouldForwardProp)(\n          prop,\n          filterFn,\n          elementToBeCreated\n        ) &&\n        ((options.shouldForwardProp: any): ShouldForwardProp)(prop, filterFn, elementToBeCreated);\n    } else {\n      // eslint-disable-next-line prefer-destructuring\n      shouldForwardProp = ((target: any): IStyledComponent).shouldForwardProp;\n    }\n  }\n\n  const componentStyle = new ComponentStyle(\n    rules,\n    styledComponentId,\n    isTargetStyledComp ? ((target: Object).componentStyle: ComponentStyle) : undefined\n  );\n\n  // statically styled-components don't need to build an execution context object,\n  // and shouldn't be increasing the number of class names\n  const isStatic = componentStyle.isStatic && attrs.length === 0;\n\n  /**\n   * forwardRef creates a new interim component, which we'll take advantage of\n   * instead of extending ParentComponent to create _another_ interim class\n   */\n  let WrappedStyledComponent: IStyledComponent;\n\n  const forwardRef = (props, ref) =>\n    // eslint-disable-next-line\n    useStyledComponentImpl(WrappedStyledComponent, props, ref, isStatic);\n\n  forwardRef.displayName = displayName;\n\n  WrappedStyledComponent = ((React.forwardRef(forwardRef): any): IStyledComponent);\n  WrappedStyledComponent.attrs = finalAttrs;\n  WrappedStyledComponent.componentStyle = componentStyle;\n  WrappedStyledComponent.displayName = displayName;\n  WrappedStyledComponent.shouldForwardProp = shouldForwardProp;\n\n  // this static is used to preserve the cascade of static classes for component selector\n  // purposes; this is especially important with usage of the css prop\n  WrappedStyledComponent.foldedComponentIds = isTargetStyledComp\n    ? Array.prototype.concat(\n        ((target: any): IStyledComponent).foldedComponentIds,\n        ((target: any): IStyledComponent).styledComponentId\n      )\n    : EMPTY_ARRAY;\n\n  WrappedStyledComponent.styledComponentId = styledComponentId;\n\n  // fold the underlying StyledComponent target up since we folded the styles\n  WrappedStyledComponent.target = isTargetStyledComp\n    ? ((target: any): IStyledComponent).target\n    : target;\n\n  WrappedStyledComponent.withComponent = function withComponent(tag: Target) {\n    const { componentId: previousComponentId, ...optionsToCopy } = options;\n\n    const newComponentId =\n      previousComponentId &&\n      `${previousComponentId}-${isTag(tag) ? tag : escape(getComponentName(tag))}`;\n\n    const newOptions = {\n      ...optionsToCopy,\n      attrs: finalAttrs,\n      componentId: newComponentId,\n    };\n\n    return createStyledComponent(tag, newOptions, rules);\n  };\n\n  Object.defineProperty(WrappedStyledComponent, 'defaultProps', {\n    get() {\n      return this._foldedDefaultProps;\n    },\n\n    set(obj) {\n      this._foldedDefaultProps = isTargetStyledComp\n        ? merge({}, ((target: any): IStyledComponent).defaultProps, obj)\n        : obj;\n    },\n  });\n\n  if (process.env.NODE_ENV !== 'production') {\n    checkDynamicCreation(displayName, styledComponentId);\n\n    WrappedStyledComponent.warnTooManyClasses = createWarnTooManyClasses(\n      displayName,\n      styledComponentId\n    );\n  }\n\n  // If the Object prototype is frozen, the \"toString\" property is non-writable. This means that any objects which inherit this property\n  // cannot have the property changed using an assignment. If using strict mode, attempting that will cause an error. If not using strict\n  // mode, attempting that will be silently ignored.\n  // However, we can still explicitly shadow the prototype's \"toString\" property by defining a new \"toString\" property on this object.\n  Object.defineProperty(WrappedStyledComponent, 'toString', { value: () => `.${WrappedStyledComponent.styledComponentId}` });\n\n  if (isCompositeComponent) {\n    hoist<\n      IStyledStatics,\n      $PropertyType<IStyledComponent, 'target'>,\n      { [key: $Keys<IStyledStatics>]: true }\n    >(WrappedStyledComponent, ((target: any): $PropertyType<IStyledComponent, 'target'>), {\n      // all SC-specific things should not be hoisted\n      attrs: true,\n      componentStyle: true,\n      displayName: true,\n      foldedComponentIds: true,\n      shouldForwardProp: true,\n      styledComponentId: true,\n      target: true,\n      withComponent: true,\n    });\n  }\n\n  return WrappedStyledComponent;\n}\n","// @flow\nimport type { IStyledComponent } from '../types';\nimport getComponentName from './getComponentName';\nimport isTag from './isTag';\n\nexport default function generateDisplayName(\n  target: $PropertyType<IStyledComponent, 'target'>\n): string {\n  return isTag(target) ? `styled.${target}` : `Styled(${getComponentName(target)})`;\n}\n","/**\n * Convenience function for joining strings to form className chains\n */\nexport default function joinStrings(a: ?String, b: ?String): ?String {\n  return a && b ? `${a} ${b}` : a || b;\n}\n","// @flow\n// Thanks to ReactDOMFactories for this handy list!\n\nexport default [\n  'a',\n  'abbr',\n  'address',\n  'area',\n  'article',\n  'aside',\n  'audio',\n  'b',\n  'base',\n  'bdi',\n  'bdo',\n  'big',\n  'blockquote',\n  'body',\n  'br',\n  'button',\n  'canvas',\n  'caption',\n  'cite',\n  'code',\n  'col',\n  'colgroup',\n  'data',\n  'datalist',\n  'dd',\n  'del',\n  'details',\n  'dfn',\n  'dialog',\n  'div',\n  'dl',\n  'dt',\n  'em',\n  'embed',\n  'fieldset',\n  'figcaption',\n  'figure',\n  'footer',\n  'form',\n  'h1',\n  'h2',\n  'h3',\n  'h4',\n  'h5',\n  'h6',\n  'head',\n  'header',\n  'hgroup',\n  'hr',\n  'html',\n  'i',\n  'iframe',\n  'img',\n  'input',\n  'ins',\n  'kbd',\n  'keygen',\n  'label',\n  'legend',\n  'li',\n  'link',\n  'main',\n  'map',\n  'mark',\n  'marquee',\n  'menu',\n  'menuitem',\n  'meta',\n  'meter',\n  'nav',\n  'noscript',\n  'object',\n  'ol',\n  'optgroup',\n  'option',\n  'output',\n  'p',\n  'param',\n  'picture',\n  'pre',\n  'progress',\n  'q',\n  'rp',\n  'rt',\n  'ruby',\n  's',\n  'samp',\n  'script',\n  'section',\n  'select',\n  'small',\n  'source',\n  'span',\n  'strong',\n  'style',\n  'sub',\n  'summary',\n  'sup',\n  'table',\n  'tbody',\n  'td',\n  'textarea',\n  'tfoot',\n  'th',\n  'thead',\n  'time',\n  'title',\n  'tr',\n  'track',\n  'u',\n  'ul',\n  'var',\n  'video',\n  'wbr',\n\n  // SVG\n  'circle',\n  'clipPath',\n  'defs',\n  'ellipse',\n  'foreignObject',\n  'g',\n  'image',\n  'line',\n  'linearGradient',\n  'marker',\n  'mask',\n  'path',\n  'pattern',\n  'polygon',\n  'polyline',\n  'radialGradient',\n  'rect',\n  'stop',\n  'svg',\n  'text',\n  'textPath',\n  'tspan',\n];\n","// @flow\nimport constructWithOptions from './constructWithOptions';\nimport StyledComponent from '../models/StyledComponent';\nimport domElements from '../utils/domElements';\n\nimport type { Target } from '../types';\n\nconst styled = (tag: Target) => constructWithOptions(StyledComponent, tag);\n\n// Shorthands for all valid HTML Elements\ndomElements.forEach(domElement => {\n  styled[domElement] = styled(domElement);\n});\n\nexport default styled;\n","// @flow\nimport { isValidElementType } from 'react-is';\nimport css from './css';\nimport throwStyledError from '../utils/error';\nimport { EMPTY_OBJECT } from '../utils/empties';\n\nimport type { Target } from '../types';\n\nexport default function constructWithOptions(\n  componentConstructor: Function,\n  tag: Target,\n  options: Object = EMPTY_OBJECT\n) {\n  if (!isValidElementType(tag)) {\n    return throwStyledError(1, String(tag));\n  }\n\n  /* This is callable directly as a template function */\n  // $FlowFixMe: Not typed to avoid destructuring arguments\n  const templateFunction = (...args) => componentConstructor(tag, options, css(...args));\n\n  /* If config methods are called, wrap up a new template function and merge options */\n  templateFunction.withConfig = config =>\n    constructWithOptions(componentConstructor, tag, { ...options, ...config });\n\n  /* Modify/inject new props at runtime */\n  templateFunction.attrs = attrs =>\n    constructWithOptions(componentConstructor, tag, {\n      ...options,\n      attrs: Array.prototype.concat(options.attrs, attrs).filter(Boolean),\n    });\n\n  return templateFunction;\n}\n","// @flow\nimport StyleSheet from '../sheet';\nimport type { RuleSet, Stringifier } from '../types';\nimport flatten from '../utils/flatten';\nimport isStaticRules from '../utils/isStaticRules';\n\nexport default class GlobalStyle {\n  componentId: string;\n\n  isStatic: boolean;\n\n  rules: RuleSet;\n\n  constructor(rules: RuleSet, componentId: string) {\n    this.rules = rules;\n    this.componentId = componentId;\n    this.isStatic = isStaticRules(rules);\n\n    // pre-register the first instance to ensure global styles\n    // load before component ones\n    StyleSheet.registerId(this.componentId + 1);\n  }\n\n  createStyles(\n    instance: number,\n    executionContext: Object,\n    styleSheet: StyleSheet,\n    stylis: Stringifier\n  ) {\n    const flatCSS = flatten(this.rules, executionContext, styleSheet, stylis);\n    const css = stylis(flatCSS.join(''), '');\n    const id = this.componentId + instance;\n\n    // NOTE: We use the id as a name as well, since these rules never change\n    styleSheet.insertRules(id, id, css);\n  }\n\n  removeStyles(instance: number, styleSheet: StyleSheet) {\n    styleSheet.clearRules(this.componentId + instance);\n  }\n\n  renderStyles(\n    instance: number,\n    executionContext: Object,\n    styleSheet: StyleSheet,\n    stylis: Stringifier\n  ) {\n    if (instance > 2) StyleSheet.registerId(this.componentId + instance);\n\n    // NOTE: Remove old styles, then inject the new ones\n    this.removeStyles(instance, styleSheet);\n    this.createStyles(instance, executionContext, styleSheet, stylis);\n  }\n}\n","// @flow\n/* eslint-disable no-underscore-dangle */\nimport React from 'react';\nimport { IS_BROWSER, SC_ATTR, SC_ATTR_VERSION, SC_VERSION } from '../constants';\nimport throwStyledError from '../utils/error';\nimport getNonce from '../utils/nonce';\nimport StyleSheet from '../sheet';\nimport StyleSheetManager from './StyleSheetManager';\n\ndeclare var __SERVER__: boolean;\n\nconst CLOSING_TAG_R = /^\\s*<\\/[a-z]/i;\n\nexport default class ServerStyleSheet {\n  isStreaming: boolean;\n\n  instance: StyleSheet;\n\n  sealed: boolean;\n\n  constructor() {\n    this.instance = new StyleSheet({ isServer: true });\n    this.sealed = false;\n  }\n\n  _emitSheetCSS = (): string => {\n    const css = this.instance.toString();\n    if (!css) return '';\n\n    const nonce = getNonce();\n    const attrs = [nonce && `nonce=\"${nonce}\"`, `${SC_ATTR}=\"true\"`, `${SC_ATTR_VERSION}=\"${SC_VERSION}\"`];\n    const htmlAttr = attrs.filter(Boolean).join(' ');\n\n    return `<style ${htmlAttr}>${css}</style>`;\n  };\n\n  collectStyles(children: any) {\n    if (this.sealed) {\n      return throwStyledError(2);\n    }\n\n    return <StyleSheetManager sheet={this.instance}>{children}</StyleSheetManager>;\n  }\n\n  getStyleTags = (): string => {\n    if (this.sealed) {\n      return throwStyledError(2);\n    }\n\n    return this._emitSheetCSS();\n  };\n\n  getStyleElement = () => {\n    if (this.sealed) {\n      return throwStyledError(2);\n    }\n\n    const props = {\n      [SC_ATTR]: '',\n      [SC_ATTR_VERSION]: SC_VERSION,\n      dangerouslySetInnerHTML: {\n        __html: this.instance.toString(),\n      },\n    };\n\n    const nonce = getNonce();\n    if (nonce) {\n      (props: any).nonce = nonce;\n    }\n\n    // v4 returned an array for this fn, so we'll do the same for v5 for backward compat\n    return [<style {...props} key=\"sc-0-0\" />];\n  };\n\n  // eslint-disable-next-line consistent-return\n  interleaveWithNodeStream(input: any) {\n    if (!__SERVER__ || IS_BROWSER) {\n      return throwStyledError(3);\n    } else if (this.sealed) {\n      return throwStyledError(2);\n    }\n\n    if (__SERVER__) {\n      this.seal();\n\n      // eslint-disable-next-line global-require\n      const { Readable, Transform } = require('stream');\n\n      const readableStream: Readable = input;\n      const { instance: sheet, _emitSheetCSS } = this;\n\n      const transformer = new Transform({\n        transform: function appendStyleChunks(chunk, /* encoding */ _, callback) {\n          // Get the chunk and retrieve the sheet's CSS as an HTML chunk,\n          // then reset its rules so we get only new ones for the next chunk\n          const renderedHtml = chunk.toString();\n          const html = _emitSheetCSS();\n\n          sheet.clearTag();\n\n          // prepend style html to chunk, unless the start of the chunk is a\n          // closing tag in which case append right after that\n          if (CLOSING_TAG_R.test(renderedHtml)) {\n            const endOfClosingTag = renderedHtml.indexOf('>') + 1;\n            const before = renderedHtml.slice(0, endOfClosingTag);\n            const after = renderedHtml.slice(endOfClosingTag);\n\n            this.push(before + html + after);\n          } else {\n            this.push(html + renderedHtml);\n          }\n\n          callback();\n        },\n      });\n\n      readableStream.on('error', err => {\n        // forward the error to the transform stream\n        transformer.emit('error', err);\n      });\n\n      return readableStream.pipe(transformer);\n    }\n  }\n\n  seal = () => {\n    this.sealed = true;\n  };\n}\n","// @flow\n/* Import singletons */\nimport isStyledComponent from './utils/isStyledComponent';\nimport css from './constructors/css';\nimport createGlobalStyle from './constructors/createGlobalStyle';\nimport keyframes from './constructors/keyframes';\nimport ServerStyleSheet from './models/ServerStyleSheet';\nimport { SC_VERSION } from './constants';\n\nimport StyleSheetManager, {\n  StyleSheetContext,\n  StyleSheetConsumer,\n} from './models/StyleSheetManager';\n\n/* Import components */\nimport ThemeProvider, { ThemeContext, ThemeConsumer } from './models/ThemeProvider';\n\n/* Import Higher Order Components */\nimport withTheme from './hoc/withTheme';\n\n/* Import hooks */\nimport useTheme from './hooks/useTheme';\n\ndeclare var __SERVER__: boolean;\n\n/* Warning if you've imported this file on React Native */\nif (\n  process.env.NODE_ENV !== 'production' &&\n  typeof navigator !== 'undefined' &&\n  navigator.product === 'ReactNative'\n) {\n  // eslint-disable-next-line no-console\n  console.warn(\n    \"It looks like you've imported 'styled-components' on React Native.\\n\" +\n      \"Perhaps you're looking to import 'styled-components/native'?\\n\" +\n      'Read more about this at https://www.styled-components.com/docs/basics#react-native'\n  );\n}\n\n/* Warning if there are several instances of styled-components */\nif (process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test' && typeof window !== 'undefined') {\n  window['__styled-components-init__'] = window['__styled-components-init__'] || 0;\n\n  if (window['__styled-components-init__'] === 1) {\n    // eslint-disable-next-line no-console\n    console.warn(\n      \"It looks like there are several instances of 'styled-components' initialized in this application. \" +\n        'This may cause dynamic styles to not render properly, errors during the rehydration process, ' +\n        'a missing theme prop, and makes your application bigger without good reason.\\n\\n' +\n        'See https://s-c.sh/2BAXzed for more info.'\n    );\n  }\n\n  window['__styled-components-init__'] += 1;\n}\n\n/* Export everything */\nexport * from './secretInternals';\nexport {\n  createGlobalStyle,\n  css,\n  isStyledComponent,\n  keyframes,\n  ServerStyleSheet,\n  StyleSheetConsumer,\n  StyleSheetContext,\n  StyleSheetManager,\n  ThemeConsumer,\n  ThemeContext,\n  ThemeProvider,\n  useTheme,\n  SC_VERSION as version,\n  withTheme,\n};\n","import styled from 'styled-components';\nimport { ISeedProps } from '../types/Seed';\n\nexport const Bracket = styled.div<ISeedProps>(\n  (props) => `\n  display: flex;\n  flex-direction: row;\n  @media (max-width: ${props.mobileBreakpoint}px) {\n    flex-direction: column;\n  }\n  `\n);\n\nexport const Round = styled.div<ISeedProps>(\n  (props) => `\n  flex: 0;\n  // min-width:300px;\n  display:flex;\n  flex-direction:column;\n  @media (max-width: ${props.mobileBreakpoint}px) {\n    min-width:0;\n  }\n  `\n);\n\nexport const RoundTitle = styled.div`\n  color: #8f8f8f;\n  font-weight: 400;\n  text-align: center;\n`;\n\nexport const SeedsList = styled.div`\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  flex-flow: row wrap;\n  justify-content: center;\n  height: 100%;\n  list-style: none;\n`;\n","import styled from 'styled-components';\nimport { ISeedProps } from '../types/Seed';\n\nexport const SeedItem = styled.div`\n  color: #fff;\n  width: 100%;\n  background-color: #1a1d2e;\n  padding: 0;\n  border-radius: 0.2em;\n  box-shadow: 0 2px 4px -2px #111630;\n  text-align: center;\n  position: relative;\n`;\n\nexport const SeedTeam = styled.div`\n  padding: 0.3rem 0.5rem;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  border-radius: 0.2em;\n  align-items: center;\n`;\n\nexport const SeedTime = styled.div<ISeedProps>(\n  (props) => `\nmargin-top: 2px;\nfont-size: 12px;\ncolor: #8f8f8f;\nheight: 0;\n@media (max-width: ${props.mobileBreakpoint}px) {\n  height:auto;\n}\n`\n);\n\n/*\n * Difference between \"SingleLineSeed\" and \"Seed\" is that single line seed\n * will directly connect to the next node, it's good for double elimination losing brackets.\n *\n * The best behavior in such case is, to check if the next round seeds matches the current round seeds\n */\n\nexport const SingleLineSeed = styled.div<ISeedProps>(\n  (props) => `\npadding: 1em 1.5em;\nmin-width: 225px;\nwidth:100%;\nposition: relative;\ndisplay: flex;\nalign-items: center;\nflex: 0 1 auto;\nflex-direction: column;\njustify-content: center;\nfont-size: 14px;\n@media (max-width: ${props.mobileBreakpoint}px) {\n  width:100%;\n}\n@media (min-width: ${(props.mobileBreakpoint || 0) + 1}px) {\n  &::after {\n      content: \"\";\n      position: absolute;\n      height: 50%;\n      width: 3em;\n    [dir=\"rtl\"] & {\n      left: -1.5em;\n    }\n    [dir=\"ltr\"] & {\n      right: -1.5em;\n    }\n  }\n  &:nth-child(even)::after {\n    border-bottom: 1px solid #707070;\n    top: -0.5px;\n  }\n  &:nth-child(odd)::after {\n    border-top: 1px solid #707070;\n    top: calc(50% - 0.5px);\n  }\n}\n`\n);\n\nexport const Seed = styled.div<ISeedProps>(\n  (props) => `\n  padding: 1em 1.5em;\n  min-width: 225px;\n  width:100%;\n  position: relative;\n  display: flex;\n  align-items: center;\n  flex: 0 1 auto;\n  flex-direction: column;\n  justify-content: center;\n  font-size: 14px;\n  @media (max-width: ${props.mobileBreakpoint}px) {\n    width:100%;\n  }\n  @media (min-width: ${(props.mobileBreakpoint || 0) + 1}px) {\n    &::after {\n        content: \"\";\n        position: absolute;\n        height: 50%;\n        width: 1.5em;\n      [dir=\"rtl\"] & {\n        left: 0px;\n      }\n      [dir=\"ltr\"] & {\n        right: 0px;\n      }\n    }\n\n    &:nth-child(even)::before{\n      content:'';\n      border-top: 1px solid #707070;\n      position:absolute;\n      top: -0.5px;\n      width:1.5em;\n      [dir=\"rtl\"] & {\n        left:-1.5em;\n        }\n      [dir=\"ltr\"] & {\n        right:-1.5em;\n      }\n    }\n\n    &:nth-child(even)::after {\n      border-bottom: 1px solid #707070;\n      top: -0.5px;\n     [dir=\"rtl\"] & {\n        border-left: 1px solid #707070;\n        }\n      [dir=\"ltr\"] & {\n        border-right: 1px solid #707070;\n      }\n    }\n    &:nth-child(odd):not(:last-child)::after {\n      border-top: 1px solid #707070;\n      top: calc(50% - 0.5px);\n      [dir=\"rtl\"] & {\n        border-left: 1px solid #707070;\n        }\n      [dir=\"ltr\"] & {\n        border-right: 1px solid #707070;\n      }\n    }\n}\n`\n);\n","import React from 'react';\nimport { Seed, SeedItem, SeedTeam, SeedTime } from '../components/seed';\nimport { RoundTitle } from '../components/round';\nimport { IRenderSeedProps } from '../types/Seed';\n\n/* ------------------------- default title component ------------------------ */\nexport const renderTitle = (title: string | JSX.Element) => <RoundTitle>{title}</RoundTitle>;\n\n/* ------------------------- default seed component ------------------------- */\nexport const renderSeed = ({ seed, breakpoint }: IRenderSeedProps) => {\n  return (\n    <Seed mobileBreakpoint={breakpoint}>\n      <SeedItem>\n        <div>\n          <SeedTeam>{seed.teams?.[0]?.name || '-----------'}</SeedTeam>\n          <SeedTeam>{seed.teams?.[1]?.name || '-----------'}</SeedTeam>\n        </div>\n      </SeedItem>\n      <SeedTime mobileBreakpoint={breakpoint}>{seed?.date}</SeedTime>\n    </Seed>\n  );\n};\n","import React, { Fragment } from 'react';\nimport { Round, Bracket, SeedsList } from '../components/round';\nimport SwipeableViews from 'react-swipeable-views';\nimport useMedia from '../hooks/useMedia';\nimport { renderSeed, renderTitle } from '../utils/renders';\nimport { ISingleEliminationProps } from '../types/SingleElimination';\n\nconst SingleElimination = ({\n  rounds,\n  rtl = false,\n  roundClassName,\n  bracketClassName,\n  swipeableProps = {},\n  mobileBreakpoint = 992,\n  renderSeedComponent = renderSeed,\n  roundTitleComponent = renderTitle,\n}: ISingleEliminationProps) => {\n  // Checking responsive size\n  const isResponsive = useMedia(mobileBreakpoint);\n\n  const data = rounds.map((round, roundIdx) => (\n    <Round key={round.title} className={roundClassName} mobileBreakpoint={mobileBreakpoint}>\n      {round.title && roundTitleComponent(round.title, roundIdx)}\n      <SeedsList>\n        {round.seeds.map((seed, idx) => {\n          return (\n            <Fragment key={seed.id}>\n              {renderSeedComponent({\n                seed,\n                breakpoint: mobileBreakpoint,\n                roundIndex: roundIdx,\n                seedIndex: idx,\n                rounds,\n              })}\n            </Fragment>\n          );\n        })}\n      </SeedsList>\n    </Round>\n  ));\n\n  if (isResponsive) {\n    // Since SwipeableViewsProps have an issue that it uses ref inside of it, We need to remove ref from the object\n    const { ref, ...rest } = swipeableProps;\n    return (\n      <Bracket className={bracketClassName} dir={rtl ? 'rtl' : 'ltr'} mobileBreakpoint={mobileBreakpoint}>\n        <SwipeableViews style={{ minHeight: '500px' }} axis={rtl ? 'x-reverse' : 'x'} {...rest}>\n          {data}\n        </SwipeableViews>\n      </Bracket>\n    );\n  }\n  return (\n    <Bracket className={bracketClassName} dir={rtl ? 'rtl' : 'ltr'} mobileBreakpoint={mobileBreakpoint}>\n      {data}\n    </Bracket>\n  );\n};\n\nexport { SingleElimination };\n","import { useState, useEffect } from 'react';\n\nexport default function useMedia(breakPoint: number) {\n  // checking window object to support server side rendering.\n  const [isSmaller, setIsSmaller] = useState(typeof window !== 'undefined' ? window.innerWidth <= breakPoint : false);\n\n  useEffect(() => {\n    function screenResized() {\n      // To make sure that the state is only being updated when it has to be\n      if (isSmaller && window.innerWidth > breakPoint) {\n        setIsSmaller(false);\n      } else if (!isSmaller && window.innerWidth <= breakPoint) {\n        setIsSmaller(true);\n      }\n    }\n    if (typeof window !== 'undefined') window.addEventListener('resize', screenResized);\n\n    // to remove the event listener when this component is unmounted.\n    return () => {\n      if (typeof window !== 'undefined') window.removeEventListener('resize', screenResized);\n    };\n  }, [isSmaller]);\n\n  // the return value should be true or false\n  return isSmaller;\n}\n","import React, { useState, useEffect } from \"react\";\nimport db from \"../firebaseConfig\";\nimport { collection, getDocs } from \"firebase/firestore\";\nimport { Bracket } from \"react-brackets\";\n\nconst TournamentsSection = () => {\n  const [tournaments, setTournaments] = useState([]);\n  const [selectedTournament, setSelectedTournament] = useState(null);\n\n  useEffect(() => {\n    const fetchTournaments = async () => {\n      const querySnapshot = await getDocs(collection(db, \"tournaments\"));\n      const data = querySnapshot.docs.map((doc) => ({\n        id: doc.id,\n        ...doc.data(),\n      }));\n      setTournaments(data);\n    };\n\n    fetchTournaments();\n  }, []);\n\n  const handleMoreInfo = (tournament) => {\n    setSelectedTournament(tournament);\n  };\n\n  const handleCloseModal = () => {\n    setSelectedTournament(null);\n  };\n\n  return (\n    <section id=\"torneos\" className=\"tournaments\">\n      <div className=\"container\">\n        <h2>Torneos</h2>\n        <div className=\"tournament-cards\">\n          {tournaments.length === 0 && (\n            <p className=\"no-data-message\">\n              No hay torneos para mostrar en este momento.\n            </p>\n          )}\n          {tournaments.map((tournament) => (\n            <div key={tournament.id} className=\"tournament-card\">\n              <h3>{tournament.title}</h3>\n              <img\n                src={tournament.logo || \"/assets/logo.png\"}\n                alt={tournament.title}\n                className=\"news-image\"\n              />\n              <button onClick={() => handleMoreInfo(tournament)}>\n                Más Información\n              </button>\n            </div>\n          ))}\n        </div>\n        {selectedTournament && (\n          <div className=\"modal\">\n            <div className=\"modal-content tournament-modal\">\n              <button className=\"close-modal\" onClick={handleCloseModal}>\n                &times;\n              </button>\n              <h3>{selectedTournament.title}</h3>\n              <Bracket rounds={selectedTournament.rounds} />\n            </div>\n          </div>\n        )}\n      </div>\n    </section>\n  );\n};\n\nexport default TournamentsSection;\n","import React, { useState, useEffect } from \"react\";\nimport db from \"../firebaseConfig\";\nimport { collection, getDocs } from \"firebase/firestore\";\n\nconst NoticiasSection = () => {\n  const [news, setNews] = useState([]);\n  const [selectedNews, setSelectedNews] = useState(null);\n\n  useEffect(() => {\n    const fetchNews = async () => {\n      const querySnapshot = await getDocs(collection(db, \"news\"));\n      const data = querySnapshot.docs.map((doc) => ({\n        id: doc.id,\n        ...doc.data(),\n      }));\n      setNews(data);\n    };\n\n    fetchNews();\n  }, []);\n\n  const handleMoreInfo = (newsItem) => {\n    setSelectedNews(newsItem);\n  };\n\n  const handleCloseModal = () => {\n    setSelectedNews(null);\n  };\n\n  return (\n    <section id=\"noticias\" className=\"news\">\n      <div className=\"container\">\n        <h2>Noticias</h2>\n        <div className=\"news-cards\">\n          {news.length === 0 && (\n            <p className=\"no-data-message\">\n              No hay noticias para mostrar en este momento.\n            </p>\n          )}\n          {news.map((item) => (\n            <div key={item.id} className=\"news-card\">\n              <img\n                src={item.logo || \"/assets/logo.png\"}\n                alt={item.title}\n                className=\"news-image\"\n              />\n              <h3>{item.title}</h3>\n              <p>{item.description}</p>\n              <small>\n                {item.author} - {new Date(item.date).toLocaleDateString()}\n              </small>\n              <button onClick={() => handleMoreInfo(item)}>Leer Más</button>\n            </div>\n          ))}\n        </div>\n        {selectedNews && (\n          <div className=\"modal news-modal\">\n            <div className=\"modal-content\">\n              <button className=\"close-modal\" onClick={handleCloseModal}>\n                &times;\n              </button>\n              <h3>{selectedNews.title}</h3>\n              <small>\n                {selectedNews.author} -{\" \"}\n                {new Date(selectedNews.date).toLocaleDateString()}\n              </small>\n              <div className=\"media-wrapper\">\n                {selectedNews.logo.includes(\"youtube\") ? (\n                  <iframe\n                    src={selectedNews.media}\n                    title={selectedNews.title}\n                    frameBorder=\"0\"\n                    allowFullScreen\n                  ></iframe>\n                ) : (\n                  <img\n                    src={selectedNews.logo}\n                    alt={selectedNews.title}\n                    className=\"modal-image\"\n                  />\n                )}\n              </div>\n              <div\n                className=\"modal-content-body\"\n                dangerouslySetInnerHTML={{ __html: selectedNews.body }}\n              ></div>\n            </div>\n          </div>\n        )}\n      </div>\n    </section>\n  );\n};\n\nexport default NoticiasSection;\n","import React, { useState, useEffect } from \"react\";\nimport db from \"../firebaseConfig\";\nimport { collection, getDocs } from \"firebase/firestore\";\n\nconst AffiliatesSection = () => {\n  const [affiliates, setAffiliates] = useState([]);\n\n  useEffect(() => {\n    const fetchAffiliates = async () => {\n      const querySnapshot = await getDocs(collection(db, \"affiliates\"));\n      const dataList = querySnapshot.docs.map((doc) => ({\n        id: doc.id,\n        ...doc.data(),\n      }));\n      setAffiliates(dataList);\n    };\n\n    fetchAffiliates();\n  }, []);\n\n  return (\n    <section id=\"affiliates\" className=\"affiliates\">\n      <div className=\"container\">\n        <h2>Afiliados</h2>\n        <div className=\"affiliate-cards\">\n          {affiliates.length === 0 && (\n            <p className=\"no-data-message\">\n              No hay afiliados para mostrar en este momento.\n            </p>\n          )}\n          {affiliates.map((affiliate) => (\n            <div key={affiliate.id} className=\"affiliate-card\">\n              <img\n                src={affiliate.logo || \"/assets/logo.png\"}\n                alt={`${affiliate.name} Logo`}\n                className=\"affiliate-logo\"\n              />\n\n              <div className=\"social-links\">\n                {!affiliate.socialLink && <h3>{affiliate.name}</h3>}\n                {affiliate.socialLink && (\n                  <a\n                    href={affiliate.socialLink}\n                    target=\"_blank\"\n                    rel=\"noopener noreferrer\"\n                  >\n                    <h3>{affiliate.name}</h3>\n                  </a>\n                )}\n              </div>\n            </div>\n          ))}\n        </div>\n      </div>\n    </section>\n  );\n};\n\nexport default AffiliatesSection;\n","import React from \"react\";\n\nconst Footer = () => (\n  <footer className=\"site-footer\">\n    <div className=\"container\">\n      <p>&copy; 2025 Villanos eSports. Todos los derechos reservados.</p>\n    </div>\n  </footer>\n);\n\nexport default Footer;\n","import React from \"react\";\nimport Header from \"./components/Header.js\";\nimport HeroSection from \"./components/HeroSection.js\";\nimport AboutSection from \"./components/AboutSection.js\";\nimport TeamsSection from \"./components/TeamsSection.js\";\nimport ContactSection from \"./components/ContactSection.js\";\nimport PromoteAppSection from \"./components/PromoteAppSection\";\nimport TournamentsSection from \"./components/TournamentsSection\";\nimport NoticiasSection from \"./components/NoticiasSection\";\nimport AffiliatesSection from \"./components/AffiliatesSection.js\";\nimport Footer from \"./components/Footer.js\";\n\nimport \"./styles.css\";\n\nfunction HomePage() {\n  return (\n    <>\n      <Header />\n      <main>\n        <HeroSection />\n        <AboutSection />\n        <NoticiasSection />\n        <TournamentsSection />\n        <TeamsSection />\n        <AffiliatesSection />\n        <PromoteAppSection />\n        <ContactSection />\n      </main>\n      <Footer />\n    </>\n  );\n}\n\nexport default HomePage;\n","import React, { useEffect, useState } from \"react\";\nimport { getAuth, onAuthStateChanged } from \"firebase/auth\";\n\nconst ProtectedRoute = ({ children }) => {\n  const [user, setUser] = useState(null);\n  const auth = getAuth();\n\n  useEffect(() => {\n    const unsubscribe = onAuthStateChanged(auth, (user) => {\n      setUser(user);\n    });\n    return () => unsubscribe();\n  }, [auth]);\n\n  if (!user) {\n    return <p>Please log in to access this page.</p>;\n  }\n\n  return children;\n};\n\nexport default ProtectedRoute;\n","import React from \"react\";\nimport { BrowserRouter as Router, Route, Routes } from \"react-router-dom\";\nimport AdminDashboard from \"./adminDashboard\";\nimport HomePage from \"./HomePage\";\nimport ProtectedRoute from \"./components/ProtectedRoutes\";\n\nfunction App() {\n  return (\n    <Router>\n      <Routes>\n        <Route path=\"/\" element={<HomePage />} />\n        <Route\n          path=\"/vadmin\"\n          element={\n            <ProtectedRoute>\n              <AdminDashboard />\n            </ProtectedRoute>\n          }\n        />\n      </Routes>\n    </Router>\n  );\n}\n\nexport default App;\n","const reportWebVitals = onPerfEntry => {\n  if (onPerfEntry && onPerfEntry instanceof Function) {\n    import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n      getCLS(onPerfEntry);\n      getFID(onPerfEntry);\n      getFCP(onPerfEntry);\n      getLCP(onPerfEntry);\n      getTTFB(onPerfEntry);\n    });\n  }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport './index.css';\nimport App from './App';\nimport reportWebVitals from './reportWebVitals';\n\nconst root = ReactDOM.createRoot(document.getElementById('root'));\nroot.render(\n  <React.StrictMode>\n    <App />\n  </React.StrictMode>\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"names":["DIFF_DELETE","diff_main","text1","text2","cursor_pos","cleanup","_fix_unicode","editdiff","oldText","newText","oldRange","index","length","newRange","oldLength","newLength","oldCursor","oldBefore","slice","oldAfter","maybeNewCursor","newCursor","newBefore","newAfter","prefixLength","Math","min","oldPrefix","newPrefix","make_edit_splice","cursor","suffixLength","oldSuffix","newSuffix","find_cursor_edit_diff","commonlength","diff_commonPrefix","commonprefix","substring","diff_commonSuffix","commonsuffix","diffs","longtext","shorttext","i","indexOf","hm","diff_halfMatchI_","best_longtext_a","best_longtext_b","best_shorttext_a","best_shorttext_b","seed","floor","j","best_common","text1_a","text1_b","text2_a","text2_b","hm1","ceil","hm2","mid_common","diff_halfMatch_","diffs_a","diffs_b","concat","text1_length","text2_length","max_d","v_offset","v_length","v1","Array","v2","x","delta","front","k1start","k1end","k2start","k2end","d","k1","k1_offset","y1","x1","charAt","k2_offset","x2","diff_bisectSplit_","k2","y2","diff_bisect_","diff_compute_","unshift","push","diff_cleanupMerge","changes","equalities","equalitiesLength","lastequality","pointer","length_insertions1","length_deletions1","length_insertions2","length_deletions2","max","splice","diff_cleanupSemanticScore_","one","two","char1","char2","nonAlphaNumeric1","match","nonAlphaNumericRegex_","nonAlphaNumeric2","whitespace1","whitespaceRegex_","whitespace2","lineBreak1","linebreakRegex_","lineBreak2","blankLine1","blanklineEndRegex_","blankLine2","blanklineStartRegex_","equality1","edit","equality2","commonOffset","commonString","bestEquality1","bestEdit","bestEquality2","bestScore","score","diff_cleanupSemanticLossless","deletion","insertion","overlap_length1","diff_commonOverlap_","overlap_length2","diff_cleanupSemantic","y","text1a","text2a","text1b","text2b","diffsb","pointermin","pointermax","pointermid","pointerstart","is_surrogate_pair_start","charCodeAt","text_length","best","pattern","found","pointerend","is_surrogate_pair_end","fix_unicode","count_delete","count_insert","text_delete","text_insert","previous_equality","ends_with_pair_start","stray","k","starts_with_pair_end","n","pop","charCode","str","before","oldMiddle","newMiddle","after","tuples","ret","remove_empty_tuples","diff","INSERT","DELETE","EQUAL","module","exports","reactIs","require","REACT_STATICS","childContextTypes","contextType","contextTypes","defaultProps","displayName","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","type","KNOWN_STATICS","name","prototype","caller","callee","arguments","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","component","isMemo","ForwardRef","render","Memo","defineProperty","Object","getOwnPropertyNames","getOwnPropertySymbols","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","keys","targetStatics","sourceStatics","key","descriptor","e","b","Symbol","for","c","f","g","h","l","m","p","q","r","t","v","w","z","a","u","$$typeof","A","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Fragment","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isPortal","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","HASH_UNDEFINED","MAX_SAFE_INTEGER","argsTag","boolTag","dateTag","funcTag","genTag","mapTag","numberTag","objectTag","promiseTag","regexpTag","setTag","stringTag","symbolTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","reFlags","reIsHostCtor","reIsUint","cloneableTags","freeGlobal","global","freeSelf","self","root","Function","freeExports","nodeType","freeModule","moduleExports","addMapEntry","map","pair","set","addSetEntry","value","add","arrayReduce","array","iteratee","accumulator","initAccum","isHostObject","result","toString","mapToArray","size","forEach","overArg","func","transform","arg","setToArray","arrayProto","funcProto","objectProto","coreJsData","maskSrcKey","uid","exec","IE_PROTO","funcToString","hasOwnProperty","objectToString","reIsNative","RegExp","call","replace","Buffer","undefined","Uint8Array","getPrototype","objectCreate","create","propertyIsEnumerable","nativeGetSymbols","nativeIsBuffer","isBuffer","nativeKeys","DataView","getNative","Map","Promise","Set","WeakMap","nativeCreate","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","valueOf","Hash","entries","this","clear","entry","ListCache","MapCache","Stack","__data__","arrayLikeKeys","inherited","isArray","isObjectLike","isArrayLike","isArrayLikeObject","isArguments","baseTimes","String","skipIndexes","isIndex","assignValue","object","objValue","eq","assocIndexOf","baseClone","isDeep","isFull","customizer","stack","isObject","isArr","constructor","input","initCloneArray","source","copyArray","tag","getTag","isFunc","buffer","copy","cloneBuffer","isPrototype","proto","initCloneObject","copyObject","getSymbols","copySymbols","baseAssign","cloneFunc","Ctor","cloneArrayBuffer","dataView","byteOffset","byteLength","cloneDataView","typedArray","cloneTypedArray","cloneMap","regexp","lastIndex","cloneRegExp","cloneSet","symbol","initCloneByTag","stacked","get","props","keysFunc","symbolsFunc","values","offset","arrayPush","baseGetAllKeys","getAllKeys","arrayEach","subValue","baseIsNative","isFunction","test","arrayBuffer","newValue","getMapData","data","isKeyable","getValue","has","cache","pairs","LARGE_ARRAY_SIZE","other","ArrayBuffer","resolve","ctorString","isLength","baseKeys","arrayTag","errorTag","typedArrayTags","freeProcess","process","nodeUtil","binding","nodeIsTypedArray","isTypedArray","arraySome","predicate","nativeObjectToString","symToStringTag","toStringTag","SetCache","isArg","isBuff","isType","baseGetTag","isOwn","unmasked","getRawTag","baseIsArguments","baseIsEqual","bitmask","equalFunc","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","message","convert","isPartial","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","objLength","othProps","othLength","skipCtor","othValue","compared","objCtor","othCtor","equalObjects","baseIsEqualDeep","isMasked","arrLength","seen","arrValue","othIndex","resIndex","arrayFilter","baseUnary","hashClear","hashDelete","hashGet","hashHas","hashSet","listCacheClear","listCacheDelete","listCacheGet","listCacheHas","listCacheSet","mapCacheClear","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","setCacheAdd","setCacheHas","stackClear","stackDelete","stackGet","stackHas","stackSet","cacheHas","arrStacked","othStacked","objStacked","stubArray","types","stubFalse","baseIsTypedArray","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","propName","componentName","location","propFullName","secret","err","Error","getShim","isRequired","ReactPropTypes","bigint","bool","number","string","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","cloneDeep","isEqual","AttributeMap","compose","keepNull","attributes","reduce","attrs","invert","attr","base","baseInverted","memo","AttributeMap_1","default","Op_1","OpIterator_1","NULL_CHARACTER","fromCharCode","getEmbedTypeAndData","embedType","Delta","ops","registerEmbed","handler","handlers","unregisterEmbed","getHandler","insert","newOp","delete","retain","lastOp","chop","filter","partition","passed","failed","op","initialValue","changeLength","elem","start","end","Infinity","iter","hasNext","nextOp","next","thisIter","otherIter","firstOther","peek","firstLeft","peekType","peekLength","thisOp","otherOp","action","thisData","otherData","rest","strings","join","retDelta","diffResult","opLength","eachLine","newline","line","inverted","baseIndex","baseOp","opData","baseOpData","priority","transformPosition","transformedData","nextType","Op","OpIterator","retOp","substr","Scheduler","React","ReactDOM","formatProdErrorMessage","code","url","encodeURIComponent","isValidContainer","REACT_LEGACY_ELEMENT_TYPE","REACT_ELEMENT_TYPE","REACT_PORTAL_TYPE","REACT_FRAGMENT_TYPE","REACT_STRICT_MODE_TYPE","REACT_PROFILER_TYPE","REACT_PROVIDER_TYPE","REACT_CONSUMER_TYPE","REACT_CONTEXT_TYPE","REACT_FORWARD_REF_TYPE","REACT_SUSPENSE_TYPE","REACT_SUSPENSE_LIST_TYPE","REACT_MEMO_TYPE","REACT_LAZY_TYPE","REACT_OFFSCREEN_TYPE","REACT_MEMO_CACHE_SENTINEL","MAYBE_ITERATOR_SYMBOL","iterator","getIteratorFn","maybeIterable","REACT_CLIENT_REFERENCE","getComponentNameFromType","_context","innerType","_payload","_init","prefix","suffix","ReactSharedInternals","__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","assign","describeBuiltInComponentFrame","trim","reentry","describeNativeComponentFrame","fn","construct","previousPrepareStackTrace","prepareStackTrace","RunInRootFrame","DetermineComponentFrameRoot","Fake","Reflect","control","x$0","x$1","catch","sample","namePropDescriptor","configurable","_RunInRootFrame$Deter","sampleStack","controlStack","sampleLines","split","controlLines","includes","frame","describeFiber","fiber","getStackByFiberInDevAndProd","workInProgress","info","return","getNearestMountedFiber","nearestMounted","alternate","flags","getSuspenseInstanceFromFiber","suspenseState","memoizedState","dehydrated","assertIsMounted","findCurrentHostFiberImpl","child","sibling","isArrayImpl","ReactDOMSharedInternals","__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","sharedNotPendingObject","pending","method","valueStack","createCursor","defaultValue","current","contextStackCursor","contextFiberStackCursor","rootInstanceStackCursor","hostTransitionProviderCursor","pushHostContainer","nextRootInstance","documentElement","namespaceURI","getOwnHostContext","parentNode","tagName","getChildHostContextProd","popHostContainer","pushHostContext","context","JSCompiler_inline_result","popHostContext","HostTransitionContext","_currentValue","scheduleCallback$3","unstable_scheduleCallback","cancelCallback$1","unstable_cancelCallback","shouldYield","unstable_shouldYield","requestPaint","unstable_requestPaint","now","unstable_now","getCurrentPriorityLevel","unstable_getCurrentPriorityLevel","ImmediatePriority","unstable_ImmediatePriority","UserBlockingPriority","unstable_UserBlockingPriority","NormalPriority$1","unstable_NormalPriority","LowPriority","unstable_LowPriority","IdlePriority","unstable_IdlePriority","log$1","log","unstable_setDisableYieldValue","rendererID","injectedHook","setIsStrictModeForDevtools","newIsStrictMode","setStrictMode","clz32","LN2","nextTransitionLane","nextRetryLane","getHighestPriorityLanes","lanes","pendingSyncLanes","getNextLanes","wipLanes","pendingLanes","nextLanes","suspendedLanes","pingedLanes","warmLanes","finishedLanes","nonIdlePendingLanes","checkIfRootIsPrerendering","renderLanes","computeExpirationTime","lane","currentTime","claimNextTransitionLane","claimNextRetryLane","createLaneMap","initial","laneMap","markRootUpdated$1","updateLane","markSpawnedDeferredLane","spawnedLane","entangledLanes","spawnedLaneIndex","entanglements","markRootEntangled","rootEntangledLanes","index$8","lanesToEventPriority","resolveUpdatePriority","updatePriority","window","event","getEventPriority","randomKey","random","internalInstanceKey","internalPropsKey","internalContainerInstanceKey","internalEventHandlersKey","internalEventHandlerListenersKey","internalEventHandlesSetKey","internalRootNodeResourcesKey","internalHoistableMarker","detachDeletedInstance","getClosestInstanceFromNode","targetNode","targetInst","getParentSuspenseInstance","getInstanceFromNode","getNodeFromInstance","inst","stateNode","getResourcesFromRoot","resources","hoistableStyles","hoistableScripts","markNodeAsHoistable","allNativeEvents","registrationNameDependencies","registerTwoPhaseEvent","registrationName","dependencies","registerDirectEvent","canUseDOM","document","createElement","VALID_ATTRIBUTE_NAME_REGEX","illegalAttributeNameCache","validatedAttributeNameCache","setValueForAttribute","attributeName","removeAttribute","prefix$10","toLowerCase","setAttribute","setValueForKnownAttribute","setValueForNamespacedAttribute","namespace","setAttributeNS","getToStringValue","isCheckable","nodeName","track","_valueTracker","valueField","currentValue","enumerable","setValue","stopTracking","trackValueOnNode","updateValueIfChanged","tracker","lastValue","checked","getActiveElement","doc","activeElement","body","escapeSelectorAttributeValueInsideDoubleQuotesRegex","escapeSelectorAttributeValueInsideDoubleQuotes","ch","updateInput","lastDefaultValue","defaultChecked","setDefaultValue","initInput","isHydrating","ownerDocument","updateOptions","multiple","propValue","setDefaultSelected","options","selected","defaultSelected","disabled","updateTextarea","initTextarea","children","textContent","setTextContent","text","firstChild","lastChild","nodeValue","unitlessNumbers","setValueForStyle","style","styleName","isCustomProperty","setProperty","cssFloat","setValueForStyles","styles","prevStyles","styleName$16","styleName$17","isCustomElement","aliases","isJavaScriptProtocol","sanitizeURL","currentReplayingEvent","getEventTarget","nativeEvent","target","srcElement","correspondingUseElement","restoreTarget","restoreQueue","restoreStateOfTarget","internalInstance","querySelectorAll","otherNode","form","otherProps","isInsideEventHandler","batchedUpdates$1","flushSyncWork$1","getListener","passiveBrowserEventsSupported","addEventListener","removeEventListener","startText","fallbackText","getData","startValue","startLength","endValue","endLength","minEnd","getEventCharCode","keyCode","functionThatReturnsTrue","functionThatReturnsFalse","createSyntheticEvent","Interface","SyntheticBaseEvent","reactName","reactEventType","nativeEventTarget","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","stopPropagation","cancelBubble","persist","isPersistent","lastMovementX","lastMovementY","lastMouseEvent","EventInterface","eventPhase","bubbles","cancelable","timeStamp","Date","isTrusted","SyntheticEvent","UIEventInterface","view","detail","SyntheticUIEvent","MouseEventInterface","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","getEventModifierState","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","SyntheticMouseEvent","SyntheticDragEvent","dataTransfer","SyntheticFocusEvent","SyntheticAnimationEvent","animationName","elapsedTime","pseudoElement","SyntheticClipboardEvent","clipboardData","SyntheticCompositionEvent","normalizeKey","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","translateToKey","modifierKeyToProp","Alt","Control","Meta","Shift","modifierStateGetter","keyArg","SyntheticKeyboardEvent","repeat","locale","which","SyntheticPointerEvent","pointerId","width","height","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","SyntheticTouchEvent","touches","targetTouches","changedTouches","SyntheticTransitionEvent","propertyName","SyntheticWheelEvent","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","SyntheticToggleEvent","newState","oldState","END_KEYCODES","canUseCompositionEvent","documentMode","canUseTextInputEvent","useFallbackCompositionData","SPACEBAR_CHAR","hasSpaceKeypress","isFallbackCompositionEnd","domEventName","getDataFromCustomEvent","isComposing","supportedInputTypes","color","date","datetime","email","month","password","range","search","tel","time","week","isTextInputElement","createAndAccumulateChangeEvent","dispatchQueue","accumulateTwoPhaseListeners","listeners","activeElement$1","activeElementInst$1","runEventInBatch","processDispatchQueue","getInstIfValueChanged","getTargetInstForChangeEvent","isInputEventSupported","JSCompiler_inline_result$jscomp$283","isSupported$jscomp$inline_418","element$jscomp$inline_419","oninput","stopWatchingForValueChange","detachEvent","handlePropertyChange","handleEventsForInputEventPolyfill","attachEvent","getTargetInstForInputEventPolyfill","getTargetInstForClickEvent","getTargetInstForInputOrChangeEvent","objectIs","is","shallowEqual","objA","objB","keysA","keysB","currentKey","getLeafNode","getNodeForCharacterOffset","nodeEnd","nextSibling","containsNode","outerNode","innerNode","contains","compareDocumentPosition","getActiveElementDeep","containerInfo","defaultView","HTMLIFrameElement","contentWindow","href","hasSelectionCapabilities","contentEditable","restoreSelection","priorSelectionInformation","curFocusedElem","focusedElem","priorSelectionRange","selectionRange","selectionStart","selectionEnd","getSelection","extend","endMarker","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","left","scrollLeft","top","scrollTop","focus","skipSelectionChangeEvent","activeElementInst","lastSelection","mouseDown","constructSelectEvent","makePrefixMap","styleProp","eventName","prefixes","vendorPrefixes","animationend","animationiteration","animationstart","transitionrun","transitionstart","transitioncancel","transitionend","prefixedEventNames","getVendorPrefixedEventName","prefixMap","animation","transition","ANIMATION_END","ANIMATION_ITERATION","ANIMATION_START","TRANSITION_RUN","TRANSITION_START","TRANSITION_CANCEL","TRANSITION_END","topLevelEventsToReactNames","simpleEventPluginEvents","registerSimpleEvent","concurrentQueues","concurrentQueuesIndex","concurrentlyUpdatedLanes","finishQueueingConcurrentUpdates","endIndex","queue","update","markUpdateLaneFromFiberToRoot","enqueueUpdate$1","enqueueConcurrentHookUpdate","getRootForUpdatedFiber","enqueueConcurrentRenderForLane","sourceFiber","isHidden","parent","childLanes","_visibility","hiddenUpdates","nestedUpdateCount","rootWithNestedUpdates","emptyContextObject","CapturedStacks","createCapturedValueAtFiber","existing","forkStack","forkStackIndex","treeForkProvider","treeForkCount","idStack","idStackIndex","treeContextProvider","treeContextId","treeContextOverflow","pushTreeFork","totalChildren","pushTreeId","baseIdWithLeadingBit","baseLength","numberOfOverflowBits","pushMaterializedTreeId","popTreeContext","hydrationParentFiber","nextHydratableInstance","hydrationErrors","rootOrSingletonContext","HydrationMismatchException","throwOnHydrationMismatch","queueHydrationError","prepareToHydrateHostInstance","instance","memoizedProps","listenToNonDelegatedEvent","mediaEventTypes","suppressHydrationWarning","checkForUnmatchedText","popover","onScroll","onScrollEnd","onClick","onclick","noop$1","popToNextHostParent","popHydrationState","JSCompiler_temp","shouldClear","shouldSetTextContent","getNextHydratable","resetHydrationState","error","SuspenseException","SuspenseyCommitException","noopSuspenseyCommitThenable","then","isThenableResolved","thenable","status","noop$3","trackUsedThenable","thenableState","reason","workInProgressRoot","shellSuspendCounter","fulfilledValue","fulfilledThenable","rejectedThenable","suspendedThenable","getSuspendedThenable","thenableState$1","thenableIndexCounter$1","unwrapThenable","coerceRef","ref","throwOnInvalidObjectType","returnFiber","newChild","resolveLazy","lazyType","init","createChildReconciler","shouldTrackSideEffects","deleteChild","childToDelete","deletions","deleteRemainingChildren","currentFirstChild","mapRemainingChildren","existingChildren","useFiber","pendingProps","createWorkInProgress","placeChild","newFiber","lastPlacedIndex","newIndex","placeSingleChild","updateTextNode","createFiberFromText","mode","updateElement","updateFragment","createFiberFromTypeAndProps","updatePortal","portal","implementation","createFiberFromPortal","fragment","createFiberFromFragment","createChild","readContextDuringReconciliation","updateSlot","oldFiber","updateFromMap","newIdx","reconcileChildFibersImpl","newChildren","resultingFirstChild","previousNewFiber","nextOldFiber","reconcileChildrenArray","step","done","reconcileChildrenIterator","firstChildFiber","createFiberImplClass","reconcileChildFibers","mountChildFibers","currentTreeHiddenStackCursor","prevEntangledRenderLanesCursor","pushHiddenContext","entangledRenderLanes","baseLanes","reuseHiddenContextOnStack","popHiddenContext","suspenseHandlerStackCursor","shellBoundary","pushPrimaryTreeSuspenseHandler","suspenseStackCursor","pushOffscreenSuspenseHandler","reuseSuspenseHandlerOnStack","popSuspenseHandler","findFirstSuspended","row","state","revealOrder","AbortControllerLocal","AbortController","signal","aborted","listener","abort","scheduleCallback$2","NormalPriority","CacheContext","Consumer","Provider","_currentValue2","_threadCount","createCache","controller","refCount","releaseCache","currentEntangledListeners","currentEntangledPendingCount","currentEntangledLane","currentEntangledActionThenable","pingEngtangledActionScope","prevOnStartTransitionFinish","S","entangledListeners","requestTransitionLane","entangleAsyncAction","resumedCache","peekCacheFromPool","cacheResumedFromPreviousRender","pooledCache","pushTransition","offscreenWorkInProgress","prevCachePool","pool","getSuspendedCache","cacheFromPool","currentlyRenderingFiber$1","currentHook","workInProgressHook","didScheduleRenderPhaseUpdate","didScheduleRenderPhaseUpdateDuringThisPass","shouldDoubleInvokeUserFnsInHooksDEV","localIdCounter","thenableIndexCounter","globalClientIdCounter","throwInvalidHookError","areHookInputsEqual","nextDeps","prevDeps","renderWithHooks","Component","secondArg","nextRenderLanes","updateQueue","H","HooksDispatcherOnMount","HooksDispatcherOnUpdate","renderWithHooksAgain","finishRenderingHooks","ContextOnlyDispatcher","didRenderTooFewHooks","didReceiveUpdate","checkIfContextChanged","numberOfReRenders","lastEffect","events","stores","memoCache","HooksDispatcherOnRerender","TransitionAwareHostComponent","dispatcher","maybeThenable","useState","useThenable","checkDidRenderIdHook","didRenderIdHook","bailoutHooks","resetHooksOnUnwind","mountWorkInProgressHook","hook","baseState","baseQueue","updateWorkInProgressHook","nextCurrentHook","nextWorkInProgressHook","use","usable","readContext","useMemoCache","basicStateReducer","updateReducer","reducer","updateReducerImpl","lastRenderedReducer","pendingQueue","baseFirst","newBaseQueueFirst","newBaseQueueLast","didReadFromEntangledAsyncAction$54","workInProgressRootRenderLanes","revertLane","hasEagerState","eagerState","workInProgressRootSkippedLanes","lastRenderedState","dispatch","rerenderReducer","lastRenderPhaseUpdate","updateSyncExternalStore","subscribe","getSnapshot","getServerSnapshot","isHydrating$jscomp$0","snapshotChanged","updateEffect","subscribeToStore","bind","pushEffect","updateStoreInstance","destroy","pushStoreConsistencyCheck","renderedSnapshot","nextSnapshot","checkIfSnapshotChanged","forceStoreRerender","latestGetSnapshot","nextValue","scheduleUpdateOnFiber","mountStateImpl","initialState","initialStateInitializer","updateOptimisticImpl","passthrough","dispatchActionState","actionQueue","setPendingState","setState","payload","isRenderPhaseUpdate","actionNode","isTransition","T","runActionStateAction","prevState","prevTransition","currentTransition","onStartTransitionFinish","handleActionReturnValue","onActionError","error$60","nextState","onActionSuccess","notifyActionListeners","last","actionStateReducer","mountActionState","initialStateProp","ssrFormState","formState","JSCompiler_inline_result$jscomp$0","inRootOrSingleton","dispatchSetState","dispatchOptimisticSetState","updateActionState","updateActionStateImpl","stateHook","currentStateHook","actionQueueHook","actionStateActionEffect","rerenderActionState","deps","updateRef","mountEffectImpl","fiberFlags","hookFlags","updateEffectImpl","mountEffect","updateInsertionEffect","updateLayoutEffect","imperativeHandleEffect","refCleanup","updateImperativeHandle","mountDebugValue","updateCallback","callback","updateMemo","nextCreate","mountDeferredValueImpl","requestDeferredLane","updateDeferredValueImpl","prevValue","startTransition","pendingState","finishedState","previousPriority","dispatchSetStateInternal","thenableWithOverride","chainThenableValue","requestUpdateLane","noop$2","startHostTransition","formFiber","formData","ensureFormComponentIsStateful","requestFormReset$1","existingStateHook","initialResetState","useHostTransitionStatus","updateId","updateRefresh","refreshCache","provider","root$63","enqueueUpdate","createUpdate","entangleTransitions","dispatchReducerAction","enqueueRenderPhaseUpdate","entangleTransitionUpdate","currentState","throwIfDuringRender","queueLanes","useCallback","useContext","useEffect","useImperativeHandle","useLayoutEffect","useInsertionEffect","useMemo","useReducer","useRef","useDebugValue","useDeferredValue","useTransition","useSyncExternalStore","useId","useCacheRefresh","useFormState","useActionState","useOptimistic","initialArg","identifierPrefix","booleanOrThenable","applyDerivedStateFromProps","ctor","nextProps","classComponentUpdater","isMounted","_reactInternals","enqueueSetState","enqueueReplaceState","enqueueForceUpdate","checkShouldComponentUpdate","oldProps","newProps","nextContext","shouldComponentUpdate","isPureReactComponent","callComponentWillReceiveProps","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","resolveClassComponentProps","baseProps","propName$67","reportGlobalError","reportError","ErrorEvent","dispatchEvent","emit","console","defaultOnUncaughtError","defaultOnCaughtError","defaultOnRecoverableError","logUncaughtError","errorInfo","onUncaughtError","componentStack","e$68","setTimeout","logCaughtError","boundary","onCaughtError","errorBoundary","e$69","createRootErrorUpdate","createClassErrorUpdate","initializeClassErrorUpdate","componentDidCatch","legacyErrorBoundariesThatAlreadyFailed","SelectiveHydrationException","reconcileChildren","nextChildren","updateForwardRef","propsWithoutRef","prepareToReadContext","bailoutOnAlreadyFinishedWork","updateMemoComponent","shouldConstruct","updateSimpleMemoComponent","checkScheduledUpdateOrContext","prevProps","updateFunctionComponent","updateOffscreenComponent","nextIsDetached","_pendingVisibility","markRef","deferHiddenOffscreenComponent","cachePool","nextBaseLanes","propagateParentContextChanges","replayFunctionComponent","updateClassComponent","updater","refs","initializeUpdateQueue","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","processUpdateQueue","suspendIfUpdateReadFromEntangledAsyncAction","componentDidMount","unresolvedOldProps","oldContext","contextType$jscomp$0","hasForceUpdate","cloneUpdateQueue","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","mountHostRootWithoutHydrating","SUSPENDED_MARKER","treeContext","retryLane","mountSuspenseOffscreenState","getRemainingWorkInPrimaryTree","primaryTreeDidDefer","workInProgressDeferredLane","updateSuspenseComponent","showFallback","didSuspend","JSCompiler_temp$jscomp$0","nextInstance","id","overflow","fallback","mountWorkInProgressOffscreenFiber","mountSuspensePrimaryChildren","retrySuspenseComponentWithoutHydrating","dataset","digest","dgst","renderDidSuspendDelayIfPossible","retryDehydratedSuspenseBoundary","_reactRetry","subtreeFlags","primaryChildren","offscreenProps","createFiberFromOffscreen","scheduleSuspenseWorkOnFiber","propagationRoot","scheduleContextWorkOnParentPath","initSuspenseListRenderState","isBackwards","tail","lastContentRow","tailMode","renderState","rendering","renderingStartTime","updateSuspenseListComponent","beginWork","pushProvider","didSuspendBefore","attemptEarlyBailoutIfNoScheduledUpdate","lazyComponent","propagateContextChanges","isDehydrated","getResource","getOwnerDocumentFromRootContainer","setInitialProperties","resolveSingletonInstance","anyProps","hasAttribute","getAttribute","rel","crossOrigin","title","src","canHydrateInstance","canHydrateTextInstance","pooledCacheLanes","valueCursor","currentlyRenderingFiber","lastContextDependency","providerFiber","popProvider","contexts","forcePropagateEntireTree","list","nextFiber","firstContext","dependency","isInsidePropagationBailout","currentParent","currentDependencies","memoizedValue","readContextForConsumer","consumer","firstBaseUpdate","lastBaseUpdate","shared","hiddenCallbacks","callbacks","executionContext","enqueueCapturedUpdate","capturedUpdate","newFirst","newLast","clone","didReadFromEntangledAsyncAction","workInProgress$jscomp$0","instance$jscomp$0","lastPendingUpdate","firstPendingUpdate","isHiddenUpdate","callCallback","commitCallbacks","commitHookEffectListMount","finishedWork","firstEffect","captureCommitPhaseError","commitHookEffectListUnmount","nearestMountedAncestor$jscomp$0","nearestMountedAncestor","commitClassCallbacks","safelyCallComponentWillUnmount","componentWillUnmount","safelyAttachRef","instanceToUse","safelyDetachRef","error$112","commitHostMount","autoFocus","srcSet","srcset","commitHostUpdate","domElement","lastProps","propKey","lastProp","setProp","propKey$203","propKey$219","propKey$224","propKey$229","setPropOnCustomElement","propKey$234","updateProperties","isHostParent","getHostSibling","insertOrAppendPlacementNodeIntoContainer","insertBefore","appendChild","_reactRootContainer","insertOrAppendPlacementNode","offscreenSubtreeIsHidden","offscreenSubtreeWasHidden","needsFormReset","PossiblyWeakSet","WeakSet","nextEffect","shouldFireAfterActiveInstanceBlur","commitLayoutEffectOnFiber","finishedRoot","recursivelyTraverseLayoutEffects","__reactInternalSnapshotBeforeUpdate","error$111","commitSuspenseHydrationCallbacks","prevOffscreenSubtreeIsHidden","prevOffscreenSubtreeWasHidden","recursivelyTraverseReappearLayoutEffects","detachFiberAfterEffects","hostParent","hostParentIsContainer","recursivelyTraverseDeletionEffects","commitDeletionEffectsOnFiber","deletedFiber","onCommitFiberUnmount","count","removeChild","prevHostParent","prevHostParentIsContainer","removeAttributeNode","prevHostParentIsContainer$119","clearSuspenseBoundary","retryIfBlockedOn","attachSuspenseRetryListeners","wakeables","retryCache","_retryCache","getRetryCache","wakeable","retry","resolveRetryWakeable","recursivelyTraverseMutationEffects","root$jscomp$0","parentFiber","commitMutationEffectsOnFiber","currentHoistableRoot","commitReconciliationEffects","hoistableRoot","currentResource","getElementsByTagName","head","querySelector","maybeNodes","getHydratableHoistableCache","content","property","httpEquiv","charSet","mountHoistable","acquireResource","nextNode","tagCaches","getHoistableRoot","recursivelyResetForms","globalMostRecentFallbackTime","_current","recursivelyTraverseDisappearLayoutEffects","display","retryQueue","parent$jscomp$0","parent$113","parent$115","reset","finishedRoot$jscomp$0","includeWorkInProgressEffects","commitOffscreenPassiveMountEffects","previousCache","commitCachePassiveMountEffect","recursivelyTraversePassiveMountEffects","committedLanes","committedTransitions","commitPassiveMountOnFiber","_finishedWork$memoize2","onPostCommit","passiveEffectDuration","recursivelyTraverseAtomicPassiveEffects","recursivelyTraverseReconnectPassiveEffects","committedLanes$jscomp$0","committedTransitions$jscomp$0","suspenseyCommitFlag","recursivelyAccumulateSuspenseyCommit","accumulateSuspenseyCommitOnFiber","resource","suspendedState","media","matchMedia","matches","loading","getStyleKey","getStylesheetSelectorFromKey","_p","onUnsuspend","stylesheetPropsFromRawProps","preloadPropsMap","adoptPreloadPropsForStylesheet","linkInstance","reject","onload","onerror","stylesheets","preload","suspendResource","previousHoistableRoot","detachAlternateSiblings","previousFiber","recursivelyTraversePassiveUnmountEffects","commitPassiveUnmountEffectsInsideOfDeletedTree_begin","commitPassiveUnmountOnFiber","recursivelyTraverseDisconnectPassiveEffects","deletedSubtreeRoot","FiberNode","isReactComponent","resetWorkInProgress","owner","fiberTag","hostContext","itemProp","precedence","onLoad","onError","async","isHostHoistableType","elements","primaryChildInstance","_pendingMarkers","_transitions","detach","attach","pendingChildren","markUpdate","preloadResourceAndSuspendIfNeeded","preloadResource","scheduleRetryEffect","workInProgressSuspendedRetryLanes","cutOffTailIfNeeded","hasRenderedATailFallback","lastTailNode","lastTailNode$131","bubbleProperties","completedWork","didBailout","newChildLanes","child$132","completeWork","pendingContext","queueRecoverableErrors","createElementNS","innerHTML","createTextNode","cache$144","listenToAllSupportedEvents","workInProgressRootExitStatus","workInProgressRootRenderTargetTime","unwindWork","unwindInterruptedWork","interruptedWork","DefaultAsyncDispatcher","getCacheForType","resourceType","cacheForType","PossiblyWeakMap","workInProgressSuspendedReason","workInProgressThrownValue","workInProgressRootDidSkipSuspendedSiblings","workInProgressRootIsPrerendering","workInProgressRootDidAttachPingListener","workInProgressRootInterleavedUpdatedLanes","workInProgressRootPingedLanes","workInProgressRootConcurrentErrors","workInProgressRootRecoverableErrors","workInProgressRootDidIncludeRecursiveRenderUpdate","workInProgressTransitions","rootDoesHavePassiveEffects","rootWithPendingPassiveEffects","pendingPassiveEffectsLanes","pendingPassiveEffectsRemainingLanes","pendingPassiveTransitions","suspenseHandler","cancelPendingCommit","prepareFreshStack","markRootSuspended","ensureRootIsScheduled","performWorkOnRoot","forceSync","shouldTimeSlice","expiredLanes","exitStatus","prevExecutionContext","prevDispatcher","pushDispatcher","prevAsyncDispatcher","pushAsyncDispatcher","thrownValue","throwAndUnwindWorkLoop","replaySuspendedUnitOfWork","hostFiber","completeUnitOfWork","resetWorkInProgressStack","workLoopConcurrent","thrownValue$166","handleThrow","renderRootConcurrent","renderRootSync","renderWasConcurrent","isRenderConsistentWithExternalStores","errorRecoveryDisabledLanes","wasRootDehydrated","timeoutHandle","scheduleTimeout","commitRootWhenReady","errors","apply","recoverableErrors","transitions","didIncludeRenderPhaseUpdate","updatedLanes","suspendedRetryLanes","didSkipSuspendedSiblings","suspendedCommitReason","completedRenderStartTime","completedRenderEndTime","unsuspend","noop","insertSuspendedStylesheets","commit","stylesheetTimer","clearTimeout","waitForCommitToBeReady","commitRoot","check","didAttemptEntireTree","expirationTimes","index$6","flushSyncWorkAcrossRoots_impl","cancelTimeout","allEntangledLanes","index$4","shouldYieldForPrerendering","unitOfWork","workLoopSync","thrownValue$164","performUnitOfWork","suspendedReason","rootRenderLanes","attachPingListener","markerInstances","cause","wrapperError","throwException","unwindUnitOfWork","skipSiblings","previousUpdateLanePriority","renderPriorityLevel","flushPassiveEffects","callbackNode","callbackPriority","remainingLanes","previouslyPendingLanes","index$7","hiddenUpdatesForLane","markRootFinished","priorityLevel","scheduleCallback$1","eventsEnabled","_enabled","selection","e$20","indexWithinAnchor","indexWithinFocus","selectionInformation","resolvedPrevProps","clearContainerSparingly","commitBeforeMutationEffects","releaseRootPooledCache","onCommitFiberRoot","onCommitRoot","onRecoverableError","commitRootImpl","root$170","renderPriority","onPostCommitFiberRoot","captureCommitPhaseErrorOnRoot","rootFiber","pingCache","threadIDs","pingSuspendedRoot","retryTimedOutBoundary","boundaryFiber","firstScheduledRoot","lastScheduledRoot","didScheduleMicrotask","mightHavePendingSyncWork","isFlushingWork","currentEventTransitionLane","cb","processRootScheduleInMicrotask","scheduleMicrotask","syncTransitionLanes","onlyLegacy","didPerformSomeWork","root$172","performSyncWorkOnRoot","currentPopstateTransitionEvent","shouldAttemptEagerTransition","prev","scheduleTaskForRootDuringMicrotask","index$5","expirationTime","performWorkOnRootViaSchedulerTask","didTimeout","originalCallbackNode","workInProgressRootRenderLanes$jscomp$0","coerceFormActionProp","actionProp","createFormDataWithSubmitter","submitter","temp","FormData","i$jscomp$inline_1439","eventName$jscomp$inline_1440","toUpperCase","nonDelegatedEvents","eventSystemFlags","_dispatchQueue$i","previousInstance","i$jscomp$0","_dispatchListeners$i","targetElement","listenerSetKey","addTrappedEventListener","listenToNativeEvent","isCapturePhaseListener","listeningMarker","rootContainerElement","targetContainer","listenerWrapper","dispatchDiscreteEvent","dispatchContinuousEvent","capture","passive","dispatchEventForPluginEventSystem","targetInst$jscomp$0","ancestorInst","nodeTag","container","grandTag","SyntheticEventCtor","inCapturePhase","accumulateTargetOnly","reactEventName","lastHostComponent","_instance","createDispatchListener","parentWindow","getParent","accumulateEnterLeaveListenersForEvent","getTargetInstFunc","handleEventFunc","fallbackData","eventType","getNativeBeforeInputChars","char","getFallbackBeforeInputChars","maybeTargetInst","formAction","extractEvents$1","targetFiber","captureName","_instance2","common","_instance3","NORMALIZE_NEWLINES_REGEX","NORMALIZE_NULL_AND_REPLACEMENT_REGEX","normalizeMarkupForTextOrAttribute","markup","serverText","clientText","formEncType","formMethod","formTarget","encType","__html","muted","isNaN","endsWith","hasSrc","hasSrcSet","propValue$186","parentNamespace","dangerouslySetInnerHTML","localPromise","queueMicrotask","handleErrorInNextTick","parentInstance","suspenseInstance","depth","targetInstance","previousSibling","rootContainerInstance","preconnectsSet","getRootNode","previousDispatcher","previousWasRendering","wasRendering","formInst","D","preconnectAs","C","L","as","globalDocument","preloadSelector","imageSrcSet","imageSizes","getScriptKey","getScriptSelectorFromKey","X","scripts","adoptPreloadPropsForScript","link","insertStylesheet","M","limitedEscapedHref","currentProps","preloadProps","styles$242","resource$243","integrity","hrefLang","referrerPolicy","rawProps","styleProps","instance$248","nodes","prior","stylesheetProps","scriptProps","keyAttribute","caches","nodeKey","precedencesByRoot","insertStylesheetIntoRoot","precedences","FiberRootNode","hydrate","incompleteTransitions","createFiberRoot","initialChildren","hydrationCallbacks","transitionCallbacks","getContextForSubtree","parentComponent","updateContainerImpl","markRetryLaneImpl","markRetryLaneIfNotHydrated","attemptContinuousHydration","blockedOn","findInstanceBlockingEvent","return_targetInst","clearIfContinuousEvent","queuedFocus","accumulateOrCreateContinuousQueuedReplayableEvent","queuedDrag","queuedMouse","queuedPointers","queuedPointerCaptures","queueIfContinuousEvent","discreteReplayableEvents","findInstanceBlockingTarget","hasScheduledReplayAttempt","queuedExplicitHydrationTargets","existingQueuedEvent","targetContainers","attemptExplicitHydrationTarget","queuedTarget","runWithPriority","attemptReplayContinuousQueuedEvent","queuedEvent","nextBlockedOn","nativeEventClone","shift","attemptReplayContinuousQueuedEventInMap","replayUnblockedEvents","scheduleCallbackIfUnblocked","unblocked","lastScheduledReplayQueue","scheduleReplayQueueIfNeeded","formReplayingQueue","submitterOrAction","unblock","$$reactFormReplay","formProps","ReactDOMRoot","internalRoot","_internalRoot","ReactDOMHydrationRoot","unmount","unstable_scheduleHydration","isomorphicReactPackageVersion$jscomp$inline_1686","version","findDOMNode","componentOrElement","parentA","parentB","didFindChild","child$2","findCurrentFiberUsingSlowPath","internals$jscomp$inline_2165","bundleType","rendererPackageName","currentDispatcherRef","findFiberByHostInstance","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","hook$jscomp$inline_2166","isDisabled","supportsFiber","inject","createRoot","unstable_strictMode","unstable_transitionCallbacks","hydrateRoot","Internals","getCrossOriginStringAs","createPortal","createPortal$1","flushSync","previousTransition","previousUpdatePriority","preconnect","prefetchDNS","preinit","fetchPriority","nonce","preinitModule","preloadModule","requestFormReset","unstable_batchedUpdates","permalink","useFormStatus","checkDCE","Events","EE","once","addListener","emitter","TypeError","evt","_events","_eventsCount","clearEvent","EventEmitter","__proto__","eventNames","names","ee","listenerCount","a1","a2","a3","a4","a5","args","len","removeListener","on","removeAllListeners","off","prefixed","cookieNameRegExp","cookieValueRegExp","domainValueRegExp","pathValueRegExp","__toString","NullObject","startIndex","decode","decodeURIComponent","_interopRequireDefault","_react","_default","Children","params","newStartX","startX","viewLength","resistance","indexMax","exp","_constant","RESISTANCE_COEF","UNCERTAINTY_THRESHOLD","displaySameSlide","getChildrenKey","oldKey","_checkIndexBounds","_computeIndex","_getDisplaySameSlide","_mod","getDomTreeShapes","findNativeHandler","_extends2","_objectWithoutProperties2","_classCallCheck2","_createClass2","_possibleConstructorReturn2","_getPrototypeOf2","_inherits2","_propTypes","_reactSwipeableViewsCore","remove","direction","willChange","WebkitFlexShrink","flexShrink","axisProperties","overflowX","overflowY","flexDirection","translate","rotationMatrix","scrollPosition","scrollLength","clientLength","createTransition","duration","easeFunction","delay","applyRotationMatrix","touch","axis","adaptMouse","rootNode","domTreeShapes","getComputedStyle","getPropertyValue","clientWidth","scrollWidth","clientHeight","scrollHeight","nodeWhoClaimedTheScroll","some","goingForward","areNotAtStart","areNotAtEnd","SwipeableViews","_React$Component","_this","containerNode","ignoreNextScrollEvents","lastX","vx","startY","isSwiping","started","transitionListener","touchMoveListener","activeSlide","indexCurrent","firstRenderTimeout","setRootNode","setContainerNode","setActiveSlide","updateHeight","handleSwipeStart","getBoundingClientRect","computedStyle","transformValues","rootStyle","tranformNormalized","parseInt","paddingLeft","paddingRight","handleSwipeMove","_this$props","ignoreNativeScroll","onSwitching","dx","abs","dy","constant","computeIndex","setIndexCurrent","isDragging","handleTouchStart","handleSwipeEnd","indexNew","indexLatest","threshold","hysteresis","onChangeIndex","handleTransitionEnd","onTouchStart","handleTouchEnd","onTouchEnd","handleMouseDown","onMouseDown","handleMouseUp","onMouseUp","handleMouseLeave","onMouseLeave","handleMouseMove","onMouseMove","handleScroll","offsetHeight","heightLatest","renderOnlyActive","disableLazyLoading","_this2","swipeableViews","slideUpdateHeight","_this3","getDisplaySameSlide","animateTransitions","WebkitTransform","onTransitionEnd","WebkitTransition","_this4","_this$props2","animateHeight","containerStyleProp","containerStyle","enableMouseEvents","slideStyleProp","slideStyle","slideClassName","springConfig","_this$state","touchEvents","mouseEvents","additionalTranstion","WebkitFlexDirection","className","indexChild","hidden","jsxProd","config","maybeKey","jsx","jsxs","ReactNoopUpdateQueue","emptyObject","ComponentDummy","PureComponent","partialState","forceUpdate","pureComponentPrototype","ReactElement","isValidElement","userProvidedKeyEscapeRegex","getElementKey","escaperLookup","escape","mapIntoArray","escapedPrefix","nameSoFar","oldElement","newKey","invokeCallback","nextNamePrefix","resolveThenable","mapChildren","lazyInitializer","_status","_result","moduleObject","forEachFunc","forEachContext","toArray","only","act","cloneElement","childArray","createContext","childrenLength","createRef","forwardRef","lazy","scope","unstable_useCacheRefresh","Context","heap","parentIndex","first","halfLength","leftIndex","rightIndex","right","sortIndex","performance","localPerformance","localDate","initialTime","taskQueue","timerQueue","taskIdCounter","currentTask","currentPriorityLevel","isPerformingWork","isHostCallbackScheduled","isHostTimeoutScheduled","localSetTimeout","localClearTimeout","localSetImmediate","setImmediate","advanceTimers","timer","startTime","handleTimeout","requestHostCallback","firstTimer","requestHostTimeout","schedulePerformWorkUntilDeadline","isMessageLoopRunning","taskTimeoutID","frameInterval","shouldYieldToHost","performWorkUntilDeadline","hasMoreWork","previousPriorityLevel","continuationCallback","MessageChannel","channel","port","port2","port1","onmessage","postMessage","ms","unstable_Profiling","task","unstable_continueExecution","unstable_forceFrameRate","fps","unstable_getFirstCallbackNode","unstable_next","eventHandler","unstable_pauseExecution","unstable_runWithPriority","timeout","unstable_wrapCallback","parentPriorityLevel","compareContext","bHasOwnProperty","idx","valueA","valueB","warning","obj","__esModule","ReferenceError","Constructor","_defineProperties","writable","protoProps","staticProps","_extends","_getPrototypeOf","o","setPrototypeOf","subClass","superClass","objectWithoutPropertiesLoose","excluded","sourceSymbolKeys","sourceKeys","_typeof","assertThisInitialized","_setPrototypeOf","_typeof2","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","loaded","__webpack_modules__","getter","definition","chunkId","all","promises","miniCssF","globalThis","prop","inProgress","dataWebpackPrefix","script","needAttach","s","charset","nc","onScriptComplete","doneFns","nmd","paths","installedChunks","installedChunkData","promise","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","chunkIds","moreModules","runtime","chunkLoadingGlobal","toPropertyKey","toPrimitive","Number","_defineProperty","ownKeys","_objectSpread2","getOwnPropertyDescriptors","defineProperties","PopStateEventType","createBrowserHistory","getUrlBasedHistory","window2","globalHistory","pathname","hash","createLocation","usr","to","createPath","invariant","cond","warn","getHistoryState","_objectSpread","parsePath","_ref","path","parsedPath","hashIndex","searchIndex","getLocation","createHref2","validateLocation","v5Compat","history","getIndex","handlePop","nextIndex","createURL","origin","URL","replaceState","listen","createHref","encodeLocation","historyState","pushState","DOMException","go","matchRoutes","routes","locationArg","matchRoutesImpl","basename","allowPartial","stripBasename","branches","flattenRoutes","sort","siblings","every","compareIndexes","routesMeta","meta","childrenIndex","rankRouteBranches","decoded","decodePath","matchRouteBranch","parentsMeta","parentPath","flattenRoute","route","relativePath","caseSensitive","startsWith","joinPaths","computeScore","_route$path","exploded","explodeOptionalSegments","segments","isOptional","required","restExploded","subpath","paramRe","dynamicSegmentValue","indexRouteValue","emptySegmentValue","staticSegmentValue","splatPenalty","isSplat","initialScore","segment","branch","matchedParams","matchedPathname","remainingPathname","matchPath","pathnameBase","normalizePathname","matcher","compiledParams","regexpSource","_","paramName","compilePath","captureGroups","memo2","_ref2","splatValue","nextChar","getInvalidPathError","field","dest","JSON","stringify","getPathContributingMatches","getResolveToMatches","pathMatches","resolveTo","toArg","routePathnames","locationPathname","isPathRelative","from","isEmptyPath","toPathname","routePathnameIndex","toSegments","fromPathname","resolvePathname","normalizeSearch","normalizeHash","resolvePath","hasExplicitTrailingSlash","hasCurrentTrailingSlash","isRouteErrorResponse","statusText","internal","validMutationMethodsArr","validRequestMethodsArr","DataRouterContext","DataRouterStateContext","ViewTransitionContext","isTransitioning","FetchersContext","AwaitContext","NavigationContext","LocationContext","RouteContext","outlet","isDataRoute","RouteErrorContext","useInRouterContext","React2","useLocation","navigateEffectWarning","useIsomorphicLayoutEffect","static","useNavigate","router","useDataRouterContext","useCurrentRouteId","activeRef","navigate","fromRouteId","useNavigateStable","dataRouterContext","navigator","navigator2","routePathnamesJson","parse","relative","useNavigateUnstable","useResolvedPath","useRoutesImpl","dataRouterState","future","parentMatches","routeMatch","parentParams","parentPathname","parentPathnameBase","parentRoute","warningOnce","locationFromContext","_parsedLocationArg$pa","parsedLocationArg","parentSegments","renderedMatches","_renderMatches","navigationType","DefaultErrorComponent","useRouteError","lightgrey","preStyles","padding","backgroundColor","codeStyles","devInfo","fontStyle","defaultErrorElement","RenderErrorBoundary","super","revalidation","routeContext","RenderedRoute","_ref9","staticContext","errorElement","ErrorBoundary","_deepestRenderedBoundaryId","initialized","errorIndex","findIndex","renderFallback","fallbackIndex","HydrateFallback","hydrateFallbackElement","loaderData","errors2","needsToRunLoader","loader","reduceRight","shouldRenderHydrateFallback","matches2","getChildren","getDataRouterConsoleError","hookName","ctx","useDataRouterState","useRouteContext","thisRoute","_state$errors","routeId","alreadyWarned","React3","_ref12","Route","_props","Router","_ref15","basenameProp","locationProp","staticProp","navigationContext","locationContext","trailingPathname","Routes","_ref16","createRoutesFromChildren","treePath","hasErrorBoundary","shouldRevalidate","handle","defaultMethod","defaultEncType","isHtmlElement","_formDataSupportsSubmitter","supportedFormEncTypes","getFormEncType","getFormSubmissionInfo","isButtonElement","isInputElement","isFormDataSubmitterSupported","append","invariant2","loadRouteModule","routeModulesCache","routeModule","import","__reactRouterContext","isSpaMode","reload","isPageLinkDescriptor","page","isHtmlLinkDescriptor","getNewMatchesForLinks","nextMatches","currentMatches","manifest","isNew","matchPathChanged","_currentMatches$index","manifestRoute","hasLoader","_currentMatches$","routeChoice","currentUrl","currentParams","nextUrl","nextParams","defaultShouldRevalidate","dedupeHrefs","hrefs","dedupeLinkDescriptors","descriptors","preloads","preloadsSet","deduped","sorted","sortKeys","createHtml","html","singleFetchUrl","reqUrl","React5","RemixRootDefaultErrorBoundary","_ref21","isOutsideRemixApp","errorInstance","heyDeveloper","BoundaryShell","fontSize","errorString","background","_ref22","_routeModules$root","renderScripts","routeModules","useFrameworkContext","Layout","lang","fontFamily","Scripts","isFogOfWarEnabled","useDataRouterContext2","React9","useDataRouterStateContext","FrameworkContext","composeEventHandlers","theirHandler","ourHandler","getActiveMatches","isHydrated","errorIdx","PrefetchPageLinks","_ref29","dataLinkProps","_objectWithoutProperties","_excluded","PrefetchPageLinksImpl","useKeyedPrefetchLinks","keyedPrefetchLinks","setKeyedPrefetchLinks","interrupted","links","mod","flat","getKeyedPrefetchLinks","_ref30","linkProps","_excluded2","newMatchesForData","newMatchesForAssets","dataHrefs","routesParams","foundOptOutRoute","_routeModules$m$route2","m2","hasClientLoader","searchParams","moduleHrefs","manifestPatch","imports","getModuleLinkHrefs","_ref31","serverHandoffString","renderMeta","isStatic","routerMatches","enableFogOfWar","didRenderScripts","initialScripts","_manifest$hmr","contextScript","routeModulesScript","hmr","routeIds","Boolean","initialRoutes","acc","getPartialManifest","routePreloads","mergeRefs","_len3","_key3","isBrowser","__reactRouterVersion","BrowserRouter","_ref32","historyRef","React10","setStateImpl","ABSOLUTE_URL_REGEX2","Link","_ref35","forwardedRef","absoluteHref","discover","prefetch","reloadDocument","replace2","preventScrollReset","viewTransition","_excluded4","isAbsolute","isExternal","targetUrl","protocol","joinedPathname","useHref","shouldPrefetch","prefetchRef","prefetchHandlers","theirElementProps","frameworkContext","maybePrefetch","setMaybePrefetch","setShouldPrefetch","onFocus","onBlur","onMouseEnter","observer","IntersectionObserver","isIntersecting","observe","disconnect","setIntent","cancelIntent","usePrefetchBehavior","internalOnClick","replaceProp","isModifiedEvent","shouldProcessLinkClick","useLinkClickHandler","NavLink","_ref36","ariaCurrentProp","classNameProp","_excluded5","routerState","opts","vtContext","useDataRouterContext3","currentPath","currentLocation","nextPath","nextLocation","useViewTransitionState","nextLocationPathname","navigation","endSlashPosition","isActive","isPending","renderProps","ariaCurrent","Form","_ref37","fetcherKey","onSubmit","_excluded6","submit","useSubmit","URLSearchParams","indexValues","getAll","hasNakedIndexParam","qs","useFormAction","submitMethod","getDataRouterConsoleError2","fetcherId","getUniqueFetcherId","currentRouteId","fetch","TextEncoder","stringToByteArray$1","out","base64","byteToCharMap_","charToByteMap_","byteToCharMapWebSafe_","charToByteMapWebSafe_","ENCODED_VALS_BASE","ENCODED_VALS","ENCODED_VALS_WEBSAFE","HAS_NATIVE_SUPPORT","atob","encodeByteArray","webSafe","init_","byteToCharMap","output","byte1","haveByte2","byte2","haveByte3","byte3","outByte1","outByte2","outByte3","outByte4","encodeString","btoa","decodeString","bytes","pos","c1","c2","c3","byteArrayToString","decodeStringToByteArray","charToByteMap","byte4","DecodeBase64StringError","base64urlEncodeWithoutPadding","utf8Bytes","base64Encode","base64Decode","getDefaultsFromGlobal","getGlobal","__FIREBASE_DEFAULTS__","getDefaults","getDefaultsFromEnvVariable","defaultsJsonString","getDefaultsFromCookie","cookie","getDefaultEmulatorHost","productName","_a","_b","emulatorHosts","getDefaultEmulatorHostnameAndPort","host","separatorIndex","lastIndexOf","getDefaultAppConfig","getExperimentalSetting","Deferred","wrapCallback","createMockUserToken","token","projectId","project","iat","sub","user_id","iss","aud","auth_time","firebase","sign_in_provider","identities","alg","getUA","isSafari","forceEnvironment","isNode","userAgent","isIndexedDBAvailable","indexedDB","FirebaseError","customData","captureStackTrace","ErrorFactory","service","serviceName","fullCode","template","PATTERN","replaceTemplate","fullMessage","deepEqual","aKeys","bKeys","aProp","bProp","thing","querystring","querystringParams","arrayVal","querystringDecode","extractQuerystring","queryStart","fragmentStart","ObserverProxy","executor","onNoObservers","observers","unsubscribes","observerCount","finalized","forEachObserver","close","complete","nextOrObserver","methods","implementsAnyMethods","unsub","unsubscribeOne","finalError","sendOne","getModularInstance","_delegate","instanceFactory","multipleInstances","serviceProps","instantiationMode","onInstanceCreated","setInstantiationMode","setMultipleInstances","setServiceProps","setInstanceCreatedCallback","DEFAULT_ENTRY_NAME","instances","instancesDeferred","instancesOptions","onInitCallbacks","identifier","normalizedIdentifier","normalizeInstanceIdentifier","deferred","isInitialized","shouldAutoInitialize","getOrInitializeService","instanceIdentifier","getImmediate","optional","getComponent","setComponent","isComponentEager","instanceDeferred","clearInstance","services","INTERNAL","_delete","isComponentSet","getOptions","initialize","onInit","existingCallbacks","existingInstance","invokeOnInitCallbacks","ComponentContainer","providers","addComponent","getProvider","addOrOverwriteComponent","getProviders","LogLevel","levelStringToEnum","DEBUG","VERBOSE","INFO","WARN","ERROR","SILENT","defaultLogLevel","ConsoleMethod","defaultLogHandler","logType","logLevel","toISOString","_len","_key","Logger","_logLevel","_logHandler","_userLogHandler","val","setLogLevel","logHandler","userLogHandler","debug","_len2","_key2","_len4","_key4","_len5","_key5","_len6","_key6","idbProxyableTypes","cursorAdvanceMethods","cursorRequestMap","transactionDoneMap","transactionStoreNamesMap","transformCache","reverseTransformCache","idbProxyTraps","receiver","IDBTransaction","objectStoreNames","objectStore","wrap","wrapFunction","IDBDatabase","transaction","IDBCursor","advance","continue","continuePrimaryKey","unwrap","storeNames","tx","transformCachableValue","unlisten","cacheDonePromiseForTransaction","IDBObjectStore","IDBIndex","Proxy","instanceOfAny","IDBRequest","success","promisifyRequest","readMethods","writeMethods","cachedMethods","getMethod","targetFuncName","useIndex","isWrite","storeName","store","oldTraps","PlatformLoggerServiceImpl","getPlatformInfoString","isVersionServiceProvider","library","logString","logger","PLATFORM_LOG_STRING","name$q","name$p","name$n","name$o","name$l","name$m","name$k","name$j","name$i","name$h","name$g","name$f","name$e","name$d","name$c","name$b","name$a","name$9","name$8","name$7","name$6","name$5","name$4","name$3","name$1","name$2","_apps","_serverApps","_components","_addComponent","app","_registerComponent","serverApp","_getProvider","heartbeatController","triggerHeartbeat","_isFirebaseServerApp","settings","ERROR_FACTORY","FirebaseAppImpl","_isDeleted","_options","_config","_name","_automaticDataCollectionEnabled","automaticDataCollectionEnabled","_container","checkDestroyed","isDeleted","appName","SDK_VERSION","initializeApp","rawConfig","existingApp","newApp","getApp","registerVersion","libraryKeyOrName","variant","libraryMismatch","versionMismatch","STORE_NAME","dbPromise","getDbPromise","blocked","upgrade","blocking","terminated","open","openPromise","oldVersion","newVersion","db","openDB","createObjectStore","originalErrorMessage","writeHeartbeatsToIndexedDB","heartbeatObject","put","computeKey","idbGetError","appId","HeartbeatServiceImpl","_heartbeatsCache","_storage","HeartbeatStorageImpl","_heartbeatsCachePromise","read","agent","getUTCDateString","heartbeats","lastSentHeartbeatDate","singleDateHeartbeat","hbTimestamp","overwrite","getHeartbeatsHeader","heartbeatsToSend","unsentEntries","heartbeatsCache","maxSize","heartbeatEntry","find","hb","dates","countBytes","extractHeartbeatsForHeader","headerString","_canUseIndexedDBPromise","runIndexedDBEnvironmentCheck","preExist","DB_CHECK_NAME","onsuccess","deleteDatabase","onupgradeneeded","idbHeartbeatObject","readHeartbeatsFromIndexedDB","heartbeatsObject","existingHeartbeatsObject","version$1","blockSize","B","isFinite","F","G","I","J","pow","E","and","or","xor","Md5","bloom_blob_es2018","multiply","modulo","toNumber","getBits","fromNumber","fromString","Integer","commonjsGlobal","aa","ca","ba","da","ea","fa","ha","ia","ja","ka","Qb","la","ma","oa","pa","qa","sa","ta","ua","va","wa","xa","za","Ba","Ca","Ea","Da","N","Fa","Ga","Ha","Ia","proxy","Ja","Ka","Ma","La","Na","Oa","Qa","Ra","Sa","K","Ta","Ua","Xa","Va","Wa","Ya","Za","$a","handleEvent","ab","bb","eb","fb","gb","ib","jb","kb","lb","mb","OPEN","wb","nb","ob","pb","qb","rb","sb","STAT_EVENT","stat","tb","ub","vb","yb","Cb","Ab","NO_ERROR","TIMEOUT","xb","Bb","Hb","zb","Pb","Db","R","U","O","W","P","Eb","XMLHttpRequest","Fb","Gb","Ib","Jb","Kb","Lb","Mb","Y","Sb","Wb","Ob","Ub","Q","Rb","Xb","Yb","Zb","$b","ac","Aa","ya","getResponseHeader","bc","cc","dc","ec","fc","gc","Z","Nb","TextDecoder","stream","Tb","getAllResponseHeaders","ra","Vb","cancel","hc","ic","PerformanceNavigationTiming","getEntriesByType","nextHopProtocol","chrome","loadTimes","wasFetchedViaSpdy","jc","kc","na","V","mc","lc","oc","qc","rc","sc","tc","uc","Dc","Ac","vc","Bc","decodeURI","encodeURI","Cc","wc","xc","yc","zc","pc","Ec","onabort","ontimeout","Hc","Ic","Jc","Kc","readyState","responseType","responseText","response","onreadystatechange","Headers","Nc","Pa","ga","Mc","Lc","Oc","Pc","headers","send","credentials","Request","ReadableStream","getReader","setRequestHeader","Qc","Rc","Sc","Uc","Vc","Wc","Tc","mozResponseArrayBuffer","Xc","internalChannelParams","Yc","xmlHttpFactory","useFetchStreams","supportsCrossDomainXhr","concurrentRequestLimit","fastHandshake","encodeInitMessageHeaders","forceLongPolling","detectBufferingProxy","longPollingTimeout","Zc","$c","sendBeacon","Image","ad","ed","dd","round","cd","fd","bd","Fc","ok","Gc","hostname","gd","hd","messageUrlParams","messageHeaders","clientProtocolHeaderRequired","initMessageHeaders","messageContentType","sendRawJson","httpSessionIdParam","__headers__","statusCode","__status__","__sm__","jd","withCredentials","connect","OSID","OAID","createWebChannel","createWebChannelTransport","webchannel_blob_es2018","getStatEventTarget","Event","Stat","PROXY","NOPROXY","HTTP_ERROR","ErrorCode","COMPLETE","EventType","CLOSE","MESSAGE","WebChannel","FetchXmlHttpFactory","listenOnce","getLastError","getLastErrorCode","getStatus","getResponseJson","getResponseText","setWithCredentials","XhrIo","User","isAuthenticated","toKey","UNAUTHENTICATED","GOOGLE_CREDENTIALS","FIRST_PARTY","MOCK_USER","__PRIVATE_getLogLevel","__PRIVATE_logDebug","__PRIVATE_argToString","__PRIVATE_logError","__PRIVATE_logWarn","fail","__PRIVATE_hardAssert","__PRIVATE_debugCast","OK","CANCELLED","UNKNOWN","INVALID_ARGUMENT","DEADLINE_EXCEEDED","NOT_FOUND","ALREADY_EXISTS","PERMISSION_DENIED","RESOURCE_EXHAUSTED","FAILED_PRECONDITION","ABORTED","OUT_OF_RANGE","UNIMPLEMENTED","UNAVAILABLE","DATA_LOSS","FirestoreError","__PRIVATE_Deferred","__PRIVATE_OAuthToken","user","__PRIVATE_EmptyAuthCredentialsProvider","getToken","invalidateToken","enqueueRetryable","shutdown","__PRIVATE_EmulatorAuthCredentialsProvider","changeListener","__PRIVATE_FirebaseAuthCredentialsProvider","currentUser","forceRefresh","auth","__PRIVATE_guardedChangeListener","__PRIVATE_awaitNextToken","__PRIVATE_registerAuth","addAuthTokenListener","accessToken","removeAuthTokenListener","getUid","__PRIVATE_FirstPartyToken","__PRIVATE_FirstPartyAuthCredentialsProvider","AppCheckToken","__PRIVATE_FirebaseAppCheckTokenProvider","appCheck","onTokenChanged","__PRIVATE_registerAppCheck","addTokenListener","removeTokenListener","__PRIVATE_randomBytes","crypto","msCrypto","getRandomValues","__PRIVATE_AutoId","newId","__PRIVATE_primitiveComparator","__PRIVATE_arrayEquals","Timestamp","fromMillis","fromDate","getTime","seconds","nanoseconds","toDate","toMillis","_compareTo","toJSON","padStart","SnapshotVersion","fromTimestamp","timestamp","compareTo","toMicroseconds","toTimestamp","BasePath","comparator","limit","popFirst","popLast","firstSegment","lastSegment","isEmpty","isPrefixOf","isImmediateParentOf","ResourcePath","canonicalString","toUriEncodedString","emptyPath","FieldPath$1","isValidIdentifier","isKeyField","keyField","fromServerFormat","__PRIVATE_addCurrentSegment","DocumentKey","fromPath","fromName","empty","collectionGroup","hasCollectionId","getCollectionGroup","getCollectionPath","isDocumentKey","fromSegments","FieldIndex","indexId","fields","indexState","UNKNOWN_ID","__PRIVATE_newIndexOffsetSuccessorFromReadTime","IndexOffset","__PRIVATE_newIndexOffsetFromDocument","readTime","documentKey","largestBatchId","__PRIVATE_indexOffsetComparator","PersistenceTransaction","onCommittedListeners","addOnCommittedListener","raiseOnCommittedEvent","__PRIVATE_ignoreIfPrimaryLeaseLoss","PersistencePromise","nextCallback","catchCallback","isDone","callbackAttached","wrapFailure","wrapSuccess","toPromise","wrapUserFunction","waitFor","mapArray","doWhile","__PRIVATE_getAndroidVersion","__PRIVATE_isIndexedDbTransactionError","__PRIVATE_ListenSequence","previousValue","sequenceNumberHandler","ie","se","writeSequenceNumber","__PRIVATE_isNullOrUndefined","__PRIVATE_isNegativeZero","isSafeInteger","isInteger","MIN_SAFE_INTEGER","__PRIVATE_encodeResourcePath","__PRIVATE_encodeSeparator","__PRIVATE_encodeSegment","oe","__PRIVATE_objectSize","SortedMap","LLRBNode","EMPTY","BLACK","minKey","maxKey","inorderTraversal","reverseTraversal","getIterator","SortedMapIterator","getIteratorFrom","getReverseIterator","getReverseIteratorFrom","isReverse","nodeStack","getNext","RED","fixUp","removeMin","isRed","moveRedLeft","rotateRight","moveRedRight","rotateLeft","colorFlip","checkMaxDepth","SortedSet","forEachInRange","forEachWhile","firstAfterOrEqual","SortedSetIterator","unionWith","FieldMask","covers","__PRIVATE_Base64DecodeError","ByteString","binaryString","fromBase64String","fromUint8Array","toBase64","toUint8Array","approximateByteSize","EMPTY_BYTE_STRING","ne","__PRIVATE_normalizeTimestamp","nanos","__PRIVATE_normalizeNumber","__PRIVATE_normalizeByteString","__PRIVATE_isServerTimestamp","mapValue","__type__","stringValue","__PRIVATE_getPreviousValue","__previous_value__","__PRIVATE_getLocalWriteTime","__local_write_time__","timestampValue","DatabaseInfo","databaseId","persistenceKey","ssl","autoDetectLongPolling","longPollingOptions","DatabaseId","database","isDefaultDatabase","re","__PRIVATE_typeOrder","__PRIVATE_isMaxValue","__PRIVATE_isVectorValue","__PRIVATE_valueEquals","booleanValue","bytesValue","referenceValue","geoPointValue","latitude","longitude","integerValue","doubleValue","arrayValue","__PRIVATE_arrayValueContains","__PRIVATE_valueCompare","__PRIVATE_compareTimestamps","__PRIVATE_compareArrays","canonicalId","__PRIVATE_canonifyValue","__PRIVATE_estimateByteSize","__PRIVATE_isNullValue","__PRIVATE_isNanValue","__PRIVATE_isMapValue","__PRIVATE_deepClone","ObjectValue","getFieldsMap","setAll","applyChanges","__PRIVATE_extractFieldMask","MutableDocument","documentType","createTime","documentState","newInvalidDocument","newFoundDocument","newNoDocument","newUnknownDocument","convertToFoundDocument","convertToNoDocument","convertToUnknownDocument","setHasCommittedMutations","setHasLocalMutations","setReadTime","hasLocalMutations","hasCommittedMutations","hasPendingWrites","isValidDocument","isFoundDocument","isNoDocument","isUnknownDocument","mutableCopy","Bound","position","inclusive","__PRIVATE_boundCompareToDocument","dir","__PRIVATE_boundEquals","OrderBy","__PRIVATE_orderByEquals","Filter","FieldFilter","createKeyFieldInFilter","__PRIVATE_KeyFieldFilter","__PRIVATE_ArrayContainsFilter","__PRIVATE_InFilter","__PRIVATE_NotInFilter","__PRIVATE_ArrayContainsAnyFilter","__PRIVATE_KeyFieldInFilter","__PRIVATE_KeyFieldNotInFilter","matchesComparison","isInequality","getFlattenedFilters","getFilters","CompositeFilter","filters","ae","__PRIVATE_compositeFilterIsConjunction","__PRIVATE_compositeFilterIsFlatConjunction","__PRIVATE_compositeFilterIsFlat","__PRIVATE_canonifyFilter","__PRIVATE_filterEquals","__PRIVATE_stringifyFilter","__PRIVATE_extractDocumentKeysFromArrayValue","nullValue","__PRIVATE_TargetImpl","orderBy","startAt","endAt","ue","__PRIVATE_newTarget","__PRIVATE_canonifyTarget","__PRIVATE_targetEquals","__PRIVATE_targetIsDocumentTarget","__PRIVATE_QueryImpl","explicitOrderBy","limitType","ce","le","he","__PRIVATE_newQuery","__PRIVATE_newQueryForPath","__PRIVATE_queryMatchesAllDocuments","__PRIVATE_isCollectionGroupQuery","__PRIVATE_queryNormalizedOrderBy","__PRIVATE_queryToTarget","__PRIVATE__queryToTarget","__PRIVATE_queryWithLimit","__PRIVATE_queryEquals","__PRIVATE_canonifyQuery","__PRIVATE_stringifyQuery","__PRIVATE_queryMatches","__PRIVATE_queryCollectionGroup","__PRIVATE_newQueryComparator","__PRIVATE_compareDocs","ObjectMap","mapKeyFn","equalsFn","inner","innerSize","__PRIVATE_mutableDocumentMap","_e","documentMap","__PRIVATE_convertOverlayedDocumentMapToDocumentMap","overlayedDocument","__PRIVATE_newOverlayMap","__PRIVATE_newDocumentKeyMap","__PRIVATE_newMutationMap","__PRIVATE_documentKeySet","__PRIVATE_targetIdSet","__PRIVATE_toDouble","useProto3Json","__PRIVATE_toInteger","TransformOperation","__PRIVATE_applyTransformOperationToLocalView","__PRIVATE_ServerTimestampTransform","__PRIVATE_ArrayUnionTransformOperation","__PRIVATE_applyArrayUnionTransformOperation","__PRIVATE_ArrayRemoveTransformOperation","__PRIVATE_applyArrayRemoveTransformOperation","__PRIVATE_computeTransformOperationBaseValue","asNumber","Pe","serializer","__PRIVATE_applyTransformOperationToRemoteDocument","__PRIVATE_NumericIncrementTransformOperation","__PRIVATE_coercedFieldValuesArray","MutationResult","transformResults","Precondition","updateTime","exists","none","isNone","__PRIVATE_preconditionIsValidForDocument","Mutation","__PRIVATE_calculateOverlayMutation","__PRIVATE_DeleteMutation","__PRIVATE_SetMutation","__PRIVATE_PatchMutation","__PRIVATE_mutationApplyToRemoteDocument","__PRIVATE_serverTransformResults","fieldTransforms","precondition","__PRIVATE_getPatch","__PRIVATE_mutationApplyToLocalView","__PRIVATE_localTransformResults","fieldMask","__PRIVATE_mutationExtractBaseValue","__PRIVATE_mutationEquals","__PRIVATE_fieldTransformEquals","getFieldMask","__PRIVATE_VerifyMutation","MutationBatch","batchId","localWriteTime","baseMutations","mutations","applyToRemoteDocument","mutationResults","applyToLocalView","applyToLocalDocumentSet","mutatedFields","MutationBatchResult","batch","commitVersion","docVersions","Overlay","mutation","getKey","ExistenceFilter","unchangedNames","__PRIVATE_isPermanentError","__PRIVATE_mapCodeFromRpcCode","__PRIVATE_newTextEncoder","Te","__PRIVATE_getMd5HashValue","encode","__PRIVATE_get64BitUints","getUint32","BloomFilter","bitmap","hashCount","__PRIVATE_BloomFilterError","Ie","Ee","de","mightContain","Ae","RemoteEvent","snapshotVersion","targetChanges","targetMismatches","documentUpdates","resolvedLimboDocuments","createSynthesizedRemoteEventForCurrentChange","TargetChange","createSynthesizedTargetChangeForCurrentChange","resumeToken","addedDocuments","modifiedDocuments","removedDocuments","__PRIVATE_DocumentWatchChange","Re","removedTargetIds","Ve","__PRIVATE_ExistenceFilterChange","targetId","me","__PRIVATE_WatchTargetChange","targetIds","__PRIVATE_TargetState","fe","ge","__PRIVATE_snapshotChangesMap","ye","we","pe","Se","be","De","ve","Ce","Fe","Me","xe","Oe","Ne","__PRIVATE_WatchChangeAggregator","Le","ke","qe","__PRIVATE_documentTargetMap","Qe","Ke","$e","Ue","We","Ge","forEachTarget","ze","je","removeTarget","He","Be","Je","Ye","Ze","Xe","et","tt","localCacheCount","existenceFilterCount","bloomFilter","applied","bitmapLength","bits","nt","rt","getRemoteKeysForTarget","it","st","ot","purpose","_t","ut","asc","desc","in","JsonProtoSerializer","__PRIVATE_toInt32Proto","__PRIVATE_toBytes","__PRIVATE_toVersion","__PRIVATE_fromVersion","__PRIVATE_toResourceName","__PRIVATE_toResourcePath","__PRIVATE_fromResourceName","__PRIVATE_isValidResourceName","__PRIVATE_toName","__PRIVATE_extractLocalPathFromResourceName","__PRIVATE_toQueryPath","__PRIVATE_fromQueryPath","__PRIVATE_getEncodedDatabaseId","__PRIVATE_toMutationDocument","toMutation","updateMask","__PRIVATE_toDocumentMask","verify","updateTransforms","fieldPath","setToServerValue","appendMissingElements","removeAllFromArray","increment","currentDocument","__PRIVATE_toDocumentsTarget","documents","__PRIVATE_toQueryTarget","structuredQuery","collectionId","allDescendants","__PRIVATE_toFilter","where","__PRIVATE_toFieldPathReference","__PRIVATE_toDirection","ct","__PRIVATE_convertQueryTargetToQuery","__PRIVATE_fromFilter","__PRIVATE_fromFieldPathReference","unaryFilter","NaN","fieldFilter","compositeFilter","__PRIVATE_toOperatorName","__PRIVATE_toCompositeOperatorName","fieldPaths","TargetData","sequenceNumber","lastLimboFreeSnapshotVersion","expectedCount","withSequenceNumber","withResumeToken","withExpectedCount","withLastLimboFreeSnapshotVersion","__PRIVATE_LocalSerializer","ht","__PRIVATE_fromBundledQuery","__PRIVATE_FirestoreIndexValueWriter","Et","dt","At","Rt","Vt","ft","gt","yt","wt","St","bt","Dt","vt","Ct","__PRIVATE_MemoryIndexManager","__PRIVATE_MemoryCollectionParentIndex","addToCollectionParentIndex","ln","getCollectionParents","getEntries","addFieldIndex","deleteFieldIndex","deleteAllFieldIndexes","createTargetIndexes","getDocumentsMatchingTarget","getIndexType","getFieldIndexes","getNextCollectionGroupToUpdate","getMinOffset","getMinOffsetFromCollectionGroup","updateCollectionGroup","updateIndexEntries","didRun","sequenceNumbersCollected","targetsRemoved","documentsRemoved","LruParams","withCacheSize","DEFAULT_COLLECTION_PERCENTILE","DEFAULT_MAX_SEQUENCE_NUMBERS_TO_COLLECT","cacheSizeCollectionThreshold","percentileToCollect","maximumSequenceNumbersToCollect","DEFAULT","DISABLED","__PRIVATE_TargetIdGenerator","kn","qn","Qn","__PRIVATE_bufferEntryComparator","_ref3","_ref4","__PRIVATE_RollingSequenceNumberBuffer","Gn","zn","jn","Hn","maxValue","__PRIVATE_LruScheduler","garbageCollector","asyncQueue","localStore","Jn","Yn","stop","enqueueAfterDelay","collectGarbage","__PRIVATE_LruGarbageCollectorImpl","Zn","calculateTargetCount","Xn","nthSequenceNumber","er","removeTargets","removeOrphanedDocuments","collect","getCacheSize","tr","__PRIVATE_newLruGarbageCollector","RemoteDocumentChangeBuffer","changesApplied","addEntry","assertNotApplied","removeEntry","getEntry","getFromCache","getAllFromCache","OverlayedDocument","LocalDocumentsView","remoteDocumentCache","mutationQueue","documentOverlayCache","indexManager","getDocument","getOverlay","getDocuments","getLocalViewOfDocuments","populateOverlays","computeViews","getOverlayedDocuments","getOverlays","recalculateAndSaveOverlays","getAllMutationBatchesAffectingDocumentKeys","saveOverlays","recalculateAndSaveOverlaysForDocumentKeys","getDocumentsMatchingQuery","getDocumentsMatchingDocumentQuery","getDocumentsMatchingCollectionGroupQuery","getDocumentsMatchingCollectionQuery","getNextDocuments","getAllFromCollectionGroup","getOverlaysForCollectionGroup","getOverlaysForCollection","__PRIVATE_MemoryBundleCache","Tr","Ir","getBundleMetadata","saveBundleMetadata","getNamedQuery","saveNamedQuery","query","bundledQuery","__PRIVATE_MemoryDocumentOverlayCache","overlays","Er","Tt","removeOverlaysForBatchId","__PRIVATE_MemoryGlobalsCache","sessionToken","getSessionToken","setSessionToken","__PRIVATE_ReferenceSet","dr","__PRIVATE_DocReference","Ar","Rr","Vr","addReference","mr","removeReference","gr","pr","yr","wr","Sr","containsKey","br","__PRIVATE_MemoryMutationQueue","referenceDelegate","Dr","vr","checkEmpty","addMutationBatch","lookupMutationBatch","Cr","getNextMutationBatchAfterBatchId","Fr","getHighestUnacknowledgedBatchId","getAllMutationBatches","getAllMutationBatchesAffectingDocumentKey","POSITIVE_INFINITY","Mr","getAllMutationBatchesAffectingQuery","removeMutationBatch","Or","markPotentiallyOrphaned","Ln","performConsistencyCheck","__PRIVATE_MemoryRemoteDocumentCacheImpl","Nr","docs","setIndexManager","Lr","newChangeBuffer","__PRIVATE_MemoryRemoteDocumentChangeBuffer","getSize","hr","__PRIVATE_MemoryTargetCache","persistence","Br","lastRemoteSnapshotVersion","highestTargetId","kr","qr","targetCount","Qr","getLastRemoteSnapshotVersion","getHighestSequenceNumber","allocateTargetId","setTargetsMetadata","Un","addTargetData","updateTargetData","removeTargetData","removeMatchingKeysForTargetId","getTargetCount","getTargetData","addMatchingKeys","removeMatchingKeys","getMatchingKeysForTargetId","__PRIVATE_MemoryPersistence","Kr","$r","Ur","Wr","Gr","zr","jr","setDatabaseDeletedListener","setNetworkEnabled","getIndexManager","getDocumentOverlayCache","getMutationQueue","getGlobalsCache","getTargetCache","getRemoteDocumentCache","getBundleCache","runTransaction","__PRIVATE_MemoryTransaction","Hr","Jr","Yr","currentSequenceNumber","__PRIVATE_MemoryEagerDelegate","Xr","ei","ti","Zr","ni","updateLimboDocument","__PRIVATE_MemoryLruDelegate","ri","nr","ir","__PRIVATE_LocalViewChanges","fromCache","Wi","Gi","zi","docChanges","QueryContext","_documentReadCount","documentReadCount","incrementDocumentReadCount","__PRIVATE_QueryEngine","ji","Hi","Ji","Yi","Zi","Xi","es","ts","ns","rs","ss","os","__PRIVATE_LocalStoreImpl","_s","us","cs","ls","hs","Ps","localDocuments","__PRIVATE_newLocalStore","__PRIVATE_localStoreHandleUserChange","Ts","removedBatchIds","addedBatchIds","__PRIVATE_localStoreGetLastRemoteSnapshotVersion","__PRIVATE_populateDocumentChangeBuffer","Is","Es","__PRIVATE_localStoreGetNextMutationBatch","__PRIVATE_localStoreAllocateTarget","__PRIVATE_localStoreReleaseTarget","__PRIVATE_localStoreExecuteQuery","__PRIVATE_setMaxReadTime","ds","__PRIVATE_LocalClientState","activeTargetIds","ps","ys","gs","updateTimeMs","__PRIVATE_MemorySharedClientState","_o","ao","onlineStateHandler","addPendingMutation","updateMutationState","addLocalQueryTarget","updateQueryState","removeLocalQueryTarget","isLocalQueryTarget","clearQueryState","getAllActiveQueryTargets","isActiveQueryTarget","handleUserChange","setOnlineState","notifyBundleLoaded","__PRIVATE_NoopConnectivityMonitor","uo","__PRIVATE_BrowserConnectivityMonitor","co","lo","ho","Po","To","Io","__PRIVATE_generateUniqueDebugId","BatchGetDocuments","Commit","RunQuery","RunAggregationQuery","__PRIVATE_StreamBridge","Eo","Ao","Ro","Vo","mo","fo","po","yo","onMessage","wo","So","bo","Do","vo","__PRIVATE_WebChannelConnection","Co","databaseInfo","Fo","Mo","xo","Oo","No","Lo","Bo","ko","terminate","qo","forwardChannelRequestTimeoutMs","timeoutSeconds","__PRIVATE_closeFn","__PRIVATE_unguardedEventListen","__PRIVATE_newSerializer","__PRIVATE_ExponentialBackoff","li","timerId","Qo","Ko","$o","Uo","Wo","Go","zo","jo","Ho","Jo","skipDelay","__PRIVATE_PersistentStream","Yo","Zo","connection","authCredentialsProvider","appCheckCredentialsProvider","Xo","e_","t_","n_","r_","i_","s_","o_","__","a_","u_","c_","l_","h_","P_","T_","I_","E_","d_","A_","onNext","enqueueAndForget","__PRIVATE_PersistentListenStream","targetChange","targetChangeType","documentChange","documentDelete","documentRemove","__PRIVATE_fromWatchChange","R_","V_","addTarget","__PRIVATE_toListenRequestLabels","labels","m_","__PRIVATE_PersistentWriteStream","f_","lastStreamToken","g_","streamToken","writeResults","p_","__PRIVATE_fromWriteResults","commitTime","y_","w_","writes","__PRIVATE_DatastoreImpl","authCredentials","appCheckCredentials","S_","b_","_ref10","_ref11","__PRIVATE_OnlineStateTracker","D_","v_","C_","F_","M_","x_","O_","N_","__PRIVATE_RemoteStoreImpl","datastore","remoteSyncer","L_","q_","Q_","__PRIVATE_canUseNetwork","k_","__PRIVATE_disableNetworkInternal","K_","__PRIVATE_enableNetworkInternal","__PRIVATE_remoteStoreListen","B_","__PRIVATE_shouldStartWatchStream","__PRIVATE_startWatchStream","__PRIVATE_ensureWatchStream","__PRIVATE_sendWatchRequest","__PRIVATE_remoteStoreUnlisten","__PRIVATE_sendUnwatchRequest","U_","__PRIVATE_getDatabaseId","__PRIVATE_cleanUpWatchStreamState","__PRIVATE_onWatchStreamConnected","__PRIVATE_onWatchStreamOpen","__PRIVATE_onWatchStreamClose","__PRIVATE_onWatchStreamChange","rejectListen","__PRIVATE_disableNetworkUntilRecovery","applyRemoteEvent","__PRIVATE_executeWithRecovery","__PRIVATE_fillWritePipeline","__PRIVATE_ensureWriteStream","__PRIVATE_canAddToWritePipeline","__PRIVATE_addToWritePipeline","__PRIVATE_shouldStartWriteStream","__PRIVATE_startWriteStream","__PRIVATE_onWriteStreamOpen","__PRIVATE_onWriteHandshakeComplete","__PRIVATE_onMutationResult","applySuccessfulWrite","__PRIVATE_onWriteStreamClose","rejectFailedWrite","__PRIVATE_remoteStoreHandleCredentialChange","verifyOperationInProgress","handleCredentialChange","__PRIVATE_remoteStoreApplyPrimaryState","W_","G_","__PRIVATE_onConnected","DelayedOperation","targetTimeMs","removalCallback","createAndSchedule","timerHandle","handleDelayElapsed","__PRIVATE_wrapInUserErrorIfRecoverable","DocumentSet","emptySet","keyedMap","sortedSet","__PRIVATE_DocumentChangeSet","z_","j_","ViewSnapshot","oldDocs","mutatedKeys","syncStateChanged","excludesMetadataChanges","hasCachedResults","fromInitialDocuments","__PRIVATE_QueryListenersInfo","H_","J_","Y_","Z_","__PRIVATE_EventManagerImpl","queries","__PRIVATE_newQueriesObjectMap","onlineState","__PRIVATE_eventManagerListen","onListen","onFirstRemoteStoreListen","__PRIVATE_raiseSnapshotsInSyncEvent","__PRIVATE_eventManagerUnlisten","onUnlisten","onLastRemoteStoreUnlisten","__PRIVATE_eventManagerOnWatchChange","__PRIVATE_eventManagerOnWatchError","X_","Cache","__PRIVATE_QueryListener","includeMetadataChanges","__PRIVATE_AddedLimboDocument","__PRIVATE_RemovedLimboDocument","__PRIVATE_View","order","snapshot","__PRIVATE_QueryView","LimboResolution","__PRIVATE_SyncEngineImpl","remoteStore","eventManager","sharedClientState","maxConcurrentLimboResolutions","isPrimaryClient","__PRIVATE_syncEngineListen","__PRIVATE_ensureWatchCallbacks","__PRIVATE_allocateTargetAndMaybeListen","__PRIVATE_triggerRemoteStoreListen","__PRIVATE_initializeViewAndComputeSnapshot","__PRIVATE_updateTrackedLimbos","__PRIVATE_syncEngineUnlisten","__PRIVATE_removeAndCleanupTarget","__PRIVATE_triggerRemoteStoreUnlisten","__PRIVATE_syncEngineApplyRemoteEvent","trackRemovals","__PRIVATE_localStoreApplyRemoteEventToLocalCache","__PRIVATE_syncEngineEmitNewSnapsAndNotifyLocalStore","__PRIVATE_syncEngineApplyOnlineStateChange","__PRIVATE_syncEngineRejectListen","__PRIVATE_pumpEnqueuedLimboResolutions","__PRIVATE_syncEngineApplySuccessfulWrite","__PRIVATE_localStoreAcknowledgeBatch","__PRIVATE_processUserCallback","__PRIVATE_triggerPendingWritesCallbacks","__PRIVATE_syncEngineRejectFailedWrite","__PRIVATE_removeLimboTarget","__PRIVATE_trackLimboChange","__PRIVATE_syncEngineHandleCredentialChange","__PRIVATE_syncEngineGetRemoteKeysForTarget","__PRIVATE_syncEngineEnsureWriteCallbacks","__PRIVATE_MemoryOfflineComponentProvider","kind","synchronizeTabs","gcScheduler","indexBackfillerScheduler","initialUser","build","__PRIVATE_LruGcMemoryOfflineComponentProvider","cacheSizeBytes","OnlineComponentProvider","createDatastore","createRemoteStore","createEventManager","syncEngine","createSyncEngine","__PRIVATE_AsyncObserver","eu","FirestoreClient","clientId","authCredentialListener","appCheckCredentialListener","_uninitializedComponentsProvider","configuration","setCredentialChangeListener","setAppCheckTokenChangeListener","enterRestrictedMode","enqueueAndForgetEvenWhileRestricted","_onlineComponents","_offlineComponents","__PRIVATE_setOfflineComponentProvider","__PRIVATE_setOnlineComponentProvider","__PRIVATE_ensureOfflineComponents","_offline","__PRIVATE_ensureOnlineComponents","_online","__PRIVATE_getSyncEngine","__PRIVATE_getEventManager","__PRIVATE_firestoreClientGetDocumentsViaSnapshotListener","__PRIVATE_cloneLongPollingOptions","__PRIVATE_validateNonEmptyArgument","__PRIVATE_validateDocumentPath","__PRIVATE_validateCollectionPath","__PRIVATE_valueDescription","__PRIVATE_cast","FirestoreSettingsImpl","ignoreUndefinedProperties","localCache","__PRIVATE_validateIsNotUsedTogether","experimentalForceLongPolling","experimentalAutoDetectLongPolling","experimentalLongPollingOptions","Firestore$1","_authCredentials","_appCheckCredentials","_databaseId","_app","_persistenceKey","_settings","_settingsFrozen","_terminateTask","_initialized","_terminated","_setSettings","sessionIndex","iamToken","authTokenFactory","client","_getSettings","_freezeSettings","_terminate","_restart","Query","converter","_query","firestore","withConverter","DocumentReference","_path","CollectionReference","collection","_len7","_key7","_len8","_key8","__PRIVATE_AsyncQueueImpl","Iu","Eu","du","Au","Ru","Vu","mu","fu","visibilityState","gu","isShuttingDown","enqueue","pu","yu","wu","Su","bu","Du","vu","Cu","Firestore","_queue","_firestoreClient","ensureFirestoreConfigured","__PRIVATE_configureFirestore","_componentsProvider","_offlineComponentProvider","_onlineComponentProvider","Bytes","_byteString","FieldPath","_len9","_key9","_internalPath","FieldValue","_methodName","GeoPoint","_lat","_long","VectorValue","_values","ParsedSetData","ParsedUpdateData","__PRIVATE_isWrite","__PRIVATE_ParseContextImpl","Fu","Mu","xu","Ou","Nu","Lu","Bu","ku","qu","__PRIVATE_createError","methodName","Qu","Ku","__PRIVATE_UserDataReader","$u","__PRIVATE_newUserDataReader","__PRIVATE_parseSetData","merge","mergeFields","__PRIVATE_validatePlainObject","__PRIVATE_parseObject","__PRIVATE_fieldPathFromArgument$1","__PRIVATE_fieldMaskContains","__PRIVATE_DeleteFieldValueImpl","_toFieldTransform","__PRIVATE_parseUpdateData","__PRIVATE_fieldPathFromDotSeparatedString","__PRIVATE_parseData","__PRIVATE_parseUpdateVarargs","__PRIVATE_looksLikeJsonObject","DocumentSnapshot$1","_firestore","_userDataWriter","_document","_converter","QueryDocumentSnapshot$1","fromFirestore","convertValue","__PRIVATE_fieldPathFromArgument","__PRIVATE_validateHasExplicitOrderByForLimitToLast","AbstractUserDataWriter","convertTimestamp","convertServerTimestamp","convertBytes","convertReference","convertGeoPoint","convertArray","convertObject","convertVectorValue","convertObjectMap","convertDocumentKey","__PRIVATE_applyFirestoreDataConverter","toFirestore","SnapshotMetadata","DocumentSnapshot","_firestoreImpl","metadata","QueryDocumentSnapshot","serverTimestamps","QuerySnapshot","_snapshot","_cachedChanges","_cachedChangesIncludeMetadataChanges","oldIndex","__PRIVATE_resultChangeType","__PRIVATE_ExpUserDataWriter","getDocs","executeWrite","__PRIVATE_syncEngineWrite","_ref13","mockUserToken","connectFirestoreEmulator","getFirestore","apiKey","authDomain","databaseURL","storageBucket","messagingSenderId","DEFAULT_HOST","CONFIG_STORAGE_BUCKET_KEY","StorageError","status_","prependCode","serverResponse","_baseMessage","_codeEquals","StorageErrorCode","unknown","retryLimitExceeded","RETRY_LIMIT_EXCEEDED","canceled","CANCELED","cannotSliceBlob","CANNOT_SLICE_BLOB","invalidArgument","appDeleted","APP_DELETED","invalidFormat","format","INVALID_FORMAT","internalError","INTERNAL_ERROR","Location","bucket","path_","isRoot","fullServerUrl","bucketOnlyServerUrl","makeFromBucketSpec","bucketString","bucketLocation","makeFromUrl","INVALID_DEFAULT_BUCKET","bucketDomain","gsRegex","httpModify","loc","firebaseStorageHost","groups","regex","indices","postModify","group","captures","bucketValue","pathValue","INVALID_URL","invalidUrl","FailRequest","promise_","getPromise","isString","isNativeBlob","isNativeBlobDefined","Blob","validateNumber","argument","minValue","makeUrl","urlPart","makeQueryString","queryPart","isRetryStatusCode","additionalRetryCodes","isFiveHundredCode","isExtraRetryCode","isAdditionalRetryCode","NetworkRequest","url_","method_","headers_","body_","successCodes_","additionalRetryCodes_","callback_","errorCallback_","timeout_","progressCallback_","connectionFactory_","pendingConnection_","backoffId_","canceled_","appDelete_","resolve_","reject_","start_","doTheRequest","backoffCallback","RequestEndStatus","progressListener","progressEvent","total","lengthComputable","addUploadProgressListener","removeUploadProgressListener","hitServer","getErrorCode","wasCanceled","ABORT","successCode","backoffDone","requestWentThrough","wasSuccessCode","getResponse","getErrorText","doRequest","backoffCompleteCb","waitSeconds","retryTimeoutId","globalTimeoutId","hitTimeout","cancelState","triggeredCallback","triggerCallback","callWithDelay","millis","responseHandler","clearGlobalTimeout","waitMillis","stopped","wasTimeout","appDelete","getBlobBuilder","BlobBuilder","WebKitBlobBuilder","getBlob$1","getBlob","UNSUPPORTED_ENVIRONMENT","decodeBase64","encoded","polyFill","StringFormat","StringData","contentType","dataFromString","stringData","utf8Bytes_","base64Bytes_","dataUrl","parts","DataURLParts","percentEncodedBytes_","dataURLBytes_","hasMinus","hasUnder","hasPlus","hasSlash","dataURL","middle","FbsBlob","elideCopy","blobType","data_","size_","type_","startByte","endByte","sliced","blob","webkitSlice","mozSlice","sliceBlob","blobby","uint8Arrays","finalLength","merged","uploadData","jsonObjectOrNull","lastComponent","noXform_","Mapping","server","local","xform","mappings_","getMappings","mappings","nameMapping","_metadata","fullPath","xformPath","sizeMapping","fromResource","mapping","_makeStorageReference","addRef","fromResourceString","resourceString","toResourceString","RequestInfo","urlParams","errorHandler","progressCallback","successCodes","handlerCheck","cndn","metadataHandler","xhr","downloadUrlHandler","tokens","alt","downloadUrlFromResourceString","_protocol","sharedErrorHandler","newErr","UNAUTHORIZED_APP","QUOTA_EXCEEDED","UNAUTHORIZED","objectErrorHandler","OBJECT_NOT_FOUND","getMetadata$2","maxOperationRetryTime","requestInfo","metadataForUpload_","metadataClone","determineContentType_","multipartUpload","genBoundary","metadata_","preBlobPart","postBlobPart","maxUploadRetryTime","ResumableUploadStatus","checkResumeHeader_","allowed","RESUMABLE_UPLOAD_CHUNK_SIZE","continueResumableUpload","chunkSize","SERVER_FILE_WRONG_SIZE","bytesLeft","bytesToUpload","uploadCommand","uploadStatus","newCurrent","TaskState","taskStateFromInternalTaskState","Observer","argsToForward","XhrConnection","sent_","xhr_","initXhr","errorCode_","sendPromise_","NETWORK_ERROR","header","upload","XhrTextConnection","newTextConnection","UploadTask","isExponentialBackoffExpired","sleepTime","maxSleepTime","_transferred","_needToFetchStatus","_needToFetchMetadata","_observers","_error","_uploadUrl","_request","_chunkMultiplier","_resolve","_reject","_blob","_mappings","_resumable","_shouldDoResumable","_state","_errorHandler","completeTransitions_","backoffExpired","_transition","_metadataErrorHandler","storage","_promise","_start","_makeProgressCallback","sizeBefore","_updateProgress","_createResumable","_fetchStatus","_fetchMetadata","pendingTimeout","_continueUpload","_oneShotUpload","_resolveToken","_getAuthToken","_getAppCheckToken","authToken","appCheckToken","metadataForUpload","createResumableUpload","_location","createRequest","_makeRequest","sizeString","getResumableUploadStatus","statusRequest","uploadRequest","newStatus","_increaseMultiplier","metadataRequest","multipartRequest","transferred","old","_notifyObservers","wasPaused","externalState","bytesTransferred","totalBytes","completed","_addObserver","_removeObserver","onFulfilled","onRejected","_notifyObserver","_finishPromise","triggered","resume","valid","pause","Reference","_service","_newRef","newPath","_throwIfRoot","INVALID_ROOT_OPERATION","invalidRootOperation","getDownloadURL$1","getDownloadUrl","makeRequestWithTokens","NO_DOWNLOAD_URL","_getChild$1","childPath","canonicalChildPath","refFromPath","FirebaseStorageImpl","_bucket","NO_DEFAULT_BUCKET","reference","ref$1","serviceOrRef","pathOrUrl","extractBucket","_authProvider","_appCheckProvider","_url","_firebaseVersion","_host","_appId","_deleted","_maxOperationRetryTime","_maxUploadRetryTime","_requests","_overrideAuthToken","tokenData","requestFactory","firebaseVersion","addGmpidHeader_","addAuthHeader_","addVersionHeader_","addAppCheckHeader_","makeRequest","STORAGE_TYPE","uploadBytesResumable","uploadBytesResumable$1","getStorage","bucketUrl","storageInstance","emulator","connectStorageEmulator$1","connectStorageEmulator","factory","authProvider","appCheckProvider","baseAssignValue","fromRight","iterable","createBaseFor","allocUnsafe","baseCreate","objectCtorString","nativeKeysIn","isProto","baseKeysIn","keysIn","srcIndex","mergeFunc","safeGet","srcValue","assignMergeValue","isCommon","isTyped","isPlainObject","toPlainObject","baseMerge","baseFor","baseMergeDeep","thisArg","nativeMax","otherArgs","identity","nativeNow","lastCalled","stamp","remaining","shortOut","baseSetToString","setToString","overRest","assigner","baseRest","sources","guard","isIterateeCall","createAssigner","Scope","Scope2","TYPE","LEVEL","ATTRIBUTE","BLOT","INLINE","BLOCK","BLOCK_BLOT","INLINE_BLOT","BLOCK_ATTRIBUTE","INLINE_ATTRIBUTE","ANY","Attributor","attrName","keyName","attributeBit","whitelist","item","canAdd","_node","ParchmentError","_Registry","classes","tags","bubble","blots","_unused","scroll","match2","blotClass","Node","TEXT_NODE","blot","domNode","Text","block","inline","register","definitions","isBlot","isAttr","blotName","Registry","ClassAttributor$1","classList","camelize","part","StyleAttributor$1","AttributorStore$1","attribute","move","_ShadowBlot","rawValue","statics","cloneNode","deleteAt","isolate","formatAt","insertAt","def","optimize","requiredContainer","replaceWith","replacement","_force","_mutations","wrapper","ShadowBlot","_LeafBlot","_domNode","DOCUMENT_POSITION_CONTAINED_BY","_inclusive","childNodes","LeafBlot$1","LinkedList","at","cur","refNode","curNode","forEachAt","startNode","curIndex","curLength","makeAttachedBlot","_unused2","replaceChild","_ParentBlot","uiNode","attachUI","uiClass","reverse","childLength","descendant","criteria","descendants","MAX_VALUE","lengthLeft","childIndex","enforceAllowedChildren","allowedChildren","splitAfter","childBlot","refBlot","refDomNode","moveChildren","targetParent","defaultChild","force","_length","addedNodes","removedNodes","DOCUMENT_POSITION_FOLLOWING","ParentBlot$1","_InlineBlot","formats","obj1","obj2","InlineBlot$1","_BlockBlot","BlockBlot$1","_ContainerBlot","checkMerge","ContainerBlot$1","EmbedBlot$1","_scroll","OBSERVER_CONFIG","characterData","characterDataOldValue","childList","subtree","_ScrollBlot","registry","MutationObserver","mutationsMap","records","takeRecords","mark","markParent","grandChild","ScrollBlot$1","_TextBlot","splitText","TextBlot$1","getSymbolsIn","cloneSymbol","nodeIsMap","isMap","baseIsMap","nodeIsSet","isSet","baseIsSet","isFlat","copySymbolsIn","baseAssignIn","getAllKeysIn","CLONE_DEEP_FLAG","Break","EmbedBlot","TextBlot","entityMap","escapeText","Inline","InlineBlot","selfIndex","otherIndex","Block","BlockBlot","blockDelta","lines","lineIndex","BlockEmbed","AttributorStore","blocks","LeafBlot","leaf","bubbleFormats","Cursor","textNode","CONTENTS","savedLength","restore","composing","getNativeRange","prevTextBlot","prevTextLength","nextTextBlot","nextText","mergedTextBlot","newTextNode","remapOffset","startOffset","endNode","endOffset","levels","level","newLevel","quill","handleDOM","Emitter","domListeners","listenDOM","EDITOR_CHANGE","SCROLL_BEFORE_UPDATE","SCROLL_BLOT_MOUNT","SCROLL_BLOT_UNMOUNT","SCROLL_OPTIMIZE","SCROLL_UPDATE","SCROLL_EMBED_UPDATE","SELECTION_CHANGE","TEXT_CHANGE","COMPOSITION_BEFORE_START","COMPOSITION_START","COMPOSITION_BEFORE_END","COMPOSITION_END","API","USER","Range","savedRange","lastRange","lastNative","handleComposition","handleDragging","hasFocus","native","setNativeRange","triggeredByTyping","ignored","preventScroll","setRange","nativeRange","collapsed","getBounds","nextLine","rect","side","bottom","getRangeAt","normalizeNative","getRange","isConnected","normalized","normalizedToRange","positions","indexes","startContainer","endContainer","rangeToNative","getPosition","leafOffset","blur","ASCII","convertListHTML","items","lastIndent","endTag","getListType","indent","convertHTML","previousType","replaceAll","ParentBlot","outerHTML","combineFormats","combined","combinedValue","normalizeDelta","normalizedDelta","shiftRange","amount","getDelta","applyDelta","batchStart","deleteDelta","splitOpLines","isImplicitNewlinePrepended","isImplicitNewlineAppended","isInlineEmbed","updateEmbedAt","prependedLength","addedLength","batchEnd","deleteText","formatLine","formatText","getContents","getFormat","leaves","lineFormats","leafFormats","getHTML","lineOffset","lineLength","getText","insertContents","contents","change","insertEmbed","embed","insertText","isBlank","removeFormat","selectionInfo","oldDelta","textBlot","oldValue","CursorBlot","relativeSelectionInfo","Module","GUARD_TEXT","contentNode","childNode","leftGuard","rightGuard","prevLength","setupListeners","handleCompositionStart","handleCompositionEnd","Embed","Theme","modules","addModule","ModuleClass","_Theme","getElementRect","scaleX","offsetWidth","scaleY","paddingValueToInt","getScrollDistance","targetStart","targetEnd","scrollStart","scrollEnd","scrollPaddingStart","scrollPaddingEnd","scrollRectIntoView","targetRect","_window$visualViewpor","_window$visualViewpor2","_window$visualViewpor3","_window$visualViewpor4","isDocumentBody","bounding","visualViewport","scrollDistanceX","scrollPaddingLeft","scrollPaddingRight","scrollDistanceY","scrollPaddingTop","scrollPaddingBottom","_document$defaultView","scrollBy","scrolledLeft","scrolledTop","parentElement","CORE_FORMATS","createRegistryWithFormats","sourceRegistry","coreBlot","iterations","_format$requiredConta","globalRegistry","Parchment","Quill","containerOrSelector","resolveSelector","shouldUseDefaultTheme","theme","DEFAULTS","_Quill$DEFAULTS","quillModuleDefaults","quillDefaults","_theme$DEFAULTS","themeModuleDefaults","themeDefaults","userModuleOptions","expandModuleConfig","toolbar","omitUndefinedValuesFromOptions","modulesWithDefaults","moduleClass","bounds","expandConfig","addContainer","scrollBlotName","ScrollBlot","editor","Editor","Selection","composition","Composition","keyboard","clipboard","uploader","toggle","modify","setContents","placeholder","readOnly","disable","allowReadOnlyEdits","overload","enable","editReadOnly","modifier","enabled","scrollSelectionIntoView","setSelection","containerBounds","getLength","getLeaf","getLine","getLines","getModule","getSemanticHTML","_length2","isEnabled","scrollIntoView","delete1","delete2","setText","updateContents","selector","expanded","fromEntries","lengthOrSource","parchment","ContainerBlot","isLine","isUpdatable","updateContent","handleDragStart","emitMount","emitUnmount","emitEmbedUpdate","renderBlocks","deltaToRenderBlocks","shouldInsertNewlineChar","insertInlineContents","newlineCharLength","lineEndIndex","refBlotOffset","renderBlock","createBlock","blockEmbed","blotIndex","blotLength","currentBlockDelta","splitted","_op$attributes","_op$attributes2","inlineContents","Container","AlignAttribute","AlignClass","ClassAttributor","AlignStyle","StyleAttributor","ColorAttributor","hex","ColorClass","ColorStyle","BackgroundClass","BackgroundStyle","CodeBlockContainer","innerText","CodeBlock","Code","DirectionAttribute","DirectionClass","DirectionStyle","FontClass","FontStyle","SizeClass","SizeStyle","SHORTKEY","platform","Keyboard","bindings","addBinding","handleEnter","handleBackspace","handleDelete","handleDeleteRange","keyBinding","shortKey","normalize","singleBinding","leafStart","offsetStart","leafEnd","offsetEnd","prefixText","suffixText","curContext","curFormats","prevFormats","formatDelta","nextFormats","deleteRange","defaultOptions","bold","makeFormatHandler","italic","underline","outdent","makeCodeBlockHandler","tab","table","cutoff","cell","getTable","_table","tableSide","blockquote","numLines","makeEmbedArrowHandler","makeTableArrowHandler","TAB","up","targetRow","targetCell","targetLine","firstFormats","lastFormats","normalWeightRegexp","blockTagNames","isBlockElement","ignoreRegexp","idRegexp","indentRegexp","normalizeListItem","msoList","others","_node$parentNode","listItems","parseListItem","idMatch","indentMatch","typeRegexp","typeMatch","parsed","_childListItems$","childListItems","_listItems$","nextElementSibling","ul","listItem","NORMALIZERS","_node$getAttribute","createDocumentFragment","normalizeFontWeight","previousElementSibling","_br$parentNode","normalizeEmptyLines","CLIPBOARD_CONFIG","_node$parentElement3","isPre","isBetweenInlineElements","matchNewline","deltaEndsWith","ELEMENT_NODE","applyFormat","ATTRIBUTE_ATTRIBUTORS","STYLE_ATTRIBUTORS","newDelta","_style$fontWeight","textDecoration","strike","fontWeight","_ref5","parseFloat","textIndent","composed","checkedAttr","language","_node$parentElement","_node$parentElement2","createMatchAlias","Clipboard","_this$options$matcher","onCaptureCopy","onCapturePaste","matchers","addMatcher","normalizeHTML","normalizeExternalHTML","DOMParser","parseFromString","nodeMatches","elementMatchers","textMatchers","prepareMatching","traverse","dangerouslyPasteHTML","paste","_e$clipboardData","_e$clipboardData2","isCut","onCopy","setData","normalizeURIList","urlList","_e$clipboardData3","_e$clipboardData4","_e$clipboardData6","_e$clipboardData5","files","_doc$body$firstElemen","childElementCount","firstElementChild","onPaste","pastedDelta","endText","preNodes","childrenDelta","reducedDelta","HTMLParagraphElement","History","undo","redo","currentRange","ignoreChange","userOnly","record","transformRange","inputType","inverseDelta","lastRecorded","changeDelta","undoDelta","undoRange","maxStack","transformStack","stackItem","deleteLength","changeIndex","endsWithNewlineChange","getLastChangeIndex","remoteDelta","oldItem","Uploader","caretRangeFromPoint","caretPositionFromPoint","offsetNode","_e$dataTransfer","uploads","file","_this$options$mimetyp","mimetypes","reader","FileReader","readAsDataURL","images","image","INSERT_TYPES","handleBeforeInput","replaceText","staticRange","getTargetRanges","_event$dataTransfer","getPlainTextFromInputEvent","isMac","handleArrowKeys","handleNavigationShortcuts","isRTL","canMoveCaretBeforeUINode","ensureListeningToSelectionChange","selectionChangeDeadline","isListening","handleSelectionChange","setStartAfter","setEndAfter","Input","UINode","IndentClass","normalizedValue","Blockquote","Header","ListContainer","ListItem","ui","listEventHandler","Bold","Italic","sanitize","PROTOCOL_WHITELIST","SANITIZED_URL","protocols","anchor","Script","Strike","Underline","Formula","katex","throwOnError","errorColor","formula","ATTRIBUTES","Video","video","TokenAttributor","CodeToken","SyntaxCodeBlock","SyntaxCodeBlockContainer","forceNext","highlight","forced","cachedText","codeBlock","BreakBlot","Syntax","hljs","languages","highlightBlot","initListener","initTimer","select","label","option","interval","lib","versionString","majorVersion","nodeText","TableCell","tableId","cellOffset","rowOffset","TableRow","thisHead","thisTail","nextHead","nextTail","childFormats","TableBody","TableContainer","balanceCells","rows","maxColumns","fill","cells","column","deleteColumn","insertColumn","insertRow","listenBalanceCells","balanceTables","deleteRow","deleteTable","insertColumnLeft","insertColumnRight","insertRowAbove","insertRowBelow","insertTable","columns","Toolbar","_quill$container","controls","addButton","addSelect","addControls","HTMLElement","_this$options$handler","addHandler","selectedIndex","prompt","clean","align","center","justify","codeIcon","rtl","bullet","ordered","optionsCounter","toggleAriaAttribute","buildPicker","togglePicker","buildItem","tabIndex","selectItem","buildLabel","buildOptions","trigger","Picker","colorLabel","stroke","icons","defaultItem","boundsContainer","TEMPLATE","el","isScrollable","marginTop","hide","rootBounds","verticalShift","show","ALIGNS","COLORS","FONTS","HEADERS","SIZES","BaseTheme","tooltip","textbox","pickers","picker","extendToolbar","buildButtons","buildPickers","selects","fillSelect","IconPicker","ColorPicker","fileInput","click","BaseTooltip","Tooltip","save","restoreFocus","preview","linkRange","extractVideoUrl","TOOLBAR_CONFIG","BubbleTooltip","lastLine","indexBounds","arrow","marginLeft","BubbleTheme","SnowTooltip","LinkBlot","SnowTheme","_range","Indent","List","InlineCode","Table","Icons","ReactQuill","editingAreaRef","dirtyProps","cleanProps","generation","onEditorChange","rangeOrDelta","oldRangeOrDelta","_this$onEditorChangeT","onEditorChangeText","unprivilegedEditor","_this$onEditorChangeS","onEditorChangeSelection","isControlled","validateProps","lastDeltaChangeSet","_nextProps$value","prevContents","getEditorContents","nextContents","isEqualValue","setEditorContents","setEditorReadOnly","shouldComponentRegenerate","instantiateEditor","destroyEditor","regenerationSnapshot","postpone","setEditorSelection","hookEditor","createEditor","getEditingArea","getEditorConfig","unhookEditor","getEditor","setEditorTabIndex","makeUnprivilegedEditor","getEditorSelection","isDelta","sel","_editor$scroll","renderEditingArea","preserveWhitespace","properties","_this$props$className","onKeyPress","onKeyDown","onKeyUp","_this$props$onChange","onChange","nextSelection","_this$props$onChangeS","currentSelection","hasGainedFocus","hasLostFocus","_this$props$onFocus","_this$props3","onChangeSelection","_this$props$onBlur","_this$props4","AdminDashboard","setTab","setForm","description","rounds","author","logo","socialLink","editing","setEditing","uploading","setUploading","fetchData","dataList","collectionName","handleInputChange","handleFileUpload","uploadTask","downloadURL","getDownloadURL","handleTeamChange","roundIndex","seedIndex","teamIndex","updatedRounds","seeds","teams","_jsxs","_jsx","_Fragment","handleRoundChange","handleAddSeed","handleRemoveSeed","handleRemoveRound","handleAddRound","docRef","_len17","_key17","updateDoc","addDoc","handleEdit","__rest","SuppressedError","_prodErrorMap","prodErrorMap","_DEFAULT_AUTH_ERROR_FACTORY","logClient","_logError","msg","_fail","authOrCode","createErrorInternal","_createError","_errorWithCustomMessage","errorMap","_serverAppCurrentUserOperationNotSupportedError","_assertInstanceOf","fullParams","_errorFactory","_assert","assertion","debugFail","failure","debugAssert","_getCurrentUrl","_isHttpOrHttps","_getCurrentScheme","_isOnline","onLine","browser","isBrowserExtension","Delay","shortDelay","longDelay","isMobile","_emulatorUrl","FetchProvider","fetchImpl","headersImpl","responseImpl","Response","SERVER_ERROR_MAP","DEFAULT_API_TIMEOUT_MS","_addTidIfNecessary","tenantId","_performApiRequest","_performFetchWithErrorHandling","_getAdditionalHeaders","languageCode","fetchArgs","_getFinalTarget","apiHost","customErrorMap","fetchFn","_canInitEmulator","networkTimeout","NetworkTimeout","race","clearNetworkTimeout","json","_makeTaggedError","errorMessage","serverErrorCode","serverErrorMessage","authError","_performSignInRequest","_serverResponse","apiScheme","_parseEnforcementState","enforcementStateStr","errorParams","phoneNumber","_tokenResponse","isEnterprise","grecaptcha","enterprise","RecaptchaConfig","siteKey","recaptchaEnforcementState","recaptchaKey","getProviderEnforcementState","providerStr","enforcementState","isProviderEnabled","isAnyProviderEnabled","getRecaptchaConfig","getAccountInfo","utcTimestampToDateString","utcTimestamp","toUTCString","secondsStringToMilliseconds","_parseToken","algorithm","signature","_tokenExpiresIn","parsedToken","_logoutIfInvalidated","isUserInvalidated","signOut","ProactiveRefresh","isRunning","errorBackoff","schedule","_stop","getInterval","wasError","stsTokenManager","iteration","getIdToken","UserMetadata","createdAt","lastLoginAt","_initializeTime","lastSignInTime","creationTime","_copy","_reloadWithoutSaving","idToken","users","coreAccount","_notifyReloadListener","newProviderData","providerUserInfo","extractProviderData","providerData","original","newData","providerId","oldIsAnonymous","isAnonymous","newIsAnonymous","passwordHash","updates","localId","photoURL","photoUrl","emailVerified","rawId","StsTokenManager","refreshToken","isExpired","updateFromServerResponse","expiresIn","updateTokensAndExpiration","updateFromIdToken","refresh","clearRefreshToken","oldToken","tokenApiHost","access_token","expires_in","refresh_token","requestStsToken","expiresInSec","fromJSON","manager","_assign","_clone","_performRefresh","assertStringOrUndefined","UserImpl","opt","proactiveRefresh","reloadUserInfo","reloadListener","_persistUserIfCurrent","_notifyListenersIfCurrent","getIdTokenResult","userInternal","claims","signInProvider","authTime","issuedAtTime","signInSecondFactor","userInfo","newUser","_onReload","_startProactiveRefresh","_stopProactiveRefresh","_updateTokensIfNecessary","tokensRefreshed","deleteAccount","_redirectEventId","_fromJSON","_c","_d","_f","_g","_h","plainObjectTokenManager","_fromIdTokenResponse","idTokenResponse","_fromGetAccountInfoResponse","instanceCache","_getInstance","cls","InMemoryPersistence","_isAvailable","_set","_get","_remove","_addListener","_listener","_removeListener","inMemoryPersistence","_persistenceKeyName","PersistenceUserManager","userKey","fullUserKey","fullPersistenceKey","boundEventHandler","_onStorageEvent","setCurrentUser","getCurrentUser","removeCurrentUser","savePersistenceForRedirect","setPersistence","newPersistence","persistenceHierarchy","availablePersistences","selectedPersistence","userToMigrate","migrationHierarchy","_shouldAllowMigration","_getBrowserName","_isIEMobile","_isFirefox","_isBlackBerry","_isWebOS","_isSafari","_isChromeIOS","_isAndroid","_isIOS","_isIE10","isIE","_isMobileBrowser","_getClientVersion","clientPlatform","reportedPlatform","frameworks","reportedFrameworks","AuthMiddlewareQueue","pushCallback","onAbort","wrappedCallback","runMiddleware","nextUser","onAbortStack","beforeStateCallback","originalMessage","PasswordPolicyImpl","responseOptions","customStrengthOptions","minPasswordLength","maxPasswordLength","containsLowercaseCharacter","containsLowercaseLetter","containsUppercaseCharacter","containsUppercaseLetter","containsNumericCharacter","containsNonAlphanumericCharacter","allowedNonAlphanumericCharacters","forceUpgradeOnSignin","schemaVersion","validatePassword","isValid","passwordPolicy","validatePasswordLengthOptions","validatePasswordCharacterOptions","meetsMinPasswordLength","meetsMaxPasswordLength","passwordChar","updatePasswordCharacterOptionsStatuses","AuthImpl","heartbeatServiceProvider","appCheckServiceProvider","emulatorConfig","operations","authStateSubscription","Subscription","idTokenSubscription","beforeStateQueue","redirectUser","isProactiveRefreshEnabled","EXPECTED_PASSWORD_POLICY_SCHEMA_VERSION","_isInitialized","_initializationPromise","_popupRedirectResolver","_agentRecaptchaConfig","_tenantRecaptchaConfigs","_projectPasswordPolicy","_tenantPasswordPolicies","lastNotifiedUid","appVerificationDisabledForTesting","clientVersion","sdkClientVersion","_initializeWithPersistence","popupRedirectResolver","persistenceManager","_shouldInitProactively","_initialize","initializeCurrentUser","assertedPersistence","_currentUser","_updateCurrentUser","initializeCurrentUserFromIdToken","directlySetCurrentUser","authIdToken","previouslyStoredUser","futureCurrentUser","needsTocheckMiddleware","getOrInitRedirectPersistenceManager","redirectUserEventId","storedUserEventId","tryRedirectSignIn","_overrideRedirectResult","reloadAndSetCurrentUserOrClear","redirectResolver","_completeRedirectFn","_setRedirectUser","useDeviceLanguage","navigatorLanguage","_getUserLanguage","updateCurrentUser","userExtern","skipBeforeStateCallbacks","notifyAuthListeners","redirectPersistenceManager","_getRecaptchaConfig","_getPasswordPolicyInternal","_updatePasswordPolicy","_getPasswordPolicy","_getPersistence","_updateErrorMap","onAuthStateChanged","registerStateListener","beforeAuthStateChanged","onIdTokenChanged","authStateReady","unsubscribe","revokeAccessToken","tokenType","revokeToken","redirectManager","resolver","_redirectPersistence","_redirectUserForId","currentUid","subscription","isUnsubscribed","addObserver","_logFramework","framework","_getFrameworks","heartbeatsHeader","appCheckTokenResult","_logWarn","_castAuth","createSubscribe","externalJSProvider","loadJS","recaptchaV2Script","recaptchaEnterpriseScript","gapiScript","_loadJS","_generateCallbackName","MockGreCAPTCHATopLevel","MockGreCAPTCHA","ready","execute","_siteKey","_parameters","FAKE_TOKEN","RecaptchaEnterpriseVerifier","authExtern","retrieveRecaptchaToken","clientType","retrieveSiteKey","injectRecaptchaFields","isCaptchaResp","isFakeToken","verifier","captchaResponse","newRequest","phoneEnrollmentInfo","recaptchaToken","phoneSignInInfo","handleRecaptchaFlow","authInstance","actionName","actionMethod","recaptchaAuthProvider","requestWithRecaptcha","requestWithRecaptchaFields","_initializeRecaptchaConfig","authInternal","connectAuthEmulator","disableWarnings","extractProtocol","authority","hostAndPort","bracketedIPv6","parsePort","extractHostAndPort","portStr","freeze","attachBanner","sty","border","margin","zIndex","textAlign","emitEmulatorWarning","protocolEnd","AuthCredential","signInMethod","_getIdTokenResponse","_auth","_linkToIdToken","_idToken","_getReauthenticationResolver","linkEmailPassword","signInWithPassword","EmailAuthCredential","_email","_password","_tenantId","_fromEmailAndPassword","_fromEmailAndCode","oobCode","returnSecureToken","signInWithEmailLink$1","signInWithEmailLinkForLinking","signInWithIdp","OAuthCredential","pendingToken","_fromParams","cred","oauthToken","oauthTokenSecret","buildRequest","autoCreate","requestUri","postBody","sendPhoneVerificationCode","VERIFY_PHONE_NUMBER_FOR_EXISTING_ERROR_MAP_","PhoneAuthCredential","_fromVerification","verificationId","verificationCode","_fromTokenResponse","temporaryProof","signInWithPhoneNumber$1","_makeVerificationRequest","linkWithPhoneNumber$1","operation","verifyPhoneNumberForExisting","sessionInfo","ActionCodeURL","actionLink","parseMode","continueUrl","parseLink","doubleDeepLink","iOSDeepLink","parseDeepLink","EmailAuthProvider","PROVIDER_ID","credential","credentialWithLink","emailLink","actionCodeUrl","EMAIL_PASSWORD_SIGN_IN_METHOD","EMAIL_LINK_SIGN_IN_METHOD","FederatedAuthProvider","defaultLanguageCode","customParameters","setDefaultLanguage","setCustomParameters","customOAuthParameters","getCustomParameters","BaseOAuthProvider","scopes","addScope","getScopes","FacebookAuthProvider","FACEBOOK_SIGN_IN_METHOD","credentialFromResult","userCredential","credentialFromTaggedObject","credentialFromError","tokenResponse","oauthAccessToken","GoogleAuthProvider","GOOGLE_SIGN_IN_METHOD","oauthIdToken","GithubAuthProvider","GITHUB_SIGN_IN_METHOD","TwitterAuthProvider","TWITTER_SIGN_IN_METHOD","_ref7","UserCredentialImpl","operationType","providerIdForResponse","_forOperation","MultiFactorError","_fromErrorAndOperation","_processCredentialSavingMfaContextIfNecessary","_link$1","bypassAuthState","_reauthenticate","_signInWithCredential","startEnrollPhoneMfa","STORAGE_AVAILABLE_KEY","BrowserPersistenceClass","storageRetriever","setItem","removeItem","getItem","BrowserLocalPersistence","localStorage","poll","onStorageEvent","pollTimer","fallbackToPolling","forAllChangedKeys","_oldValue","notifyListeners","detachListener","stopPolling","triggerListeners","storedValue","startPolling","setInterval","StorageEvent","clearInterval","attachListener","browserLocalPersistence","BrowserSessionPersistence","sessionStorage","browserSessionPersistence","Receiver","eventTarget","handlersMap","receivers","isListeningto","newInstance","messageEvent","eventId","ports","fulfilled","_allSettled","_subscribe","_unsubscribe","_generateEventId","digits","Sender","removeMessageHandler","messageChannel","_send","completionTimer","ackTimer","finally","_window","_isWorker","DB_NAME","DB_OBJECTSTORE_NAME","DB_DATA_KEYPATH","DBPromise","getObjectStore","isReadWrite","_openDatabase","keyPath","_deleteDatabase","_putObject","_deleteObject","IndexedDBLocalPersistence","pendingWrites","sender","serviceWorkerReceiverAvailable","activeServiceWorker","_workerInitializationPromise","initializeServiceWorkerMessaging","_openDb","_withRetries","numAttempts","initializeReceiver","initializeSender","_origin","keyProcessed","_poll","_data","serviceWorker","active","_getActiveServiceWorker","results","notifyServiceWorker","_getServiceWorkerController","_withPendingWrite","write","getObject","getAllRequest","keysInResult","fbase_key","localKey","indexedDBLocalPersistence","startSignInPhoneMfa","RECAPTCHA_VERIFIER_TYPE","_verifyPhoneNumber","phoneInfoOptions","session","startPhoneMfaEnrollmentRequest","startPhoneMfaEnrollmentResponse","injectRecaptchaV2Token","phoneSessionInfo","mfaEnrollmentId","multiFactorHint","multiFactorUid","startPhoneMfaSignInRequest","mfaPendingCredential","startPhoneMfaSignInResponse","phoneResponseInfo","sendPhoneVerificationCodeRequest","sendPhoneVerificationCodeResponse","_reset","recaptchaV2Verifier","recaptchaV2Token","recaptchaVersion","PhoneAuthProvider","verifyPhoneNumber","phoneOptions","applicationVerifier","_withDefaultResolver","resolverOverride","PHONE_SIGN_IN_METHOD","IdpCredential","_buildIdpRequest","sessionId","returnIdpCredential","_signIn","_reauth","_link","AbstractPopupRedirectOperation","pendingPromise","onExecution","registerConsumer","onAuthEvent","urlResponse","getIdpTask","unregisterAndCleanUp","unregisterConsumer","cleanUp","_POLL_WINDOW_CLOSE_TIMEOUT","PopupOperation","authWindow","pollId","currentPopupAction","executeNotNull","_openPopup","associatedEvent","_originValidation","_isIframeWebStorageSupported","isSupported","pollUserCancellation","closed","redirectOutcomeMap","RedirectAction","readyOutcome","pendingRedirectKey","resolverPersistence","hasPendingRedirect","_getAndClearPendingRedirectStatus","_getRedirectResult","resolverExtern","AuthEventManager","cachedEventUids","consumers","queuedRedirectEvent","hasHandledPotentialRedirect","lastProcessedEventTime","authEventConsumer","isEventForConsumer","sendToConsumer","saveEventToCache","onEvent","hasEventBeenHandled","handled","isNullRedirectEvent","isRedirectEvent","eventIdMatches","eventUid","IP_ADDRESS_REGEX","HTTP_REGEX","_validateOrigin","authorizedDomains","_getProjectConfig","domain","matchDomain","expected","ceUrl","escapedDomainPattern","NETWORK_TIMEOUT","resetUnloadedGapiModules","beacon","___jsl","hint","CP","loadGapi","loadGapiIframe","gapi","load","iframes","getContext","Iframe","cbName","cachedGApiLoader","PING_TIMEOUT","IFRAME_ATTRIBUTES","tabindex","EID_FROM_APIHOST","getIframeUrl","eid","fw","_openIframe","_loadGapi","messageHandlersFilter","CROSS_ORIGIN_IFRAMES_FILTER","dontclear","iframe","restyle","setHideOnLeave","networkError","networkErrorTimer","clearTimerAndResolve","ping","BASE_POPUP_OPTIONS","resizable","statusbar","AuthPopup","_open","screen","availHeight","availWidth","scrollbars","optionsString","accum","_ref14","standalone","_isIOSStandalone","createEvent","initMouseEvent","openAsNewWindowIOS","newWin","WIDGET_PATH","EMULATOR_WIDGET_PATH","FIREBASE_APP_CHECK_FRAGMENT_ID","_getRedirectUrl","authType","redirectUrl","additionalParams","tid","paramsDict","appCheckTokenFragment","getHandlerBase","WEB_STORAGE_SUPPORT_KEY","browserPopupRedirectResolver","eventManagers","originValidationPromises","_openRedirect","_setWindowLocation","initAndGetManager","iframeEvent","authEvent","AuthInterop","internalListeners","assertAuthConfigured","updateProactiveRefresh","authIdTokenMaxAge","lastPostedIdToken","getAuth","initializeAuth","authTokenSyncPath","isSecureContext","authTokenSyncUrl","mintCookie","idTokenResult","idTokenAge","authEmulatorHost","getScriptParentElement","hierarchy","_initializeAuthInstance","_instanceIdentifier","getVersionForPlatform","AuthButton","setUser","resolverInternal","signInWithPopup","justifyContent","HeroSection","AboutSection","TeamsSection","setTeams","fetchTeams","team","ContactSection","PromoteAppSection","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","flex","flexGrow","flexPositive","flexNegative","flexOrder","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","msGridRow","msGridRowSpan","msGridColumn","msGridColumnSpan","lineHeight","opacity","orphans","tabSize","widows","zoom","WebkitLineClamp","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","memoize","reactPropsRegex","isPropValid","styledComponentId","REACT_APP_SC_ATTR","SC_ATTR","SC_DISABLE_SPEEDY","REACT_APP_SC_DISABLE_SPEEDY","groupSizes","Uint32Array","indexOfGroup","insertRules","insertRule","clearGroup","deleteRule","getGroup","getRule","registerName","__webpack_nonce__","sheet","styleSheets","ownerNode","cssRules","cssText","$","rules","isServer","useCSSOMInjection","registerId","reconstructWithOptions","allocateGSInstance","hasNameForId","clearNames","clearRules","clearTag","te","staticRulesId","componentId","baseHash","baseStyle","generateAndInjectStyles","plugins","stylisPlugins","disableCSSOMInjection","disableVendorPrefixes","getName","isCss","parentComponentId","shouldForwardProp","componentStyle","foldedComponentIds","$as","withComponent","_foldedDefaultProps","withConfig","createStyles","removeStyles","renderStyles","_emitSheetCSS","getStyleTags","sealed","getStyleElement","seal","collectStyles","interleaveWithNodeStream","Bracket","styled","div","mobileBreakpoint","Round","RoundTitle","_templateObject","_taggedTemplateLiteralLoose","SeedsList","_templateObject2","SeedItem","_templateObject$1","SeedTeam","_templateObject2$1","SeedTime","Seed","renderTitle","renderSeed","breakpoint","_seed$teams","_seed$teams$","_seed$teams2","_seed$teams2$","SingleElimination","_ref$rtl","roundClassName","bracketClassName","swipeableProps","_ref$swipeableProps","_ref$mobileBreakpoint","renderSeedComponent","_ref$renderSeedCompon","roundTitleComponent","_ref$roundTitleCompon","isResponsive","breakPoint","_useState","innerWidth","isSmaller","setIsSmaller","screenResized","useMedia","roundIdx","_objectWithoutPropertiesLoose","minHeight","TournamentsSection","tournaments","setTournaments","selectedTournament","setSelectedTournament","fetchTournaments","tournament","handleMoreInfo","handleCloseModal","NoticiasSection","news","setNews","selectedNews","setSelectedNews","fetchNews","toLocaleDateString","frameBorder","allowFullScreen","AffiliatesSection","affiliates","setAffiliates","fetchAffiliates","affiliate","Footer","HomePage","ProtectedRoute","onPerfEntry","getCLS","getFID","getFCP","getLCP","getTTFB","getElementById","App","reportWebVitals"],"sourceRoot":""}