UNPKG

186 kBJavaScriptView Raw
1!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(require("@firebase/app")):"function"==typeof define&&define.amd?define(["@firebase/app"],e):e((t=t||self).firebase)}(this,function(Bi){"use strict";try{(function(){Bi=Bi&&Object.prototype.hasOwnProperty.call(Bi,"default")?Bi.default:Bi;var r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])})(t,e)};function t(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}var u=function(){return(u=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var i in e=arguments[n])Object.prototype.hasOwnProperty.call(e,i)&&(t[i]=e[i]);return t}).apply(this,arguments)};function e(t,s,a,h){return new(a=a||Promise)(function(e,n){function r(t){try{o(h.next(t))}catch(t){n(t)}}function i(t){try{o(h.throw(t))}catch(t){n(t)}}function o(t){t.done?e(t.value):function(e){return e instanceof a?e:new a(function(t){t(e)})}(t.value).then(r,i)}o((h=h.apply(t,s||[])).next())})}function n(n,r){var i,o,s,t,a={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return t={next:e(0),throw:e(1),return:e(2)},"function"==typeof Symbol&&(t[Symbol.iterator]=function(){return this}),t;function e(e){return function(t){return function(e){if(i)throw new TypeError("Generator is already executing.");for(;a;)try{if(i=1,o&&(s=2&e[0]?o.return:e[0]?o.throw||((s=o.return)&&s.call(o),0):o.next)&&!(s=s.call(o,e[1])).done)return s;switch(o=0,s&&(e=[2&e[0],s.value]),e[0]){case 0:case 1:s=e;break;case 4:return a.label++,{value:e[1],done:!1};case 5:a.label++,o=e[1],e=[0];continue;case 7:e=a.ops.pop(),a.trys.pop();continue;default:if(!(s=0<(s=a.trys).length&&s[s.length-1])&&(6===e[0]||2===e[0])){a=0;continue}if(3===e[0]&&(!s||e[1]>s[0]&&e[1]<s[3])){a.label=e[1];break}if(6===e[0]&&a.label<s[1]){a.label=s[1],s=e;break}if(s&&a.label<s[2]){a.label=s[2],a.ops.push(e);break}s[2]&&a.ops.pop(),a.trys.pop();continue}e=r.call(n,a)}catch(t){e=[6,t],o=0}finally{i=s=0}if(5&e[0])throw e[1];return{value:e[0]?e[1]:void 0,done:!0}}([e,t])}}}function f(t){var e="function"==typeof Symbol&&Symbol.iterator,n=e&&t[e],r=0;if(n)return n.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function _(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,i,o=n.call(t),s=[];try{for(;(void 0===e||0<e--)&&!(r=o.next()).done;)s.push(r.value)}catch(t){i={error:t}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(i)throw i.error}}return s}function o(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(_(arguments[e]));return t}function s(t){for(var e=[],n=0,r=0;r<t.length;r++){var i=t.charCodeAt(r);i<128?e[n++]=i:(i<2048?e[n++]=i>>6|192:(55296==(64512&i)&&r+1<t.length&&56320==(64512&t.charCodeAt(r+1))?(i=65536+((1023&i)<<10)+(1023&t.charCodeAt(++r)),e[n++]=i>>18|240,e[n++]=i>>12&63|128):e[n++]=i>>12|224,e[n++]=i>>6&63|128),e[n++]=63&i|128)}return e}function a(t){try{return l.decodeString(t,!0)}catch(t){console.error("base64Decode failed: ",t)}return null}var h={NODE_CLIENT:!1,NODE_ADMIN:!1,SDK_VERSION:"${JSCORE_VERSION}"},C=function(t,e){if(!t)throw c(e)},c=function(t){return new Error("Firebase Database ("+h.SDK_VERSION+") INTERNAL ASSERT FAILED: "+t)},l={byteToCharMap_:null,charToByteMap_:null,byteToCharMapWebSafe_:null,charToByteMapWebSafe_:null,ENCODED_VALS_BASE:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",get ENCODED_VALS(){return this.ENCODED_VALS_BASE+"+/="},get ENCODED_VALS_WEBSAFE(){return this.ENCODED_VALS_BASE+"-_."},HAS_NATIVE_SUPPORT:"function"==typeof atob,encodeByteArray:function(t,e){if(!Array.isArray(t))throw Error("encodeByteArray takes an array as a parameter");this.init_();for(var n=e?this.byteToCharMapWebSafe_:this.byteToCharMap_,r=[],i=0;i<t.length;i+=3){var o=t[i],s=i+1<t.length,a=s?t[i+1]:0,h=i+2<t.length,l=h?t[i+2]:0,u=o>>2,c=(3&o)<<4|a>>4,p=(15&a)<<2|l>>6,d=63&l;h||(d=64,s||(p=64)),r.push(n[u],n[c],n[p],n[d])}return r.join("")},encodeString:function(t,e){return this.HAS_NATIVE_SUPPORT&&!e?btoa(t):this.encodeByteArray(s(t),e)},decodeString:function(t,e){return this.HAS_NATIVE_SUPPORT&&!e?atob(t):function(t){for(var e=[],n=0,r=0;n<t.length;){var i=t[n++];if(i<128)e[r++]=String.fromCharCode(i);else if(191<i&&i<224){var o=t[n++];e[r++]=String.fromCharCode((31&i)<<6|63&o)}else if(239<i&&i<365){var s=((7&i)<<18|(63&(o=t[n++]))<<12|(63&(a=t[n++]))<<6|63&t[n++])-65536;e[r++]=String.fromCharCode(55296+(s>>10)),e[r++]=String.fromCharCode(56320+(1023&s))}else{o=t[n++];var a=t[n++];e[r++]=String.fromCharCode((15&i)<<12|(63&o)<<6|63&a)}}return e.join("")}(this.decodeStringToByteArray(t,e))},decodeStringToByteArray:function(t,e){this.init_();for(var n=e?this.charToByteMapWebSafe_:this.charToByteMap_,r=[],i=0;i<t.length;){var o=n[t.charAt(i++)],s=i<t.length?n[t.charAt(i)]:0,a=++i<t.length?n[t.charAt(i)]:64,h=++i<t.length?n[t.charAt(i)]:64;if(++i,null==o||null==s||null==a||null==h)throw Error();var l=o<<2|s>>4;if(r.push(l),64!==a){var u=s<<4&240|a>>2;if(r.push(u),64!==h){var c=a<<6&192|h;r.push(c)}}}return r},init_:function(){if(!this.byteToCharMap_){this.byteToCharMap_={},this.charToByteMap_={},this.byteToCharMapWebSafe_={},this.charToByteMapWebSafe_={};for(var t=0;t<this.ENCODED_VALS.length;t++)this.byteToCharMap_[t]=this.ENCODED_VALS.charAt(t),this.charToByteMap_[this.byteToCharMap_[t]]=t,this.byteToCharMapWebSafe_[t]=this.ENCODED_VALS_WEBSAFE.charAt(t),(this.charToByteMapWebSafe_[this.byteToCharMapWebSafe_[t]]=t)>=this.ENCODED_VALS_BASE.length&&(this.charToByteMap_[this.ENCODED_VALS_WEBSAFE.charAt(t)]=t,this.charToByteMapWebSafe_[this.ENCODED_VALS.charAt(t)]=t)}}};function i(t){return function t(e,n){if(!(n instanceof Object))return n;switch(n.constructor){case Date:var r=n;return new Date(r.getTime());case Object:void 0===e&&(e={});break;case Array:e=[];break;default:return n}for(var i in n)n.hasOwnProperty(i)&&(e[i]=t(e[i],n[i]));return e}(void 0,t)}var p=(d.prototype.wrapCallback=function(n){var r=this;return function(t,e){t?r.reject(t):r.resolve(e),"function"==typeof n&&(r.promise.catch(function(){}),1===n.length?n(t):n(t,e))}},d);function d(){var n=this;this.reject=function(){},this.resolve=function(){},this.promise=new Promise(function(t,e){n.resolve=t,n.reject=e})}function y(){return"undefined"!=typeof window&&!!(window.cordova||window.phonegap||window.PhoneGap)&&/ios|iphone|ipod|ipad|android|blackberry|iemobile/i.test("undefined"!=typeof navigator&&"string"==typeof navigator.userAgent?navigator.userAgent:"")}function v(){return!0===h.NODE_ADMIN}var g,m=(t(E,g=Error),E);function E(t,e){var n=g.call(this,e)||this;return n.code=t,n.name="FirebaseError",Object.setPrototypeOf(n,E.prototype),Error.captureStackTrace&&Error.captureStackTrace(n,w.prototype.create),n}var w=(b.prototype.create=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];for(var r=e[0]||{},i=this.service+"/"+t,o=this.errors[t],s=o?function(t,r){return t.replace(S,function(t,e){var n=r[e];return null!=n?n.toString():"<"+e+"?>"})}(o,r):"Error",a=this.serviceName+": "+s+" ("+i+").",h=new m(i,a),l=0,u=Object.keys(r);l<u.length;l++){var c=u[l];"_"!==c.slice(-1)&&(c in h&&console.warn('Overwriting FirebaseError base field "'+c+'" can cause unexpected behavior.'),h[c]=r[c])}return h},b);function b(t,e,n){this.service=t,this.serviceName=e,this.errors=n}var S=/\{\$([^}]+)}/g;function T(t){return JSON.parse(t)}function I(t){return JSON.stringify(t)}function N(t){var e={},n={},r={},i="";try{var o=t.split(".");e=T(a(o[0])||""),n=T(a(o[1])||""),i=o[2],r=n.d||{},delete n.d}catch(t){}return{header:e,claims:n,data:r,signature:i}}function R(t,e){return Object.prototype.hasOwnProperty.call(t,e)}function P(t,e){return Object.prototype.hasOwnProperty.call(t,e)?t[e]:void 0}function D(t){for(var e in t)if(Object.prototype.hasOwnProperty.call(t,e))return!1;return!0}function O(t,e,n){var r={};for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(r[i]=e.call(n,t[i],i,t));return r}var x=(k.prototype.reset=function(){this.chain_[0]=1732584193,this.chain_[1]=4023233417,this.chain_[2]=2562383102,this.chain_[3]=271733878,this.chain_[4]=3285377520,this.inbuf_=0,this.total_=0},k.prototype.compress_=function(t,e){e=e||0;var n=this.W_;if("string"==typeof t)for(var r=0;r<16;r++)n[r]=t.charCodeAt(e)<<24|t.charCodeAt(e+1)<<16|t.charCodeAt(e+2)<<8|t.charCodeAt(e+3),e+=4;else for(r=0;r<16;r++)n[r]=t[e]<<24|t[e+1]<<16|t[e+2]<<8|t[e+3],e+=4;for(r=16;r<80;r++){var i=n[r-3]^n[r-8]^n[r-14]^n[r-16];n[r]=4294967295&(i<<1|i>>>31)}var o,s,a=this.chain_[0],h=this.chain_[1],l=this.chain_[2],u=this.chain_[3],c=this.chain_[4];for(r=0;r<80;r++)s=r<40?r<20?(o=u^h&(l^u),1518500249):(o=h^l^u,1859775393):r<60?(o=h&l|u&(h|l),2400959708):(o=h^l^u,3395469782),i=(a<<5|a>>>27)+o+c+s+n[r]&4294967295,c=u,u=l,l=4294967295&(h<<30|h>>>2),h=a,a=i;this.chain_[0]=this.chain_[0]+a&4294967295,this.chain_[1]=this.chain_[1]+h&4294967295,this.chain_[2]=this.chain_[2]+l&4294967295,this.chain_[3]=this.chain_[3]+u&4294967295,this.chain_[4]=this.chain_[4]+c&4294967295},k.prototype.update=function(t,e){if(null!=t){void 0===e&&(e=t.length);for(var n=e-this.blockSize,r=0,i=this.buf_,o=this.inbuf_;r<e;){if(0===o)for(;r<=n;)this.compress_(t,r),r+=this.blockSize;if("string"==typeof t){for(;r<e;)if(i[o]=t.charCodeAt(r),++r,++o===this.blockSize){this.compress_(i),o=0;break}}else for(;r<e;)if(i[o]=t[r],++r,++o===this.blockSize){this.compress_(i),o=0;break}}this.inbuf_=o,this.total_+=e}},k.prototype.digest=function(){var t=[],e=8*this.total_;this.inbuf_<56?this.update(this.pad_,56-this.inbuf_):this.update(this.pad_,this.blockSize-(this.inbuf_-56));for(var n=this.blockSize-1;56<=n;n--)this.buf_[n]=255&e,e/=256;this.compress_(this.buf_);var r=0;for(n=0;n<5;n++)for(var i=24;0<=i;i-=8)t[r]=this.chain_[n]>>i&255,++r;return t},k);function k(){this.chain_=[],this.buf_=[],this.W_=[],this.pad_=[],this.inbuf_=0,this.total_=0,this.blockSize=64,this.pad_[0]=128;for(var t=1;t<this.blockSize;++t)this.pad_[t]=0;this.reset()}function F(t,e,n,r){var i;if(r<e?i="at least "+e:n<r&&(i=0===n?"none":"no more than "+n),i)throw new Error(t+" failed: Was called with "+r+(1===r?" argument.":" arguments.")+" Expects "+i+".")}function A(t,e,n){var r="";switch(e){case 1:r=n?"first":"First";break;case 2:r=n?"second":"Second";break;case 3:r=n?"third":"Third";break;case 4:r=n?"fourth":"Fourth";break;default:throw new Error("errorPrefix called with argumentNumber > 4. Need to update it?")}var i=t+" failed: ";return i+=r+" argument "}function L(t,e,n,r){if((!r||n)&&"function"!=typeof n)throw new Error(A(t,e,r)+"must be a valid function.")}function M(t,e,n,r){if((!r||n)&&("object"!=typeof n||null===n))throw new Error(A(t,e,r)+"must be a valid context object.")}function W(t){for(var e=0,n=0;n<t.length;n++){var r=t.charCodeAt(n);r<128?e++:r<2048?e+=2:55296<=r&&r<=56319?(e+=4,n++):e+=3}return e}var Q,q,U;function V(){for(var t=0,e=0,n=arguments.length;e<n;e++)t+=arguments[e].length;var r=Array(t),i=0;for(e=0;e<n;e++)for(var o=arguments[e],s=0,a=o.length;s<a;s++,i++)r[i]=o[s];return r}(U=q=q||{})[U.DEBUG=0]="DEBUG",U[U.VERBOSE=1]="VERBOSE",U[U.INFO=2]="INFO",U[U.WARN=3]="WARN",U[U.ERROR=4]="ERROR",U[U.SILENT=5]="SILENT";q.DEBUG,q.VERBOSE,q.INFO,q.WARN,q.ERROR,q.SILENT;function H(t,e){for(var n=[],r=2;r<arguments.length;r++)n[r-2]=arguments[r];if(!(e<t.logLevel)){var i=(new Date).toISOString(),o=j[e];if(!o)throw new Error("Attempted to log a message with an invalid logType (value: "+e+")");console[o].apply(console,V(["["+i+"] "+t.name+":"],n))}}var B=q.INFO,j=((Q={})[q.DEBUG]="log",Q[q.VERBOSE]="log",Q[q.INFO]="info",Q[q.WARN]="warn",Q[q.ERROR]="error",Q),K=(Object.defineProperty(Y.prototype,"logLevel",{get:function(){return this._logLevel},set:function(t){if(!(t in q))throw new TypeError("Invalid value assigned to `logLevel`");this._logLevel=t},enumerable:!0,configurable:!0}),Object.defineProperty(Y.prototype,"logHandler",{get:function(){return this._logHandler},set:function(t){if("function"!=typeof t)throw new TypeError("Value assigned to `logHandler` must be a function");this._logHandler=t},enumerable:!0,configurable:!0}),Object.defineProperty(Y.prototype,"userLogHandler",{get:function(){return this._userLogHandler},set:function(t){this._userLogHandler=t},enumerable:!0,configurable:!0}),Y.prototype.debug=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];this._userLogHandler&&this._userLogHandler.apply(this,V([this,q.DEBUG],t)),this._logHandler.apply(this,V([this,q.DEBUG],t))},Y.prototype.log=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];this._userLogHandler&&this._userLogHandler.apply(this,V([this,q.VERBOSE],t)),this._logHandler.apply(this,V([this,q.VERBOSE],t))},Y.prototype.info=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];this._userLogHandler&&this._userLogHandler.apply(this,V([this,q.INFO],t)),this._logHandler.apply(this,V([this,q.INFO],t))},Y.prototype.warn=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];this._userLogHandler&&this._userLogHandler.apply(this,V([this,q.WARN],t)),this._logHandler.apply(this,V([this,q.WARN],t))},Y.prototype.error=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];this._userLogHandler&&this._userLogHandler.apply(this,V([this,q.ERROR],t)),this._logHandler.apply(this,V([this,q.ERROR],t))},Y);function Y(t){this.name=t,this._logLevel=B,this._logHandler=H,this._userLogHandler=null}var z=(G.prototype.setInstantiationMode=function(t){return this.instantiationMode=t,this},G.prototype.setMultipleInstances=function(t){return this.multipleInstances=t,this},G.prototype.setServiceProps=function(t){return this.serviceProps=t,this},G);function G(t,e,n){this.name=t,this.instanceFactory=e,this.type=n,this.multipleInstances=!1,this.serviceProps={},this.instantiationMode="LAZY"}var X=($.prototype.set=function(t,e){null==e?this.domStorage_.removeItem(this.prefixedName_(t)):this.domStorage_.setItem(this.prefixedName_(t),I(e))},$.prototype.get=function(t){var e=this.domStorage_.getItem(this.prefixedName_(t));return null==e?null:T(e)},$.prototype.remove=function(t){this.domStorage_.removeItem(this.prefixedName_(t))},$.prototype.prefixedName_=function(t){return this.prefix_+t},$.prototype.toString=function(){return this.domStorage_.toString()},$);function $(t){this.domStorage_=t,this.prefix_="firebase:"}var J=(Z.prototype.set=function(t,e){null==e?delete this.cache_[t]:this.cache_[t]=e},Z.prototype.get=function(t){return R(this.cache_,t)?this.cache_[t]:null},Z.prototype.remove=function(t){delete this.cache_[t]},Z);function Z(){this.cache_={},this.isInMemoryStorage=!0}function tt(t){try{if("undefined"!=typeof window&&void 0!==window[t]){var e=window[t];return e.setItem("firebase:sentinel","cache"),e.removeItem("firebase:sentinel"),new X(e)}}catch(t){}return new J}function et(t){var e=function(t){for(var e=[],n=0,r=0;r<t.length;r++){var i=t.charCodeAt(r);if(55296<=i&&i<=56319){var o=i-55296;C(++r<t.length,"Surrogate pair missing trail surrogate."),i=65536+(o<<10)+(t.charCodeAt(r)-56320)}i<128?e[n++]=i:(i<2048?e[n++]=i>>6|192:(i<65536?e[n++]=i>>12|224:(e[n++]=i>>18|240,e[n++]=i>>12&63|128),e[n++]=i>>6&63|128),e[n++]=63&i|128)}return e}(t),n=new x;n.update(e);var r=n.digest();return l.encodeByteArray(r)}function nt(t,e){C(!e||!0===t||!1===t,"Can't turn on custom loggers persistently."),!0===t?(_t.logLevel=q.VERBOSE,gt=_t.log.bind(_t),e&&ft.set("logging_enabled",!0)):"function"==typeof t?gt=t:(gt=null,ft.remove("logging_enabled"))}function rt(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];if(!0===mt&&(mt=!1,null===gt&&!0===ft.get("logging_enabled")&&nt(!0)),gt){var n=vt.apply(null,t);gt(n)}}function it(n){return function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];rt.apply(void 0,o([n],t))}}function ot(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n="FIREBASE INTERNAL ERROR: "+vt.apply(void 0,o(t));_t.error(n)}function st(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n="FIREBASE FATAL ERROR: "+vt.apply(void 0,o(t));throw _t.error(n),new Error(n)}function at(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n="FIREBASE WARNING: "+vt.apply(void 0,o(t));_t.warn(n)}function ht(t){return"number"==typeof t&&(t!=t||t===Number.POSITIVE_INFINITY||t===Number.NEGATIVE_INFINITY)}function lt(t,e){return t===e?0:t<e?-1:1}function ut(t,e){if(e&&t in e)return e[t];throw new Error("Missing required key ("+t+") in object: "+I(e))}function ct(t,e){var n=t.length;if(n<=e)return[t];for(var r=[],i=0;i<n;i+=e)n<i+e?r.push(t.substring(i,n)):r.push(t.substring(i,i+e));return r}var pt,dt=tt("localStorage"),ft=tt("sessionStorage"),_t=new K("@firebase/database"),yt=(pt=1,function(){return pt++}),vt=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];for(var n="",r=0;r<t.length;r++){var i=t[r];Array.isArray(i)||i&&"object"==typeof i&&"number"==typeof i.length?n+=vt.apply(null,i):n+="object"==typeof i?I(i):i,n+=" "}return n},gt=null,mt=!0,Ct="[MIN_NAME]",Et="[MAX_NAME]",wt=function(t,e){if(t===e)return 0;if(t===Ct||e===Et)return-1;if(e===Ct||t===Et)return 1;var n=Pt(t),r=Pt(e);return null!==n?null!==r?n-r==0?t.length-e.length:n-r:-1:null!==r?1:t<e?-1:1},bt=function(t){if("object"!=typeof t||null===t)return I(t);var e=[];for(var n in t)e.push(n);e.sort();for(var r="{",i=0;i<e.length;i++)0!==i&&(r+=","),r+=I(e[i]),r+=":",r+=bt(t[e[i]]);return r+="}"};function St(t,e){for(var n in t)t.hasOwnProperty(n)&&e(n,t[n])}function Tt(t){var e,n,r,i,o;C(!ht(t),"Invalid JSON number"),0===t?e=1/t==-1/(r=n=0)?1:0:(e=t<0,r=(t=Math.abs(t))>=Math.pow(2,-1022)?(n=(i=Math.min(Math.floor(Math.log(t)/Math.LN2),1023))+1023,Math.round(t*Math.pow(2,52-i)-Math.pow(2,52))):(n=0,Math.round(t/Math.pow(2,-1074))));var s=[];for(o=52;o;o-=1)s.push(r%2?1:0),r=Math.floor(r/2);for(o=11;o;o-=1)s.push(n%2?1:0),n=Math.floor(n/2);s.push(e?1:0),s.reverse();var a=s.join(""),h="";for(o=0;o<64;o+=8){var l=parseInt(a.substr(o,8),2).toString(16);1===l.length&&(l="0"+l),h+=l}return h.toLowerCase()}function It(t){try{t()}catch(e){setTimeout(function(){var t=e.stack||"";throw at("Exception was thrown by user callback.",t),e},Math.floor(0))}}function Nt(t,e){var n=setTimeout(t,e);return"object"==typeof n&&n.unref&&n.unref(),n}var Rt=new RegExp("^-?(0*)\\d{1,10}$"),Pt=function(t){if(Rt.test(t)){var e=Number(t);if(-2147483648<=e&&e<=2147483647)return e}return null},Dt=(Object.defineProperty(Ot,"Empty",{get:function(){return new Ot("")},enumerable:!0,configurable:!0}),Ot.prototype.getFront=function(){return this.pieceNum_>=this.pieces_.length?null:this.pieces_[this.pieceNum_]},Ot.prototype.getLength=function(){return this.pieces_.length-this.pieceNum_},Ot.prototype.popFront=function(){var t=this.pieceNum_;return t<this.pieces_.length&&t++,new Ot(this.pieces_,t)},Ot.prototype.getBack=function(){return this.pieceNum_<this.pieces_.length?this.pieces_[this.pieces_.length-1]:null},Ot.prototype.toString=function(){for(var t="",e=this.pieceNum_;e<this.pieces_.length;e++)""!==this.pieces_[e]&&(t+="/"+this.pieces_[e]);return t||"/"},Ot.prototype.toUrlEncodedString=function(){for(var t="",e=this.pieceNum_;e<this.pieces_.length;e++)""!==this.pieces_[e]&&(t+="/"+encodeURIComponent(String(this.pieces_[e])));return t||"/"},Ot.prototype.slice=function(t){return void 0===t&&(t=0),this.pieces_.slice(this.pieceNum_+t)},Ot.prototype.parent=function(){if(this.pieceNum_>=this.pieces_.length)return null;for(var t=[],e=this.pieceNum_;e<this.pieces_.length-1;e++)t.push(this.pieces_[e]);return new Ot(t,0)},Ot.prototype.child=function(t){for(var e=[],n=this.pieceNum_;n<this.pieces_.length;n++)e.push(this.pieces_[n]);if(t instanceof Ot)for(n=t.pieceNum_;n<t.pieces_.length;n++)e.push(t.pieces_[n]);else{var r=t.split("/");for(n=0;n<r.length;n++)0<r[n].length&&e.push(r[n])}return new Ot(e,0)},Ot.prototype.isEmpty=function(){return this.pieceNum_>=this.pieces_.length},Ot.relativePath=function(t,e){var n=t.getFront(),r=e.getFront();if(null===n)return e;if(n===r)return Ot.relativePath(t.popFront(),e.popFront());throw new Error("INTERNAL ERROR: innerPath ("+e+") is not within outerPath ("+t+")")},Ot.comparePaths=function(t,e){for(var n=t.slice(),r=e.slice(),i=0;i<n.length&&i<r.length;i++){var o=wt(n[i],r[i]);if(0!==o)return o}return n.length===r.length?0:n.length<r.length?-1:1},Ot.prototype.equals=function(t){if(this.getLength()!==t.getLength())return!1;for(var e=this.pieceNum_,n=t.pieceNum_;e<=this.pieces_.length;e++,n++)if(this.pieces_[e]!==t.pieces_[n])return!1;return!0},Ot.prototype.contains=function(t){var e=this.pieceNum_,n=t.pieceNum_;if(this.getLength()>t.getLength())return!1;for(;e<this.pieces_.length;){if(this.pieces_[e]!==t.pieces_[n])return!1;++e,++n}return!0},Ot);function Ot(t,e){if(void 0===e){this.pieces_=t.split("/");for(var n=0,r=0;r<this.pieces_.length;r++)0<this.pieces_[r].length&&(this.pieces_[n]=this.pieces_[r],n++);this.pieces_.length=n,this.pieceNum_=0}else this.pieces_=t,this.pieceNum_=e}var xt=(Object.defineProperty(kt,"MAX_PATH_DEPTH",{get:function(){return 32},enumerable:!0,configurable:!0}),Object.defineProperty(kt,"MAX_PATH_LENGTH_BYTES",{get:function(){return 768},enumerable:!0,configurable:!0}),kt.prototype.push=function(t){0<this.parts_.length&&(this.byteLength_+=1),this.parts_.push(t),this.byteLength_+=W(t),this.checkValid_()},kt.prototype.pop=function(){var t=this.parts_.pop();this.byteLength_-=W(t),0<this.parts_.length&&(this.byteLength_-=1)},kt.prototype.checkValid_=function(){if(this.byteLength_>kt.MAX_PATH_LENGTH_BYTES)throw new Error(this.errorPrefix_+"has a key path longer than "+kt.MAX_PATH_LENGTH_BYTES+" bytes ("+this.byteLength_+").");if(this.parts_.length>kt.MAX_PATH_DEPTH)throw new Error(this.errorPrefix_+"path specified exceeds the maximum depth that can be written ("+kt.MAX_PATH_DEPTH+") or object contains a cycle "+this.toErrorString())},kt.prototype.toErrorString=function(){return 0===this.parts_.length?"":"in property '"+this.parts_.join(".")+"'"},kt);function kt(t,e){this.errorPrefix_=e,this.parts_=t.slice(),this.byteLength_=Math.max(1,this.parts_.length);for(var n=0;n<this.parts_.length;n++)this.byteLength_+=W(this.parts_[n]);this.checkValid_()}var Ft="firebaseio.com",At="websocket",Lt="long_polling",Mt=(Wt.prototype.needsQueryParam=function(){return this.host!==this.internalHost||this.isCustomHost()||this.includeNamespaceInQueryParams},Wt.prototype.isCacheableHost=function(){return"s-"===this.internalHost.substr(0,2)},Wt.prototype.isDemoHost=function(){return"firebaseio-demo.com"===this.domain},Wt.prototype.isCustomHost=function(){return"firebaseio.com"!==this.domain&&"firebaseio-demo.com"!==this.domain},Wt.prototype.updateHost=function(t){t!==this.internalHost&&(this.internalHost=t,this.isCacheableHost()&&dt.set("host:"+this.host,this.internalHost))},Wt.prototype.connectionURL=function(t,e){var n;if(C("string"==typeof t,"typeof type must == string"),C("object"==typeof e,"typeof params must == object"),t===At)n=(this.secure?"wss://":"ws://")+this.internalHost+"/.ws?";else{if(t!==Lt)throw new Error("Unknown connection type: "+t);n=(this.secure?"https://":"http://")+this.internalHost+"/.lp?"}this.needsQueryParam()&&(e.ns=this.namespace);var r=[];return St(e,function(t,e){r.push(t+"="+e)}),n+r.join("&")},Wt.prototype.toString=function(){var t=this.toURLString();return this.persistenceKey&&(t+="<"+this.persistenceKey+">"),t},Wt.prototype.toURLString=function(){return(this.secure?"https://":"http://")+this.host},Wt);function Wt(t,e,n,r,i,o){void 0===i&&(i=""),void 0===o&&(o=!1),this.secure=e,this.namespace=n,this.webSocketOnly=r,this.persistenceKey=i,this.includeNamespaceInQueryParams=o,this.host=t.toLowerCase(),this.domain=this.host.substr(this.host.indexOf(".")+1),this.internalHost=dt.get("host:"+t)||this.host}function Qt(t){var e=$t(t),n=e.namespace;"firebase"===e.domain&&st(e.host+" is no longer supported. Please use <YOUR FIREBASE>.firebaseio.com instead"),n&&"undefined"!==n||"localhost"===e.domain||st("Cannot parse Firebase url. Please use https://<YOUR FIREBASE>.firebaseio.com"),e.secure||"undefined"!=typeof window&&window.location&&window.location.protocol&&-1!==window.location.protocol.indexOf("https:")&&at("Insecure Firebase access from a secure page. Please use https in calls to new Firebase().");var r="ws"===e.scheme||"wss"===e.scheme;return{repoInfo:new Mt(e.host,e.secure,n,r,"",n!==e.subdomain),path:new Dt(e.pathString)}}function qt(t){return"string"==typeof t&&0!==t.length&&!Jt.test(t)}function Ut(t){return"string"==typeof t&&0!==t.length&&!Zt.test(t)}function Vt(t){return null===t||"string"==typeof t||"number"==typeof t&&!ht(t)||t&&"object"==typeof t&&R(t,".sv")}function Ht(t,e,n,r,i){i&&void 0===n||ee(A(t,e,i),n,r)}function Bt(t,e,n,r,i){if(!i||void 0!==n){var o=A(t,e,i);if(!n||"object"!=typeof n||Array.isArray(n))throw new Error(o+" must be an object containing the children to replace.");var s=[];St(n,function(t,e){var n=new Dt(t);if(ee(o,e,r.child(n)),".priority"===n.getBack()&&!Vt(e))throw new Error(o+"contains an invalid value for '"+n.toString()+"', which must be a valid Firebase priority (a string, finite number, server value, or null).");s.push(n)}),function(t,e){var n,r;for(n=0;n<e.length;n++)for(var i=(r=e[n]).slice(),o=0;o<i.length;o++)if(".priority"===i[o]&&o===i.length-1);else if(!qt(i[o]))throw new Error(t+"contains an invalid key ("+i[o]+") in path "+r.toString()+'. Keys must be non-empty strings and can\'t contain ".", "#", "$", "/", "[", or "]"');e.sort(Dt.comparePaths);var s=null;for(n=0;n<e.length;n++){if(r=e[n],null!==s&&s.contains(r))throw new Error(t+"contains a path "+s.toString()+" that is ancestor of another path "+r.toString());s=r}}(o,s)}}function jt(t,e,n,r){if(!r||void 0!==n){if(ht(n))throw new Error(A(t,e,r)+"is "+n.toString()+", but must be a valid Firebase priority (a string, finite number, server value, or null).");if(!Vt(n))throw new Error(A(t,e,r)+"must be a valid Firebase priority (a string, finite number, server value, or null).")}}function Kt(t,e,n,r){if(!r||void 0!==n)switch(n){case"value":case"child_added":case"child_removed":case"child_changed":case"child_moved":break;default:throw new Error(A(t,e,r)+'must be a valid event type = "value", "child_added", "child_removed", "child_changed", or "child_moved".')}}function Yt(t,e,n,r){if(!(r&&void 0===n||qt(n)))throw new Error(A(t,e,r)+'was an invalid key = "'+n+'". Firebase keys must be non-empty strings and can\'t contain ".", "#", "$", "/", "[", or "]").')}function zt(t,e,n,r){if(!(r&&void 0===n||Ut(n)))throw new Error(A(t,e,r)+'was an invalid path = "'+n+'". Paths must be non-empty strings and can\'t contain ".", "#", "$", "[", or "]"')}function Gt(t,e){if(".info"===e.getFront())throw new Error(t+" failed = Can't modify data under /.info/")}function Xt(t,e,n){var r=n.path.toString();if("string"!=typeof n.repoInfo.host||0===n.repoInfo.host.length||!qt(n.repoInfo.namespace)&&"localhost"!==n.repoInfo.host.split(":")[0]||0!==r.length&&!function(t){return t=t&&t.replace(/^\/*\.info(\/|$)/,"/"),Ut(t)}(r))throw new Error(A(t,e,!1)+'must be a valid firebase URL and the path can\'t contain ".", "#", "$", "[", or "]".')}var $t=function(t){var e="",n="",r="",i="",o="",s=!0,a="https",h=443;if("string"==typeof t){var l=t.indexOf("//");0<=l&&(a=t.substring(0,l-1),t=t.substring(l+2));var u=t.indexOf("/");-1===u&&(u=t.length);var c=t.indexOf("?");-1===c&&(c=t.length),e=t.substring(0,Math.min(u,c)),u<c&&(i=function(t){for(var e="",n=t.split("/"),r=0;r<n.length;r++)if(0<n[r].length){var i=n[r];try{i=decodeURIComponent(i.replace(/\+/g," "))}catch(t){}e+="/"+i}return e}(t.substring(u,c)));var p=function(t){var e,n,r={};"?"===t.charAt(0)&&(t=t.substring(1));try{for(var i=f(t.split("&")),o=i.next();!o.done;o=i.next()){var s=o.value;if(0!==s.length){var a=s.split("=");2===a.length?r[decodeURIComponent(a[0])]=decodeURIComponent(a[1]):at("Invalid query segment '"+s+"' in query '"+t+"'")}}}catch(t){e={error:t}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(e)throw e.error}}return r}(t.substring(Math.min(t.length,c)));0<=(l=e.indexOf(":"))?(s="https"===a||"wss"===a,h=parseInt(e.substring(l+1),10)):l=t.length;var d=e.split(".");3===d.length?(n=d[1],o=r=d[0].toLowerCase()):2===d.length?n=d[0]:"localhost"===d[0].slice(0,l).toLowerCase()&&(n="localhost"),"ns"in p&&(o=p.ns)}return{host:e,port:h,domain:n,subdomain:r,secure:s,scheme:a,pathString:i,namespace:o}},Jt=/[\[\].#$\/\u0000-\u001F\u007F]/,Zt=/[\[\].#$\u0000-\u001F\u007F]/,te=10485760,ee=function(n,t,e){var r=e instanceof Dt?new xt(e,n):e;if(void 0===t)throw new Error(n+"contains undefined "+r.toErrorString());if("function"==typeof t)throw new Error(n+"contains a function "+r.toErrorString()+" with contents = "+t.toString());if(ht(t))throw new Error(n+"contains "+t.toString()+" "+r.toErrorString());if("string"==typeof t&&t.length>te/3&&W(t)>te)throw new Error(n+"contains a string greater than "+te+" utf8 bytes "+r.toErrorString()+" ('"+t.substring(0,50)+"...')");if(t&&"object"==typeof t){var i=!1,o=!1;if(St(t,function(t,e){if(".value"===t)i=!0;else if(".priority"!==t&&".sv"!==t&&(o=!0,!qt(t)))throw new Error(n+" contains an invalid key ("+t+") "+r.toErrorString()+'. Keys must be non-empty strings and can\'t contain ".", "#", "$", "/", "[", or "]"');r.push(t),ee(n,e,r),r.pop()}),i&&o)throw new Error(n+' contains ".value" child '+r.toErrorString()+" in addition to actual children.")}},ne=(re.prototype.cancel=function(t){F("OnDisconnect.cancel",0,1,arguments.length),L("OnDisconnect.cancel",1,t,!0);var e=new p;return this.repo_.onDisconnectCancel(this.path_,e.wrapCallback(t)),e.promise},re.prototype.remove=function(t){F("OnDisconnect.remove",0,1,arguments.length),Gt("OnDisconnect.remove",this.path_),L("OnDisconnect.remove",1,t,!0);var e=new p;return this.repo_.onDisconnectSet(this.path_,null,e.wrapCallback(t)),e.promise},re.prototype.set=function(t,e){F("OnDisconnect.set",1,2,arguments.length),Gt("OnDisconnect.set",this.path_),Ht("OnDisconnect.set",1,t,this.path_,!1),L("OnDisconnect.set",2,e,!0);var n=new p;return this.repo_.onDisconnectSet(this.path_,t,n.wrapCallback(e)),n.promise},re.prototype.setWithPriority=function(t,e,n){F("OnDisconnect.setWithPriority",2,3,arguments.length),Gt("OnDisconnect.setWithPriority",this.path_),Ht("OnDisconnect.setWithPriority",1,t,this.path_,!1),jt("OnDisconnect.setWithPriority",2,e,!1),L("OnDisconnect.setWithPriority",3,n,!0);var r=new p;return this.repo_.onDisconnectSetWithPriority(this.path_,t,e,r.wrapCallback(n)),r.promise},re.prototype.update=function(t,e){if(F("OnDisconnect.update",1,2,arguments.length),Gt("OnDisconnect.update",this.path_),Array.isArray(t)){for(var n={},r=0;r<t.length;++r)n[""+r]=t[r];t=n,at("Passing an Array to firebase.database.onDisconnect().update() is deprecated. Use set() if you want to overwrite the existing data, or an Object with integer keys if you really do want to only update some of the children.")}Bt("OnDisconnect.update",1,t,this.path_,!1),L("OnDisconnect.update",2,e,!0);var i=new p;return this.repo_.onDisconnectUpdate(this.path_,t,i.wrapCallback(e)),i.promise},re);function re(t,e){this.repo_=t,this.path_=e}var ie=(oe.prototype.toJSON=function(){return F("TransactionResult.toJSON",0,1,arguments.length),{committed:this.committed,snapshot:this.snapshot.toJSON()}},oe);function oe(t,e){this.committed=t,this.snapshot=e}var se,ae,he,le=(se="-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz",ae=0,he=[],function(t){var e,n=t===ae;ae=t;var r=new Array(8);for(e=7;0<=e;e--)r[e]=se.charAt(t%64),t=Math.floor(t/64);C(0===t,"Cannot push at time == 0");var i=r.join("");if(n){for(e=11;0<=e&&63===he[e];e--)he[e]=0;he[e]++}else for(e=0;e<12;e++)he[e]=Math.floor(64*Math.random());for(e=0;e<12;e++)i+=se.charAt(he[e]);return C(20===i.length,"nextPushId: Length should be 20."),i}),ue=(ce.Wrap=function(t,e){return new ce(t,e)},ce);function ce(t,e){this.name=t,this.node=e}var pe,de=(fe.prototype.getCompare=function(){return this.compare.bind(this)},fe.prototype.indexedValueChanged=function(t,e){var n=new ue(Ct,t),r=new ue(Ct,e);return 0!==this.compare(n,r)},fe.prototype.minPost=function(){return ue.MIN},fe);function fe(){}var _e,ye=(t(ve,_e=de),Object.defineProperty(ve,"__EMPTY_NODE",{get:function(){return pe},set:function(t){pe=t},enumerable:!0,configurable:!0}),ve.prototype.compare=function(t,e){return wt(t.name,e.name)},ve.prototype.isDefinedOn=function(t){throw c("KeyIndex.isDefinedOn not expected to be called.")},ve.prototype.indexedValueChanged=function(t,e){return!1},ve.prototype.minPost=function(){return ue.MIN},ve.prototype.maxPost=function(){return new ue(Et,pe)},ve.prototype.makePost=function(t,e){return C("string"==typeof t,"KeyIndex indexValue must always be a string."),new ue(t,pe)},ve.prototype.toString=function(){return".key"},ve);function ve(){return null!==_e&&_e.apply(this,arguments)||this}var ge,me=new ye;function Ce(t){return"number"==typeof t?"number:"+Tt(t):"string:"+t}function Ee(t){if(t.isLeafNode()){var e=t.val();C("string"==typeof e||"number"==typeof e||"object"==typeof e&&R(e,".sv"),"Priority must be a string or number.")}else C(t===ge||t.isEmpty(),"priority of unexpected type.");C(t===ge||t.getPriority().isEmpty(),"Priority nodes can't have a priority of their own.")}var we,be,Se,Te,Ie=(Object.defineProperty(Ne,"__childrenNodeConstructor",{get:function(){return we},set:function(t){we=t},enumerable:!0,configurable:!0}),Ne.prototype.isLeafNode=function(){return!0},Ne.prototype.getPriority=function(){return this.priorityNode_},Ne.prototype.updatePriority=function(t){return new Ne(this.value_,t)},Ne.prototype.getImmediateChild=function(t){return".priority"===t?this.priorityNode_:Ne.__childrenNodeConstructor.EMPTY_NODE},Ne.prototype.getChild=function(t){return t.isEmpty()?this:".priority"===t.getFront()?this.priorityNode_:Ne.__childrenNodeConstructor.EMPTY_NODE},Ne.prototype.hasChild=function(){return!1},Ne.prototype.getPredecessorChildName=function(t,e){return null},Ne.prototype.updateImmediateChild=function(t,e){return".priority"===t?this.updatePriority(e):e.isEmpty()&&".priority"!==t?this:Ne.__childrenNodeConstructor.EMPTY_NODE.updateImmediateChild(t,e).updatePriority(this.priorityNode_)},Ne.prototype.updateChild=function(t,e){var n=t.getFront();return null===n?e:e.isEmpty()&&".priority"!==n?this:(C(".priority"!==n||1===t.getLength(),".priority must be the last token in a path"),this.updateImmediateChild(n,Ne.__childrenNodeConstructor.EMPTY_NODE.updateChild(t.popFront(),e)))},Ne.prototype.isEmpty=function(){return!1},Ne.prototype.numChildren=function(){return 0},Ne.prototype.forEachChild=function(t,e){return!1},Ne.prototype.val=function(t){return t&&!this.getPriority().isEmpty()?{".value":this.getValue(),".priority":this.getPriority().val()}:this.getValue()},Ne.prototype.hash=function(){if(null===this.lazyHash_){var t="";this.priorityNode_.isEmpty()||(t+="priority:"+Ce(this.priorityNode_.val())+":");var e=typeof this.value_;t+=e+":",t+="number"==e?Tt(this.value_):this.value_,this.lazyHash_=et(t)}return this.lazyHash_},Ne.prototype.getValue=function(){return this.value_},Ne.prototype.compareTo=function(t){return t===Ne.__childrenNodeConstructor.EMPTY_NODE?1:t instanceof Ne.__childrenNodeConstructor?-1:(C(t.isLeafNode(),"Unknown node type"),this.compareToLeafNode_(t))},Ne.prototype.compareToLeafNode_=function(t){var e=typeof t.value_,n=typeof this.value_,r=Ne.VALUE_TYPE_ORDER.indexOf(e),i=Ne.VALUE_TYPE_ORDER.indexOf(n);return C(0<=r,"Unknown leaf type: "+e),C(0<=i,"Unknown leaf type: "+n),r===i?"object"==n?0:this.value_<t.value_?-1:this.value_===t.value_?0:1:i-r},Ne.prototype.withIndex=function(){return this},Ne.prototype.isIndexed=function(){return!0},Ne.prototype.equals=function(t){if(t===this)return!0;if(t.isLeafNode()){var e=t;return this.value_===e.value_&&this.priorityNode_.equals(e.priorityNode_)}return!1},Ne.VALUE_TYPE_ORDER=["object","boolean","number","string"],Ne);function Ne(t,e){void 0===e&&(e=Ne.__childrenNodeConstructor.EMPTY_NODE),this.value_=t,this.priorityNode_=e,this.lazyHash_=null,C(void 0!==this.value_&&null!==this.value_,"LeafNode shouldn't be created with null/undefined value."),Ee(this.priorityNode_)}function Re(){return null!==Te&&Te.apply(this,arguments)||this}var Pe=new(t(Re,Te=de),Re.prototype.compare=function(t,e){var n=t.node.getPriority(),r=e.node.getPriority(),i=n.compareTo(r);return 0===i?wt(t.name,e.name):i},Re.prototype.isDefinedOn=function(t){return!t.getPriority().isEmpty()},Re.prototype.indexedValueChanged=function(t,e){return!t.getPriority().equals(e.getPriority())},Re.prototype.minPost=function(){return ue.MIN},Re.prototype.maxPost=function(){return new ue(Et,new Ie("[PRIORITY-POST]",Se))},Re.prototype.makePost=function(t,e){var n=be(t);return new ue(e,new Ie("[PRIORITY-POST]",n))},Re.prototype.toString=function(){return".priority"},Re),De=(Oe.prototype.getNext=function(){if(0===this.nodeStack_.length)return null;var t,e=this.nodeStack_.pop();if(t=this.resultGenerator_?this.resultGenerator_(e.key,e.value):{key:e.key,value:e.value},this.isReverse_)for(e=e.left;!e.isEmpty();)this.nodeStack_.push(e),e=e.right;else for(e=e.right;!e.isEmpty();)this.nodeStack_.push(e),e=e.left;return t},Oe.prototype.hasNext=function(){return 0<this.nodeStack_.length},Oe.prototype.peek=function(){if(0===this.nodeStack_.length)return null;var t=this.nodeStack_[this.nodeStack_.length-1];return this.resultGenerator_?this.resultGenerator_(t.key,t.value):{key:t.key,value:t.value}},Oe);function Oe(t,e,n,r,i){void 0===i&&(i=null),this.isReverse_=r,this.resultGenerator_=i,this.nodeStack_=[];for(var o=1;!t.isEmpty();)if(t=t,o=e?n(t.key,e):1,r&&(o*=-1),o<0)t=this.isReverse_?t.left:t.right;else{if(0===o){this.nodeStack_.push(t);break}this.nodeStack_.push(t),t=this.isReverse_?t.right:t.left}}var xe=(ke.prototype.copy=function(t,e,n,r,i){return new ke(null!=t?t:this.key,null!=e?e:this.value,null!=n?n:this.color,null!=r?r:this.left,null!=i?i:this.right)},ke.prototype.count=function(){return this.left.count()+1+this.right.count()},ke.prototype.isEmpty=function(){return!1},ke.prototype.inorderTraversal=function(t){return this.left.inorderTraversal(t)||!!t(this.key,this.value)||this.right.inorderTraversal(t)},ke.prototype.reverseTraversal=function(t){return this.right.reverseTraversal(t)||t(this.key,this.value)||this.left.reverseTraversal(t)},ke.prototype.min_=function(){return this.left.isEmpty()?this:this.left.min_()},ke.prototype.minKey=function(){return this.min_().key},ke.prototype.maxKey=function(){return this.right.isEmpty()?this.key:this.right.maxKey()},ke.prototype.insert=function(t,e,n){var r=this,i=n(t,r.key);return(r=i<0?r.copy(null,null,null,r.left.insert(t,e,n),null):0===i?r.copy(null,e,null,null,null):r.copy(null,null,null,null,r.right.insert(t,e,n))).fixUp_()},ke.prototype.removeMin_=function(){if(this.left.isEmpty())return Le.EMPTY_NODE;var t=this;return t.left.isRed_()||t.left.left.isRed_()||(t=t.moveRedLeft_()),(t=t.copy(null,null,null,t.left.removeMin_(),null)).fixUp_()},ke.prototype.remove=function(t,e){var n,r;if(e(t,(n=this).key)<0)n.left.isEmpty()||n.left.isRed_()||n.left.left.isRed_()||(n=n.moveRedLeft_()),n=n.copy(null,null,null,n.left.remove(t,e),null);else{if(n.left.isRed_()&&(n=n.rotateRight_()),n.right.isEmpty()||n.right.isRed_()||n.right.left.isRed_()||(n=n.moveRedRight_()),0===e(t,n.key)){if(n.right.isEmpty())return Le.EMPTY_NODE;r=n.right.min_(),n=n.copy(r.key,r.value,null,null,n.right.removeMin_())}n=n.copy(null,null,null,null,n.right.remove(t,e))}return n.fixUp_()},ke.prototype.isRed_=function(){return this.color},ke.prototype.fixUp_=function(){var t=this;return t.right.isRed_()&&!t.left.isRed_()&&(t=t.rotateLeft_()),t.left.isRed_()&&t.left.left.isRed_()&&(t=t.rotateRight_()),t.left.isRed_()&&t.right.isRed_()&&(t=t.colorFlip_()),t},ke.prototype.moveRedLeft_=function(){var t=this.colorFlip_();return t.right.left.isRed_()&&(t=(t=(t=t.copy(null,null,null,null,t.right.rotateRight_())).rotateLeft_()).colorFlip_()),t},ke.prototype.moveRedRight_=function(){var t=this.colorFlip_();return t.left.left.isRed_()&&(t=(t=t.rotateRight_()).colorFlip_()),t},ke.prototype.rotateLeft_=function(){var t=this.copy(null,null,ke.RED,null,this.right.left);return this.right.copy(null,null,this.color,t,null)},ke.prototype.rotateRight_=function(){var t=this.copy(null,null,ke.RED,this.left.right,null);return this.left.copy(null,null,this.color,null,t)},ke.prototype.colorFlip_=function(){var t=this.left.copy(null,null,!this.left.color,null,null),e=this.right.copy(null,null,!this.right.color,null,null);return this.copy(null,null,!this.color,t,e)},ke.prototype.checkMaxDepth_=function(){var t=this.check_();return Math.pow(2,t)<=this.count()+1},ke.prototype.check_=function(){if(this.isRed_()&&this.left.isRed_())throw new Error("Red node has red child("+this.key+","+this.value+")");if(this.right.isRed_())throw new Error("Right child of ("+this.key+","+this.value+") is red");var t=this.left.check_();if(t!==this.right.check_())throw new Error("Black depths differ");return t+(this.isRed_()?0:1)},ke.RED=!0,ke.BLACK=!1,ke);function ke(t,e,n,r,i){this.key=t,this.value=e,this.color=null!=n?n:ke.RED,this.left=null!=r?r:Le.EMPTY_NODE,this.right=null!=i?i:Le.EMPTY_NODE}var Fe=(Ae.prototype.copy=function(t,e,n,r,i){return this},Ae.prototype.insert=function(t,e,n){return new xe(t,e,null)},Ae.prototype.remove=function(t,e){return this},Ae.prototype.count=function(){return 0},Ae.prototype.isEmpty=function(){return!0},Ae.prototype.inorderTraversal=function(t){return!1},Ae.prototype.reverseTraversal=function(t){return!1},Ae.prototype.minKey=function(){return null},Ae.prototype.maxKey=function(){return null},Ae.prototype.check_=function(){return 0},Ae.prototype.isRed_=function(){return!1},Ae);function Ae(){}var Le=(Me.prototype.insert=function(t,e){return new Me(this.comparator_,this.root_.insert(t,e,this.comparator_).copy(null,null,xe.BLACK,null,null))},Me.prototype.remove=function(t){return new Me(this.comparator_,this.root_.remove(t,this.comparator_).copy(null,null,xe.BLACK,null,null))},Me.prototype.get=function(t){for(var e,n=this.root_;!n.isEmpty();){if(0===(e=this.comparator_(t,n.key)))return n.value;e<0?n=n.left:0<e&&(n=n.right)}return null},Me.prototype.getPredecessorKey=function(t){for(var e,n=this.root_,r=null;!n.isEmpty();){if(0===(e=this.comparator_(t,n.key))){if(n.left.isEmpty())return r?r.key:null;for(n=n.left;!n.right.isEmpty();)n=n.right;return n.key}e<0?n=n.left:0<e&&(n=(r=n).right)}throw new Error("Attempted to find predecessor key for a nonexistent key. What gives?")},Me.prototype.isEmpty=function(){return this.root_.isEmpty()},Me.prototype.count=function(){return this.root_.count()},Me.prototype.minKey=function(){return this.root_.minKey()},Me.prototype.maxKey=function(){return this.root_.maxKey()},Me.prototype.inorderTraversal=function(t){return this.root_.inorderTraversal(t)},Me.prototype.reverseTraversal=function(t){return this.root_.reverseTraversal(t)},Me.prototype.getIterator=function(t){return new De(this.root_,null,this.comparator_,!1,t)},Me.prototype.getIteratorFrom=function(t,e){return new De(this.root_,t,this.comparator_,!1,e)},Me.prototype.getReverseIteratorFrom=function(t,e){return new De(this.root_,t,this.comparator_,!0,e)},Me.prototype.getReverseIterator=function(t){return new De(this.root_,null,this.comparator_,!0,t)},Me.EMPTY_NODE=new Fe,Me);function Me(t,e){void 0===e&&(e=Me.EMPTY_NODE),this.comparator_=t,this.root_=e}var We=Math.log(2),Qe=(qe.prototype.nextBitIsOne=function(){var t=!(this.bits_&1<<this.current_);return this.current_--,t},qe);function qe(t){var e;this.count=(e=t+1,parseInt(Math.log(e)/We,10)),this.current_=this.count-1;var n,r=(n=this.count,parseInt(Array(n+1).join("1"),2));this.bits_=t+1&r}var Ue,Ve,He=function(l,t,u,e){l.sort(t);var c=function(t,e){var n,r,i=e-t;if(0==i)return null;if(1==i)return n=l[t],r=u?u(n):n,new xe(r,n.node,xe.BLACK,null,null);var o=parseInt(i/2,10)+t,s=c(t,o),a=c(o+1,e);return n=l[o],r=u?u(n):n,new xe(r,n.node,xe.BLACK,s,a)},n=function(t){for(var e=null,n=null,a=l.length,r=function(t,e){var n=a-t,r=a;a-=t;var i=c(1+n,r),o=l[n],s=u?u(o):o;h(new xe(s,o.node,e,null,i))},h=function(t){e=e?e.left=t:n=t},i=0;i<t.count;++i){var o=t.nextBitIsOne(),s=Math.pow(2,t.count-(i+1));o?r(s,xe.BLACK):(r(s,xe.BLACK),r(s,xe.RED))}return n}(new Qe(l.length));return new Le(e||t,n)},Be={},je=(Object.defineProperty(Ke,"Default",{get:function(){return C(Pe,"ChildrenNode.ts has not been loaded"),Ue=Ue||new Ke({".priority":Be},{".priority":Pe})},enumerable:!0,configurable:!0}),Ke.prototype.get=function(t){var e=P(this.indexes_,t);if(!e)throw new Error("No index defined for "+t);return e instanceof Le?e:null},Ke.prototype.hasIndex=function(t){return R(this.indexSet_,t.toString())},Ke.prototype.addIndex=function(t,e){C(t!==me,"KeyIndex always exists and isn't meant to be added to the IndexMap.");for(var n,r=[],i=!1,o=e.getIterator(ue.Wrap),s=o.getNext();s;)i=i||t.isDefinedOn(s.node),r.push(s),s=o.getNext();n=i?He(r,t.getCompare()):Be;var a=t.toString(),h=u({},this.indexSet_);h[a]=t;var l=u({},this.indexes_);return l[a]=n,new Ke(l,h)},Ke.prototype.addToIndexes=function(h,l){var u=this;return new Ke(O(this.indexes_,function(t,e){var n=P(u.indexSet_,e);if(C(n,"Missing index implementation for "+e),t===Be){if(n.isDefinedOn(h.node)){for(var r=[],i=l.getIterator(ue.Wrap),o=i.getNext();o;)o.name!==h.name&&r.push(o),o=i.getNext();return r.push(h),He(r,n.getCompare())}return Be}var s=l.get(h.name),a=t;return s&&(a=a.remove(new ue(h.name,s))),a.insert(h,h.node)}),this.indexSet_)},Ke.prototype.removeFromIndexes=function(n,r){return new Ke(O(this.indexes_,function(t){if(t===Be)return t;var e=r.get(n.name);return e?t.remove(new ue(n.name,e)):t}),this.indexSet_)},Ke);function Ke(t,e){this.indexes_=t,this.indexSet_=e}function Ye(t,e){return wt(t.name,e.name)}function ze(t,e){return wt(t,e)}var Ge,Xe=(Object.defineProperty($e,"EMPTY_NODE",{get:function(){return Ve=Ve||new $e(new Le(ze),null,je.Default)},enumerable:!0,configurable:!0}),$e.prototype.isLeafNode=function(){return!1},$e.prototype.getPriority=function(){return this.priorityNode_||Ve},$e.prototype.updatePriority=function(t){return this.children_.isEmpty()?this:new $e(this.children_,t,this.indexMap_)},$e.prototype.getImmediateChild=function(t){if(".priority"===t)return this.getPriority();var e=this.children_.get(t);return null===e?Ve:e},$e.prototype.getChild=function(t){var e=t.getFront();return null===e?this:this.getImmediateChild(e).getChild(t.popFront())},$e.prototype.hasChild=function(t){return null!==this.children_.get(t)},$e.prototype.updateImmediateChild=function(t,e){if(C(e,"We should always be passing snapshot nodes"),".priority"===t)return this.updatePriority(e);var n=new ue(t,e),r=void 0,i=void 0;i=e.isEmpty()?(r=this.children_.remove(t),this.indexMap_.removeFromIndexes(n,this.children_)):(r=this.children_.insert(t,e),this.indexMap_.addToIndexes(n,this.children_));var o=r.isEmpty()?Ve:this.priorityNode_;return new $e(r,o,i)},$e.prototype.updateChild=function(t,e){var n=t.getFront();if(null===n)return e;C(".priority"!==t.getFront()||1===t.getLength(),".priority must be the last token in a path");var r=this.getImmediateChild(n).updateChild(t.popFront(),e);return this.updateImmediateChild(n,r)},$e.prototype.isEmpty=function(){return this.children_.isEmpty()},$e.prototype.numChildren=function(){return this.children_.count()},$e.prototype.val=function(n){if(this.isEmpty())return null;var r={},i=0,o=0,s=!0;if(this.forEachChild(Pe,function(t,e){r[t]=e.val(n),i++,s&&$e.INTEGER_REGEXP_.test(t)?o=Math.max(o,Number(t)):s=!1}),!n&&s&&o<2*i){var t=[];for(var e in r)t[e]=r[e];return t}return n&&!this.getPriority().isEmpty()&&(r[".priority"]=this.getPriority().val()),r},$e.prototype.hash=function(){if(null===this.lazyHash_){var r="";this.getPriority().isEmpty()||(r+="priority:"+Ce(this.getPriority().val())+":"),this.forEachChild(Pe,function(t,e){var n=e.hash();""!==n&&(r+=":"+t+":"+n)}),this.lazyHash_=""===r?"":et(r)}return this.lazyHash_},$e.prototype.getPredecessorChildName=function(t,e,n){var r=this.resolveIndex_(n);if(r){var i=r.getPredecessorKey(new ue(t,e));return i?i.name:null}return this.children_.getPredecessorKey(t)},$e.prototype.getFirstChildName=function(t){var e=this.resolveIndex_(t);if(e){var n=e.minKey();return n&&n.name}return this.children_.minKey()},$e.prototype.getFirstChild=function(t){var e=this.getFirstChildName(t);return e?new ue(e,this.children_.get(e)):null},$e.prototype.getLastChildName=function(t){var e=this.resolveIndex_(t);if(e){var n=e.maxKey();return n&&n.name}return this.children_.maxKey()},$e.prototype.getLastChild=function(t){var e=this.getLastChildName(t);return e?new ue(e,this.children_.get(e)):null},$e.prototype.forEachChild=function(t,e){var n=this.resolveIndex_(t);return n?n.inorderTraversal(function(t){return e(t.name,t.node)}):this.children_.inorderTraversal(e)},$e.prototype.getIterator=function(t){return this.getIteratorFrom(t.minPost(),t)},$e.prototype.getIteratorFrom=function(t,e){var n=this.resolveIndex_(e);if(n)return n.getIteratorFrom(t,function(t){return t});for(var r=this.children_.getIteratorFrom(t.name,ue.Wrap),i=r.peek();null!=i&&e.compare(i,t)<0;)r.getNext(),i=r.peek();return r},$e.prototype.getReverseIterator=function(t){return this.getReverseIteratorFrom(t.maxPost(),t)},$e.prototype.getReverseIteratorFrom=function(t,e){var n=this.resolveIndex_(e);if(n)return n.getReverseIteratorFrom(t,function(t){return t});for(var r=this.children_.getReverseIteratorFrom(t.name,ue.Wrap),i=r.peek();null!=i&&0<e.compare(i,t);)r.getNext(),i=r.peek();return r},$e.prototype.compareTo=function(t){return this.isEmpty()?t.isEmpty()?0:-1:t.isLeafNode()||t.isEmpty()?1:t===Ze?-1:0},$e.prototype.withIndex=function(t){if(t===me||this.indexMap_.hasIndex(t))return this;var e=this.indexMap_.addIndex(t,this.children_);return new $e(this.children_,this.priorityNode_,e)},$e.prototype.isIndexed=function(t){return t===me||this.indexMap_.hasIndex(t)},$e.prototype.equals=function(t){if(t===this)return!0;if(t.isLeafNode())return!1;var e=t;if(this.getPriority().equals(e.getPriority())){if(this.children_.count()!==e.children_.count())return!1;for(var n=this.getIterator(Pe),r=e.getIterator(Pe),i=n.getNext(),o=r.getNext();i&&o;){if(i.name!==o.name||!i.node.equals(o.node))return!1;i=n.getNext(),o=r.getNext()}return null===i&&null===o}return!1},$e.prototype.resolveIndex_=function(t){return t===me?null:this.indexMap_.get(t.toString())},$e.INTEGER_REGEXP_=/^(0|[1-9]\d*)$/,$e);function $e(t,e,n){this.children_=t,this.priorityNode_=e,this.indexMap_=n,this.lazyHash_=null,this.priorityNode_&&Ee(this.priorityNode_),this.children_.isEmpty()&&C(!this.priorityNode_||this.priorityNode_.isEmpty(),"An empty node cannot have a priority")}function Je(){return Ge.call(this,new Le(ze),Xe.EMPTY_NODE,je.Default)||this}var Ze=new(t(Je,Ge=Xe),Je.prototype.compareTo=function(t){return t===this?0:1},Je.prototype.equals=function(t){return t===this},Je.prototype.getPriority=function(){return this},Je.prototype.getImmediateChild=function(t){return Xe.EMPTY_NODE},Je.prototype.isEmpty=function(){return!1},Je);Object.defineProperties(ue,{MIN:{value:new ue(Ct,Xe.EMPTY_NODE)},MAX:{value:new ue(Et,Ze)}}),ye.__EMPTY_NODE=Xe.EMPTY_NODE,Ie.__childrenNodeConstructor=Xe,ge=Ze,Se=Ze;var tn,en=!0;function nn(r,t){if(void 0===t&&(t=null),null===r)return Xe.EMPTY_NODE;if("object"==typeof r&&".priority"in r&&(t=r[".priority"]),C(null===t||"string"==typeof t||"number"==typeof t||"object"==typeof t&&".sv"in t,"Invalid priority type found: "+typeof t),"object"==typeof r&&".value"in r&&null!==r[".value"]&&(r=r[".value"]),"object"!=typeof r||".sv"in r)return new Ie(r,nn(t));if(r instanceof Array||!en){var i=Xe.EMPTY_NODE;return St(r,function(t,e){if(R(r,t)&&"."!==t.substring(0,1)){var n=nn(e);!n.isLeafNode()&&n.isEmpty()||(i=i.updateImmediateChild(t,n))}}),i.updatePriority(nn(t))}var o=[],s=!1;if(St(r,function(t,e){if("."!==t.substring(0,1)){var n=nn(e);n.isEmpty()||(s=s||!n.getPriority().isEmpty(),o.push(new ue(t,n)))}}),0===o.length)return Xe.EMPTY_NODE;var e=He(o,Ye,function(t){return t.name},ze);if(s){var n=He(o,Pe.getCompare());return new Xe(e,nn(t),new je({".priority":n},{".priority":Pe}))}return new Xe(e,nn(t),je.Default)}function rn(){return null!==tn&&tn.apply(this,arguments)||this}be=nn;var on,sn=new(t(rn,tn=de),rn.prototype.compare=function(t,e){var n=t.node.compareTo(e.node);return 0===n?wt(t.name,e.name):n},rn.prototype.isDefinedOn=function(t){return!0},rn.prototype.indexedValueChanged=function(t,e){return!t.equals(e)},rn.prototype.minPost=function(){return ue.MIN},rn.prototype.maxPost=function(){return ue.MAX},rn.prototype.makePost=function(t,e){var n=nn(t);return new ue(e,n)},rn.prototype.toString=function(){return".value"},rn),an=(t(hn,on=de),hn.prototype.extractChild=function(t){return t.getChild(this.indexPath_)},hn.prototype.isDefinedOn=function(t){return!t.getChild(this.indexPath_).isEmpty()},hn.prototype.compare=function(t,e){var n=this.extractChild(t.node),r=this.extractChild(e.node),i=n.compareTo(r);return 0===i?wt(t.name,e.name):i},hn.prototype.makePost=function(t,e){var n=nn(t),r=Xe.EMPTY_NODE.updateChild(this.indexPath_,n);return new ue(e,r)},hn.prototype.maxPost=function(){var t=Xe.EMPTY_NODE.updateChild(this.indexPath_,Ze);return new ue(Et,t)},hn.prototype.toString=function(){return this.indexPath_.slice().join("/")},hn);function hn(t){var e=on.call(this)||this;return e.indexPath_=t,C(!t.isEmpty()&&".priority"!==t.getFront(),"Can't create PathIndex with empty path or .priority key"),e}var ln=(un.prototype.val=function(){return F("DataSnapshot.val",0,0,arguments.length),this.node_.val()},un.prototype.exportVal=function(){return F("DataSnapshot.exportVal",0,0,arguments.length),this.node_.val(!0)},un.prototype.toJSON=function(){return F("DataSnapshot.toJSON",0,1,arguments.length),this.exportVal()},un.prototype.exists=function(){return F("DataSnapshot.exists",0,0,arguments.length),!this.node_.isEmpty()},un.prototype.child=function(t){F("DataSnapshot.child",0,1,arguments.length),t=String(t),zt("DataSnapshot.child",1,t,!1);var e=new Dt(t),n=this.ref_.child(e);return new un(this.node_.getChild(e),n,Pe)},un.prototype.hasChild=function(t){F("DataSnapshot.hasChild",1,1,arguments.length),zt("DataSnapshot.hasChild",1,t,!1);var e=new Dt(t);return!this.node_.getChild(e).isEmpty()},un.prototype.getPriority=function(){return F("DataSnapshot.getPriority",0,0,arguments.length),this.node_.getPriority().val()},un.prototype.forEach=function(n){var r=this;return F("DataSnapshot.forEach",1,1,arguments.length),L("DataSnapshot.forEach",1,n,!1),!this.node_.isLeafNode()&&!!this.node_.forEachChild(this.index_,function(t,e){return n(new un(e,r.ref_.child(t),Pe))})},un.prototype.hasChildren=function(){return F("DataSnapshot.hasChildren",0,0,arguments.length),!this.node_.isLeafNode()&&!this.node_.isEmpty()},Object.defineProperty(un.prototype,"key",{get:function(){return this.ref_.getKey()},enumerable:!0,configurable:!0}),un.prototype.numChildren=function(){return F("DataSnapshot.numChildren",0,0,arguments.length),this.node_.numChildren()},un.prototype.getRef=function(){return F("DataSnapshot.ref",0,0,arguments.length),this.ref_},Object.defineProperty(un.prototype,"ref",{get:function(){return this.getRef()},enumerable:!0,configurable:!0}),un);function un(t,e,n){this.node_=t,this.ref_=e,this.index_=n}var cn=(pn.prototype.getPath=function(){var t=this.snapshot.getRef();return"value"===this.eventType?t.path:t.getParent().path},pn.prototype.getEventType=function(){return this.eventType},pn.prototype.getEventRunner=function(){return this.eventRegistration.getEventRunner(this)},pn.prototype.toString=function(){return this.getPath().toString()+":"+this.eventType+":"+I(this.snapshot.exportVal())},pn);function pn(t,e,n,r){this.eventType=t,this.eventRegistration=e,this.snapshot=n,this.prevName=r}var dn=(fn.prototype.getPath=function(){return this.path},fn.prototype.getEventType=function(){return"cancel"},fn.prototype.getEventRunner=function(){return this.eventRegistration.getEventRunner(this)},fn.prototype.toString=function(){return this.path.toString()+":cancel"},fn);function fn(t,e,n){this.eventRegistration=t,this.error=e,this.path=n}var _n=(yn.prototype.respondsTo=function(t){return"value"===t},yn.prototype.createEvent=function(t,e){var n=e.getQueryParams().getIndex();return new cn("value",this,new ln(t.snapshotNode,e.getRef(),n))},yn.prototype.getEventRunner=function(t){var e=this.context_;if("cancel"===t.getEventType()){C(this.cancelCallback_,"Raising a cancel event on a listener with no cancel callback");var n=this.cancelCallback_;return function(){n.call(e,t.error)}}var r=this.callback_;return function(){r.call(e,t.snapshot)}},yn.prototype.createCancelEvent=function(t,e){return this.cancelCallback_?new dn(this,t,e):null},yn.prototype.matches=function(t){return t instanceof yn&&(!t.callback_||!this.callback_||t.callback_===this.callback_&&t.context_===this.context_)},yn.prototype.hasAnyCallback=function(){return null!==this.callback_},yn);function yn(t,e,n){this.callback_=t,this.cancelCallback_=e,this.context_=n}var vn,gn=(mn.prototype.respondsTo=function(t){var e="children_added"===t?"child_added":t;return e="children_removed"===e?"child_removed":e,R(this.callbacks_,e)},mn.prototype.createCancelEvent=function(t,e){return this.cancelCallback_?new dn(this,t,e):null},mn.prototype.createEvent=function(t,e){C(null!=t.childName,"Child events should have a childName.");var n=e.getRef().child(t.childName),r=e.getQueryParams().getIndex();return new cn(t.type,this,new ln(t.snapshotNode,n,r),t.prevName)},mn.prototype.getEventRunner=function(t){var e=this.context_;if("cancel"===t.getEventType()){C(this.cancelCallback_,"Raising a cancel event on a listener with no cancel callback");var n=this.cancelCallback_;return function(){n.call(e,t.error)}}var r=this.callbacks_[t.eventType];return function(){r.call(e,t.snapshot,t.prevName)}},mn.prototype.matches=function(e){var n=this;if(e instanceof mn){if(!this.callbacks_||!e.callbacks_)return!0;if(this.context_===e.context_){var t=Object.keys(e.callbacks_),r=Object.keys(this.callbacks_),i=t.length;if(i===r.length){if(1!==i)return r.every(function(t){return e.callbacks_[t]===n.callbacks_[t]});var o=t[0],s=r[0];return!(s!==o||e.callbacks_[o]&&this.callbacks_[s]&&e.callbacks_[o]!==this.callbacks_[s])}}}return!1},mn.prototype.hasAnyCallback=function(){return null!==this.callbacks_},mn);function mn(t,e,n){this.callbacks_=t,this.cancelCallback_=e,this.context_=n}var Cn=(Object.defineProperty(En,"__referenceConstructor",{get:function(){return C(vn,"Reference.ts has not been loaded"),vn},set:function(t){vn=t},enumerable:!0,configurable:!0}),En.validateQueryEndpoints_=function(t){var e=null,n=null;if(t.hasStart()&&(e=t.getIndexStartValue()),t.hasEnd()&&(n=t.getIndexEndValue()),t.getIndex()===me){var r="Query: When ordering by key, you may only pass one argument to startAt(), endAt(), or equalTo().",i="Query: When ordering by key, the argument passed to startAt(), endAt(),or equalTo() must be a string.";if(t.hasStart()){if(t.getIndexStartName()!==Ct)throw new Error(r);if("string"!=typeof e)throw new Error(i)}if(t.hasEnd()){if(t.getIndexEndName()!==Et)throw new Error(r);if("string"!=typeof n)throw new Error(i)}}else if(t.getIndex()===Pe){if(null!=e&&!Vt(e)||null!=n&&!Vt(n))throw new Error("Query: When ordering by priority, the first argument passed to startAt(), endAt(), or equalTo() must be a valid priority value (null, a number, or a string).")}else if(C(t.getIndex()instanceof an||t.getIndex()===sn,"unknown index type."),null!=e&&"object"==typeof e||null!=n&&"object"==typeof n)throw new Error("Query: First argument passed to startAt(), endAt(), or equalTo() cannot be an object.")},En.validateLimit_=function(t){if(t.hasStart()&&t.hasEnd()&&t.hasLimit()&&!t.hasAnchoredLimit())throw new Error("Query: Can't combine startAt(), endAt(), and limit(). Use limitToFirst() or limitToLast() instead.")},En.prototype.validateNoPreviousOrderByCall_=function(t){if(!0===this.orderByCalled_)throw new Error(t+": You can't combine multiple orderBy calls.")},En.prototype.getQueryParams=function(){return this.queryParams_},En.prototype.getRef=function(){return F("Query.ref",0,0,arguments.length),new En.__referenceConstructor(this.repo,this.path)},En.prototype.on=function(t,e,n,r){F("Query.on",2,4,arguments.length),Kt("Query.on",1,t,!1),L("Query.on",2,e,!1);var i=En.getCancelAndContextArgs_("Query.on",n,r);if("value"===t)this.onValueEvent(e,i.cancel,i.context);else{var o={};o[t]=e,this.onChildEvent(o,i.cancel,i.context)}return e},En.prototype.onValueEvent=function(t,e,n){var r=new _n(t,e||null,n||null);this.repo.addEventCallbackForQuery(this,r)},En.prototype.onChildEvent=function(t,e,n){var r=new gn(t,e,n);this.repo.addEventCallbackForQuery(this,r)},En.prototype.off=function(t,e,n){F("Query.off",0,3,arguments.length),Kt("Query.off",1,t,!0),L("Query.off",2,e,!0),M("Query.off",3,n,!0);var r=null,i=null;"value"===t?r=new _n(e||null,null,n||null):t&&(e&&((i={})[t]=e),r=new gn(i,null,n||null)),this.repo.removeEventCallbackForQuery(this,r)},En.prototype.once=function(e,n,t,r){var i=this;F("Query.once",1,4,arguments.length),Kt("Query.once",1,e,!1),L("Query.once",2,n,!0);var o=En.getCancelAndContextArgs_("Query.once",t,r),s=!0,a=new p;a.promise.catch(function(){});var h=function(t){s&&(s=!1,i.off(e,h),n&&n.bind(o.context)(t),a.resolve(t))};return this.on(e,h,function(t){i.off(e,h),o.cancel&&o.cancel.bind(o.context)(t),a.reject(t)}),a.promise},En.prototype.limitToFirst=function(t){if(F("Query.limitToFirst",1,1,arguments.length),"number"!=typeof t||Math.floor(t)!==t||t<=0)throw new Error("Query.limitToFirst: First argument must be a positive integer.");if(this.queryParams_.hasLimit())throw new Error("Query.limitToFirst: Limit was already set (by another call to limit, limitToFirst, or limitToLast).");return new En(this.repo,this.path,this.queryParams_.limitToFirst(t),this.orderByCalled_)},En.prototype.limitToLast=function(t){if(F("Query.limitToLast",1,1,arguments.length),"number"!=typeof t||Math.floor(t)!==t||t<=0)throw new Error("Query.limitToLast: First argument must be a positive integer.");if(this.queryParams_.hasLimit())throw new Error("Query.limitToLast: Limit was already set (by another call to limit, limitToFirst, or limitToLast).");return new En(this.repo,this.path,this.queryParams_.limitToLast(t),this.orderByCalled_)},En.prototype.orderByChild=function(t){if(F("Query.orderByChild",1,1,arguments.length),"$key"===t)throw new Error('Query.orderByChild: "$key" is invalid. Use Query.orderByKey() instead.');if("$priority"===t)throw new Error('Query.orderByChild: "$priority" is invalid. Use Query.orderByPriority() instead.');if("$value"===t)throw new Error('Query.orderByChild: "$value" is invalid. Use Query.orderByValue() instead.');zt("Query.orderByChild",1,t,!1),this.validateNoPreviousOrderByCall_("Query.orderByChild");var e=new Dt(t);if(e.isEmpty())throw new Error("Query.orderByChild: cannot pass in empty path. Use Query.orderByValue() instead.");var n=new an(e),r=this.queryParams_.orderBy(n);return En.validateQueryEndpoints_(r),new En(this.repo,this.path,r,!0)},En.prototype.orderByKey=function(){F("Query.orderByKey",0,0,arguments.length),this.validateNoPreviousOrderByCall_("Query.orderByKey");var t=this.queryParams_.orderBy(me);return En.validateQueryEndpoints_(t),new En(this.repo,this.path,t,!0)},En.prototype.orderByPriority=function(){F("Query.orderByPriority",0,0,arguments.length),this.validateNoPreviousOrderByCall_("Query.orderByPriority");var t=this.queryParams_.orderBy(Pe);return En.validateQueryEndpoints_(t),new En(this.repo,this.path,t,!0)},En.prototype.orderByValue=function(){F("Query.orderByValue",0,0,arguments.length),this.validateNoPreviousOrderByCall_("Query.orderByValue");var t=this.queryParams_.orderBy(sn);return En.validateQueryEndpoints_(t),new En(this.repo,this.path,t,!0)},En.prototype.startAt=function(t,e){void 0===t&&(t=null),F("Query.startAt",0,2,arguments.length),Ht("Query.startAt",1,t,this.path,!0),Yt("Query.startAt",2,e,!0);var n=this.queryParams_.startAt(t,e);if(En.validateLimit_(n),En.validateQueryEndpoints_(n),this.queryParams_.hasStart())throw new Error("Query.startAt: Starting point was already set (by another call to startAt or equalTo).");return void 0===t&&(e=t=null),new En(this.repo,this.path,n,this.orderByCalled_)},En.prototype.endAt=function(t,e){void 0===t&&(t=null),F("Query.endAt",0,2,arguments.length),Ht("Query.endAt",1,t,this.path,!0),Yt("Query.endAt",2,e,!0);var n=this.queryParams_.endAt(t,e);if(En.validateLimit_(n),En.validateQueryEndpoints_(n),this.queryParams_.hasEnd())throw new Error("Query.endAt: Ending point was already set (by another call to endAt or equalTo).");return new En(this.repo,this.path,n,this.orderByCalled_)},En.prototype.equalTo=function(t,e){if(F("Query.equalTo",1,2,arguments.length),Ht("Query.equalTo",1,t,this.path,!1),Yt("Query.equalTo",2,e,!0),this.queryParams_.hasStart())throw new Error("Query.equalTo: Starting point was already set (by another call to startAt or equalTo).");if(this.queryParams_.hasEnd())throw new Error("Query.equalTo: Ending point was already set (by another call to endAt or equalTo).");return this.startAt(t,e).endAt(t,e)},En.prototype.toString=function(){return F("Query.toString",0,0,arguments.length),this.repo.toString()+this.path.toUrlEncodedString()},En.prototype.toJSON=function(){return F("Query.toJSON",0,1,arguments.length),this.toString()},En.prototype.queryObject=function(){return this.queryParams_.getQueryObject()},En.prototype.queryIdentifier=function(){var t=this.queryObject(),e=bt(t);return"{}"===e?"default":e},En.prototype.isEqual=function(t){if(F("Query.isEqual",1,1,arguments.length),!(t instanceof En))throw new Error("Query.isEqual failed: First argument must be an instance of firebase.database.Query.");var e=this.repo===t.repo,n=this.path.equals(t.path),r=this.queryIdentifier()===t.queryIdentifier();return e&&n&&r},En.getCancelAndContextArgs_=function(t,e,n){var r={cancel:null,context:null};if(e&&n)r.cancel=e,L(t,3,r.cancel,!0),r.context=n,M(t,4,r.context,!0);else if(e)if("object"==typeof e&&null!==e)r.context=e;else{if("function"!=typeof e)throw new Error(A(t,3,!0)+" must either be a cancel callback or a context object.");r.cancel=e}return r},Object.defineProperty(En.prototype,"ref",{get:function(){return this.getRef()},enumerable:!0,configurable:!0}),En);function En(t,e,n,r){this.repo=t,this.path=e,this.queryParams_=n,this.orderByCalled_=r}var wn=(bn.prototype.find=function(t){if(null!=this.value)return this.value.getChild(t);if(!t.isEmpty()&&0<this.children.size){var e=t.getFront();return t=t.popFront(),this.children.has(e)?this.children.get(e).find(t):null}return null},bn.prototype.remember=function(t,e){if(t.isEmpty())this.value=e,this.children.clear();else if(null!==this.value)this.value=this.value.updateChild(t,e);else{var n=t.getFront();this.children.has(n)||this.children.set(n,new bn);var r=this.children.get(n);t=t.popFront(),r.remember(t,e)}},bn.prototype.forget=function(t){if(t.isEmpty())return this.value=null,this.children.clear(),!0;if(null!==this.value){if(this.value.isLeafNode())return!1;var e=this.value;this.value=null;var n=this;return e.forEachChild(Pe,function(t,e){n.remember(new Dt(t),e)}),this.forget(t)}if(0<this.children.size){var r=t.getFront();return t=t.popFront(),!this.children.has(r)||this.children.get(r).forget(t)&&this.children.delete(r),0===this.children.size}return!0},bn.prototype.forEachTree=function(r,i){null!==this.value?i(r,this.value):this.forEachChild(function(t,e){var n=new Dt(r.toString()+"/"+t);e.forEachTree(n,i)})},bn.prototype.forEachChild=function(n){this.children.forEach(function(t,e){n(e,t)})},bn);function bn(){this.value=null,this.children=new Map}function Sn(t,e){return t&&"object"==typeof t?(C(".sv"in t,"Unexpected leaf node or priority contents"),e[t[".sv"]]):t}var Tn,In,Nn=function(t,r){var i,e=t.getPriority().val(),n=Sn(e,r);if(t.isLeafNode()){var o=t,s=Sn(o.getValue(),r);return s!==o.getValue()||n!==o.getPriority().val()?new Ie(s,nn(n)):t}var a=t;return n!==(i=a).getPriority().val()&&(i=i.updatePriority(new Ie(n))),a.forEachChild(Pe,function(t,e){var n=Nn(e,r);n!==e&&(i=i.updateImmediateChild(t,n))}),i};(In=Tn=Tn||{})[In.OVERWRITE=0]="OVERWRITE",In[In.MERGE=1]="MERGE",In[In.ACK_USER_WRITE=2]="ACK_USER_WRITE",In[In.LISTEN_COMPLETE=3]="LISTEN_COMPLETE";var Rn=(Pn.User=new Pn(!0,!1,null,!1),Pn.Server=new Pn(!1,!0,null,!1),Pn.forServerTaggedQuery=function(t){return new Pn(!1,!0,t,!0)},Pn);function Pn(t,e,n,r){this.fromUser=t,this.fromServer=e,this.queryId=n,this.tagged=r,C(!r||e,"Tagged queries must be from server.")}var Dn,On=(xn.prototype.operationForChild=function(t){if(this.path.isEmpty()){if(null!=this.affectedTree.value)return C(this.affectedTree.children.isEmpty(),"affectedTree should not have overlapping affected paths."),this;var e=this.affectedTree.subtree(new Dt(t));return new xn(Dt.Empty,e,this.revert)}return C(this.path.getFront()===t,"operationForChild called for unrelated child."),new xn(this.path.popFront(),this.affectedTree,this.revert)},xn);function xn(t,e,n){this.path=t,this.affectedTree=e,this.revert=n,this.type=Tn.ACK_USER_WRITE,this.source=Rn.User}var kn=(Fn.fromObject=function(t){var n=Fn.Empty;return St(t,function(t,e){n=n.set(new Dt(t),e)}),n},Fn.prototype.isEmpty=function(){return null===this.value&&this.children.isEmpty()},Fn.prototype.findRootMostMatchingPathAndValue=function(t,e){if(null!=this.value&&e(this.value))return{path:Dt.Empty,value:this.value};if(t.isEmpty())return null;var n=t.getFront(),r=this.children.get(n);if(null===r)return null;var i=r.findRootMostMatchingPathAndValue(t.popFront(),e);return null==i?null:{path:new Dt(n).child(i.path),value:i.value}},Fn.prototype.findRootMostValueAndPath=function(t){return this.findRootMostMatchingPathAndValue(t,function(){return!0})},Fn.prototype.subtree=function(t){if(t.isEmpty())return this;var e=t.getFront(),n=this.children.get(e);return null!==n?n.subtree(t.popFront()):Fn.Empty},Fn.prototype.set=function(t,e){if(t.isEmpty())return new Fn(e,this.children);var n=t.getFront(),r=(this.children.get(n)||Fn.Empty).set(t.popFront(),e),i=this.children.insert(n,r);return new Fn(this.value,i)},Fn.prototype.remove=function(t){if(t.isEmpty())return this.children.isEmpty()?Fn.Empty:new Fn(null,this.children);var e=t.getFront(),n=this.children.get(e);if(n){var r=n.remove(t.popFront()),i=void 0;return i=r.isEmpty()?this.children.remove(e):this.children.insert(e,r),null===this.value&&i.isEmpty()?Fn.Empty:new Fn(this.value,i)}return this},Fn.prototype.get=function(t){if(t.isEmpty())return this.value;var e=t.getFront(),n=this.children.get(e);return n?n.get(t.popFront()):null},Fn.prototype.setTree=function(t,e){if(t.isEmpty())return e;var n=t.getFront(),r=(this.children.get(n)||Fn.Empty).setTree(t.popFront(),e),i=void 0;return i=r.isEmpty()?this.children.remove(n):this.children.insert(n,r),new Fn(this.value,i)},Fn.prototype.fold=function(t){return this.fold_(Dt.Empty,t)},Fn.prototype.fold_=function(n,r){var i={};return this.children.inorderTraversal(function(t,e){i[t]=e.fold_(n.child(t),r)}),r(n,this.value,i)},Fn.prototype.findOnPath=function(t,e){return this.findOnPath_(t,Dt.Empty,e)},Fn.prototype.findOnPath_=function(t,e,n){var r=!!this.value&&n(e,this.value);if(r)return r;if(t.isEmpty())return null;var i=t.getFront(),o=this.children.get(i);return o?o.findOnPath_(t.popFront(),e.child(i),n):null},Fn.prototype.foreachOnPath=function(t,e){return this.foreachOnPath_(t,Dt.Empty,e)},Fn.prototype.foreachOnPath_=function(t,e,n){if(t.isEmpty())return this;this.value&&n(e,this.value);var r=t.getFront(),i=this.children.get(r);return i?i.foreachOnPath_(t.popFront(),e.child(r),n):Fn.Empty},Fn.prototype.foreach=function(t){this.foreach_(Dt.Empty,t)},Fn.prototype.foreach_=function(n,r){this.children.inorderTraversal(function(t,e){e.foreach_(n.child(t),r)}),this.value&&r(n,this.value)},Fn.prototype.foreachChild=function(n){this.children.inorderTraversal(function(t,e){e.value&&n(t,e.value)})},Fn.Empty=new Fn(null),Fn);function Fn(t,e){void 0===e&&(e=Dn=Dn||new Le(lt)),this.value=t,this.children=e}var An=(Ln.prototype.operationForChild=function(t){return this.path.isEmpty()?new Ln(this.source,Dt.Empty):new Ln(this.source,this.path.popFront())},Ln);function Ln(t,e){this.source=t,this.path=e,this.type=Tn.LISTEN_COMPLETE}var Mn=(Wn.prototype.operationForChild=function(t){return this.path.isEmpty()?new Wn(this.source,Dt.Empty,this.snap.getImmediateChild(t)):new Wn(this.source,this.path.popFront(),this.snap)},Wn);function Wn(t,e,n){this.source=t,this.path=e,this.snap=n,this.type=Tn.OVERWRITE}var Qn=(qn.prototype.operationForChild=function(t){if(this.path.isEmpty()){var e=this.children.subtree(new Dt(t));return e.isEmpty()?null:e.value?new Mn(this.source,Dt.Empty,e.value):new qn(this.source,Dt.Empty,e)}return C(this.path.getFront()===t,"Can't get a merge for a child not on the path of the operation"),new qn(this.source,this.path.popFront(),this.children)},qn.prototype.toString=function(){return"Operation("+this.path+": "+this.source.toString()+" merge: "+this.children.toString()+")"},qn);function qn(t,e,n){this.source=t,this.path=e,this.children=n,this.type=Tn.MERGE}var Un=(Vn.prototype.isFullyInitialized=function(){return this.fullyInitialized_},Vn.prototype.isFiltered=function(){return this.filtered_},Vn.prototype.isCompleteForPath=function(t){if(t.isEmpty())return this.isFullyInitialized()&&!this.filtered_;var e=t.getFront();return this.isCompleteForChild(e)},Vn.prototype.isCompleteForChild=function(t){return this.isFullyInitialized()&&!this.filtered_||this.node_.hasChild(t)},Vn.prototype.getNode=function(){return this.node_},Vn);function Vn(t,e,n){this.node_=t,this.fullyInitialized_=e,this.filtered_=n}var Hn=(Bn.prototype.updateEventSnap=function(t,e,n){return new Bn(new Un(t,e,n),this.serverCache_)},Bn.prototype.updateServerSnap=function(t,e,n){return new Bn(this.eventCache_,new Un(t,e,n))},Bn.prototype.getEventCache=function(){return this.eventCache_},Bn.prototype.getCompleteEventSnap=function(){return this.eventCache_.isFullyInitialized()?this.eventCache_.getNode():null},Bn.prototype.getServerCache=function(){return this.serverCache_},Bn.prototype.getCompleteServerSnap=function(){return this.serverCache_.isFullyInitialized()?this.serverCache_.getNode():null},Bn.Empty=new Bn(new Un(Xe.EMPTY_NODE,!1,!1),new Un(Xe.EMPTY_NODE,!1,!1)),Bn);function Bn(t,e){this.eventCache_=t,this.serverCache_=e}var jn=(Kn.valueChange=function(t){return new Kn(Kn.VALUE,t)},Kn.childAddedChange=function(t,e){return new Kn(Kn.CHILD_ADDED,e,t)},Kn.childRemovedChange=function(t,e){return new Kn(Kn.CHILD_REMOVED,e,t)},Kn.childChangedChange=function(t,e,n){return new Kn(Kn.CHILD_CHANGED,e,t,n)},Kn.childMovedChange=function(t,e){return new Kn(Kn.CHILD_MOVED,e,t)},Kn.CHILD_ADDED="child_added",Kn.CHILD_REMOVED="child_removed",Kn.CHILD_CHANGED="child_changed",Kn.CHILD_MOVED="child_moved",Kn.VALUE="value",Kn);function Kn(t,e,n,r,i){this.type=t,this.snapshotNode=e,this.childName=n,this.oldSnap=r,this.prevName=i}var Yn=(zn.prototype.updateChild=function(t,e,n,r,i,o){C(t.isIndexed(this.index_),"A node must be indexed if only a child is updated");var s=t.getImmediateChild(e);return s.getChild(r).equals(n.getChild(r))&&s.isEmpty()===n.isEmpty()?t:(null!=o&&(n.isEmpty()?t.hasChild(e)?o.trackChildChange(jn.childRemovedChange(e,s)):C(t.isLeafNode(),"A child remove without an old child only makes sense on a leaf node"):s.isEmpty()?o.trackChildChange(jn.childAddedChange(e,n)):o.trackChildChange(jn.childChangedChange(e,n,s))),t.isLeafNode()&&n.isEmpty()?t:t.updateImmediateChild(e,n).withIndex(this.index_))},zn.prototype.updateFullNode=function(r,n,i){return null!=i&&(r.isLeafNode()||r.forEachChild(Pe,function(t,e){n.hasChild(t)||i.trackChildChange(jn.childRemovedChange(t,e))}),n.isLeafNode()||n.forEachChild(Pe,function(t,e){if(r.hasChild(t)){var n=r.getImmediateChild(t);n.equals(e)||i.trackChildChange(jn.childChangedChange(t,e,n))}else i.trackChildChange(jn.childAddedChange(t,e))})),n.withIndex(this.index_)},zn.prototype.updatePriority=function(t,e){return t.isEmpty()?Xe.EMPTY_NODE:t.updatePriority(e)},zn.prototype.filtersNodes=function(){return!1},zn.prototype.getIndexedFilter=function(){return this},zn.prototype.getIndex=function(){return this.index_},zn);function zn(t){this.index_=t}var Gn=(Xn.prototype.trackChildChange=function(t){var e=t.type,n=t.childName;C(e===jn.CHILD_ADDED||e===jn.CHILD_CHANGED||e===jn.CHILD_REMOVED,"Only child changes supported for tracking"),C(".priority"!==n,"Only non-priority child changes can be tracked.");var r=this.changeMap.get(n);if(r){var i=r.type;if(e===jn.CHILD_ADDED&&i===jn.CHILD_REMOVED)this.changeMap.set(n,jn.childChangedChange(n,t.snapshotNode,r.snapshotNode));else if(e===jn.CHILD_REMOVED&&i===jn.CHILD_ADDED)this.changeMap.delete(n);else if(e===jn.CHILD_REMOVED&&i===jn.CHILD_CHANGED)this.changeMap.set(n,jn.childRemovedChange(n,r.oldSnap));else if(e===jn.CHILD_CHANGED&&i===jn.CHILD_ADDED)this.changeMap.set(n,jn.childAddedChange(n,t.snapshotNode));else{if(e!==jn.CHILD_CHANGED||i!==jn.CHILD_CHANGED)throw c("Illegal combination of changes: "+t+" occurred after "+r);this.changeMap.set(n,jn.childChangedChange(n,t.snapshotNode,r.oldSnap))}}else this.changeMap.set(n,t)},Xn.prototype.getChanges=function(){return Array.from(this.changeMap.values())},Xn);function Xn(){this.changeMap=new Map}function $n(){}var Jn=new($n.prototype.getCompleteChild=function(t){return null},$n.prototype.getChildAfterChild=function(t,e,n){return null},$n),Zn=(tr.prototype.getCompleteChild=function(t){var e=this.viewCache_.getEventCache();if(e.isCompleteForChild(t))return e.getNode().getImmediateChild(t);var n=null!=this.optCompleteServerCache_?new Un(this.optCompleteServerCache_,!0,!1):this.viewCache_.getServerCache();return this.writes_.calcCompleteChild(t,n)},tr.prototype.getChildAfterChild=function(t,e,n){var r=null!=this.optCompleteServerCache_?this.optCompleteServerCache_:this.viewCache_.getCompleteServerSnap(),i=this.writes_.calcIndexedSlice(r,e,1,n,t);return 0===i.length?null:i[0]},tr);function tr(t,e,n){void 0===n&&(n=null),this.writes_=t,this.viewCache_=e,this.optCompleteServerCache_=n}var er=function(t,e){this.viewCache=t,this.changes=e},nr=(rr.prototype.assertIndexed=function(t){C(t.getEventCache().getNode().isIndexed(this.filter_.getIndex()),"Event snap not indexed"),C(t.getServerCache().getNode().isIndexed(this.filter_.getIndex()),"Server snap not indexed")},rr.prototype.applyOperation=function(t,e,n,r){var i,o,s=new Gn;if(e.type===Tn.OVERWRITE){var a=e;i=a.source.fromUser?this.applyUserOverwrite_(t,a.path,a.snap,n,r,s):(C(a.source.fromServer,"Unknown source."),o=a.source.tagged||t.getServerCache().isFiltered()&&!a.path.isEmpty(),this.applyServerOverwrite_(t,a.path,a.snap,n,r,o,s))}else if(e.type===Tn.MERGE){var h=e;i=h.source.fromUser?this.applyUserMerge_(t,h.path,h.children,n,r,s):(C(h.source.fromServer,"Unknown source."),o=h.source.tagged||t.getServerCache().isFiltered(),this.applyServerMerge_(t,h.path,h.children,n,r,o,s))}else if(e.type===Tn.ACK_USER_WRITE){var l=e;i=l.revert?this.revertUserWrite_(t,l.path,n,r,s):this.ackUserWrite_(t,l.path,l.affectedTree,n,r,s)}else{if(e.type!==Tn.LISTEN_COMPLETE)throw c("Unknown operation type: "+e.type);i=this.listenComplete_(t,e.path,n,s)}var u=s.getChanges();return rr.maybeAddValueEvent_(t,i,u),new er(i,u)},rr.maybeAddValueEvent_=function(t,e,n){var r=e.getEventCache();if(r.isFullyInitialized()){var i=r.getNode().isLeafNode()||r.getNode().isEmpty(),o=t.getCompleteEventSnap();(0<n.length||!t.getEventCache().isFullyInitialized()||i&&!r.getNode().equals(o)||!r.getNode().getPriority().equals(o.getPriority()))&&n.push(jn.valueChange(e.getCompleteEventSnap()))}},rr.prototype.generateEventCacheAfterServerEvent_=function(t,e,n,r,i){var o=t.getEventCache();if(null!=n.shadowingWrite(e))return t;var s=void 0,a=void 0;if(e.isEmpty())if(C(t.getServerCache().isFullyInitialized(),"If change path is empty, we must have complete server data"),t.getServerCache().isFiltered()){var h=t.getCompleteServerSnap(),l=h instanceof Xe?h:Xe.EMPTY_NODE,u=n.calcCompleteEventChildren(l);s=this.filter_.updateFullNode(t.getEventCache().getNode(),u,i)}else{var c=n.calcCompleteEventCache(t.getCompleteServerSnap());s=this.filter_.updateFullNode(t.getEventCache().getNode(),c,i)}else{var p=e.getFront();if(".priority"===p){C(1===e.getLength(),"Can't have a priority with additional path components");var d=o.getNode();a=t.getServerCache().getNode();var f=n.calcEventCacheAfterServerOverwrite(e,d,a);s=null!=f?this.filter_.updatePriority(d,f):o.getNode()}else{var _=e.popFront(),y=void 0;if(o.isCompleteForChild(p)){a=t.getServerCache().getNode();var v=n.calcEventCacheAfterServerOverwrite(e,o.getNode(),a);y=null!=v?o.getNode().getImmediateChild(p).updateChild(_,v):o.getNode().getImmediateChild(p)}else y=n.calcCompleteChild(p,t.getServerCache());s=null!=y?this.filter_.updateChild(o.getNode(),p,y,_,r,i):o.getNode()}}return t.updateEventSnap(s,o.isFullyInitialized()||e.isEmpty(),this.filter_.filtersNodes())},rr.prototype.applyServerOverwrite_=function(t,e,n,r,i,o,s){var a,h=t.getServerCache(),l=o?this.filter_:this.filter_.getIndexedFilter();if(e.isEmpty())a=l.updateFullNode(h.getNode(),n,null);else if(l.filtersNodes()&&!h.isFiltered()){var u=h.getNode().updateChild(e,n);a=l.updateFullNode(h.getNode(),u,null)}else{var c=e.getFront();if(!h.isCompleteForPath(e)&&1<e.getLength())return t;var p=e.popFront(),d=h.getNode().getImmediateChild(c).updateChild(p,n);a=".priority"===c?l.updatePriority(h.getNode(),d):l.updateChild(h.getNode(),c,d,p,Jn,null)}var f=t.updateServerSnap(a,h.isFullyInitialized()||e.isEmpty(),l.filtersNodes()),_=new Zn(r,f,i);return this.generateEventCacheAfterServerEvent_(f,e,r,_,s)},rr.prototype.applyUserOverwrite_=function(t,e,n,r,i,o){var s,a,h=t.getEventCache(),l=new Zn(r,t,i);if(e.isEmpty())a=this.filter_.updateFullNode(t.getEventCache().getNode(),n,o),s=t.updateEventSnap(a,!0,this.filter_.filtersNodes());else{var u=e.getFront();if(".priority"===u)a=this.filter_.updatePriority(t.getEventCache().getNode(),n),s=t.updateEventSnap(a,h.isFullyInitialized(),h.isFiltered());else{var c=e.popFront(),p=h.getNode().getImmediateChild(u),d=void 0;if(c.isEmpty())d=n;else{var f=l.getCompleteChild(u);d=null!=f?".priority"===c.getBack()&&f.getChild(c.parent()).isEmpty()?f:f.updateChild(c,n):Xe.EMPTY_NODE}if(p.equals(d))s=t;else{var _=this.filter_.updateChild(h.getNode(),u,d,c,l,o);s=t.updateEventSnap(_,h.isFullyInitialized(),this.filter_.filtersNodes())}}}return s},rr.cacheHasChild_=function(t,e){return t.getEventCache().isCompleteForChild(e)},rr.prototype.applyUserMerge_=function(r,i,t,o,s,a){var h=this,l=r;return t.foreach(function(t,e){var n=i.child(t);rr.cacheHasChild_(r,n.getFront())&&(l=h.applyUserOverwrite_(l,n,e,o,s,a))}),t.foreach(function(t,e){var n=i.child(t);rr.cacheHasChild_(r,n.getFront())||(l=h.applyUserOverwrite_(l,n,e,o,s,a))}),l},rr.prototype.applyMerge_=function(n,t){return t.foreach(function(t,e){n=n.updateChild(t,e)}),n},rr.prototype.applyServerMerge_=function(o,t,e,s,a,h,l){var u=this;if(o.getServerCache().getNode().isEmpty()&&!o.getServerCache().isFullyInitialized())return o;var n,c=o;n=t.isEmpty()?e:kn.Empty.setTree(t,e);var p=o.getServerCache().getNode();return n.children.inorderTraversal(function(t,e){if(p.hasChild(t)){var n=o.getServerCache().getNode().getImmediateChild(t),r=u.applyMerge_(n,e);c=u.applyServerOverwrite_(c,new Dt(t),r,s,a,h,l)}}),n.children.inorderTraversal(function(t,e){var n=!o.getServerCache().isCompleteForChild(t)&&null==e.value;if(!p.hasChild(t)&&!n){var r=o.getServerCache().getNode().getImmediateChild(t),i=u.applyMerge_(r,e);c=u.applyServerOverwrite_(c,new Dt(t),i,s,a,h,l)}}),c},rr.prototype.ackUserWrite_=function(t,r,e,n,i,o){if(null!=n.shadowingWrite(r))return t;var s=t.getServerCache().isFiltered(),a=t.getServerCache();if(null!=e.value){if(r.isEmpty()&&a.isFullyInitialized()||a.isCompleteForPath(r))return this.applyServerOverwrite_(t,r,a.getNode().getChild(r),n,i,s,o);if(r.isEmpty()){var h=kn.Empty;return a.getNode().forEachChild(me,function(t,e){h=h.set(new Dt(t),e)}),this.applyServerMerge_(t,r,h,n,i,s,o)}return t}var l=kn.Empty;return e.foreach(function(t,e){var n=r.child(t);a.isCompleteForPath(n)&&(l=l.set(t,a.getNode().getChild(n)))}),this.applyServerMerge_(t,r,l,n,i,s,o)},rr.prototype.listenComplete_=function(t,e,n,r){var i=t.getServerCache(),o=t.updateServerSnap(i.getNode(),i.isFullyInitialized()||e.isEmpty(),i.isFiltered());return this.generateEventCacheAfterServerEvent_(o,e,n,Jn,r)},rr.prototype.revertUserWrite_=function(t,e,n,r,i){var o;if(null!=n.shadowingWrite(e))return t;var s=new Zn(n,t,r),a=t.getEventCache().getNode(),h=void 0;if(e.isEmpty()||".priority"===e.getFront()){var l=void 0;if(t.getServerCache().isFullyInitialized())l=n.calcCompleteEventCache(t.getCompleteServerSnap());else{var u=t.getServerCache().getNode();C(u instanceof Xe,"serverChildren would be complete if leaf node"),l=n.calcCompleteEventChildren(u)}l=l,h=this.filter_.updateFullNode(a,l,i)}else{var c=e.getFront(),p=n.calcCompleteChild(c,t.getServerCache());null==p&&t.getServerCache().isCompleteForChild(c)&&(p=a.getImmediateChild(c)),(h=null!=p?this.filter_.updateChild(a,c,p,e.popFront(),s,i):t.getEventCache().getNode().hasChild(c)?this.filter_.updateChild(a,c,Xe.EMPTY_NODE,e.popFront(),s,i):a).isEmpty()&&t.getServerCache().isFullyInitialized()&&(o=n.calcCompleteEventCache(t.getCompleteServerSnap())).isLeafNode()&&(h=this.filter_.updateFullNode(h,o,i))}return o=t.getServerCache().isFullyInitialized()||null!=n.shadowingWrite(Dt.Empty),t.updateEventSnap(h,o,this.filter_.filtersNodes())},rr);function rr(t){this.filter_=t}var ir=(or.prototype.generateEventsForChanges=function(t,e,n){var r=this,i=[],o=[];return t.forEach(function(t){t.type===jn.CHILD_CHANGED&&r.index_.indexedValueChanged(t.oldSnap,t.snapshotNode)&&o.push(jn.childMovedChange(t.childName,t.snapshotNode))}),this.generateEventsForType_(i,jn.CHILD_REMOVED,t,n,e),this.generateEventsForType_(i,jn.CHILD_ADDED,t,n,e),this.generateEventsForType_(i,jn.CHILD_MOVED,o,n,e),this.generateEventsForType_(i,jn.CHILD_CHANGED,t,n,e),this.generateEventsForType_(i,jn.VALUE,t,n,e),i},or.prototype.generateEventsForType_=function(r,e,t,i,o){var s=this,n=t.filter(function(t){return t.type===e});n.sort(this.compareChanges_.bind(this)),n.forEach(function(e){var n=s.materializeSingleChange_(e,o);i.forEach(function(t){t.respondsTo(e.type)&&r.push(t.createEvent(n,s.query_))})})},or.prototype.materializeSingleChange_=function(t,e){return"value"===t.type||"child_removed"===t.type||(t.prevName=e.getPredecessorChildName(t.childName,t.snapshotNode,this.index_)),t},or.prototype.compareChanges_=function(t,e){if(null==t.childName||null==e.childName)throw c("Should only compare child_ events.");var n=new ue(t.childName,t.snapshotNode),r=new ue(e.childName,e.snapshotNode);return this.index_.compare(n,r)},or);function or(t){this.query_=t,this.index_=this.query_.getQueryParams().getIndex()}var sr,ar=(hr.prototype.getQuery=function(){return this.query_},hr.prototype.getServerCache=function(){return this.viewCache_.getServerCache().getNode()},hr.prototype.getCompleteServerCache=function(t){var e=this.viewCache_.getCompleteServerSnap();return e&&(this.query_.getQueryParams().loadsAllData()||!t.isEmpty()&&!e.getImmediateChild(t.getFront()).isEmpty())?e.getChild(t):null},hr.prototype.isEmpty=function(){return 0===this.eventRegistrations_.length},hr.prototype.addEventRegistration=function(t){this.eventRegistrations_.push(t)},hr.prototype.removeEventRegistration=function(t,n){var r=[];if(n){C(null==t,"A cancel should cancel all event registrations.");var i=this.query_.path;this.eventRegistrations_.forEach(function(t){n=n;var e=t.createCancelEvent(n,i);e&&r.push(e)})}if(t){for(var e=[],o=0;o<this.eventRegistrations_.length;++o){var s=this.eventRegistrations_[o];if(s.matches(t)){if(t.hasAnyCallback()){e=e.concat(this.eventRegistrations_.slice(o+1));break}}else e.push(s)}this.eventRegistrations_=e}else this.eventRegistrations_=[];return r},hr.prototype.applyOperation=function(t,e,n){t.type===Tn.MERGE&&null!==t.source.queryId&&(C(this.viewCache_.getCompleteServerSnap(),"We should always have a full cache before handling merges"),C(this.viewCache_.getCompleteEventSnap(),"Missing event cache, even though we have a server cache"));var r=this.viewCache_,i=this.processor_.applyOperation(r,t,e,n);return this.processor_.assertIndexed(i.viewCache),C(i.viewCache.getServerCache().isFullyInitialized()||!r.getServerCache().isFullyInitialized(),"Once a server snap is complete, it should never go back"),this.viewCache_=i.viewCache,this.generateEventsForChanges_(i.changes,i.viewCache.getEventCache().getNode(),null)},hr.prototype.getInitialEvents=function(t){var e=this.viewCache_.getEventCache(),n=[];return e.getNode().isLeafNode()||e.getNode().forEachChild(Pe,function(t,e){n.push(jn.childAddedChange(t,e))}),e.isFullyInitialized()&&n.push(jn.valueChange(e.getNode())),this.generateEventsForChanges_(n,e.getNode(),t)},hr.prototype.generateEventsForChanges_=function(t,e,n){var r=n?[n]:this.eventRegistrations_;return this.eventGenerator_.generateEventsForChanges(t,e,r)},hr);function hr(t,e){this.query_=t,this.eventRegistrations_=[];var n=this.query_.getQueryParams(),r=new Yn(n.getIndex()),i=n.getNodeFilter();this.processor_=new nr(i);var o=e.getServerCache(),s=e.getEventCache(),a=r.updateFullNode(Xe.EMPTY_NODE,o.getNode(),null),h=i.updateFullNode(Xe.EMPTY_NODE,s.getNode(),null),l=new Un(a,o.isFullyInitialized(),r.filtersNodes()),u=new Un(h,s.isFullyInitialized(),i.filtersNodes());this.viewCache_=new Hn(u,l),this.eventGenerator_=new ir(this.query_)}var lr=(Object.defineProperty(ur,"__referenceConstructor",{get:function(){return C(sr,"Reference.ts has not been loaded"),sr},set:function(t){C(!sr,"__referenceConstructor has already been defined"),sr=t},enumerable:!0,configurable:!0}),ur.prototype.isEmpty=function(){return 0===this.views.size},ur.prototype.applyOperation=function(t,e,n){var r,i,o=t.source.queryId;if(null!==o){var s=this.views.get(o);return C(null!=s,"SyncTree gave us an op for an invalid query."),s.applyOperation(t,e,n)}var a=[];try{for(var h=f(this.views.values()),l=h.next();!l.done;l=h.next())s=l.value,a=a.concat(s.applyOperation(t,e,n))}catch(t){r={error:t}}finally{try{l&&!l.done&&(i=h.return)&&i.call(h)}finally{if(r)throw r.error}}return a},ur.prototype.addEventRegistration=function(t,e,n,r,i){var o=t.queryIdentifier(),s=this.views.get(o);if(!s){var a=n.calcCompleteEventCache(i?r:null),h=!1;h=!!a||(a=r instanceof Xe?n.calcCompleteEventChildren(r):Xe.EMPTY_NODE,!1);var l=new Hn(new Un(a,h,!1),new Un(r,i,!1));s=new ar(t,l),this.views.set(o,s)}return s.addEventRegistration(e),s.getInitialEvents(e)},ur.prototype.removeEventRegistration=function(t,e,n){var r,i,o=t.queryIdentifier(),s=[],a=[],h=this.hasCompleteView();if("default"===o)try{for(var l=f(this.views.entries()),u=l.next();!u.done;u=l.next()){var c=_(u.value,2),p=c[0],d=c[1];a=a.concat(d.removeEventRegistration(e,n)),d.isEmpty()&&(this.views.delete(p),d.getQuery().getQueryParams().loadsAllData()||s.push(d.getQuery()))}}catch(t){r={error:t}}finally{try{u&&!u.done&&(i=l.return)&&i.call(l)}finally{if(r)throw r.error}}else(d=this.views.get(o))&&(a=a.concat(d.removeEventRegistration(e,n)),d.isEmpty()&&(this.views.delete(o),d.getQuery().getQueryParams().loadsAllData()||s.push(d.getQuery())));return h&&!this.hasCompleteView()&&s.push(new ur.__referenceConstructor(t.repo,t.path)),{removed:s,events:a}},ur.prototype.getQueryViews=function(){var e,t,n=[];try{for(var r=f(this.views.values()),i=r.next();!i.done;i=r.next()){var o=i.value;o.getQuery().getQueryParams().loadsAllData()||n.push(o)}}catch(t){e={error:t}}finally{try{i&&!i.done&&(t=r.return)&&t.call(r)}finally{if(e)throw e.error}}return n},ur.prototype.getCompleteServerCache=function(t){var e,n,r=null;try{for(var i=f(this.views.values()),o=i.next();!o.done;o=i.next()){var s=o.value;r=r||s.getCompleteServerCache(t)}}catch(t){e={error:t}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(e)throw e.error}}return r},ur.prototype.viewForQuery=function(t){if(t.getQueryParams().loadsAllData())return this.getCompleteView();var e=t.queryIdentifier();return this.views.get(e)},ur.prototype.viewExistsForQuery=function(t){return null!=this.viewForQuery(t)},ur.prototype.hasCompleteView=function(){return null!=this.getCompleteView()},ur.prototype.getCompleteView=function(){var e,t;try{for(var n=f(this.views.values()),r=n.next();!r.done;r=n.next()){var i=r.value;if(i.getQuery().getQueryParams().loadsAllData())return i}}catch(t){e={error:t}}finally{try{r&&!r.done&&(t=n.return)&&t.call(n)}finally{if(e)throw e.error}}return null},ur);function ur(){this.views=new Map}var cr=(pr.prototype.addWrite=function(t,e){if(t.isEmpty())return new pr(new kn(e));var n=this.writeTree_.findRootMostValueAndPath(t);if(null!=n){var r=n.path,i=n.value,o=Dt.relativePath(r,t);return i=i.updateChild(o,e),new pr(this.writeTree_.set(r,i))}var s=new kn(e);return new pr(this.writeTree_.setTree(t,s))},pr.prototype.addWrites=function(n,t){var r=this;return St(t,function(t,e){r=r.addWrite(n.child(t),e)}),r},pr.prototype.removeWrite=function(t){return t.isEmpty()?pr.Empty:new pr(this.writeTree_.setTree(t,kn.Empty))},pr.prototype.hasCompleteWrite=function(t){return null!=this.getCompleteNode(t)},pr.prototype.getCompleteNode=function(t){var e=this.writeTree_.findRootMostValueAndPath(t);return null!=e?this.writeTree_.get(e.path).getChild(Dt.relativePath(e.path,t)):null},pr.prototype.getCompleteChildren=function(){var n=[],t=this.writeTree_.value;return null!=t?t.isLeafNode()||t.forEachChild(Pe,function(t,e){n.push(new ue(t,e))}):this.writeTree_.children.inorderTraversal(function(t,e){null!=e.value&&n.push(new ue(t,e.value))}),n},pr.prototype.childCompoundWrite=function(t){if(t.isEmpty())return this;var e=this.getCompleteNode(t);return new pr(null!=e?new kn(e):this.writeTree_.subtree(t))},pr.prototype.isEmpty=function(){return this.writeTree_.isEmpty()},pr.prototype.apply=function(t){return function n(r,t,i){if(null!=t.value)return i.updateChild(r,t.value);var o=null;return t.children.inorderTraversal(function(t,e){".priority"===t?(C(null!==e.value,"Priority writes must always be leaf nodes"),o=e.value):i=n(r.child(t),e,i)}),i.getChild(r).isEmpty()||null===o||(i=i.updateChild(r.child(".priority"),o)),i}(Dt.Empty,this.writeTree_,t)},pr.Empty=new pr(new kn(null)),pr);function pr(t){this.writeTree_=t}var dr=(fr.prototype.childWrites=function(t){return new _r(t,this)},fr.prototype.addOverwrite=function(t,e,n,r){C(n>this.lastWriteId_,"Stacking an older write on top of newer ones"),void 0===r&&(r=!0),this.allWrites_.push({path:t,snap:e,writeId:n,visible:r}),r&&(this.visibleWrites_=this.visibleWrites_.addWrite(t,e)),this.lastWriteId_=n},fr.prototype.addMerge=function(t,e,n){C(n>this.lastWriteId_,"Stacking an older merge on top of newer ones"),this.allWrites_.push({path:t,children:e,writeId:n,visible:!0}),this.visibleWrites_=this.visibleWrites_.addWrites(t,e),this.lastWriteId_=n},fr.prototype.getWrite=function(t){for(var e=0;e<this.allWrites_.length;e++){var n=this.allWrites_[e];if(n.writeId===t)return n}return null},fr.prototype.removeWrite=function(e){var n=this,t=this.allWrites_.findIndex(function(t){return t.writeId===e});C(0<=t,"removeWrite called with nonexistent writeId.");var r=this.allWrites_[t];this.allWrites_.splice(t,1);for(var i=r.visible,o=!1,s=this.allWrites_.length-1;i&&0<=s;){var a=this.allWrites_[s];a.visible&&(t<=s&&this.recordContainsPath_(a,r.path)?i=!1:r.path.contains(a.path)&&(o=!0)),s--}return!!i&&(o?this.resetTree_():r.snap?this.visibleWrites_=this.visibleWrites_.removeWrite(r.path):St(r.children,function(t){n.visibleWrites_=n.visibleWrites_.removeWrite(r.path.child(t))}),!0)},fr.prototype.getCompleteWriteData=function(t){return this.visibleWrites_.getCompleteNode(t)},fr.prototype.calcCompleteEventCache=function(e,t,n,r){if(n||r){var i=this.visibleWrites_.childCompoundWrite(e);if(!r&&i.isEmpty())return t;if(r||null!=t||i.hasCompleteWrite(Dt.Empty)){var o=fr.layerTree_(this.allWrites_,function(t){return(t.visible||r)&&(!n||!~n.indexOf(t.writeId))&&(t.path.contains(e)||e.contains(t.path))},e);return h=t||Xe.EMPTY_NODE,o.apply(h)}return null}var s=this.visibleWrites_.getCompleteNode(e);if(null!=s)return s;var a=this.visibleWrites_.childCompoundWrite(e);if(a.isEmpty())return t;if(null!=t||a.hasCompleteWrite(Dt.Empty)){var h=t||Xe.EMPTY_NODE;return a.apply(h)}return null},fr.prototype.calcCompleteEventChildren=function(t,e){var r=Xe.EMPTY_NODE,n=this.visibleWrites_.getCompleteNode(t);if(n)return n.isLeafNode()||n.forEachChild(Pe,function(t,e){r=r.updateImmediateChild(t,e)}),r;if(e){var i=this.visibleWrites_.childCompoundWrite(t);return e.forEachChild(Pe,function(t,e){var n=i.childCompoundWrite(new Dt(t)).apply(e);r=r.updateImmediateChild(t,n)}),i.getCompleteChildren().forEach(function(t){r=r.updateImmediateChild(t.name,t.node)}),r}return this.visibleWrites_.childCompoundWrite(t).getCompleteChildren().forEach(function(t){r=r.updateImmediateChild(t.name,t.node)}),r},fr.prototype.calcEventCacheAfterServerOverwrite=function(t,e,n,r){C(n||r,"Either existingEventSnap or existingServerSnap must exist");var i=t.child(e);if(this.visibleWrites_.hasCompleteWrite(i))return null;var o=this.visibleWrites_.childCompoundWrite(i);return o.isEmpty()?r.getChild(e):o.apply(r.getChild(e))},fr.prototype.calcCompleteChild=function(t,e,n){var r=t.child(e),i=this.visibleWrites_.getCompleteNode(r);return null!=i?i:n.isCompleteForChild(e)?this.visibleWrites_.childCompoundWrite(r).apply(n.getNode().getImmediateChild(e)):null},fr.prototype.shadowingWrite=function(t){return this.visibleWrites_.getCompleteNode(t)},fr.prototype.calcIndexedSlice=function(t,e,n,r,i,o){var s,a=this.visibleWrites_.childCompoundWrite(t),h=a.getCompleteNode(Dt.Empty);if(null!=h)s=h;else{if(null==e)return[];s=a.apply(e)}if((s=s.withIndex(o)).isEmpty()||s.isLeafNode())return[];for(var l=[],u=o.getCompare(),c=i?s.getReverseIteratorFrom(n,o):s.getIteratorFrom(n,o),p=c.getNext();p&&l.length<r;)0!==u(p,n)&&l.push(p),p=c.getNext();return l},fr.prototype.recordContainsPath_=function(t,e){if(t.snap)return t.path.contains(e);for(var n in t.children)if(t.children.hasOwnProperty(n)&&t.path.child(n).contains(e))return!0;return!1},fr.prototype.resetTree_=function(){this.visibleWrites_=fr.layerTree_(this.allWrites_,fr.DefaultFilter_,Dt.Empty),0<this.allWrites_.length?this.lastWriteId_=this.allWrites_[this.allWrites_.length-1].writeId:this.lastWriteId_=-1},fr.DefaultFilter_=function(t){return t.visible},fr.layerTree_=function(t,e,n){for(var r=cr.Empty,i=0;i<t.length;++i){var o=t[i];if(e(o)){var s=o.path,a=void 0;if(o.snap)n.contains(s)?(a=Dt.relativePath(n,s),r=r.addWrite(a,o.snap)):s.contains(n)&&(a=Dt.relativePath(s,n),r=r.addWrite(Dt.Empty,o.snap.getChild(a)));else{if(!o.children)throw c("WriteRecord should have .snap or .children");if(n.contains(s))a=Dt.relativePath(n,s),r=r.addWrites(a,o.children);else if(s.contains(n))if((a=Dt.relativePath(s,n)).isEmpty())r=r.addWrites(Dt.Empty,o.children);else{var h=P(o.children,a.getFront());if(h){var l=h.getChild(a.popFront());r=r.addWrite(Dt.Empty,l)}}}}}return r},fr);function fr(){this.visibleWrites_=cr.Empty,this.allWrites_=[],this.lastWriteId_=-1}var _r=(yr.prototype.calcCompleteEventCache=function(t,e,n){return this.writeTree_.calcCompleteEventCache(this.treePath_,t,e,n)},yr.prototype.calcCompleteEventChildren=function(t){return this.writeTree_.calcCompleteEventChildren(this.treePath_,t)},yr.prototype.calcEventCacheAfterServerOverwrite=function(t,e,n){return this.writeTree_.calcEventCacheAfterServerOverwrite(this.treePath_,t,e,n)},yr.prototype.shadowingWrite=function(t){return this.writeTree_.shadowingWrite(this.treePath_.child(t))},yr.prototype.calcIndexedSlice=function(t,e,n,r,i){return this.writeTree_.calcIndexedSlice(this.treePath_,t,e,n,r,i)},yr.prototype.calcCompleteChild=function(t,e){return this.writeTree_.calcCompleteChild(this.treePath_,t,e)},yr.prototype.child=function(t){return new yr(this.treePath_.child(t),this.writeTree_)},yr);function yr(t,e){this.treePath_=t,this.writeTree_=e}var vr=(gr.prototype.applyUserOverwrite=function(t,e,n,r){return this.pendingWriteTree_.addOverwrite(t,e,n,r),r?this.applyOperationToSyncPoints_(new Mn(Rn.User,t,e)):[]},gr.prototype.applyUserMerge=function(t,e,n){this.pendingWriteTree_.addMerge(t,e,n);var r=kn.fromObject(e);return this.applyOperationToSyncPoints_(new Qn(Rn.User,t,r))},gr.prototype.ackUserWrite=function(t,e){void 0===e&&(e=!1);var n=this.pendingWriteTree_.getWrite(t);if(this.pendingWriteTree_.removeWrite(t)){var r=kn.Empty;return null!=n.snap?r=r.set(Dt.Empty,!0):St(n.children,function(t,e){r=r.set(new Dt(t),e)}),this.applyOperationToSyncPoints_(new On(n.path,r,e))}return[]},gr.prototype.applyServerOverwrite=function(t,e){return this.applyOperationToSyncPoints_(new Mn(Rn.Server,t,e))},gr.prototype.applyServerMerge=function(t,e){var n=kn.fromObject(e);return this.applyOperationToSyncPoints_(new Qn(Rn.Server,t,n))},gr.prototype.applyListenComplete=function(t){return this.applyOperationToSyncPoints_(new An(Rn.Server,t))},gr.prototype.applyTaggedQueryOverwrite=function(t,e,n){var r=this.queryKeyForTag_(n);if(null==r)return[];var i=gr.parseQueryKey_(r),o=i.path,s=i.queryId,a=Dt.relativePath(o,t),h=new Mn(Rn.forServerTaggedQuery(s),a,e);return this.applyTaggedOperation_(o,h)},gr.prototype.applyTaggedQueryMerge=function(t,e,n){var r=this.queryKeyForTag_(n);if(r){var i=gr.parseQueryKey_(r),o=i.path,s=i.queryId,a=Dt.relativePath(o,t),h=kn.fromObject(e),l=new Qn(Rn.forServerTaggedQuery(s),a,h);return this.applyTaggedOperation_(o,l)}return[]},gr.prototype.applyTaggedListenComplete=function(t,e){var n=this.queryKeyForTag_(e);if(n){var r=gr.parseQueryKey_(n),i=r.path,o=r.queryId,s=Dt.relativePath(i,t),a=new An(Rn.forServerTaggedQuery(o),s);return this.applyTaggedOperation_(i,a)}return[]},gr.prototype.addEventRegistration=function(t,e){var r=t.path,i=null,o=!1;this.syncPointTree_.foreachOnPath(r,function(t,e){var n=Dt.relativePath(t,r);i=i||e.getCompleteServerCache(n),o=o||e.hasCompleteView()});var n,s=this.syncPointTree_.get(r);s?(o=o||s.hasCompleteView(),i=i||s.getCompleteServerCache(Dt.Empty)):(s=new lr,this.syncPointTree_=this.syncPointTree_.set(r,s)),null!=i?n=!0:(n=!1,i=Xe.EMPTY_NODE,this.syncPointTree_.subtree(r).foreachChild(function(t,e){var n=e.getCompleteServerCache(Dt.Empty);n&&(i=i.updateImmediateChild(t,n))}));var a=s.viewExistsForQuery(t);if(!a&&!t.getQueryParams().loadsAllData()){var h=gr.makeQueryKey_(t);C(!this.queryToTagMap.has(h),"View does not exist, but we have a tag");var l=gr.getNextQueryTag_();this.queryToTagMap.set(h,l),this.tagToQueryMap.set(l,h)}var u=this.pendingWriteTree_.childWrites(r),c=s.addEventRegistration(t,e,u,i,n);if(!a&&!o){var p=s.viewForQuery(t);c=c.concat(this.setupListener_(t,p))}return c},gr.prototype.removeEventRegistration=function(t,e,n){var r=this,i=t.path,o=this.syncPointTree_.get(i),s=[];if(o&&("default"===t.queryIdentifier()||o.viewExistsForQuery(t))){var a=o.removeEventRegistration(t,e,n);o.isEmpty()&&(this.syncPointTree_=this.syncPointTree_.remove(i));var h=a.removed;s=a.events;var l=-1!==h.findIndex(function(t){return t.getQueryParams().loadsAllData()}),u=this.syncPointTree_.findOnPath(i,function(t,e){return e.hasCompleteView()});if(l&&!u){var c=this.syncPointTree_.subtree(i);if(!c.isEmpty())for(var p=this.collectDistinctViewsForSubTree_(c),d=0;d<p.length;++d){var f=p[d],_=f.getQuery(),y=this.createListenerForView_(f);this.listenProvider_.startListening(gr.queryForListening_(_),this.tagForQuery_(_),y.hashFn,y.onComplete)}}!u&&0<h.length&&!n&&(l?this.listenProvider_.stopListening(gr.queryForListening_(t),null):h.forEach(function(t){var e=r.queryToTagMap.get(gr.makeQueryKey_(t));r.listenProvider_.stopListening(gr.queryForListening_(t),e)})),this.removeTags_(h)}return s},gr.prototype.calcCompleteEventCache=function(i,t){var e=this.pendingWriteTree_,n=this.syncPointTree_.findOnPath(i,function(t,e){var n=Dt.relativePath(t,i),r=e.getCompleteServerCache(n);if(r)return r});return e.calcCompleteEventCache(i,n,t,!0)},gr.prototype.collectDistinctViewsForSubTree_=function(t){return t.fold(function(t,e,n){if(e&&e.hasCompleteView())return[e.getCompleteView()];var r=[];return e&&(r=e.getQueryViews()),St(n,function(t,e){r=r.concat(e)}),r})},gr.prototype.removeTags_=function(t){for(var e=0;e<t.length;++e){var n=t[e];if(!n.getQueryParams().loadsAllData()){var r=gr.makeQueryKey_(n),i=this.queryToTagMap.get(r);this.queryToTagMap.delete(r),this.tagToQueryMap.delete(i)}}},gr.queryForListening_=function(t){return t.getQueryParams().loadsAllData()&&!t.getQueryParams().isDefault()?t.getRef():t},gr.prototype.setupListener_=function(t,e){var n=t.path,r=this.tagForQuery_(t),i=this.createListenerForView_(e),o=this.listenProvider_.startListening(gr.queryForListening_(t),r,i.hashFn,i.onComplete),s=this.syncPointTree_.subtree(n);if(r)C(!s.value.hasCompleteView(),"If we're adding a query, it shouldn't be shadowed");else for(var a=s.fold(function(t,e,n){if(!t.isEmpty()&&e&&e.hasCompleteView())return[e.getCompleteView().getQuery()];var r=[];return e&&(r=r.concat(e.getQueryViews().map(function(t){return t.getQuery()}))),St(n,function(t,e){r=r.concat(e)}),r}),h=0;h<a.length;++h){var l=a[h];this.listenProvider_.stopListening(gr.queryForListening_(l),this.tagForQuery_(l))}return o},gr.prototype.createListenerForView_=function(t){var n=this,r=t.getQuery(),i=this.tagForQuery_(r);return{hashFn:function(){return(t.getServerCache()||Xe.EMPTY_NODE).hash()},onComplete:function(t){if("ok"===t)return i?n.applyTaggedListenComplete(r.path,i):n.applyListenComplete(r.path);var e=function(t,e){var n="Unknown Error";"too_big"===t?n="The data requested exceeds the maximum size that can be accessed with a single request.":"permission_denied"===t?n="Client doesn't have permission to access the desired data.":"unavailable"===t&&(n="The service is unavailable");var r=new Error(t+" at "+e.path.toString()+": "+n);return r.code=t.toUpperCase(),r}(t,r);return n.removeEventRegistration(r,null,e)}}},gr.makeQueryKey_=function(t){return t.path.toString()+"$"+t.queryIdentifier()},gr.parseQueryKey_=function(t){var e=t.indexOf("$");return C(-1!==e&&e<t.length-1,"Bad queryKey."),{queryId:t.substr(e+1),path:new Dt(t.substr(0,e))}},gr.prototype.queryKeyForTag_=function(t){return this.tagToQueryMap.get(t)},gr.prototype.tagForQuery_=function(t){var e=gr.makeQueryKey_(t);return this.queryToTagMap.get(e)},gr.getNextQueryTag_=function(){return gr.nextQueryTag_++},gr.prototype.applyTaggedOperation_=function(t,e){var n=this.syncPointTree_.get(t);C(n,"Missing sync point for query tag that we're tracking");var r=this.pendingWriteTree_.childWrites(t);return n.applyOperation(e,r,null)},gr.prototype.applyOperationToSyncPoints_=function(t){return this.applyOperationHelper_(t,this.syncPointTree_,null,this.pendingWriteTree_.childWrites(Dt.Empty))},gr.prototype.applyOperationHelper_=function(t,e,n,r){if(t.path.isEmpty())return this.applyOperationDescendantsHelper_(t,e,n,r);var i=e.get(Dt.Empty);null==n&&null!=i&&(n=i.getCompleteServerCache(Dt.Empty));var o=[],s=t.path.getFront(),a=t.operationForChild(s),h=e.children.get(s);if(h&&a){var l=n?n.getImmediateChild(s):null,u=r.child(s);o=o.concat(this.applyOperationHelper_(a,h,l,u))}return i&&(o=o.concat(i.applyOperation(t,r,n))),o},gr.prototype.applyOperationDescendantsHelper_=function(o,t,s,a){var h=this,e=t.get(Dt.Empty);null==s&&null!=e&&(s=e.getCompleteServerCache(Dt.Empty));var l=[];return t.children.inorderTraversal(function(t,e){var n=s?s.getImmediateChild(t):null,r=a.child(t),i=o.operationForChild(t);i&&(l=l.concat(h.applyOperationDescendantsHelper_(i,e,n,r)))}),e&&(l=l.concat(e.applyOperation(o,a,s))),l},gr.nextQueryTag_=1,gr);function gr(t){this.listenProvider_=t,this.syncPointTree_=kn.Empty,this.pendingWriteTree_=new dr,this.tagToQueryMap=new Map,this.queryToTagMap=new Map}var mr=(Cr.prototype.getNode=function(t){return this.rootNode_.getChild(t)},Cr.prototype.updateSnapshot=function(t,e){this.rootNode_=this.rootNode_.updateChild(t,e)},Cr);function Cr(){this.rootNode_=Xe.EMPTY_NODE}var Er=(wr.prototype.getToken=function(t){return this.auth_?this.auth_.getToken(t).catch(function(t){return t&&"auth/token-not-initialized"===t.code?(rt("Got auth/token-not-initialized error. Treating as null token."),null):Promise.reject(t)}):Promise.resolve(null)},wr.prototype.addTokenChangeListener=function(e){this.auth_?this.auth_.addAuthTokenListener(e):(setTimeout(function(){return e(null)},0),this.authProvider_.get().then(function(t){return t.addAuthTokenListener(e)}))},wr.prototype.removeTokenChangeListener=function(e){this.authProvider_.get().then(function(t){return t.removeAuthTokenListener(e)})},wr.prototype.notifyForInvalidToken=function(){var t='Provided authentication credentials for the app named "'+this.app_.name+'" are invalid. This usually indicates your app was not initialized correctly. ';"credential"in this.app_.options?t+='Make sure the "credential" property provided to initializeApp() is authorized to access the specified "databaseURL" and is from the correct project.':"serviceAccount"in this.app_.options?t+='Make sure the "serviceAccount" property provided to initializeApp() is authorized to access the specified "databaseURL" and is from the correct project.':t+='Make sure the "apiKey" and "databaseURL" properties provided to initializeApp() match the values provided for your app at https://console.firebase.google.com/.',at(t)},wr);function wr(t,e){var n=this;this.app_=t,this.authProvider_=e,this.auth_=null,this.auth_=e.getImmediate({optional:!0}),this.auth_||e.get().then(function(t){return n.auth_=t})}var br=(Sr.prototype.incrementCounter=function(t,e){void 0===e&&(e=1),R(this.counters_,t)||(this.counters_[t]=0),this.counters_[t]+=e},Sr.prototype.get=function(){return i(this.counters_)},Sr);function Sr(){this.counters_={}}var Tr=(Ir.getCollection=function(t){var e=t.toString();return this.collections_[e]||(this.collections_[e]=new br),this.collections_[e]},Ir.getOrCreateReporter=function(t,e){var n=t.toString();return this.reporters_[n]||(this.reporters_[n]=e()),this.reporters_[n]},Ir.collections_={},Ir.reporters_={},Ir);function Ir(){}var Nr=(Rr.prototype.get=function(){var t=this.collection_.get(),n=u({},t);return this.last_&&St(this.last_,function(t,e){n[t]=n[t]-e}),this.last_=t,n},Rr);function Rr(t){this.collection_=t,this.last_=null}var Pr=(Dr.prototype.includeStat=function(t){this.statsToReport_[t]=!0},Dr.prototype.reportStats_=function(){var n=this,t=this.statsListener_.get(),r={},i=!1;St(t,function(t,e){0<e&&R(n.statsToReport_,t)&&(r[t]=e,i=!0)}),i&&this.server_.reportStats(r),Nt(this.reportStats_.bind(this),Math.floor(2*Math.random()*3e5))},Dr);function Dr(t,e){this.server_=e,this.statsToReport_={},this.statsListener_=new Nr(t);var n=1e4+2e4*Math.random();Nt(this.reportStats_.bind(this),Math.floor(n))}var Or=(xr.prototype.queueEvents=function(t){for(var e=null,n=0;n<t.length;n++){var r=t[n],i=r.getPath();null===e||i.equals(e.getPath())||(this.eventLists_.push(e),e=null),null===e&&(e=new kr(i)),e.add(r)}e&&this.eventLists_.push(e)},xr.prototype.raiseEventsAtPath=function(e,t){this.queueEvents(t),this.raiseQueuedEventsMatchingPredicate_(function(t){return t.equals(e)})},xr.prototype.raiseEventsForChangedPath=function(e,t){this.queueEvents(t),this.raiseQueuedEventsMatchingPredicate_(function(t){return t.contains(e)||e.contains(t)})},xr.prototype.raiseQueuedEventsMatchingPredicate_=function(t){this.recursionDepth_++;for(var e=!0,n=0;n<this.eventLists_.length;n++){var r=this.eventLists_[n];r&&(t(r.getPath())?(this.eventLists_[n].raise(),this.eventLists_[n]=null):e=!1)}e&&(this.eventLists_=[]),this.recursionDepth_--},xr);function xr(){this.eventLists_=[],this.recursionDepth_=0}var kr=(Fr.prototype.add=function(t){this.events_.push(t)},Fr.prototype.raise=function(){for(var t=0;t<this.events_.length;t++){var e=this.events_[t];if(null!==e){this.events_[t]=null;var n=e.getEventRunner();gt&&rt("event: "+e.toString()),It(n)}}},Fr.prototype.getPath=function(){return this.path_},Fr);function Fr(t){this.path_=t,this.events_=[]}var Ar=(Lr.prototype.trigger=function(t){for(var e=[],n=1;n<arguments.length;n++)e[n-1]=arguments[n];if(Array.isArray(this.listeners_[t]))for(var r=o(this.listeners_[t]),i=0;i<r.length;i++)r[i].callback.apply(r[i].context,e)},Lr.prototype.on=function(t,e,n){this.validateEventType_(t),this.listeners_[t]=this.listeners_[t]||[],this.listeners_[t].push({callback:e,context:n});var r=this.getInitialEvent(t);r&&e.apply(n,r)},Lr.prototype.off=function(t,e,n){this.validateEventType_(t);for(var r=this.listeners_[t]||[],i=0;i<r.length;i++)if(r[i].callback===e&&(!n||n===r[i].context))return void r.splice(i,1)},Lr.prototype.validateEventType_=function(e){C(this.allowedEvents_.find(function(t){return t===e}),"Unknown event: "+e)},Lr);function Lr(t){this.allowedEvents_=t,this.listeners_={},C(Array.isArray(t)&&0<t.length,"Requires a non-empty array")}var Mr,Wr=(t(Qr,Mr=Ar),Qr.getInstance=function(){return new Qr},Qr.prototype.getInitialEvent=function(t){return C("visible"===t,"Unknown event type: "+t),[this.visible_]},Qr);function Qr(){var e,t,n=Mr.call(this,["visible"])||this;return"undefined"!=typeof document&&void 0!==document.addEventListener&&(void 0!==document.hidden?(t="visibilitychange",e="hidden"):void 0!==document.mozHidden?(t="mozvisibilitychange",e="mozHidden"):void 0!==document.msHidden?(t="msvisibilitychange",e="msHidden"):void 0!==document.webkitHidden&&(t="webkitvisibilitychange",e="webkitHidden")),n.visible_=!0,t&&document.addEventListener(t,function(){var t=!document[e];t!==n.visible_&&(n.visible_=t,n.trigger("visible",t))},!1),n}var qr,Ur=(t(Vr,qr=Ar),Vr.getInstance=function(){return new Vr},Vr.prototype.getInitialEvent=function(t){return C("online"===t,"Unknown event type: "+t),[this.online_]},Vr.prototype.currentlyOnline=function(){return this.online_},Vr);function Vr(){var t=qr.call(this,["online"])||this;return t.online_=!0,"undefined"==typeof window||void 0===window.addEventListener||y()||(window.addEventListener("online",function(){t.online_||(t.online_=!0,t.trigger("online",!0))},!1),window.addEventListener("offline",function(){t.online_&&(t.online_=!1,t.trigger("online",!1))},!1)),t}var Hr=(Br.prototype.closeAfter=function(t,e){this.closeAfterResponse=t,this.onClose=e,this.closeAfterResponse<this.currentResponseNum&&(this.onClose(),this.onClose=null)},Br.prototype.handleResponse=function(t,e){var r=this;this.pendingResponses[t]=e;for(var n=function(){var e=i.pendingResponses[i.currentResponseNum];delete i.pendingResponses[i.currentResponseNum];for(var t=function(t){e[t]&&It(function(){r.onMessage_(e[t])})},n=0;n<e.length;++n)t(n);if(i.currentResponseNum===i.closeAfterResponse)return i.onClose&&(i.onClose(),i.onClose=null),"break";i.currentResponseNum++},i=this;this.pendingResponses[this.currentResponseNum]&&"break"!==n(););},Br);function Br(t){this.onMessage_=t,this.pendingResponses=[],this.currentResponseNum=0,this.closeAfterResponse=-1,this.onClose=null}var jr=(Kr.prototype.open=function(t,e){var s=this;this.curSegmentNum=0,this.onDisconnect_=e,this.myPacketOrderer=new Hr(t),this.isClosed_=!1,this.connectTimeoutTimer_=setTimeout(function(){s.log_("Timed out trying to connect."),s.onClosed_(),s.connectTimeoutTimer_=null},Math.floor(3e4)),function(t){if("complete"===document.readyState)t();else{var e=!1,n=function(){document.body?e||(e=!0,t()):setTimeout(n,Math.floor(10))};document.addEventListener?(document.addEventListener("DOMContentLoaded",n,!1),window.addEventListener("load",n,!1)):document.attachEvent&&(document.attachEvent("onreadystatechange",function(){"complete"===document.readyState&&n()}),window.attachEvent("onload",n))}}(function(){if(!s.isClosed_){s.scriptTagHolder=new Yr(function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n=_(t,5),r=n[0],i=n[1],o=n[2];if(n[3],n[4],s.incrementIncomingBytes_(t),s.scriptTagHolder)if(s.connectTimeoutTimer_&&(clearTimeout(s.connectTimeoutTimer_),s.connectTimeoutTimer_=null),s.everConnected_=!0,"start"===r)s.id=i,s.password=o;else{if("close"!==r)throw new Error("Unrecognized command received: "+r);i?(s.scriptTagHolder.sendNewPolls=!1,s.myPacketOrderer.closeAfter(i,function(){s.onClosed_()})):s.onClosed_()}},function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n=_(t,2),r=n[0],i=n[1];s.incrementIncomingBytes_(t),s.myPacketOrderer.handleResponse(r,i)},function(){s.onClosed_()},s.urlFn);var t={start:"t"};t.ser=Math.floor(1e8*Math.random()),s.scriptTagHolder.uniqueCallbackIdentifier&&(t.cb=s.scriptTagHolder.uniqueCallbackIdentifier),t.v="5",s.transportSessionId&&(t.s=s.transportSessionId),s.lastSessionId&&(t.ls=s.lastSessionId),"undefined"!=typeof location&&location.href&&-1!==location.href.indexOf(Ft)&&(t.r="f");var e=s.urlFn(t);s.log_("Connecting via long-poll to "+e),s.scriptTagHolder.addTag(e,function(){})}})},Kr.prototype.start=function(){this.scriptTagHolder.startLongPoll(this.id,this.password),this.addDisconnectPingFrame(this.id,this.password)},Kr.forceAllow=function(){Kr.forceAllow_=!0},Kr.forceDisallow=function(){Kr.forceDisallow_=!0},Kr.isAvailable=function(){return!!Kr.forceAllow_||!(Kr.forceDisallow_||"undefined"==typeof document||null==document.createElement||"object"==typeof window&&window.chrome&&window.chrome.extension&&!/^chrome/.test(window.location.href)||"object"==typeof Windows&&"object"==typeof Windows.UI)},Kr.prototype.markConnectionHealthy=function(){},Kr.prototype.shutdown_=function(){this.isClosed_=!0,this.scriptTagHolder&&(this.scriptTagHolder.close(),this.scriptTagHolder=null),this.myDisconnFrame&&(document.body.removeChild(this.myDisconnFrame),this.myDisconnFrame=null),this.connectTimeoutTimer_&&(clearTimeout(this.connectTimeoutTimer_),this.connectTimeoutTimer_=null)},Kr.prototype.onClosed_=function(){this.isClosed_||(this.log_("Longpoll is closing itself"),this.shutdown_(),this.onDisconnect_&&(this.onDisconnect_(this.everConnected_),this.onDisconnect_=null))},Kr.prototype.close=function(){this.isClosed_||(this.log_("Longpoll is being closed."),this.shutdown_())},Kr.prototype.send=function(t){var e=I(t);this.bytesSent+=e.length,this.stats_.incrementCounter("bytes_sent",e.length);for(var n=function(t){var e=s(t);return l.encodeByteArray(e,!0)}(e),r=ct(n,1840),i=0;i<r.length;i++)this.scriptTagHolder.enqueueSegment(this.curSegmentNum,r.length,r[i]),this.curSegmentNum++},Kr.prototype.addDisconnectPingFrame=function(t,e){this.myDisconnFrame=document.createElement("iframe");var n={dframe:"t"};n.id=t,n.pw=e,this.myDisconnFrame.src=this.urlFn(n),this.myDisconnFrame.style.display="none",document.body.appendChild(this.myDisconnFrame)},Kr.prototype.incrementIncomingBytes_=function(t){var e=I(t).length;this.bytesReceived+=e,this.stats_.incrementCounter("bytes_received",e)},Kr);function Kr(t,e,n,r){this.connId=t,this.repoInfo=e,this.transportSessionId=n,this.lastSessionId=r,this.bytesSent=0,this.bytesReceived=0,this.everConnected_=!1,this.log_=it(t),this.stats_=Tr.getCollection(e),this.urlFn=function(t){return e.connectionURL(Lt,t)}}var Yr=(zr.createIFrame_=function(){var e=document.createElement("iframe");if(e.style.display="none",!document.body)throw"Document body has not initialized. Wait to initialize Firebase until after the document is ready.";document.body.appendChild(e);try{e.contentWindow.document||rt("No IE domain setting required")}catch(t){var n=document.domain;e.src="javascript:void((function(){document.open();document.domain='"+n+"';document.close();})())"}return e.contentDocument?e.doc=e.contentDocument:e.contentWindow?e.doc=e.contentWindow.document:e.document&&(e.doc=e.document),e},zr.prototype.close=function(){var t=this;this.alive=!1,this.myIFrame&&(this.myIFrame.doc.body.innerHTML="",setTimeout(function(){null!==t.myIFrame&&(document.body.removeChild(t.myIFrame),t.myIFrame=null)},Math.floor(0)));var e=this.onDisconnect;e&&(this.onDisconnect=null,e())},zr.prototype.startLongPoll=function(t,e){for(this.myID=t,this.myPW=e,this.alive=!0;this.newRequest_(););},zr.prototype.newRequest_=function(){if(this.alive&&this.sendNewPolls&&this.outstandingRequests.size<(0<this.pendingSegs.length?2:1)){this.currentSerial++;var t={};t.id=this.myID,t.pw=this.myPW,t.ser=this.currentSerial;for(var e=this.urlFn(t),n="",r=0;0<this.pendingSegs.length&&this.pendingSegs[0].d.length+30+n.length<=1870;){var i=this.pendingSegs.shift();n=n+"&seg"+r+"="+i.seg+"&ts"+r+"="+i.ts+"&d"+r+"="+i.d,r++}return e+=n,this.addLongPollTag_(e,this.currentSerial),!0}return!1},zr.prototype.enqueueSegment=function(t,e,n){this.pendingSegs.push({seg:t,ts:e,d:n}),this.alive&&this.newRequest_()},zr.prototype.addLongPollTag_=function(t,e){var n=this;function r(){n.outstandingRequests.delete(e),n.newRequest_()}this.outstandingRequests.add(e);var i=setTimeout(r,Math.floor(25e3));this.addTag(t,function(){clearTimeout(i),r()})},zr.prototype.addTag=function(t,n){var r=this;setTimeout(function(){try{if(!r.sendNewPolls)return;var e=r.myIFrame.doc.createElement("script");e.type="text/javascript",e.async=!0,e.src=t,e.onload=e.onreadystatechange=function(){var t=e.readyState;t&&"loaded"!==t&&"complete"!==t||(e.onload=e.onreadystatechange=null,e.parentNode&&e.parentNode.removeChild(e),n())},e.onerror=function(){rt("Long-poll script failed to load: "+t),r.sendNewPolls=!1,r.close()},r.myIFrame.doc.body.appendChild(e)}catch(t){}},Math.floor(1))},zr);function zr(t,e,n,r){this.onDisconnect=n,this.urlFn=r,this.outstandingRequests=new Set,this.pendingSegs=[],this.currentSerial=Math.floor(1e8*Math.random()),this.sendNewPolls=!0,this.uniqueCallbackIdentifier=yt(),window["pLPCommand"+this.uniqueCallbackIdentifier]=t,window["pRTLPCB"+this.uniqueCallbackIdentifier]=e,this.myIFrame=zr.createIFrame_();var i="";this.myIFrame.src&&"javascript:"===this.myIFrame.src.substr(0,"javascript:".length)&&(i='<script>document.domain="'+document.domain+'";<\/script>');var o="<html><body>"+i+"</body></html>";try{this.myIFrame.doc.open(),this.myIFrame.doc.write(o),this.myIFrame.doc.close()}catch(t){rt("frame writing exception"),t.stack&&rt(t.stack),rt(t)}}var Gr="";var Xr=null;"undefined"!=typeof MozWebSocket?Xr=MozWebSocket:"undefined"!=typeof WebSocket&&(Xr=WebSocket);var $r=(Jr.connectionURL_=function(t,e,n){var r={v:"5"};return"undefined"!=typeof location&&location.href&&-1!==location.href.indexOf(Ft)&&(r.r="f"),e&&(r.s=e),n&&(r.ls=n),t.connectionURL(At,r)},Jr.prototype.open=function(t,e){var n=this;this.onDisconnect=e,this.onMessage=t,this.log_("Websocket connecting to "+this.connURL),this.everConnected_=!1,dt.set("previous_websocket_failure",!0);try{if(v()){var r=h.NODE_ADMIN?"AdminNode":"Node",i={headers:{"User-Agent":"Firebase/5/"+Gr+"/"+process.platform+"/"+r}},o=process.env,s=0===this.connURL.indexOf("wss://")?o.HTTPS_PROXY||o.https_proxy:o.HTTP_PROXY||o.http_proxy;s&&(i.proxy={origin:s}),this.mySock=new Xr(this.connURL,[],i)}else this.mySock=new Xr(this.connURL)}catch(t){this.log_("Error instantiating WebSocket.");var a=t.message||t.data;return a&&this.log_(a),void this.onClosed_()}this.mySock.onopen=function(){n.log_("Websocket connected."),n.everConnected_=!0},this.mySock.onclose=function(){n.log_("Websocket connection was disconnected."),n.mySock=null,n.onClosed_()},this.mySock.onmessage=function(t){n.handleIncomingFrame(t)},this.mySock.onerror=function(t){n.log_("WebSocket error. Closing connection.");var e=t.message||t.data;e&&n.log_(e),n.onClosed_()}},Jr.prototype.start=function(){},Jr.forceDisallow=function(){Jr.forceDisallow_=!0},Jr.isAvailable=function(){var t=!1;if("undefined"!=typeof navigator&&navigator.userAgent){var e=navigator.userAgent.match(/Android ([0-9]{0,}\.[0-9]{0,})/);e&&1<e.length&&parseFloat(e[1])<4.4&&(t=!0)}return!t&&null!==Xr&&!Jr.forceDisallow_},Jr.previouslyFailed=function(){return dt.isInMemoryStorage||!0===dt.get("previous_websocket_failure")},Jr.prototype.markConnectionHealthy=function(){dt.remove("previous_websocket_failure")},Jr.prototype.appendFrame_=function(t){if(this.frames.push(t),this.frames.length===this.totalFrames){var e=this.frames.join("");this.frames=null;var n=T(e);this.onMessage(n)}},Jr.prototype.handleNewFrameCount_=function(t){this.totalFrames=t,this.frames=[]},Jr.prototype.extractFrameCount_=function(t){if(C(null===this.frames,"We already have a frame buffer"),t.length<=6){var e=Number(t);if(!isNaN(e))return this.handleNewFrameCount_(e),null}return this.handleNewFrameCount_(1),t},Jr.prototype.handleIncomingFrame=function(t){if(null!==this.mySock){var e=t.data;if(this.bytesReceived+=e.length,this.stats_.incrementCounter("bytes_received",e.length),this.resetKeepAlive(),null!==this.frames)this.appendFrame_(e);else{var n=this.extractFrameCount_(e);null!==n&&this.appendFrame_(n)}}},Jr.prototype.send=function(t){this.resetKeepAlive();var e=I(t);this.bytesSent+=e.length,this.stats_.incrementCounter("bytes_sent",e.length);var n=ct(e,16384);1<n.length&&this.sendString_(String(n.length));for(var r=0;r<n.length;r++)this.sendString_(n[r])},Jr.prototype.shutdown_=function(){this.isClosed_=!0,this.keepaliveTimer&&(clearInterval(this.keepaliveTimer),this.keepaliveTimer=null),this.mySock&&(this.mySock.close(),this.mySock=null)},Jr.prototype.onClosed_=function(){this.isClosed_||(this.log_("WebSocket is closing itself"),this.shutdown_(),this.onDisconnect&&(this.onDisconnect(this.everConnected_),this.onDisconnect=null))},Jr.prototype.close=function(){this.isClosed_||(this.log_("WebSocket is being closed"),this.shutdown_())},Jr.prototype.resetKeepAlive=function(){var t=this;clearInterval(this.keepaliveTimer),this.keepaliveTimer=setInterval(function(){t.mySock&&t.sendString_("0"),t.resetKeepAlive()},Math.floor(45e3))},Jr.prototype.sendString_=function(t){try{this.mySock.send(t)}catch(t){this.log_("Exception thrown from WebSocket.send():",t.message||t.data,"Closing connection."),setTimeout(this.onClosed_.bind(this),0)}},Jr.responsesRequiredToBeHealthy=2,Jr.healthyTimeout=3e4,Jr);function Jr(t,e,n,r){this.connId=t,this.keepaliveTimer=null,this.frames=null,this.totalFrames=0,this.bytesSent=0,this.bytesReceived=0,this.log_=it(this.connId),this.stats_=Tr.getCollection(e),this.connURL=Jr.connectionURL_(e,n,r)}var Zr=(Object.defineProperty(ti,"ALL_TRANSPORTS",{get:function(){return[jr,$r]},enumerable:!0,configurable:!0}),ti.prototype.initTransports_=function(t){var e,n,r=$r&&$r.isAvailable(),i=r&&!$r.previouslyFailed();if(t.webSocketOnly&&(r||at("wss:// URL used, but browser isn't known to support websockets. Trying anyway."),i=!0),i)this.transports_=[$r];else{var o=this.transports_=[];try{for(var s=f(ti.ALL_TRANSPORTS),a=s.next();!a.done;a=s.next()){var h=a.value;h&&h.isAvailable()&&o.push(h)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(n=s.return)&&n.call(s)}finally{if(e)throw e.error}}}},ti.prototype.initialTransport=function(){if(0<this.transports_.length)return this.transports_[0];throw new Error("No transports available")},ti.prototype.upgradeTransport=function(){return 1<this.transports_.length?this.transports_[1]:null},ti);function ti(t){this.initTransports_(t)}var ei=(ni.prototype.start_=function(){var t=this,e=this.transportManager_.initialTransport();this.conn_=new e(this.nextTransportId_(),this.repoInfo_,void 0,this.lastSessionId),this.primaryResponsesRequired_=e.responsesRequiredToBeHealthy||0;var n=this.connReceiver_(this.conn_),r=this.disconnReceiver_(this.conn_);this.tx_=this.conn_,this.rx_=this.conn_,this.secondaryConn_=null,this.isHealthy_=!1,setTimeout(function(){t.conn_&&t.conn_.open(n,r)},Math.floor(0));var i=e.healthyTimeout||0;0<i&&(this.healthyTimeout_=Nt(function(){t.healthyTimeout_=null,t.isHealthy_||(t.conn_&&102400<t.conn_.bytesReceived?(t.log_("Connection exceeded healthy timeout but has received "+t.conn_.bytesReceived+" bytes. Marking connection healthy."),t.isHealthy_=!0,t.conn_.markConnectionHealthy()):t.conn_&&10240<t.conn_.bytesSent?t.log_("Connection exceeded healthy timeout but has sent "+t.conn_.bytesSent+" bytes. Leaving connection alive."):(t.log_("Closing unhealthy connection after timeout."),t.close()))},Math.floor(i)))},ni.prototype.nextTransportId_=function(){return"c:"+this.id+":"+this.connectionCount++},ni.prototype.disconnReceiver_=function(e){var n=this;return function(t){e===n.conn_?n.onConnectionLost_(t):e===n.secondaryConn_?(n.log_("Secondary connection lost."),n.onSecondaryConnectionLost_()):n.log_("closing an old connection")}},ni.prototype.connReceiver_=function(e){var n=this;return function(t){2!==n.state_&&(e===n.rx_?n.onPrimaryMessageReceived_(t):e===n.secondaryConn_?n.onSecondaryMessageReceived_(t):n.log_("message on old connection"))}},ni.prototype.sendRequest=function(t){var e={t:"d",d:t};this.sendData_(e)},ni.prototype.tryCleanupConnection=function(){this.tx_===this.secondaryConn_&&this.rx_===this.secondaryConn_&&(this.log_("cleaning up and promoting a connection: "+this.secondaryConn_.connId),this.conn_=this.secondaryConn_,this.secondaryConn_=null)},ni.prototype.onSecondaryControl_=function(t){if("t"in t){var e=t.t;"a"===e?this.upgradeIfSecondaryHealthy_():"r"===e?(this.log_("Got a reset on secondary, closing it"),this.secondaryConn_.close(),this.tx_!==this.secondaryConn_&&this.rx_!==this.secondaryConn_||this.close()):"o"===e&&(this.log_("got pong on secondary."),this.secondaryResponsesRequired_--,this.upgradeIfSecondaryHealthy_())}},ni.prototype.onSecondaryMessageReceived_=function(t){var e=ut("t",t),n=ut("d",t);if("c"===e)this.onSecondaryControl_(n);else{if("d"!==e)throw new Error("Unknown protocol layer: "+e);this.pendingDataMessages.push(n)}},ni.prototype.upgradeIfSecondaryHealthy_=function(){this.secondaryResponsesRequired_<=0?(this.log_("Secondary connection is healthy."),this.isHealthy_=!0,this.secondaryConn_.markConnectionHealthy(),this.proceedWithUpgrade_()):(this.log_("sending ping on secondary."),this.secondaryConn_.send({t:"c",d:{t:"p",d:{}}}))},ni.prototype.proceedWithUpgrade_=function(){this.secondaryConn_.start(),this.log_("sending client ack on secondary"),this.secondaryConn_.send({t:"c",d:{t:"a",d:{}}}),this.log_("Ending transmission on primary"),this.conn_.send({t:"c",d:{t:"n",d:{}}}),this.tx_=this.secondaryConn_,this.tryCleanupConnection()},ni.prototype.onPrimaryMessageReceived_=function(t){var e=ut("t",t),n=ut("d",t);"c"===e?this.onControl_(n):"d"===e&&this.onDataMessage_(n)},ni.prototype.onDataMessage_=function(t){this.onPrimaryResponse_(),this.onMessage_(t)},ni.prototype.onPrimaryResponse_=function(){this.isHealthy_||(this.primaryResponsesRequired_--,this.primaryResponsesRequired_<=0&&(this.log_("Primary connection is healthy."),this.isHealthy_=!0,this.conn_.markConnectionHealthy()))},ni.prototype.onControl_=function(t){var e=ut("t",t);if("d"in t){var n=t.d;if("h"===e)this.onHandshake_(n);else if("n"===e){this.log_("recvd end transmission on primary"),this.rx_=this.secondaryConn_;for(var r=0;r<this.pendingDataMessages.length;++r)this.onDataMessage_(this.pendingDataMessages[r]);this.pendingDataMessages=[],this.tryCleanupConnection()}else"s"===e?this.onConnectionShutdown_(n):"r"===e?this.onReset_(n):"e"===e?ot("Server Error: "+n):"o"===e?(this.log_("got pong on primary."),this.onPrimaryResponse_(),this.sendPingOnPrimaryIfNecessary_()):ot("Unknown control packet command: "+e)}},ni.prototype.onHandshake_=function(t){var e=t.ts,n=t.v,r=t.h;this.sessionId=t.s,this.repoInfo_.updateHost(r),0===this.state_&&(this.conn_.start(),this.onConnectionEstablished_(this.conn_,e),"5"!==n&&at("Protocol version mismatch detected"),this.tryStartUpgrade_())},ni.prototype.tryStartUpgrade_=function(){var t=this.transportManager_.upgradeTransport();t&&this.startUpgrade_(t)},ni.prototype.startUpgrade_=function(t){var e=this;this.secondaryConn_=new t(this.nextTransportId_(),this.repoInfo_,this.sessionId),this.secondaryResponsesRequired_=t.responsesRequiredToBeHealthy||0;var n=this.connReceiver_(this.secondaryConn_),r=this.disconnReceiver_(this.secondaryConn_);this.secondaryConn_.open(n,r),Nt(function(){e.secondaryConn_&&(e.log_("Timed out trying to upgrade."),e.secondaryConn_.close())},Math.floor(6e4))},ni.prototype.onReset_=function(t){this.log_("Reset packet received. New host: "+t),this.repoInfo_.updateHost(t),1===this.state_?this.close():(this.closeConnections_(),this.start_())},ni.prototype.onConnectionEstablished_=function(t,e){var n=this;this.log_("Realtime connection established."),this.conn_=t,this.state_=1,this.onReady_&&(this.onReady_(e,this.sessionId),this.onReady_=null),0===this.primaryResponsesRequired_?(this.log_("Primary connection is healthy."),this.isHealthy_=!0):Nt(function(){n.sendPingOnPrimaryIfNecessary_()},Math.floor(5e3))},ni.prototype.sendPingOnPrimaryIfNecessary_=function(){this.isHealthy_||1!==this.state_||(this.log_("sending ping on primary."),this.sendData_({t:"c",d:{t:"p",d:{}}}))},ni.prototype.onSecondaryConnectionLost_=function(){var t=this.secondaryConn_;this.secondaryConn_=null,this.tx_!==t&&this.rx_!==t||this.close()},ni.prototype.onConnectionLost_=function(t){this.conn_=null,t||0!==this.state_?1===this.state_&&this.log_("Realtime connection lost."):(this.log_("Realtime connection failed."),this.repoInfo_.isCacheableHost()&&(dt.remove("host:"+this.repoInfo_.host),this.repoInfo_.internalHost=this.repoInfo_.host)),this.close()},ni.prototype.onConnectionShutdown_=function(t){this.log_("Connection shutdown command received. Shutting down..."),this.onKill_&&(this.onKill_(t),this.onKill_=null),this.onDisconnect_=null,this.close()},ni.prototype.sendData_=function(t){if(1!==this.state_)throw"Connection is not connected";this.tx_.send(t)},ni.prototype.close=function(){2!==this.state_&&(this.log_("Closing realtime connection."),this.state_=2,this.closeConnections_(),this.onDisconnect_&&(this.onDisconnect_(),this.onDisconnect_=null))},ni.prototype.closeConnections_=function(){this.log_("Shutting down all connections"),this.conn_&&(this.conn_.close(),this.conn_=null),this.secondaryConn_&&(this.secondaryConn_.close(),this.secondaryConn_=null),this.healthyTimeout_&&(clearTimeout(this.healthyTimeout_),this.healthyTimeout_=null)},ni);function ni(t,e,n,r,i,o,s){this.id=t,this.repoInfo_=e,this.onMessage_=n,this.onReady_=r,this.onDisconnect_=i,this.onKill_=o,this.lastSessionId=s,this.connectionCount=0,this.pendingDataMessages=[],this.state_=0,this.log_=it("c:"+this.id+":"),this.transportManager_=new Zr(e),this.log_("Connection created"),this.start_()}var ri=(ii.prototype.put=function(t,e,n,r){},ii.prototype.merge=function(t,e,n,r){},ii.prototype.refreshAuthToken=function(t){},ii.prototype.onDisconnectPut=function(t,e,n){},ii.prototype.onDisconnectMerge=function(t,e,n){},ii.prototype.onDisconnectCancel=function(t,e){},ii.prototype.reportStats=function(t){},ii);function ii(){}var oi,si=(t(ai,oi=ri),ai.prototype.sendRequest=function(t,e,n){var r=++this.requestNumber_,i={r:r,a:t,b:e};this.log_(I(i)),C(this.connected_,"sendRequest call when we're not connected not allowed."),this.realtime_.sendRequest(i),n&&(this.requestCBHash_[r]=n)},ai.prototype.listen=function(t,e,n,r){var i=t.queryIdentifier(),o=t.path.toString();this.log_("Listen called for "+o+" "+i),this.listens.has(o)||this.listens.set(o,new Map),C(t.getQueryParams().isDefault()||!t.getQueryParams().loadsAllData(),"listen() called for non-default but complete query"),C(!this.listens.get(o).has(i),"listen() called twice for same path/queryId.");var s={onComplete:r,hashFn:e,query:t,tag:n};this.listens.get(o).set(i,s),this.connected_&&this.sendListen_(s)},ai.prototype.sendListen_=function(r){var i=this,o=r.query,s=o.path.toString(),a=o.queryIdentifier();this.log_("Listen on "+s+" for "+a);var t={p:s};r.tag&&(t.q=o.queryObject(),t.t=r.tag),t.h=r.hashFn(),this.sendRequest("q",t,function(t){var e=t.d,n=t.s;ai.warnOnListenWarnings_(e,o),(i.listens.get(s)&&i.listens.get(s).get(a))===r&&(i.log_("listen response",t),"ok"!==n&&i.removeListen_(s,a),r.onComplete&&r.onComplete(n,e))})},ai.warnOnListenWarnings_=function(t,e){if(t&&"object"==typeof t&&R(t,"w")){var n=P(t,"w");if(Array.isArray(n)&&~n.indexOf("no_index")){var r='".indexOn": "'+e.getQueryParams().getIndex().toString()+'"',i=e.path.toString();at("Using an unspecified index. Your data will be downloaded and filtered on the client. Consider adding "+r+" at "+i+" to your security rules for better performance.")}}},ai.prototype.refreshAuthToken=function(t){this.authToken_=t,this.log_("Auth token refreshed"),this.authToken_?this.tryAuth():this.connected_&&this.sendRequest("unauth",{},function(){}),this.reduceReconnectDelayIfAdminCredential_(t)},ai.prototype.reduceReconnectDelayIfAdminCredential_=function(t){(t&&40===t.length||function(t){var e=N(t).claims;return"object"==typeof e&&!0===e.admin}(t))&&(this.log_("Admin auth credential detected. Reducing max reconnect time."),this.maxReconnectDelay_=3e4)},ai.prototype.tryAuth=function(){var r=this;if(this.connected_&&this.authToken_){var i=this.authToken_,t=function(t){var e=N(t).claims;return!!e&&"object"==typeof e&&e.hasOwnProperty("iat")}(i)?"auth":"gauth",e={cred:i};null===this.authOverride_?e.noauth=!0:"object"==typeof this.authOverride_&&(e.authvar=this.authOverride_),this.sendRequest(t,e,function(t){var e=t.s,n=t.d||"error";r.authToken_===i&&("ok"===e?r.invalidAuthTokenCount_=0:r.onAuthRevoked_(e,n))})}},ai.prototype.unlisten=function(t,e){var n=t.path.toString(),r=t.queryIdentifier();this.log_("Unlisten called for "+n+" "+r),C(t.getQueryParams().isDefault()||!t.getQueryParams().loadsAllData(),"unlisten() called for non-default but complete query"),this.removeListen_(n,r)&&this.connected_&&this.sendUnlisten_(n,r,t.queryObject(),e)},ai.prototype.sendUnlisten_=function(t,e,n,r){this.log_("Unlisten on "+t+" for "+e);var i={p:t};r&&(i.q=n,i.t=r),this.sendRequest("n",i)},ai.prototype.onDisconnectPut=function(t,e,n){this.connected_?this.sendOnDisconnect_("o",t,e,n):this.onDisconnectRequestQueue_.push({pathString:t,action:"o",data:e,onComplete:n})},ai.prototype.onDisconnectMerge=function(t,e,n){this.connected_?this.sendOnDisconnect_("om",t,e,n):this.onDisconnectRequestQueue_.push({pathString:t,action:"om",data:e,onComplete:n})},ai.prototype.onDisconnectCancel=function(t,e){this.connected_?this.sendOnDisconnect_("oc",t,null,e):this.onDisconnectRequestQueue_.push({pathString:t,action:"oc",data:null,onComplete:e})},ai.prototype.sendOnDisconnect_=function(t,e,n,r){var i={p:e,d:n};this.log_("onDisconnect "+t,i),this.sendRequest(t,i,function(t){r&&setTimeout(function(){r(t.s,t.d)},Math.floor(0))})},ai.prototype.put=function(t,e,n,r){this.putInternal("p",t,e,n,r)},ai.prototype.merge=function(t,e,n,r){this.putInternal("m",t,e,n,r)},ai.prototype.putInternal=function(t,e,n,r,i){var o={p:e,d:n};void 0!==i&&(o.h=i),this.outstandingPuts_.push({action:t,request:o,onComplete:r}),this.outstandingPutCount_++;var s=this.outstandingPuts_.length-1;this.connected_?this.sendPut_(s):this.log_("Buffering put: "+e)},ai.prototype.sendPut_=function(e){var n=this,r=this.outstandingPuts_[e].action,t=this.outstandingPuts_[e].request,i=this.outstandingPuts_[e].onComplete;this.outstandingPuts_[e].queued=this.connected_,this.sendRequest(r,t,function(t){n.log_(r+" response",t),delete n.outstandingPuts_[e],n.outstandingPutCount_--,0===n.outstandingPutCount_&&(n.outstandingPuts_=[]),i&&i(t.s,t.d)})},ai.prototype.reportStats=function(t){var n=this;if(this.connected_){var e={c:t};this.log_("reportStats",e),this.sendRequest("s",e,function(t){if("ok"!==t.s){var e=t.d;n.log_("reportStats","Error sending stats: "+e)}})}},ai.prototype.onDataMessage_=function(t){if("r"in t){this.log_("from server: "+I(t));var e=t.r,n=this.requestCBHash_[e];n&&(delete this.requestCBHash_[e],n(t.b))}else{if("error"in t)throw"A server-side error has occurred: "+t.error;"a"in t&&this.onDataPush_(t.a,t.b)}},ai.prototype.onDataPush_=function(t,e){this.log_("handleServerMessage",t,e),"d"===t?this.onDataUpdate_(e.p,e.d,!1,e.t):"m"===t?this.onDataUpdate_(e.p,e.d,!0,e.t):"c"===t?this.onListenRevoked_(e.p,e.q):"ac"===t?this.onAuthRevoked_(e.s,e.d):"sd"===t?this.onSecurityDebugPacket_(e):ot("Unrecognized action received from server: "+I(t)+"\nAre you using the latest client?")},ai.prototype.onReady_=function(t,e){this.log_("connection ready"),this.connected_=!0,this.lastConnectionEstablishedTime_=(new Date).getTime(),this.handleTimestamp_(t),this.lastSessionId=e,this.firstConnection_&&this.sendConnectStats_(),this.restoreState_(),this.firstConnection_=!1,this.onConnectStatus_(!0)},ai.prototype.scheduleConnect_=function(t){var e=this;C(!this.realtime_,"Scheduling a connect when we're already connected/ing?"),this.establishConnectionTimer_&&clearTimeout(this.establishConnectionTimer_),this.establishConnectionTimer_=setTimeout(function(){e.establishConnectionTimer_=null,e.establishConnection_()},Math.floor(t))},ai.prototype.onVisible_=function(t){t&&!this.visible_&&this.reconnectDelay_===this.maxReconnectDelay_&&(this.log_("Window became visible. Reducing delay."),this.reconnectDelay_=1e3,this.realtime_||this.scheduleConnect_(0)),this.visible_=t},ai.prototype.onOnline_=function(t){t?(this.log_("Browser went online."),this.reconnectDelay_=1e3,this.realtime_||this.scheduleConnect_(0)):(this.log_("Browser went offline. Killing connection."),this.realtime_&&this.realtime_.close())},ai.prototype.onRealtimeDisconnect_=function(){if(this.log_("data client disconnected"),this.connected_=!1,this.realtime_=null,this.cancelSentTransactions_(),this.requestCBHash_={},this.shouldReconnect_()){this.visible_?this.lastConnectionEstablishedTime_&&(3e4<(new Date).getTime()-this.lastConnectionEstablishedTime_&&(this.reconnectDelay_=1e3),this.lastConnectionEstablishedTime_=null):(this.log_("Window isn't visible. Delaying reconnect."),this.reconnectDelay_=this.maxReconnectDelay_,this.lastConnectionAttemptTime_=(new Date).getTime());var t=(new Date).getTime()-this.lastConnectionAttemptTime_,e=Math.max(0,this.reconnectDelay_-t);e=Math.random()*e,this.log_("Trying to reconnect in "+e+"ms"),this.scheduleConnect_(e),this.reconnectDelay_=Math.min(this.maxReconnectDelay_,1.3*this.reconnectDelay_)}this.onConnectStatus_(!1)},ai.prototype.establishConnection_=function(){if(this.shouldReconnect_()){this.log_("Making a connection attempt"),this.lastConnectionAttemptTime_=(new Date).getTime(),this.lastConnectionEstablishedTime_=null;var e=this.onDataMessage_.bind(this),n=this.onReady_.bind(this),r=this.onRealtimeDisconnect_.bind(this),i=this.id+":"+ai.nextConnectionId_++,o=this,s=this.lastSessionId,a=!1,h=null,l=function(){h?h.close():(a=!0,r())};this.realtime_={close:l,sendRequest:function(t){C(h,"sendRequest call when we're not connected not allowed."),h.sendRequest(t)}};var t=this.forceTokenRefresh_;this.forceTokenRefresh_=!1,this.authTokenProvider_.getToken(t).then(function(t){a?rt("getToken() completed but was canceled"):(rt("getToken() completed. Creating connection."),o.authToken_=t&&t.accessToken,h=new ei(i,o.repoInfo_,e,n,r,function(t){at(t+" ("+o.repoInfo_.toString()+")"),o.interrupt("server_kill")},s))}).then(null,function(t){o.log_("Failed to get token: "+t),a||l()})}},ai.prototype.interrupt=function(t){rt("Interrupting connection for reason: "+t),this.interruptReasons_[t]=!0,this.realtime_?this.realtime_.close():(this.establishConnectionTimer_&&(clearTimeout(this.establishConnectionTimer_),this.establishConnectionTimer_=null),this.connected_&&this.onRealtimeDisconnect_())},ai.prototype.resume=function(t){rt("Resuming connection for reason: "+t),delete this.interruptReasons_[t],D(this.interruptReasons_)&&(this.reconnectDelay_=1e3,this.realtime_||this.scheduleConnect_(0))},ai.prototype.handleTimestamp_=function(t){var e=t-(new Date).getTime();this.onServerInfoUpdate_({serverTimeOffset:e})},ai.prototype.cancelSentTransactions_=function(){for(var t=0;t<this.outstandingPuts_.length;t++){var e=this.outstandingPuts_[t];e&&"h"in e.request&&e.queued&&(e.onComplete&&e.onComplete("disconnect"),delete this.outstandingPuts_[t],this.outstandingPutCount_--)}0===this.outstandingPutCount_&&(this.outstandingPuts_=[])},ai.prototype.onListenRevoked_=function(t,e){var n;n=e?e.map(function(t){return bt(t)}).join("$"):"default";var r=this.removeListen_(t,n);r&&r.onComplete&&r.onComplete("permission_denied")},ai.prototype.removeListen_=function(t,e){var n,r=new Dt(t).toString();if(this.listens.has(r)){var i=this.listens.get(r);n=i.get(e),i.delete(e),0===i.size&&this.listens.delete(r)}else n=void 0;return n},ai.prototype.onAuthRevoked_=function(t,e){rt("Auth token revoked: "+t+"/"+e),this.authToken_=null,this.forceTokenRefresh_=!0,this.realtime_.close(),"invalid_token"!==t&&"permission_denied"!==t||(this.invalidAuthTokenCount_++,3<=this.invalidAuthTokenCount_&&(this.reconnectDelay_=3e4,this.authTokenProvider_.notifyForInvalidToken()))},ai.prototype.onSecurityDebugPacket_=function(t){this.securityDebugCallback_?this.securityDebugCallback_(t):"msg"in t&&console.log("FIREBASE: "+t.msg.replace("\n","\nFIREBASE: "))},ai.prototype.restoreState_=function(){var e,t,n,r;this.tryAuth();try{for(var i=f(this.listens.values()),o=i.next();!o.done;o=i.next()){var s=o.value;try{for(var a=(n=void 0,f(s.values())),h=a.next();!h.done;h=a.next()){var l=h.value;this.sendListen_(l)}}catch(t){n={error:t}}finally{try{h&&!h.done&&(r=a.return)&&r.call(a)}finally{if(n)throw n.error}}}}catch(t){e={error:t}}finally{try{o&&!o.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}for(var u=0;u<this.outstandingPuts_.length;u++)this.outstandingPuts_[u]&&this.sendPut_(u);for(;this.onDisconnectRequestQueue_.length;){var c=this.onDisconnectRequestQueue_.shift();this.sendOnDisconnect_(c.action,c.pathString,c.data,c.onComplete)}},ai.prototype.sendConnectStats_=function(){var t={};t["sdk.js."+Gr.replace(/\./g,"-")]=1,y()?t["framework.cordova"]=1:"object"==typeof navigator&&"ReactNative"===navigator.product&&(t["framework.reactnative"]=1),this.reportStats(t)},ai.prototype.shouldReconnect_=function(){var t=Ur.getInstance().currentlyOnline();return D(this.interruptReasons_)&&t},ai.nextPersistentConnectionId_=0,ai.nextConnectionId_=0,ai);function ai(t,e,n,r,i,o){var s=oi.call(this)||this;if(s.repoInfo_=t,s.onDataUpdate_=e,s.onConnectStatus_=n,s.onServerInfoUpdate_=r,s.authTokenProvider_=i,s.authOverride_=o,s.id=ai.nextPersistentConnectionId_++,s.log_=it("p:"+s.id+":"),s.interruptReasons_={},s.listens=new Map,s.outstandingPuts_=[],s.outstandingPutCount_=0,s.onDisconnectRequestQueue_=[],s.connected_=!1,s.reconnectDelay_=1e3,s.maxReconnectDelay_=3e5,s.securityDebugCallback_=null,s.lastSessionId=null,s.establishConnectionTimer_=null,s.visible_=!1,s.requestCBHash_={},s.requestNumber_=0,s.realtime_=null,s.authToken_=null,s.forceTokenRefresh_=!1,s.invalidAuthTokenCount_=0,s.firstConnection_=!0,s.lastConnectionAttemptTime_=null,s.lastConnectionEstablishedTime_=null,o&&!v())throw new Error("Auth override specified in options, but not supported on non Node.js platforms");return s.scheduleConnect_(0),Wr.getInstance().on("visible",s.onVisible_,s),-1===t.host.indexOf("fblocal")&&Ur.getInstance().on("online",s.onOnline_,s),s}var hi,li=(t(ui,hi=ri),ui.prototype.reportStats=function(t){throw new Error("Method not implemented.")},ui.getListenId_=function(t,e){return void 0!==e?"tag$"+e:(C(t.getQueryParams().isDefault(),"should have a tag if it's not a default query."),t.path.toString())},ui.prototype.listen=function(t,e,r,i){var o=this,s=t.path.toString();this.log_("Listen called for "+s+" "+t.queryIdentifier());var a=ui.getListenId_(t,r),h={};this.listens_[a]=h;var n=t.getQueryParams().toRestQueryStringParameters();this.restRequest_(s+".json",n,function(t,e){var n=e;404===t&&(t=n=null),null===t&&o.onDataUpdate_(s,n,!1,r),P(o.listens_,a)===h&&i(t?401===t?"permission_denied":"rest_error:"+t:"ok",null)})},ui.prototype.unlisten=function(t,e){var n=ui.getListenId_(t,e);delete this.listens_[n]},ui.prototype.refreshAuthToken=function(t){},ui.prototype.restRequest_=function(i,o,s){var a=this;void 0===o&&(o={}),o.format="export",this.authTokenProvider_.getToken(!1).then(function(t){var e=t&&t.accessToken;e&&(o.auth=e);var n=(a.repoInfo_.secure?"https://":"http://")+a.repoInfo_.host+i+"?ns="+a.repoInfo_.namespace+function(t){for(var n=[],e=function(e,t){Array.isArray(t)?t.forEach(function(t){n.push(encodeURIComponent(e)+"="+encodeURIComponent(t))}):n.push(encodeURIComponent(e)+"="+encodeURIComponent(t))},r=0,i=Object.entries(t);r<i.length;r++){var o=i[r];e(o[0],o[1])}return n.length?"&"+n.join("&"):""}(o);a.log_("Sending REST request for "+n);var r=new XMLHttpRequest;r.onreadystatechange=function(){if(s&&4===r.readyState){a.log_("REST Response for "+n+" received. status:",r.status,"response:",r.responseText);var t=null;if(200<=r.status&&r.status<300){try{t=T(r.responseText)}catch(t){at("Failed to parse JSON response for "+n+": "+r.responseText)}s(null,t)}else 401!==r.status&&404!==r.status&&at("Got unsuccessful REST response for "+n+" Status: "+r.status),s(r.status);s=null}},r.open("GET",n,!0),r.send()})},ui);function ui(t,e,n){var r=hi.call(this)||this;return r.repoInfo_=t,r.onDataUpdate_=e,r.authTokenProvider_=n,r.log_=it("p:rest:"),r.listens_={},r}var ci="repo_interrupt",pi=(di.prototype.toString=function(){return(this.repoInfo_.secure?"https://":"http://")+this.repoInfo_.host},di.prototype.name=function(){return this.repoInfo_.namespace},di.prototype.serverTime=function(){var t=this.infoData_.getNode(new Dt(".info/serverTimeOffset")).val()||0;return(new Date).getTime()+t},di.prototype.generateServerValues=function(){return function(t){return(t=t||{}).timestamp=t.timestamp||(new Date).getTime(),t}({timestamp:this.serverTime()})},di.prototype.onDataUpdate_=function(t,e,n,r){this.dataUpdateCount++;var i=new Dt(t);e=this.interceptServerDataCallback_?this.interceptServerDataCallback_(t,e):e;var o=[];if(r)if(n){var s=O(e,function(t){return nn(t)});o=this.serverSyncTree_.applyTaggedQueryMerge(i,s,r)}else{var a=nn(e);o=this.serverSyncTree_.applyTaggedQueryOverwrite(i,a,r)}else if(n){var h=O(e,function(t){return nn(t)});o=this.serverSyncTree_.applyServerMerge(i,h)}else{var l=nn(e);o=this.serverSyncTree_.applyServerOverwrite(i,l)}var u=i;0<o.length&&(u=this.rerunTransactions_(i)),this.eventQueue_.raiseEventsForChangedPath(u,o)},di.prototype.interceptServerData_=function(t){this.interceptServerDataCallback_=t},di.prototype.onConnectStatus_=function(t){this.updateInfo_("connected",t),!1===t&&this.runOnDisconnectEvents_()},di.prototype.onServerInfoUpdate_=function(t){var n=this;St(t,function(t,e){n.updateInfo_(t,e)})},di.prototype.updateInfo_=function(t,e){var n=new Dt("/.info/"+t),r=nn(e);this.infoData_.updateSnapshot(n,r);var i=this.infoSyncTree_.applyServerOverwrite(n,r);this.eventQueue_.raiseEventsForChangedPath(n,i)},di.prototype.getNextWriteId_=function(){return this.nextWriteId_++},di.prototype.setWithPriority=function(i,t,e,o){var s=this;this.log_("set",{path:i.toString(),value:t,priority:e});var n=this.generateServerValues(),r=nn(t,e),a=Nn(r,n),h=this.getNextWriteId_(),l=this.serverSyncTree_.applyUserOverwrite(i,a,h,!0);this.eventQueue_.queueEvents(l),this.server_.put(i.toString(),r.val(!0),function(t,e){var n="ok"===t;n||at("set at "+i+" failed: "+t);var r=s.serverSyncTree_.ackUserWrite(h,!n);s.eventQueue_.raiseEventsForChangedPath(i,r),s.callOnCompleteCallback(o,t,e)});var u=this.abortTransactions_(i);this.rerunTransactions_(u),this.eventQueue_.raiseEventsForChangedPath(u,[])},di.prototype.update=function(o,t,s){var a=this;this.log_("update",{path:o.toString(),value:t});var r=!0,i=this.generateServerValues(),h={};if(St(t,function(t,e){r=!1;var n=nn(e);h[t]=Nn(n,i)}),r)rt("update() called with empty data. Don't do anything."),this.callOnCompleteCallback(s,"ok");else{var l=this.getNextWriteId_(),e=this.serverSyncTree_.applyUserMerge(o,h,l);this.eventQueue_.queueEvents(e),this.server_.merge(o.toString(),t,function(t,e){var n="ok"===t;n||at("update at "+o+" failed: "+t);var r=a.serverSyncTree_.ackUserWrite(l,!n),i=0<r.length?a.rerunTransactions_(o):o;a.eventQueue_.raiseEventsForChangedPath(i,r),a.callOnCompleteCallback(s,t,e)}),St(t,function(t){var e=a.abortTransactions_(o.child(t));a.rerunTransactions_(e)}),this.eventQueue_.raiseEventsForChangedPath(o,[])}},di.prototype.runOnDisconnectEvents_=function(){var r=this;this.log_("onDisconnectEvents");var t=this.generateServerValues(),e=function(t,n){var r=new wn;return t.forEachTree(new Dt(""),function(t,e){r.remember(t,Nn(e,n))}),r}(this.onDisconnect_,t),i=[];e.forEachTree(Dt.Empty,function(t,e){i=i.concat(r.serverSyncTree_.applyServerOverwrite(t,e));var n=r.abortTransactions_(t);r.rerunTransactions_(n)}),this.onDisconnect_=new wn,this.eventQueue_.raiseEventsForChangedPath(Dt.Empty,i)},di.prototype.onDisconnectCancel=function(n,r){var i=this;this.server_.onDisconnectCancel(n.toString(),function(t,e){"ok"===t&&i.onDisconnect_.forget(n),i.callOnCompleteCallback(r,t,e)})},di.prototype.onDisconnectSet=function(n,t,r){var i=this,o=nn(t);this.server_.onDisconnectPut(n.toString(),o.val(!0),function(t,e){"ok"===t&&i.onDisconnect_.remember(n,o),i.callOnCompleteCallback(r,t,e)})},di.prototype.onDisconnectSetWithPriority=function(n,t,e,r){var i=this,o=nn(t,e);this.server_.onDisconnectPut(n.toString(),o.val(!0),function(t,e){"ok"===t&&i.onDisconnect_.remember(n,o),i.callOnCompleteCallback(r,t,e)})},di.prototype.onDisconnectUpdate=function(r,n,i){var o=this;if(D(n))return rt("onDisconnect().update() called with empty data. Don't do anything."),void this.callOnCompleteCallback(i,"ok");this.server_.onDisconnectMerge(r.toString(),n,function(t,e){"ok"===t&&St(n,function(t,e){var n=nn(e);o.onDisconnect_.remember(r.child(t),n)}),o.callOnCompleteCallback(i,t,e)})},di.prototype.addEventCallbackForQuery=function(t,e){var n;n=".info"===t.path.getFront()?this.infoSyncTree_.addEventRegistration(t,e):this.serverSyncTree_.addEventRegistration(t,e),this.eventQueue_.raiseEventsAtPath(t.path,n)},di.prototype.removeEventCallbackForQuery=function(t,e){var n;n=".info"===t.path.getFront()?this.infoSyncTree_.removeEventRegistration(t,e):this.serverSyncTree_.removeEventRegistration(t,e),this.eventQueue_.raiseEventsAtPath(t.path,n)},di.prototype.interrupt=function(){this.persistentConnection_&&this.persistentConnection_.interrupt(ci)},di.prototype.resume=function(){this.persistentConnection_&&this.persistentConnection_.resume(ci)},di.prototype.stats=function(t){if(void 0===t&&(t=!1),"undefined"!=typeof console){var e;e=t?(this.statsListener_||(this.statsListener_=new Nr(this.stats_)),this.statsListener_.get()):this.stats_.get();var i=Object.keys(e).reduce(function(t,e){return Math.max(e.length,t)},0);St(e,function(t,e){for(var n=t,r=t.length;r<i+2;r++)n+=" ";console.log(n+e)})}},di.prototype.statsIncrementCounter=function(t){this.stats_.incrementCounter(t),this.statsReporter_.includeStat(t)},di.prototype.log_=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var n="";this.persistentConnection_&&(n=this.persistentConnection_.id+":"),rt.apply(void 0,o([n],t))},di.prototype.callOnCompleteCallback=function(r,i,o){r&&It(function(){if("ok"===i)r(null);else{var t=(i||"error").toUpperCase(),e=t;o&&(e+=": "+o);var n=new Error(e);n.code=t,r(n)}})},Object.defineProperty(di.prototype,"database",{get:function(){return this.__database||(this.__database=new xi(this))},enumerable:!0,configurable:!0}),di);function di(t,e,n,r){var s=this;this.repoInfo_=t,this.app=n,this.dataUpdateCount=0,this.statsListener_=null,this.eventQueue_=new Or,this.nextWriteId_=1,this.interceptServerDataCallback_=null,this.onDisconnect_=new wn,this.persistentConnection_=null;var i=new Er(n,r);if(this.stats_=Tr.getCollection(t),e||0<=("object"==typeof window&&window.navigator&&window.navigator.userAgent||"").search(/googlebot|google webmaster tools|bingbot|yahoo! slurp|baiduspider|yandexbot|duckduckbot/i))this.server_=new li(this.repoInfo_,this.onDataUpdate_.bind(this),i),setTimeout(this.onConnectStatus_.bind(this,!0),0);else{var o=n.options.databaseAuthVariableOverride;if(null!=o){if("object"!=typeof o)throw new Error("Only objects are supported for option databaseAuthVariableOverride");try{I(o)}catch(t){throw new Error("Invalid authOverride provided: "+t)}}this.persistentConnection_=new si(this.repoInfo_,this.onDataUpdate_.bind(this),this.onConnectStatus_.bind(this),this.onServerInfoUpdate_.bind(this),i,o),this.server_=this.persistentConnection_}i.addTokenChangeListener(function(t){s.server_.refreshAuthToken(t)}),this.statsReporter_=Tr.getOrCreateReporter(t,function(){return new Pr(s.stats_,s.server_)}),this.transactionsInit_(),this.infoData_=new mr,this.infoSyncTree_=new vr({startListening:function(t,e,n,r){var i=[],o=s.infoData_.getNode(t.path);return o.isEmpty()||(i=s.infoSyncTree_.applyServerOverwrite(t.path,o),setTimeout(function(){r("ok")},0)),i},stopListening:function(){}}),this.updateInfo_("connected",!1),this.serverSyncTree_=new vr({startListening:function(r,t,e,i){return s.server_.listen(r,e,t,function(t,e){var n=i(t,e);s.eventQueue_.raiseEventsForChangedPath(r.path,n)}),[]},stopListening:function(t,e){s.server_.unlisten(t,e)}})}var fi=(_i.prototype.getStartPost=function(){return this.startPost_},_i.prototype.getEndPost=function(){return this.endPost_},_i.prototype.matches=function(t){return this.index_.compare(this.getStartPost(),t)<=0&&this.index_.compare(t,this.getEndPost())<=0},_i.prototype.updateChild=function(t,e,n,r,i,o){return this.matches(new ue(e,n))||(n=Xe.EMPTY_NODE),this.indexedFilter_.updateChild(t,e,n,r,i,o)},_i.prototype.updateFullNode=function(t,e,n){e.isLeafNode()&&(e=Xe.EMPTY_NODE);var r=e.withIndex(this.index_);r=r.updatePriority(Xe.EMPTY_NODE);var i=this;return e.forEachChild(Pe,function(t,e){i.matches(new ue(t,e))||(r=r.updateImmediateChild(t,Xe.EMPTY_NODE))}),this.indexedFilter_.updateFullNode(t,r,n)},_i.prototype.updatePriority=function(t,e){return t},_i.prototype.filtersNodes=function(){return!0},_i.prototype.getIndexedFilter=function(){return this.indexedFilter_},_i.prototype.getIndex=function(){return this.index_},_i.getStartPost_=function(t){if(t.hasStart()){var e=t.getIndexStartName();return t.getIndex().makePost(t.getIndexStartValue(),e)}return t.getIndex().minPost()},_i.getEndPost_=function(t){if(t.hasEnd()){var e=t.getIndexEndName();return t.getIndex().makePost(t.getIndexEndValue(),e)}return t.getIndex().maxPost()},_i);function _i(t){this.indexedFilter_=new Yn(t.getIndex()),this.index_=t.getIndex(),this.startPost_=_i.getStartPost_(t),this.endPost_=_i.getEndPost_(t)}var yi=(vi.prototype.updateChild=function(t,e,n,r,i,o){return this.rangedFilter_.matches(new ue(e,n))||(n=Xe.EMPTY_NODE),t.getImmediateChild(e).equals(n)?t:t.numChildren()<this.limit_?this.rangedFilter_.getIndexedFilter().updateChild(t,e,n,r,i,o):this.fullLimitUpdateChild_(t,e,n,i,o)},vi.prototype.updateFullNode=function(t,e,n){var r;if(e.isLeafNode()||e.isEmpty())r=Xe.EMPTY_NODE.withIndex(this.index_);else if(2*this.limit_<e.numChildren()&&e.isIndexed(this.index_)){r=Xe.EMPTY_NODE.withIndex(this.index_);var i=void 0;i=this.reverse_?e.getReverseIteratorFrom(this.rangedFilter_.getEndPost(),this.index_):e.getIteratorFrom(this.rangedFilter_.getStartPost(),this.index_);for(var o=0;i.hasNext()&&o<this.limit_;){var s=i.getNext();if(!(this.reverse_?this.index_.compare(this.rangedFilter_.getStartPost(),s)<=0:this.index_.compare(s,this.rangedFilter_.getEndPost())<=0))break;r=r.updateImmediateChild(s.name,s.node),o++}}else{r=(r=e.withIndex(this.index_)).updatePriority(Xe.EMPTY_NODE);var a=void 0,h=void 0,l=void 0;if(i=void 0,this.reverse_){i=r.getReverseIterator(this.index_),a=this.rangedFilter_.getEndPost(),h=this.rangedFilter_.getStartPost();var u=this.index_.getCompare();l=function(t,e){return u(e,t)}}else i=r.getIterator(this.index_),a=this.rangedFilter_.getStartPost(),h=this.rangedFilter_.getEndPost(),l=this.index_.getCompare();o=0;for(var c=!1;i.hasNext();)s=i.getNext(),!c&&l(a,s)<=0&&(c=!0),c&&o<this.limit_&&l(s,h)<=0?o++:r=r.updateImmediateChild(s.name,Xe.EMPTY_NODE)}return this.rangedFilter_.getIndexedFilter().updateFullNode(t,r,n)},vi.prototype.updatePriority=function(t,e){return t},vi.prototype.filtersNodes=function(){return!0},vi.prototype.getIndexedFilter=function(){return this.rangedFilter_.getIndexedFilter()},vi.prototype.getIndex=function(){return this.index_},vi.prototype.fullLimitUpdateChild_=function(t,e,n,r,i){var o;if(this.reverse_){var s=this.index_.getCompare();o=function(t,e){return s(e,t)}}else o=this.index_.getCompare();var a=t;C(a.numChildren()===this.limit_,"");var h=new ue(e,n),l=this.reverse_?a.getFirstChild(this.index_):a.getLastChild(this.index_),u=this.rangedFilter_.matches(h);if(a.hasChild(e)){for(var c=a.getImmediateChild(e),p=r.getChildAfterChild(this.index_,l,this.reverse_);null!=p&&(p.name===e||a.hasChild(p.name));)p=r.getChildAfterChild(this.index_,p,this.reverse_);var d=null==p?1:o(p,h);if(u&&!n.isEmpty()&&0<=d)return null!=i&&i.trackChildChange(jn.childChangedChange(e,n,c)),a.updateImmediateChild(e,n);null!=i&&i.trackChildChange(jn.childRemovedChange(e,c));var f=a.updateImmediateChild(e,Xe.EMPTY_NODE);return null!=p&&this.rangedFilter_.matches(p)?(null!=i&&i.trackChildChange(jn.childAddedChange(p.name,p.node)),f.updateImmediateChild(p.name,p.node)):f}return n.isEmpty()?t:u&&0<=o(l,h)?(null!=i&&(i.trackChildChange(jn.childRemovedChange(l.name,l.node)),i.trackChildChange(jn.childAddedChange(e,n))),a.updateImmediateChild(e,n).updateImmediateChild(l.name,Xe.EMPTY_NODE)):t},vi);function vi(t){this.rangedFilter_=new fi(t),this.index_=t.getIndex(),this.limit_=t.getLimit(),this.reverse_=!t.isViewFromLeft()}var gi=(mi.prototype.hasStart=function(){return this.startSet_},mi.prototype.isViewFromLeft=function(){return""===this.viewFrom_?this.startSet_:this.viewFrom_===mi.WIRE_PROTOCOL_CONSTANTS_.VIEW_FROM_LEFT},mi.prototype.getIndexStartValue=function(){return C(this.startSet_,"Only valid if start has been set"),this.indexStartValue_},mi.prototype.getIndexStartName=function(){return C(this.startSet_,"Only valid if start has been set"),this.startNameSet_?this.indexStartName_:Ct},mi.prototype.hasEnd=function(){return this.endSet_},mi.prototype.getIndexEndValue=function(){return C(this.endSet_,"Only valid if end has been set"),this.indexEndValue_},mi.prototype.getIndexEndName=function(){return C(this.endSet_,"Only valid if end has been set"),this.endNameSet_?this.indexEndName_:Et},mi.prototype.hasLimit=function(){return this.limitSet_},mi.prototype.hasAnchoredLimit=function(){return this.limitSet_&&""!==this.viewFrom_},mi.prototype.getLimit=function(){return C(this.limitSet_,"Only valid if limit has been set"),this.limit_},mi.prototype.getIndex=function(){return this.index_},mi.prototype.copy_=function(){var t=new mi;return t.limitSet_=this.limitSet_,t.limit_=this.limit_,t.startSet_=this.startSet_,t.indexStartValue_=this.indexStartValue_,t.startNameSet_=this.startNameSet_,t.indexStartName_=this.indexStartName_,t.endSet_=this.endSet_,t.indexEndValue_=this.indexEndValue_,t.endNameSet_=this.endNameSet_,t.indexEndName_=this.indexEndName_,t.index_=this.index_,t.viewFrom_=this.viewFrom_,t},mi.prototype.limit=function(t){var e=this.copy_();return e.limitSet_=!0,e.limit_=t,e.viewFrom_="",e},mi.prototype.limitToFirst=function(t){var e=this.copy_();return e.limitSet_=!0,e.limit_=t,e.viewFrom_=mi.WIRE_PROTOCOL_CONSTANTS_.VIEW_FROM_LEFT,e},mi.prototype.limitToLast=function(t){var e=this.copy_();return e.limitSet_=!0,e.limit_=t,e.viewFrom_=mi.WIRE_PROTOCOL_CONSTANTS_.VIEW_FROM_RIGHT,e},mi.prototype.startAt=function(t,e){var n=this.copy_();return n.startSet_=!0,void 0===t&&(t=null),n.indexStartValue_=t,null!=e?(n.startNameSet_=!0,n.indexStartName_=e):(n.startNameSet_=!1,n.indexStartName_=""),n},mi.prototype.endAt=function(t,e){var n=this.copy_();return n.endSet_=!0,void 0===t&&(t=null),n.indexEndValue_=t,void 0!==e?(n.endNameSet_=!0,n.indexEndName_=e):(n.endNameSet_=!1,n.indexEndName_=""),n},mi.prototype.orderBy=function(t){var e=this.copy_();return e.index_=t,e},mi.prototype.getQueryObject=function(){var t=mi.WIRE_PROTOCOL_CONSTANTS_,e={};if(this.startSet_&&(e[t.INDEX_START_VALUE]=this.indexStartValue_,this.startNameSet_&&(e[t.INDEX_START_NAME]=this.indexStartName_)),this.endSet_&&(e[t.INDEX_END_VALUE]=this.indexEndValue_,this.endNameSet_&&(e[t.INDEX_END_NAME]=this.indexEndName_)),this.limitSet_){e[t.LIMIT]=this.limit_;var n=this.viewFrom_;""===n&&(n=this.isViewFromLeft()?t.VIEW_FROM_LEFT:t.VIEW_FROM_RIGHT),e[t.VIEW_FROM]=n}return this.index_!==Pe&&(e[t.INDEX]=this.index_.toString()),e},mi.prototype.loadsAllData=function(){return!(this.startSet_||this.endSet_||this.limitSet_)},mi.prototype.isDefault=function(){return this.loadsAllData()&&this.index_===Pe},mi.prototype.getNodeFilter=function(){return this.loadsAllData()?new Yn(this.getIndex()):this.hasLimit()?new yi(this):new fi(this)},mi.prototype.toRestQueryStringParameters=function(){var t,e=mi.REST_QUERY_CONSTANTS_,n={};return this.isDefault()||(t=this.index_===Pe?e.PRIORITY_INDEX:this.index_===sn?e.VALUE_INDEX:this.index_===me?e.KEY_INDEX:(C(this.index_ instanceof an,"Unrecognized index type!"),this.index_.toString()),n[e.ORDER_BY]=I(t),this.startSet_&&(n[e.START_AT]=I(this.indexStartValue_),this.startNameSet_&&(n[e.START_AT]+=","+I(this.indexStartName_))),this.endSet_&&(n[e.END_AT]=I(this.indexEndValue_),this.endNameSet_&&(n[e.END_AT]+=","+I(this.indexEndName_))),this.limitSet_&&(this.isViewFromLeft()?n[e.LIMIT_TO_FIRST]=this.limit_:n[e.LIMIT_TO_LAST]=this.limit_)),n},mi.WIRE_PROTOCOL_CONSTANTS_={INDEX_START_VALUE:"sp",INDEX_START_NAME:"sn",INDEX_END_VALUE:"ep",INDEX_END_NAME:"en",LIMIT:"l",VIEW_FROM:"vf",VIEW_FROM_LEFT:"l",VIEW_FROM_RIGHT:"r",INDEX:"i"},mi.REST_QUERY_CONSTANTS_={ORDER_BY:"orderBy",PRIORITY_INDEX:"$priority",VALUE_INDEX:"$value",KEY_INDEX:"$key",START_AT:"startAt",END_AT:"endAt",LIMIT_TO_FIRST:"limitToFirst",LIMIT_TO_LAST:"limitToLast"},mi.DEFAULT=new mi,mi);function mi(){this.limitSet_=!1,this.startSet_=!1,this.startNameSet_=!1,this.endSet_=!1,this.endNameSet_=!1,this.limit_=0,this.viewFrom_="",this.indexStartValue_=null,this.indexStartName_="",this.indexEndValue_=null,this.indexEndName_="",this.index_=Pe}var Ci,Ei=(t(wi,Ci=Cn),wi.prototype.getKey=function(){return F("Reference.key",0,0,arguments.length),this.path.isEmpty()?null:this.path.getBack()},wi.prototype.child=function(t){return F("Reference.child",1,1,arguments.length),"number"==typeof t?t=String(t):t instanceof Dt||(null===this.path.getFront()?function(t,e,n,r){n=n&&n.replace(/^\/*\.info(\/|$)/,"/"),zt(t,e,n,r)}("Reference.child",1,t,!1):zt("Reference.child",1,t,!1)),new wi(this.repo,this.path.child(t))},wi.prototype.getParent=function(){F("Reference.parent",0,0,arguments.length);var t=this.path.parent();return null===t?null:new wi(this.repo,t)},wi.prototype.getRoot=function(){F("Reference.root",0,0,arguments.length);for(var t=this;null!==t.getParent();)t=t.getParent();return t},wi.prototype.databaseProp=function(){return this.repo.database},wi.prototype.set=function(t,e){F("Reference.set",1,2,arguments.length),Gt("Reference.set",this.path),Ht("Reference.set",1,t,this.path,!1),L("Reference.set",2,e,!0);var n=new p;return this.repo.setWithPriority(this.path,t,null,n.wrapCallback(e)),n.promise},wi.prototype.update=function(t,e){if(F("Reference.update",1,2,arguments.length),Gt("Reference.update",this.path),Array.isArray(t)){for(var n={},r=0;r<t.length;++r)n[""+r]=t[r];t=n,at("Passing an Array to Firebase.update() is deprecated. Use set() if you want to overwrite the existing data, or an Object with integer keys if you really do want to only update some of the children.")}Bt("Reference.update",1,t,this.path,!1),L("Reference.update",2,e,!0);var i=new p;return this.repo.update(this.path,t,i.wrapCallback(e)),i.promise},wi.prototype.setWithPriority=function(t,e,n){if(F("Reference.setWithPriority",2,3,arguments.length),Gt("Reference.setWithPriority",this.path),Ht("Reference.setWithPriority",1,t,this.path,!1),jt("Reference.setWithPriority",2,e,!1),L("Reference.setWithPriority",3,n,!0),".length"===this.getKey()||".keys"===this.getKey())throw"Reference.setWithPriority failed: "+this.getKey()+" is a read-only object.";var r=new p;return this.repo.setWithPriority(this.path,t,e,r.wrapCallback(n)),r.promise},wi.prototype.remove=function(t){return F("Reference.remove",0,1,arguments.length),Gt("Reference.remove",this.path),L("Reference.remove",1,t,!0),this.set(null,t)},wi.prototype.transaction=function(t,r,e){if(F("Reference.transaction",1,3,arguments.length),Gt("Reference.transaction",this.path),L("Reference.transaction",1,t,!1),L("Reference.transaction",2,r,!0),function(t,e,n,r){if((!r||void 0!==n)&&"boolean"!=typeof n)throw new Error(A(t,e,r)+"must be a boolean.")}("Reference.transaction",3,e,!0),".length"===this.getKey()||".keys"===this.getKey())throw"Reference.transaction failed: "+this.getKey()+" is a read-only object.";void 0===e&&(e=!0);var i=new p;return"function"==typeof r&&i.promise.catch(function(){}),this.repo.startTransaction(this.path,t,function(t,e,n){t?i.reject(t):i.resolve(new ie(e,n)),"function"==typeof r&&r(t,e,n)},e),i.promise},wi.prototype.setPriority=function(t,e){F("Reference.setPriority",1,2,arguments.length),Gt("Reference.setPriority",this.path),jt("Reference.setPriority",1,t,!1),L("Reference.setPriority",2,e,!0);var n=new p;return this.repo.setWithPriority(this.path.child(".priority"),t,null,n.wrapCallback(e)),n.promise},wi.prototype.push=function(t,e){F("Reference.push",0,2,arguments.length),Gt("Reference.push",this.path),Ht("Reference.push",1,t,this.path,!0),L("Reference.push",2,e,!0);var n,r=this.repo.serverTime(),i=le(r),o=this.child(i),s=this.child(i);return n=null!=t?o.set(t,e).then(function(){return s}):Promise.resolve(s),o.then=n.then.bind(n),o.catch=n.then.bind(n,void 0),"function"==typeof e&&n.catch(function(){}),o},wi.prototype.onDisconnect=function(){return Gt("Reference.onDisconnect",this.path),new ne(this.repo,this.path)},Object.defineProperty(wi.prototype,"database",{get:function(){return this.databaseProp()},enumerable:!0,configurable:!0}),Object.defineProperty(wi.prototype,"key",{get:function(){return this.getKey()},enumerable:!0,configurable:!0}),Object.defineProperty(wi.prototype,"parent",{get:function(){return this.getParent()},enumerable:!0,configurable:!0}),Object.defineProperty(wi.prototype,"root",{get:function(){return this.getRoot()},enumerable:!0,configurable:!0}),wi);function wi(t,e){if(!(t instanceof pi))throw new Error("new Reference() no longer supported - use app.database().");return Ci.call(this,t,e,gi.DEFAULT,!1)||this}Cn.__referenceConstructor=Ei,lr.__referenceConstructor=Ei;var bi,Si,Ti=function(){this.children={},this.childCount=0,this.value=null},Ii=(Ni.prototype.subTree=function(t){for(var e=t instanceof Dt?t:new Dt(t),n=this,r=e.getFront();null!==r;)n=new Ni(r,n,P(n.node_.children,r)||new Ti),r=(e=e.popFront()).getFront();return n},Ni.prototype.getValue=function(){return this.node_.value},Ni.prototype.setValue=function(t){C(void 0!==t,"Cannot set value to undefined"),this.node_.value=t,this.updateParents_()},Ni.prototype.clear=function(){this.node_.value=null,this.node_.children={},this.node_.childCount=0,this.updateParents_()},Ni.prototype.hasChildren=function(){return 0<this.node_.childCount},Ni.prototype.isEmpty=function(){return null===this.getValue()&&!this.hasChildren()},Ni.prototype.forEachChild=function(n){var r=this;St(this.node_.children,function(t,e){n(new Ni(t,r,e))})},Ni.prototype.forEachDescendant=function(e,t,n){t&&!n&&e(this),this.forEachChild(function(t){t.forEachDescendant(e,!0,n)}),t&&n&&e(this)},Ni.prototype.forEachAncestor=function(t,e){for(var n=e?this:this.parent();null!==n;){if(t(n))return!0;n=n.parent()}return!1},Ni.prototype.forEachImmediateDescendantWithValue=function(e){this.forEachChild(function(t){null!==t.getValue()?e(t):t.forEachImmediateDescendantWithValue(e)})},Ni.prototype.path=function(){return new Dt(null===this.parent_?this.name_:this.parent_.path()+"/"+this.name_)},Ni.prototype.name=function(){return this.name_},Ni.prototype.parent=function(){return this.parent_},Ni.prototype.updateParents_=function(){null!==this.parent_&&this.parent_.updateChild_(this.name_,this)},Ni.prototype.updateChild_=function(t,e){var n=e.isEmpty(),r=R(this.node_.children,t);n&&r?(delete this.node_.children[t],this.node_.childCount--,this.updateParents_()):n||r||(this.node_.children[t]=e.node_,this.node_.childCount++,this.updateParents_())},Ni);function Ni(t,e,n){void 0===t&&(t=""),void 0===e&&(e=null),void 0===n&&(n=new Ti),this.name_=t,this.parent_=e,this.node_=n}(Si=bi=bi||{})[Si.RUN=0]="RUN",Si[Si.SENT=1]="SENT",Si[Si.COMPLETED=2]="COMPLETED",Si[Si.SENT_NEEDS_ABORT=3]="SENT_NEEDS_ABORT",Si[Si.NEEDS_ABORT=4]="NEEDS_ABORT",pi.MAX_TRANSACTION_RETRIES_=25,pi.prototype.transactionsInit_=function(){this.transactionQueueTree_=new Ii},pi.prototype.startTransaction=function(t,e,n,r){this.log_("transaction on "+t);function i(){}var o=new Ei(this,t);o.on("value",i);var s={path:t,update:e,onComplete:n,status:null,order:yt(),applyLocally:r,retryCount:0,unwatcher:function(){o.off("value",i)},abortReason:null,currentWriteId:null,currentInputSnapshot:null,currentOutputSnapshotRaw:null,currentOutputSnapshotResolved:null},a=this.getLatestState_(t);s.currentInputSnapshot=a;var h=s.update(a.val());if(void 0===h){if(s.unwatcher(),s.currentOutputSnapshotRaw=null,s.currentOutputSnapshotResolved=null,s.onComplete){var l=new ln(s.currentInputSnapshot,new Ei(this,s.path),Pe);s.onComplete(null,!1,l)}}else{ee("transaction failed: Data returned ",h,s.path),s.status=bi.RUN;var u=this.transactionQueueTree_.subTree(t),c=u.getValue()||[];c.push(s),u.setValue(c);var p=void 0;if("object"==typeof h&&null!==h&&R(h,".priority"))p=P(h,".priority"),C(Vt(p),"Invalid priority returned by transaction. Priority must be a valid string, finite number, server value, or null.");else p=(this.serverSyncTree_.calcCompleteEventCache(t)||Xe.EMPTY_NODE).getPriority().val();p=p;var d=this.generateServerValues(),f=nn(h,p),_=Nn(f,d);s.currentOutputSnapshotRaw=f,s.currentOutputSnapshotResolved=_,s.currentWriteId=this.getNextWriteId_();var y=this.serverSyncTree_.applyUserOverwrite(t,_,s.currentWriteId,s.applyLocally);this.eventQueue_.raiseEventsForChangedPath(t,y),this.sendReadyTransactions_()}},pi.prototype.getLatestState_=function(t,e){return this.serverSyncTree_.calcCompleteEventCache(t,e)||Xe.EMPTY_NODE},pi.prototype.sendReadyTransactions_=function(t){var e=this;if(void 0===t&&(t=this.transactionQueueTree_),t||this.pruneCompletedTransactionsBelowNode_(t),null!==t.getValue()){var n=this.buildTransactionQueue_(t);C(0<n.length,"Sending zero length transaction queue"),n.every(function(t){return t.status===bi.RUN})&&this.sendTransactionQueue_(t.path(),n)}else t.hasChildren()&&t.forEachChild(function(t){e.sendReadyTransactions_(t)})},pi.prototype.sendTransactionQueue_=function(a,h){for(var l=this,t=h.map(function(t){return t.currentWriteId}),e=this.getLatestState_(a,t),n=e,r=e.hash(),i=0;i<h.length;i++){var o=h[i];C(o.status===bi.RUN,"tryToSendTransactionQueue_: items in queue should all be run."),o.status=bi.SENT,o.retryCount++;var s=Dt.relativePath(a,o.path);n=n.updateChild(s,o.currentOutputSnapshotRaw)}var u=n.val(!0),c=a;this.server_.put(c.toString(),u,function(t){l.log_("transaction put response",{path:c.toString(),status:t});var e=[];if("ok"===t){for(var n=[],r=0;r<h.length;r++){if(h[r].status=bi.COMPLETED,e=e.concat(l.serverSyncTree_.ackUserWrite(h[r].currentWriteId)),h[r].onComplete){var i=h[r].currentOutputSnapshotResolved,o=new Ei(l,h[r].path),s=new ln(i,o,Pe);n.push(h[r].onComplete.bind(null,null,!0,s))}h[r].unwatcher()}l.pruneCompletedTransactionsBelowNode_(l.transactionQueueTree_.subTree(a)),l.sendReadyTransactions_(),l.eventQueue_.raiseEventsForChangedPath(a,e);for(r=0;r<n.length;r++)It(n[r])}else{if("datastale"===t)for(r=0;r<h.length;r++)h[r].status===bi.SENT_NEEDS_ABORT?h[r].status=bi.NEEDS_ABORT:h[r].status=bi.RUN;else{at("transaction at "+c.toString()+" failed: "+t);for(r=0;r<h.length;r++)h[r].status=bi.NEEDS_ABORT,h[r].abortReason=t}l.rerunTransactions_(a)}},r)},pi.prototype.rerunTransactions_=function(t){var e=this.getAncestorTransactionNode_(t),n=e.path(),r=this.buildTransactionQueue_(e);return this.rerunTransactionQueue_(r,n),n},pi.prototype.rerunTransactionQueue_=function(t,e){if(0!==t.length){for(var n,r=[],i=[],o=t.filter(function(t){return t.status===bi.RUN}).map(function(t){return t.currentWriteId}),s=0;s<t.length;s++){var a=t[s],h=Dt.relativePath(e,a.path),l=!1,u=void 0;if(C(null!==h,"rerunTransactionsUnderNode_: relativePath should not be null."),a.status===bi.NEEDS_ABORT)l=!0,u=a.abortReason,i=i.concat(this.serverSyncTree_.ackUserWrite(a.currentWriteId,!0));else if(a.status===bi.RUN)if(a.retryCount>=pi.MAX_TRANSACTION_RETRIES_)l=!0,u="maxretry",i=i.concat(this.serverSyncTree_.ackUserWrite(a.currentWriteId,!0));else{var c=this.getLatestState_(a.path,o);a.currentInputSnapshot=c;var p=t[s].update(c.val());if(void 0!==p){ee("transaction failed: Data returned ",p,a.path);var d=nn(p);"object"==typeof p&&null!=p&&R(p,".priority")||(d=d.updatePriority(c.getPriority()));var f=a.currentWriteId,_=this.generateServerValues(),y=Nn(d,_);a.currentOutputSnapshotRaw=d,a.currentOutputSnapshotResolved=y,a.currentWriteId=this.getNextWriteId_(),o.splice(o.indexOf(f),1),i=(i=i.concat(this.serverSyncTree_.applyUserOverwrite(a.path,y,a.currentWriteId,a.applyLocally))).concat(this.serverSyncTree_.ackUserWrite(f,!0))}else l=!0,u="nodata",i=i.concat(this.serverSyncTree_.ackUserWrite(a.currentWriteId,!0))}if(this.eventQueue_.raiseEventsForChangedPath(e,i),i=[],l&&(t[s].status=bi.COMPLETED,n=t[s].unwatcher,setTimeout(n,Math.floor(0)),t[s].onComplete))if("nodata"===u){var v=new Ei(this,t[s].path),g=t[s].currentInputSnapshot,m=new ln(g,v,Pe);r.push(t[s].onComplete.bind(null,null,!1,m))}else r.push(t[s].onComplete.bind(null,new Error(u),!1,null))}this.pruneCompletedTransactionsBelowNode_(this.transactionQueueTree_);for(s=0;s<r.length;s++)It(r[s]);this.sendReadyTransactions_()}},pi.prototype.getAncestorTransactionNode_=function(t){var e,n=this.transactionQueueTree_;for(e=t.getFront();null!==e&&null===n.getValue();)n=n.subTree(e),e=(t=t.popFront()).getFront();return n},pi.prototype.buildTransactionQueue_=function(t){var e=[];return this.aggregateTransactionQueuesForNode_(t,e),e.sort(function(t,e){return t.order-e.order}),e},pi.prototype.aggregateTransactionQueuesForNode_=function(t,e){var n=this,r=t.getValue();if(null!==r)for(var i=0;i<r.length;i++)e.push(r[i]);t.forEachChild(function(t){n.aggregateTransactionQueuesForNode_(t,e)})},pi.prototype.pruneCompletedTransactionsBelowNode_=function(t){var e=this,n=t.getValue();if(n){for(var r=0,i=0;i<n.length;i++)n[i].status!==bi.COMPLETED&&(n[r]=n[i],r++);n.length=r,t.setValue(0<n.length?n:null)}t.forEachChild(function(t){e.pruneCompletedTransactionsBelowNode_(t)})},pi.prototype.abortTransactions_=function(t){var e=this,n=this.getAncestorTransactionNode_(t).path(),r=this.transactionQueueTree_.subTree(t);return r.forEachAncestor(function(t){e.abortTransactionsOnNode_(t)}),this.abortTransactionsOnNode_(r),r.forEachDescendant(function(t){e.abortTransactionsOnNode_(t)}),n},pi.prototype.abortTransactionsOnNode_=function(t){var e=t.getValue();if(null!==e){for(var n=[],r=[],i=-1,o=0;o<e.length;o++)if(e[o].status===bi.SENT_NEEDS_ABORT);else if(e[o].status===bi.SENT)C(i===o-1,"All SENT items should be at beginning of queue."),e[i=o].status=bi.SENT_NEEDS_ABORT,e[o].abortReason="set";else if(C(e[o].status===bi.RUN,"Unexpected transaction status in abort"),e[o].unwatcher(),r=r.concat(this.serverSyncTree_.ackUserWrite(e[o].currentWriteId,!0)),e[o].onComplete){n.push(e[o].onComplete.bind(null,new Error("set"),!1,null))}-1===i?t.setValue(null):e.length=i+1,this.eventQueue_.raiseEventsForChangedPath(t.path(),r);for(o=0;o<n.length;o++)It(n[o])}};var Ri,Pi="databaseURL",Di=(Oi.getInstance=function(){return Ri=Ri||new Oi},Oi.prototype.interrupt=function(){var e,t,n,r;try{for(var i=f(Object.keys(this.repos_)),o=i.next();!o.done;o=i.next()){var s=o.value;try{for(var a=(n=void 0,f(Object.keys(this.repos_[s]))),h=a.next();!h.done;h=a.next()){var l=h.value;this.repos_[s][l].interrupt()}}catch(t){n={error:t}}finally{try{h&&!h.done&&(r=a.return)&&r.call(a)}finally{if(n)throw n.error}}}}catch(t){e={error:t}}finally{try{o&&!o.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}},Oi.prototype.resume=function(){var e,t,n,r;try{for(var i=f(Object.keys(this.repos_)),o=i.next();!o.done;o=i.next()){var s=o.value;try{for(var a=(n=void 0,f(Object.keys(this.repos_[s]))),h=a.next();!h.done;h=a.next()){var l=h.value;this.repos_[s][l].resume()}}catch(t){n={error:t}}finally{try{h&&!h.done&&(r=a.return)&&r.call(a)}finally{if(n)throw n.error}}}}catch(t){e={error:t}}finally{try{o&&!o.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}},Oi.prototype.databaseFromApp=function(t,e,n){var r=n||t.options[Pi];void 0===r&&st("Can't determine Firebase Database URL. Be sure to include "+Pi+" option when calling firebase.initializeApp().");var i=Qt(r),o=i.repoInfo,s=void 0;return"undefined"!=typeof process&&(s=process.env.FIREBASE_DATABASE_EMULATOR_HOST),s&&(r="http://"+s+"?ns="+o.namespace,o=(i=Qt(r)).repoInfo),Xt("Invalid Firebase Database URL",1,i),i.path.isEmpty()||st("Database URL must point to the root of a Firebase Database (not including a child path)."),this.createRepo(o,t,e).database},Oi.prototype.deleteRepo=function(t){var e=P(this.repos_,t.app.name);e&&P(e,t.repoInfo_.toURLString())===t||st("Database "+t.app.name+"("+t.repoInfo_+") has already been deleted."),t.interrupt(),delete e[t.repoInfo_.toURLString()]},Oi.prototype.createRepo=function(t,e,n){var r=P(this.repos_,e.name);r||(r={},this.repos_[e.name]=r);var i=P(r,t.toURLString());return i&&st("Database initialized multiple times. Please make sure the format of the database URL matches with each database() call."),i=new pi(t,this.useRestClient_,e,n),r[t.toURLString()]=i},Oi.prototype.forceRestClient=function(t){this.useRestClient_=t},Oi);function Oi(){this.repos_={},this.useRestClient_=!1}var xi=(Object.defineProperty(ki.prototype,"app",{get:function(){return this.repo_.app},enumerable:!0,configurable:!0}),ki.prototype.ref=function(t){return this.checkDeleted_("ref"),F("database.ref",0,1,arguments.length),t instanceof Ei?this.refFromURL(t.toString()):void 0!==t?this.root_.child(t):this.root_},ki.prototype.refFromURL=function(t){var e="database.refFromURL";this.checkDeleted_(e),F(e,1,1,arguments.length);var n=Qt(t);Xt(e,1,n);var r=n.repoInfo;return r.host!==this.repo_.repoInfo_.host&&st(e+": Host name does not match the current database: (found "+r.host+" but expected "+this.repo_.repoInfo_.host+")"),this.ref(n.path.toString())},ki.prototype.checkDeleted_=function(t){null===this.repo_&&st("Cannot call "+t+" on a deleted database.")},ki.prototype.goOffline=function(){F("database.goOffline",0,0,arguments.length),this.checkDeleted_("goOffline"),this.repo_.interrupt()},ki.prototype.goOnline=function(){F("database.goOnline",0,0,arguments.length),this.checkDeleted_("goOnline"),this.repo_.resume()},ki.ServerValue={TIMESTAMP:{".sv":"timestamp"}},ki);function ki(t){(this.repo_=t)instanceof pi||st("Don't call new Database() directly - please use firebase.database()."),this.root_=new Ei(t,Dt.Empty),this.INTERNAL=new Fi(this)}var Fi=(Ai.prototype.delete=function(){return e(this,void 0,void 0,function(){return n(this,function(t){return this.database.checkDeleted_("delete"),Di.getInstance().deleteRepo(this.database.repo_),this.database.repo_=null,this.database.root_=null,this.database.INTERNAL=null,this.database=null,[2]})})},Ai);function Ai(t){this.database=t}var Li=Object.freeze({__proto__:null,forceLongPolling:function(){$r.forceDisallow(),jr.forceAllow()},forceWebSockets:function(){jr.forceDisallow()},isWebSocketsAvailable:function(){return $r.isAvailable()},setSecurityDebugCallback:function(t,e){t.repo.persistentConnection_.securityDebugCallback_=e},stats:function(t,e){t.repo.stats(e)},statsIncrementCounter:function(t,e){t.repo.statsIncrementCounter(e)},dataUpdateCount:function(t){return t.repo.dataUpdateCount},interceptServerData:function(t,e){return t.repo.interceptServerData_(e)}}),Mi=si;si.prototype.simpleListen=function(t,e){this.sendRequest("q",{p:t},e)},si.prototype.echo=function(t,e){this.sendRequest("echo",{d:t},e)};var Wi,Qi,qi=ei,Ui=Mt,Vi=Object.freeze({__proto__:null,DataConnection:Mi,RealTimeConnection:qi,hijackHash:function(i){var o=si.prototype.put;return si.prototype.put=function(t,e,n,r){void 0!==r&&(r=i()),o.call(this,t,e,n,r)},function(){si.prototype.put=o}},ConnectionTarget:Ui,queryIdentifier:function(t){return t.queryIdentifier()},forceRestClient:function(t){Di.getInstance().forceRestClient(t)}}),Hi=xi.ServerValue;Wi=(Qi=Bi).SDK_VERSION,Gr=Wi,Qi.INTERNAL.registerComponent(new z("database",function(t,e){var n=t.getProvider("app").getImmediate(),r=t.getProvider("auth-internal");return Di.getInstance().databaseFromApp(n,r,e)},"PUBLIC").setServiceProps({Reference:Ei,Query:Cn,Database:xi,DataSnapshot:ln,enableLogging:nt,INTERNAL:Li,ServerValue:Hi,TEST_ACCESS:Vi}).setMultipleInstances(!0)),Qi.registerVersion("@firebase/database","0.5.24")}).apply(this,arguments)}catch(t){throw console.error(t),new Error("Cannot instantiate firebase-database.js - be sure to load firebase-app.js first.")}});
2//# sourceMappingURL=firebase-database.js.map