dexie-cloud-addon 4.0.0-beta.13 → 4.0.0-beta.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/dist/modern/dexie-cloud-addon.js +154 -49
  2. package/dist/modern/dexie-cloud-addon.js.map +1 -1
  3. package/dist/modern/dexie-cloud-addon.min.js +1 -1
  4. package/dist/modern/dexie-cloud-addon.min.js.map +1 -1
  5. package/dist/modern/service-worker.js +152 -46
  6. package/dist/modern/service-worker.js.map +1 -1
  7. package/dist/modern/service-worker.min.js +1 -1
  8. package/dist/modern/service-worker.min.js.map +1 -1
  9. package/dist/module-es5/dexie-cloud-addon.js +109 -45
  10. package/dist/module-es5/dexie-cloud-addon.js.map +1 -1
  11. package/dist/module-es5/dexie-cloud-addon.min.js +1 -1
  12. package/dist/module-es5/dexie-cloud-addon.min.js.map +1 -1
  13. package/dist/types/DexieCloudAPI.d.ts +4 -1
  14. package/dist/types/DexieCloudEntity.d.ts +8 -0
  15. package/dist/types/Invite.d.ts +1 -1
  16. package/dist/types/WSObservable.d.ts +1 -0
  17. package/dist/types/WebSocketStatus.d.ts +1 -0
  18. package/dist/types/createMyMembersObservable.d.ts +14 -0
  19. package/dist/types/currentUserObservable.d.ts +3 -0
  20. package/dist/types/dexie-cloud-client.d.ts +1 -0
  21. package/dist/types/getGlobalRolesObservable.d.ts +5 -0
  22. package/dist/types/getInvitesObservable.d.ts +1 -1
  23. package/dist/types/helpers/BroadcastedLocalEvent.d.ts +8 -0
  24. package/dist/types/helpers/visibleState.d.ts +1 -0
  25. package/dist/types/permissionsLookup.d.ts +9 -0
  26. package/dist/types/permissionsLookupObservable.d.ts +14 -0
  27. package/dist/types/sync/globalizePrivateIds.d.ts +4 -0
  28. package/dist/types/sync/syncServerToClientOnly.d.ts +3 -0
  29. package/dist/types/types/CloudConnectionStatus.d.ts +0 -0
  30. package/dist/types/types/ConnectionStatus.d.ts +0 -0
  31. package/dist/types/types/LoginState.d.ts +41 -0
  32. package/dist/types/types/SyncConnectionStatus.d.ts +1 -0
  33. package/dist/types/types/SyncFlowStatus.d.ts +6 -0
  34. package/dist/types/types/SyncStatus.d.ts +6 -0
  35. package/dist/umd/dexie-cloud-addon.js +129 -64
  36. package/dist/umd/dexie-cloud-addon.js.map +1 -1
  37. package/dist/umd/dexie-cloud-addon.min.js +1 -1
  38. package/dist/umd/dexie-cloud-addon.min.js.map +1 -1
  39. package/dist/umd/service-worker.js +175 -69
  40. package/dist/umd/service-worker.js.map +1 -1
  41. package/dist/umd/service-worker.min.js +1 -1
  42. package/dist/umd/service-worker.min.js.map +1 -1
  43. package/dist/umd-modern/dexie-cloud-addon.js +172 -66
  44. package/dist/umd-modern/dexie-cloud-addon.js.map +1 -1
  45. package/package.json +5 -3
@@ -1 +1 @@
1
- import e,{cmp as t,liveQuery as n}from"dexie";import{Observable as r,BehaviorSubject as o,Subject as s,from as i,fromEvent as a,of as c,merge as u,Subscription as l,throwError as d,combineLatest as f,map as p,share as h,timer as y,switchMap as m}from"rxjs";const b={userId:"unauthorized",name:"Unauthorized",claims:{sub:"unauthorized"},lastLogin:new Date(0)};try{Object.freeze(b),Object.freeze(b.claims)}catch{}const v={},g=self.document&&navigator.serviceWorker;g&&g.ready.then((e=>v.registration=e)),"undefined"!=typeof self&&"clients"in self&&!self.document&&addEventListener("message",(e=>{e.data?.type?.startsWith("sw-broadcast-")&&[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.id!==e.source?.id&&t.postMessage(e.data)))}));class w{constructor(e){this.name=e}subscribe(e){if(!g)return()=>{};const t=t=>{t.data?.type===`sw-broadcast-${this.name}`&&e(t.data.message)};return g.addEventListener("message",t),()=>g.removeEventListener("message",t)}postMessage(e){"object"==typeof self.clients?[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))):v.registration&&v.registration.active?.postMessage({type:`sw-broadcast-${this.name}`,message:e})}}class _ extends r{constructor(e){const t="undefined"==typeof BroadcastChannel?new w(e):new BroadcastChannel(e);super((n=>{function r(e){n.next(e.detail)}function o(e){console.debug("BroadcastedAndLocalEvent: onMessageEvent",e),n.next(e.data)}let s;return self.addEventListener(`lbc-${e}`,r),t instanceof w?s=t.subscribe((e=>n.next(e))):(console.debug("BroadcastedAndLocalEvent: bc.addEventListener()",e,"bc is a",t),t.addEventListener("message",o)),()=>{self.removeEventListener(`lbc-${e}`,r),t instanceof w?s():t.removeEventListener("message",o)}})),this.name=e,this.bc=t}next(e){console.debug("BroadcastedAndLocalEvent: bc.postMessage()",{...e},"bc is a",this.bc),this.bc.postMessage(e);const t=new CustomEvent(`lbc-${this.name}`,{detail:e});self.dispatchEvent(t)}}function S(e){return"function"==typeof e}function k(e){return function(t){if(function(e){return S(null==e?void 0:e.lift)}(t))return t.lift((function(t){try{return e(t,this)}catch(e){this.error(e)}}));throw new TypeError("Unable to lift unknown Observable type")}}var x=function(e,t){return x=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])},x(e,t)};function E(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");function n(){this.constructor=e}x(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function I(e,t,n,r){return new(n||(n=Promise))((function(o,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))}function C(e,t){var n,r,o,s,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return s={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(s[Symbol.iterator]=function(){return this}),s;function a(s){return function(a){return function(s){if(n)throw new TypeError("Generator is already executing.");for(;i;)try{if(n=1,r&&(o=2&s[0]?r.return:s[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,s[1])).done)return o;switch(r=0,o&&(s=[2&s[0],o.value]),s[0]){case 0:case 1:o=s;break;case 4:return i.label++,{value:s[1],done:!1};case 5:i.label++,r=s[1],s=[0];continue;case 7:s=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==s[0]&&2!==s[0])){i=0;continue}if(3===s[0]&&(!o||s[1]>o[0]&&s[1]<o[3])){i.label=s[1];break}if(6===s[0]&&i.label<o[1]){i.label=o[1],o=s;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(s);break}o[2]&&i.ops.pop(),i.trys.pop();continue}s=t.call(e,i)}catch(e){s=[6,e],r=0}finally{n=o=0}if(5&s[0])throw s[1];return{value:s[0]?s[1]:void 0,done:!0}}([s,a])}}}function A(e){var t="function"==typeof Symbol&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function T(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,s=n.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=s.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(n=s.return)&&n.call(s)}finally{if(o)throw o.error}}return i}function P(e,t){for(var n=0,r=t.length,o=e.length;n<r;n++,o++)e[o]=t[n];return e}function U(e){return this instanceof U?(this.v=e,this):new U(e)}function $(e,t,n){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var r,o=n.apply(e,t||[]),s=[];return r={},i("next"),i("throw"),i("return"),r[Symbol.asyncIterator]=function(){return this},r;function i(e){o[e]&&(r[e]=function(t){return new Promise((function(n,r){s.push([e,t,n,r])>1||a(e,t)}))})}function a(e,t){try{!function(e){e.value instanceof U?Promise.resolve(e.value.v).then(c,u):l(s[0][2],e)}(o[e](t))}catch(e){l(s[0][3],e)}}function c(e){a("next",e)}function u(e){a("throw",e)}function l(e,t){e(t),s.shift(),s.length&&a(s[0][0],s[0][1])}}function D(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t,n=e[Symbol.asyncIterator];return n?n.call(e):(e=A(e),t={},r("next"),r("throw"),r("return"),t[Symbol.asyncIterator]=function(){return this},t);function r(n){t[n]=e[n]&&function(t){return new Promise((function(r,o){(function(e,t,n,r){Promise.resolve(r).then((function(t){e({value:t,done:n})}),t)})(r,o,(t=e[n](t)).done,t.value)}))}}}var O=function(e){return e&&"number"==typeof e.length&&"function"!=typeof e};function R(e){return S(null==e?void 0:e.then)}function L(e){var t=e((function(e){Error.call(e),e.stack=(new Error).stack}));return t.prototype=Object.create(Error.prototype),t.prototype.constructor=t,t}var N=L((function(e){return function(t){e(this),this.message=t?t.length+" errors occurred during unsubscription:\n"+t.map((function(e,t){return t+1+") "+e.toString()})).join("\n "):"",this.name="UnsubscriptionError",this.errors=t}}));function j(e,t){if(e){var n=e.indexOf(t);0<=n&&e.splice(n,1)}}var W=function(){function e(e){this.initialTeardown=e,this.closed=!1,this._parentage=null,this._teardowns=null}var t;return e.prototype.unsubscribe=function(){var e,t,n,r,o;if(!this.closed){this.closed=!0;var s=this._parentage;if(s)if(this._parentage=null,Array.isArray(s))try{for(var i=A(s),a=i.next();!a.done;a=i.next()){a.value.remove(this)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}else s.remove(this);var c=this.initialTeardown;if(S(c))try{c()}catch(e){o=e instanceof N?e.errors:[e]}var u=this._teardowns;if(u){this._teardowns=null;try{for(var l=A(u),d=l.next();!d.done;d=l.next()){var f=d.value;try{M(f)}catch(e){o=null!=o?o:[],e instanceof N?o=P(P([],T(o)),T(e.errors)):o.push(e)}}}catch(e){n={error:e}}finally{try{d&&!d.done&&(r=l.return)&&r.call(l)}finally{if(n)throw n.error}}}if(o)throw new N(o)}},e.prototype.add=function(t){var n;if(t&&t!==this)if(this.closed)M(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._teardowns=null!==(n=this._teardowns)&&void 0!==n?n:[]).push(t)}},e.prototype._hasParent=function(e){var t=this._parentage;return t===e||Array.isArray(t)&&t.includes(e)},e.prototype._addParent=function(e){var t=this._parentage;this._parentage=Array.isArray(t)?(t.push(e),t):t?[t,e]:e},e.prototype._removeParent=function(e){var t=this._parentage;t===e?this._parentage=null:Array.isArray(t)&&j(t,e)},e.prototype.remove=function(t){var n=this._teardowns;n&&j(n,t),t instanceof e&&t._removeParent(this)},e.EMPTY=((t=new e).closed=!0,t),e}();function B(e){return e instanceof W||e&&"closed"in e&&S(e.remove)&&S(e.add)&&S(e.unsubscribe)}function M(e){S(e)?e():e.unsubscribe()}var F={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1},K=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return setTimeout.apply(void 0,P([],T(e)))};function H(e){K((function(){throw e}))}function q(){}var z=function(e){function t(t){var n=e.call(this)||this;return n.isStopped=!1,t?(n.destination=t,B(t)&&t.add(n)):n.destination=Y,n}return E(t,e),t.create=function(e,t,n){return new V(e,t,n)},t.prototype.next=function(e){this.isStopped||this._next(e)},t.prototype.error=function(e){this.isStopped||(this.isStopped=!0,this._error(e))},t.prototype.complete=function(){this.isStopped||(this.isStopped=!0,this._complete())},t.prototype.unsubscribe=function(){this.closed||(this.isStopped=!0,e.prototype.unsubscribe.call(this),this.destination=null)},t.prototype._next=function(e){this.destination.next(e)},t.prototype._error=function(e){try{this.destination.error(e)}finally{this.unsubscribe()}},t.prototype._complete=function(){try{this.destination.complete()}finally{this.unsubscribe()}},t}(W),V=function(e){function t(t,n,r){var o,s=e.call(this)||this;if(S(t))o=t;else if(t){var i;o=t.next,n=t.error,r=t.complete,s&&F.useDeprecatedNextContext?(i=Object.create(t)).unsubscribe=function(){return s.unsubscribe()}:i=t,o=null==o?void 0:o.bind(i),n=null==n?void 0:n.bind(i),r=null==r?void 0:r.bind(i)}return s.destination={next:o?J(o):q,error:J(null!=n?n:G),complete:r?J(r):q},s}return E(t,e),t}(z);function J(e,t){return function(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];try{e.apply(void 0,P([],T(t)))}catch(e){H(e)}}}function G(e){throw e}var Y={closed:!0,next:q,error:G,complete:q},Z="function"==typeof Symbol&&Symbol.observable||"@@observable";function X(e){return e}function Q(e){return 0===e.length?X:1===e.length?e[0]:function(t){return e.reduce((function(e,t){return t(e)}),t)}}var ee=function(){function e(e){e&&(this._subscribe=e)}return e.prototype.lift=function(t){var n=new e;return n.source=this,n.operator=t,n},e.prototype.subscribe=function(e,t,n){var r,o=this,s=(r=e)&&r instanceof z||function(e){return e&&S(e.next)&&S(e.error)&&S(e.complete)}(r)&&B(r)?e:new V(e,t,n);return function(){var e=o,t=e.operator,n=e.source;s.add(t?t.call(s,n):n?o._subscribe(s):o._trySubscribe(s))}(),s},e.prototype._trySubscribe=function(e){try{return this._subscribe(e)}catch(t){e.error(t)}},e.prototype.forEach=function(e,t){var n=this;return new(t=te(t))((function(t,r){var o;o=n.subscribe((function(t){try{e(t)}catch(e){r(e),null==o||o.unsubscribe()}}),r,t)}))},e.prototype._subscribe=function(e){var t;return null===(t=this.source)||void 0===t?void 0:t.subscribe(e)},e.prototype[Z]=function(){return this},e.prototype.pipe=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return Q(e)(this)},e.prototype.toPromise=function(e){var t=this;return new(e=te(e))((function(e,n){var r;t.subscribe((function(e){return r=e}),(function(e){return n(e)}),(function(){return e(r)}))}))},e.create=function(t){return new e(t)},e}();function te(e){var t;return null!==(t=null!=e?e:F.Promise)&&void 0!==t?t:Promise}function ne(e){return S(e[Z])}function re(e){return Symbol.asyncIterator&&S(null==e?void 0:e[Symbol.asyncIterator])}function oe(e){return new TypeError("You provided "+(null!==e&&"object"==typeof e?"an invalid object":"'"+e+"'")+" where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.")}var se="function"==typeof Symbol&&Symbol.iterator?Symbol.iterator:"@@iterator";function ie(e){return S(null==e?void 0:e[se])}function ae(e){return $(this,arguments,(function(){var t,n,r;return C(this,(function(o){switch(o.label){case 0:t=e.getReader(),o.label=1;case 1:o.trys.push([1,,9,10]),o.label=2;case 2:return[4,U(t.read())];case 3:return n=o.sent(),r=n.value,n.done?[4,U(void 0)]:[3,5];case 4:return[2,o.sent()];case 5:return[4,U(r)];case 6:return[4,o.sent()];case 7:return o.sent(),[3,2];case 8:return[3,10];case 9:return t.releaseLock(),[7];case 10:return[2]}}))}))}function ce(e){return S(null==e?void 0:e.getReader)}function ue(e){if(e instanceof ee)return e;if(null!=e){if(ne(e))return o=e,new ee((function(e){var t=o[Z]();if(S(t.subscribe))return t.subscribe(e);throw new TypeError("Provided object does not correctly implement Symbol.observable")}));if(O(e))return r=e,new ee((function(e){for(var t=0;t<r.length&&!e.closed;t++)e.next(r[t]);e.complete()}));if(R(e))return n=e,new ee((function(e){n.then((function(t){e.closed||(e.next(t),e.complete())}),(function(t){return e.error(t)})).then(null,H)}));if(re(e))return le(e);if(ie(e))return t=e,new ee((function(e){var n,r;try{for(var o=A(t),s=o.next();!s.done;s=o.next()){var i=s.value;if(e.next(i),e.closed)return}}catch(e){n={error:e}}finally{try{s&&!s.done&&(r=o.return)&&r.call(o)}finally{if(n)throw n.error}}e.complete()}));if(ce(e))return le(ae(e))}var t,n,r,o;throw oe(e)}function le(e){return new ee((function(t){(function(e,t){var n,r,o,s;return I(this,void 0,void 0,(function(){var i,a;return C(this,(function(c){switch(c.label){case 0:c.trys.push([0,5,6,11]),n=D(e),c.label=1;case 1:return[4,n.next()];case 2:if((r=c.sent()).done)return[3,4];if(i=r.value,t.next(i),t.closed)return[2];c.label=3;case 3:return[3,1];case 4:return[3,11];case 5:return a=c.sent(),o={error:a},[3,11];case 6:return c.trys.push([6,,9,10]),r&&!r.done&&(s=n.return)?[4,s.call(n)]:[3,8];case 7:c.sent(),c.label=8;case 8:return[3,10];case 9:if(o)throw o.error;return[7];case 10:return[7];case 11:return t.complete(),[2]}}))}))})(e,t).catch((function(e){return t.error(e)}))}))}var de=function(e){function t(t,n,r,o,s){var i=e.call(this,t)||this;return i.onFinalize=s,i._next=n?function(e){try{n(e)}catch(e){t.error(e)}}:e.prototype._next,i._error=o?function(e){try{o(e)}catch(e){t.error(e)}finally{this.unsubscribe()}}:e.prototype._error,i._complete=r?function(){try{r()}catch(e){t.error(e)}finally{this.unsubscribe()}}:e.prototype._complete,i}return E(t,e),t.prototype.unsubscribe=function(){var t,n=this.closed;e.prototype.unsubscribe.call(this),!n&&(null===(t=this.onFinalize)||void 0===t||t.call(this))},t}(z),fe=function(e){function t(t,n){return e.call(this)||this}return E(t,e),t.prototype.schedule=function(e,t){return this},t}(W),pe=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return setInterval.apply(void 0,P([],T(e)))},he=function(e){return clearInterval(e)},ye=function(e){function t(t,n){var r=e.call(this,t,n)||this;return r.scheduler=t,r.work=n,r.pending=!1,r}return E(t,e),t.prototype.schedule=function(e,t){if(void 0===t&&(t=0),this.closed)return this;this.state=e;var n=this.id,r=this.scheduler;return null!=n&&(this.id=this.recycleAsyncId(r,n,t)),this.pending=!0,this.delay=t,this.id=this.id||this.requestAsyncId(r,this.id,t),this},t.prototype.requestAsyncId=function(e,t,n){return void 0===n&&(n=0),pe(e.flush.bind(e,this),n)},t.prototype.recycleAsyncId=function(e,t,n){if(void 0===n&&(n=0),null!=n&&this.delay===n&&!1===this.pending)return t;he(t)},t.prototype.execute=function(e,t){if(this.closed)return new Error("executing a cancelled action");this.pending=!1;var n=this._execute(e,t);if(n)return n;!1===this.pending&&null!=this.id&&(this.id=this.recycleAsyncId(this.scheduler,this.id,null))},t.prototype._execute=function(e,t){var n,r=!1;try{this.work(e)}catch(e){r=!0,n=e||new Error("Scheduled action threw falsy error")}if(r)return this.unsubscribe(),n},t.prototype.unsubscribe=function(){if(!this.closed){var t=this.id,n=this.scheduler,r=n.actions;this.work=this.state=this.scheduler=null,this.pending=!1,j(r,this),null!=t&&(this.id=this.recycleAsyncId(n,t,null)),this.delay=null,e.prototype.unsubscribe.call(this)}},t}(fe),me=function(){return Date.now()},be=function(){function e(t,n){void 0===n&&(n=e.now),this.schedulerActionCtor=t,this.now=n}return e.prototype.schedule=function(e,t,n){return void 0===t&&(t=0),new this.schedulerActionCtor(this,e).schedule(n,t)},e.now=me,e}(),ve=new(function(e){function t(t,n){void 0===n&&(n=be.now);var r=e.call(this,t,n)||this;return r.actions=[],r._active=!1,r._scheduled=void 0,r}return E(t,e),t.prototype.flush=function(e){var t=this.actions;if(this._active)t.push(e);else{var n;this._active=!0;do{if(n=e.execute(e.state,e.delay))break}while(e=t.shift());if(this._active=!1,n){for(;e=t.shift();)e.unsubscribe();throw n}}},t}(be))(ye),ge=ve;function we(e){return e&&S(e.schedule)}function _e(e){return e instanceof Date&&!isNaN(e)}function Se(e){return we((t=e)[t.length-1])?e.pop():void 0;var t}function ke(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=!1);var s=t.schedule((function(){n(),o?e.add(this.schedule(null,r)):this.unsubscribe()}),r);if(e.add(s),!o)return s}function xe(e){return k((function(t,n){var r,o=null,s=!1;o=t.subscribe(new de(n,void 0,void 0,(function(i){r=ue(e(i,xe(e)(t))),o?(o.unsubscribe(),o=null,r.subscribe(n)):s=!0}))),s&&(o.unsubscribe(),o=null,r.subscribe(n))}))}function Ee(e,t){return void 0===t&&(t=0),k((function(n,r){n.subscribe(new de(r,(function(n){return ke(r,e,(function(){return r.next(n)}),t)}),(function(){return ke(r,e,(function(){return r.complete()}),t)}),(function(n){return ke(r,e,(function(){return r.error(n)}),t)})))}))}function Ie(e,t){return void 0===t&&(t=0),k((function(n,r){r.add(e.schedule((function(){return n.subscribe(r)}),t))}))}function Ce(e,t){if(!e)throw new Error("Iterable cannot be null");return new ee((function(n){ke(n,t,(function(){var r=e[Symbol.asyncIterator]();ke(n,t,(function(){r.next().then((function(e){e.done?n.complete():n.next(e.value)}))}),0,!0)}))}))}function Ae(e,t){if(null!=e){if(ne(e))return function(e,t){return ue(e).pipe(Ie(t),Ee(t))}(e,t);if(O(e))return function(e,t){return new ee((function(n){var r=0;return t.schedule((function(){r===e.length?n.complete():(n.next(e[r++]),n.closed||this.schedule())}))}))}(e,t);if(R(e))return function(e,t){return ue(e).pipe(Ie(t),Ee(t))}(e,t);if(re(e))return Ce(e,t);if(ie(e))return function(e,t){return new ee((function(n){var r;return ke(n,t,(function(){r=e[se](),ke(n,t,(function(){var e,t,o;try{t=(e=r.next()).value,o=e.done}catch(e){return void n.error(e)}o?n.complete():n.next(t)}),0,!0)})),function(){return S(null==r?void 0:r.return)&&r.return()}}))}(e,t);if(ce(e))return function(e,t){return Ce(ae(e),t)}(e,t)}throw oe(e)}function Te(e,t){return t?Ae(e,t):ue(e)}function Pe(e,t){return k((function(n,r){var o=0;n.subscribe(new de(r,(function(n){r.next(e.call(t,n,o++))})))}))}function Ue(e,t,n){return void 0===n&&(n=1/0),S(t)?Ue((function(n,r){return Pe((function(e,o){return t(n,e,r,o)}))(ue(e(n,r)))}),n):("number"==typeof t&&(n=t),k((function(t,r){return function(e,t,n,r,o,s,i,a){var c=[],u=0,l=0,d=!1,f=function(){!d||c.length||u||t.complete()},p=function(e){return u<r?h(e):c.push(e)},h=function(e){s&&t.next(e),u++;var a=!1;ue(n(e,l++)).subscribe(new de(t,(function(e){null==o||o(e),s?p(e):t.next(e)}),(function(){a=!0}),void 0,(function(){if(a)try{u--;for(var e=function(){var e=c.shift();i?ke(t,i,(function(){return h(e)})):h(e)};c.length&&u<r;)e();f()}catch(e){t.error(e)}})))};return e.subscribe(new de(t,p,(function(){d=!0,f()}))),function(){null==a||a()}}(t,r,e,n)})))}function $e(){return void 0===(e=1)&&(e=1/0),Ue(X,e);var e}function De(e,t){return void 0===t&&(t=ve),k((function(n,r){var o=null,s=null,i=null,a=function(){if(o){o.unsubscribe(),o=null;var e=s;s=null,r.next(e)}};function c(){var n=i+e,s=t.now();if(s<n)return o=this.schedule(void 0,n-s),void r.add(o);a()}n.subscribe(new de(r,(function(n){s=n,i=t.now(),o||(o=t.schedule(c,e),r.add(o))}),(function(){a(),r.complete()}),void 0,(function(){s=o=null})))}))}function Oe(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return $e()(Te(e,Se(e)))}var Re=new ee((function(e){return e.complete()}));function Le(e){return e<=0?function(){return Re}:k((function(t,n){var r=0;t.subscribe(new de(n,(function(t){++r<=e&&(n.next(t),e<=r&&n.complete())})))}))}function Ne(e,t){return t?function(n){return Oe(t.pipe(Le(1),k((function(e,t){e.subscribe(new de(t,q))}))),n.pipe(Ne(e)))}:Ue((function(t,n){return e(t,n).pipe(Le(1),function(e){return Pe((function(){return e}))}(t))}))}function je(e,t){void 0===t&&(t=ve);var n=function(e,t,n){void 0===e&&(e=0),void 0===n&&(n=ge);var r=-1;return null!=t&&(we(t)?n=t:r=t),new ee((function(t){var o=_e(e)?+e-n.now():e;o<0&&(o=0);var s=0;return n.schedule((function(){t.closed||(t.next(s++),0<=r?this.schedule(void 0,r):t.complete())}),o)}))}(e,t);return Ne((function(){return n}))}function We(e,t){return e===t}function Be(e,t){return k((function(n,r){var o=0;n.subscribe(new de(r,(function(n){return e.call(t,n,o++)&&r.next(n)})))}))}function Me(e){return Be((function(t,n){return e<=n}))}function Fe(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var n=Se(e);return k((function(t,r){(n?Oe(e,t,n):Oe(e,t)).subscribe(r)}))}function Ke(e,t){return k((function(n,r){var o=null,s=0,i=!1,a=function(){return i&&!o&&r.complete()};n.subscribe(new de(r,(function(n){null==o||o.unsubscribe();var i=0,c=s++;ue(e(n,c)).subscribe(o=new de(r,(function(e){return r.next(t?t(n,e,c,i++):e)}),(function(){o=null,a()})))}),(function(){i=!0,a()})))}))}function He(e,t,n){var r=S(e)||t||n?{next:e,error:t,complete:n}:e;return r?k((function(e,t){var n;null===(n=r.subscribe)||void 0===n||n.call(r);var o=!0;e.subscribe(new de(t,(function(e){var n;null===(n=r.next)||void 0===n||n.call(r,e),t.next(e)}),(function(){var e;o=!1,null===(e=r.complete)||void 0===e||e.call(r),t.complete()}),(function(e){var n;o=!1,null===(n=r.error)||void 0===n||n.call(r,e),t.error(e)}),(function(){var e,t;o&&(null===(e=r.unsubscribe)||void 0===e||e.call(r)),null===(t=r.finalize)||void 0===t||t.call(r)})))})):X}var qe=L((function(e){return function(t){void 0===t&&(t=null),e(this),this.message="Timeout has occurred",this.name="TimeoutError",this.info=t}}));function ze(e){throw new qe(e)}let Ve=!1;async function Je(e,t){try{const n=await navigator.serviceWorker.ready;if("push"===t&&n.sync&&await n.sync.register(`dexie-cloud:${e.name}`),!n.active)throw new Error("Failed to trigger sync - there's no active service worker");return void n.active.postMessage({type:"dexie-cloud-sync",dbName:e.name,purpose:t})}catch(e){Ve||(console.debug("Dexie Cloud: Could not register sync event",e),Ve=!0)}}function Ge(e,t){e.cloud.usingServiceWorker?Je(e,t):e.localSyncEvent.next({purpose:t})}const Ye="undefined"!=typeof Buffer?e=>Buffer.from(e,"base64"):e=>{const t=atob(e),n=t.length,r=new Uint8Array(n);for(var o=0;o<n;o++)r[o]=t.charCodeAt(o);return r},Ze="undefined"!=typeof Buffer?e=>ArrayBuffer.isView(e)?Buffer.from(e.buffer,e.byteOffset,e.byteLength).toString("base64"):Buffer.from(e).toString("base64"):e=>btoa(String.fromCharCode.apply(null,e));async function Xe({realms:e,inviteRealms:t}){const n=JSON.stringify([...e.map((e=>({realmId:e,accepted:!0}))),...t.map((e=>({realmId:e,accepted:!1})))].sort(((e,t)=>e.realmId<t.realmId?-1:e.realmId>t.realmId?1:0))),r=(new TextEncoder).encode(n),o=await crypto.subtle.digest("SHA-1",r);return Ze(o)}function Qe(e){return Object.entries(e.cloud.schema||{}).filter((([,{markedForSync:e}])=>e)).map((([t])=>e.tables.filter((({name:e})=>e===t))[0])).filter((e=>e))}function et(e){return`$${e}_mutations`}function tt(e){const t=/^\$(.*)_mutations$/.exec(e)?.[1];if(!t)throw new Error(`Given mutationTable ${e} is not correct`);return t}const nt=[].concat;async function rt(e,t,{since:n={},limit:r=1/0}={}){const o=function(e){return nt.apply([],e)}(await Promise.all(e.map((async e=>{const t=tt(e.name),o=n[t];let s=o?e.where("rev").above(o):e;r<1/0&&(s=s.limit(r));return(await s.toArray()).map((e=>({table:t,mut:e})))})))).sort(((e,t)=>e.mut.ts-t.mut.ts)),s=[];let i=null,a=null;for(const{table:e,mut:t}of o)i&&i.table===e&&a===t.txid?i.muts.push(t):(i={table:e,muts:[t]},a=t.txid,s.push(i));return s}function ot(e){const t=new Uint8Array(e);return crypto.getRandomValues(t),btoa(String.fromCharCode.apply(null,t))}const st=crypto.getRandomValues;function it(e,t,n){if(e&&void 0!==t&&(!("isFrozen"in Object)||!Object.isFrozen(e)))if("string"!=typeof t&&"length"in t){!function(e){if(!e)throw new Error("Assertion Failed")}("string"!=typeof n&&"length"in n);for(var r=0,o=t.length;r<o;++r)it(e,t[r],n[r])}else{var s=t.indexOf(".");if(-1!==s){var i=t.substr(0,s),a=t.substr(s+1);if(""===a)void 0===n?Array.isArray(e)?isNaN(parseInt(i))||e.splice(parseInt(i),1):delete e[i]:e[i]=n;else{var c=e[i];c||(c=e[i]={}),it(c,a,n)}}else void 0===n?Array.isArray(e)&&!isNaN(parseInt(t))?e.splice(t,1):delete e[t]:e[t]=n}}const at="undefined"==typeof self?e=>{const t=Buffer.alloc(e);return st(t),t.toString("base64")}:e=>{const t=new Uint8Array(e);return crypto.getRandomValues(t),btoa(String.fromCharCode.apply(null,t))};function ct(e){return"string"==typeof e||!!(Array.isArray(e)&&e.some((e=>ct(e)))&&e.every(ut))}function ut(e){return"string"==typeof e||"number"==typeof e||Array.isArray(e)&&e.every(ut)}function lt(e,t,n){const r=e[t]||(e[t]={}),o=n.keys.map((e=>"string"==typeof e?e:JSON.stringify(e)));switch(n.type){case"insert":case"upsert":o.forEach(((e,t)=>{r[e]={type:"ups",val:n.values[t]}}));break;case"update":case"modify":o.forEach(((e,t)=>{const o="update"===n.type?n.changeSpecs[t]:n.changeSpec,s=r[e];if(s)switch(s.type){case"ups":for(const[e,t]of Object.entries(o))it(s.val,e,t);break;case"del":break;case"upd":Object.assign(s.mod,o)}else r[e]={type:"upd",mod:o}}));break;case"delete":o.forEach((e=>{r[e]={type:"del"}}))}return e}function dt(e,t){for(const{table:n,muts:r}of t)for(const t of r)lt(e,n,t)}function ft(t,n){return new Promise(((r,o)=>{const s={...n,onSubmit:e=>{t.next(void 0),r(e)},onCancel:()=>{t.next(void 0),o(new e.AbortError("User cancelled"))}};t.next(s)}))}function pt(e,t,...n){return ft(e,{type:"message-alert",title:t,alerts:n,fields:{}})}async function ht(e,t,n){let r=n||"";for(;!r||!/^[\w-\.]+@([\w-]+\.)+[\w-]{2,10}$/.test(r);)r=(await ft(e,{type:"email",title:t,alerts:r?[{type:"error",messageCode:"INVALID_EMAIL",message:"Please enter a valid email address",messageParams:{}}]:[],fields:{email:{type:"email",placeholder:"you@somedomain.com"}}})).email;return r}async function yt(e,t,n){const r=[{type:"info",messageCode:"OTP_SENT",message:"A One-Time password has been sent to {email}",messageParams:{email:t}}];n&&r.push(n);const{otp:o}=await ft(e,{type:"otp",title:"Enter OTP",alerts:r,fields:{otp:{type:"otp",label:"OTP",placeholder:"Paste OTP here"}}});return o}async function mt(e,t,n,r,o){return t.accessToken&&t.accessTokenExpiration.getTime()>Date.now()?t:t.refreshToken&&(!t.refreshTokenExpiration||t.refreshTokenExpiration.getTime()>Date.now())?await bt(e,t):await async function(e,t,n,r){const{privateKey:o,publicKey:s}=await crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:2048,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!1,["sign","verify"]);if(!o||!s)throw new Error("Could not generate RSA keypair");e.nonExportablePrivateKey=o;const i=function(e){const t=Ze(e);return function(e){let t="-----BEGIN PUBLIC KEY-----\n";for(;e.length>0;)t+=e.substring(0,64)+"\n",e=e.substring(64);return t+="-----END PUBLIC KEY-----",t}(t)}(await crypto.subtle.exportKey("spki",s));e.publicKey=s;try{const o=await t({public_key:i,hints:r});if("tokens"!==o.type)throw new Error(`Unexpected response type from token endpoint: ${o.type}`);return e.accessToken=o.accessToken,e.accessTokenExpiration=new Date(o.accessTokenExpiration),e.refreshToken=o.refreshToken,o.refreshTokenExpiration&&(e.refreshTokenExpiration=new Date(o.refreshTokenExpiration)),e.userId=o.claims.sub,e.email=o.claims.email,e.name=o.claims.name,e.claims=o.claims,o.alerts&&o.alerts.length>0&&await ft(n,{type:"message-alert",title:"Authentication Alert",fields:{},alerts:o.alerts}),e}catch(e){throw await pt(n,"Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:"We're having a problem authenticating right now.",messageParams:{}}).catch((()=>{})),e}}(t,n,r,o)}async function bt(e,t){if(!t.refreshToken)throw new Error("Cannot refresh token - refresh token is missing.");if(!t.nonExportablePrivateKey)throw new Error("login.nonExportablePrivateKey is missing - cannot sign refresh token without a private key.");const n=Date.now(),r="RSASSA-PKCS1-v1_5",o=(new TextEncoder).encode(t.refreshToken+n),s=await crypto.subtle.sign(r,t.nonExportablePrivateKey,o),i=Ze(s),a={grant_type:"refresh_token",refresh_token:t.refreshToken,scopes:["ACCESS_DB"],signature:i,signing_algorithm:r,time_stamp:n},c=await fetch(`${e}/token`,{body:JSON.stringify(a),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});if(200!==c.status)throw new Error(`RefreshToken: Status ${c.status} from ${e}/token`);const u=await c.json();return t.accessToken=u.accessToken,t.accessTokenExpiration=u.accessTokenExpiration?new Date(u.accessTokenExpiration):void 0,t}const{toString:vt}={};const gt={replace:function(e){const t=Object.keys(e);let n=null;for(let e=0,r=t.length;e<r;++e)"$"===t[e][0]&&(n=n||[],n.push(t[e]));if(!n)return e;const r={...e};for(const e of n)delete r[e];for(const t of n)r["$"+t]=e[t];return r}};function wt(...e){const t=e.reduce(((e,t)=>({...e,...t})),e.reduce(((e,t)=>({...t,...e})),{})),n=new WeakMap;return{stringify(e,r,o){const s=JSON.stringify(e,(function(e){const o=this[e],s=function(e){const r=typeof e;switch(typeof e){case"object":case"function":{if(null===e)return null;const r=Object.getPrototypeOf(e);if(!r)return gt;let s=n.get(r);if(void 0!==s)return s;const i=(o=e,vt.call(o).slice(8,-1)),a=Object.entries(t).find((([t,n])=>{var r,o;return null!==(o=null===(r=null==n?void 0:n.test)||void 0===r?void 0:r.call(n,e,i))&&void 0!==o?o:t===i}));return s=null==a?void 0:a[1],s||(s=Array.isArray(e)?null:"function"==typeof e?t.function||null:gt),n.set(r,s),s}default:return t[r]}var o}(o);return s?s.replace(o,r,t):o}),o);return s},parse(e,n){const r=[];return JSON.parse(e,(function(e,o){const s=null==o?void 0:o.$t;if(s){const e=t[s];o=e?e.revive(o,n,t):o}let i=r[r.length-1];if(i&&i[0]===o){o={...o};for(const e of i[1])delete o[e];for(const[e,t]of Object.entries(i[2]))o[e]=t;r.pop()}if(void 0===o||"$"===e[0]&&"$t"!==e){let t,n;i=r[r.length-1],i&&i[0]===this?(t=i[1],n=i[2]):r.push([this,t=[],n={}]),"$"===e[0]&&"$t"!==e?(t.push(e),n[e.substr(1)]=o):n[e]=void 0}return o}))}}}const _t={Blob:{test:(e,t)=>"Blob"===t,replace:(e,t)=>{const n=t.length;return t.push(e),{$t:"Blob",mimeType:e.type,i:n}},revive:({i:e,mimeType:t},n)=>new Blob([n[e]],{type:t})}};var St={number:{replace:e=>{switch(!0){case isNaN(e):return{$t:"number",v:"NaN"};case e===1/0:return{$t:"number",v:"Infinity"};case e===-1/0:return{$t:"number",v:"-Infinity"};default:return e}},revive:({v:e})=>Number(e)}};const kt={bigint:{replace:e=>({$t:"bigint",v:""+e}),revive:e=>BigInt(e.v)}};var xt={Date:{replace:e=>({$t:"Date",v:isNaN(e.getTime())?"NaN":e.toISOString()}),revive:({v:e})=>new Date("NaN"===e?NaN:Date.parse(e))}},Et={Set:{replace:e=>({$t:"Set",v:Array.from(e.entries())}),revive:({v:e})=>new Set(e)}},It={Map:{replace:e=>({$t:"Map",v:Array.from(e.entries())}),revive:({v:e})=>new Map(e)}};const Ct="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"==typeof global?global:void 0;var At=["Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","DataView","BigInt64Array","BigUint64Array"].reduce(((e,t)=>({...e,[t]:{replace:(e,n,r)=>({$t:t,v:r.ArrayBuffer.replace(0===e.byteOffset&&e.byteLength===e.buffer.byteLength?e.buffer:e.buffer.slice(e.byteOffset,e.byteOffset+e.byteLength),n,r).v}),revive:({v:e},n,r)=>{const o=Ct[t];return o&&new o(r.ArrayBuffer.revive({v:e},n,r))}}})),{});function Tt(e){return function(e){for(var t="",n=0,r=e.length;n<r;n++)t+=$t[e[n]];return t}(Ze(e))}function Pt(e){return Ye(function(e){if("string"!=typeof e)throw new Error("invalid decoder input: "+e);for(var t="",n=0,r=e.length;n<r;n++)t+=Ut[e[n]];return t}(e))}const Ut={"-":"=",0:"A",1:"B",2:"C",3:"D",4:"E",5:"F",6:"G",7:"H",8:"I",9:"J",A:"K",B:"L",C:"M",D:"N",E:"O",F:"P",G:"Q",H:"R",I:"S",J:"T",K:"U",L:"V",M:"W",N:"X",O:"Y",P:"Z",Q:"a",R:"b",S:"c",T:"d",U:"e",V:"f",W:"g",X:"h",Y:"i",Z:"j",_:"k",a:"l",b:"m",c:"n",d:"o",e:"p",f:"q",g:"r",h:"s",i:"t",j:"u",k:"v",l:"w",m:"x",n:"y",o:"z",p:"0",q:"1",r:"2",s:"3",t:"4",u:"5",v:"6",w:"7",x:"8",y:"9",z:"+","|":"/"},$t={};for(const e of Object.keys(Ut))$t[Ut[e]]=e;var Dt={ArrayBuffer:{replace:e=>({$t:"ArrayBuffer",v:Tt(e)}),revive:({v:e})=>{const t=Pt(e);return t.buffer.byteLength===t.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength)}}};class Ot{constructor(e,t){this.buf=e,this.type=t}}function Rt(e){const t=new XMLHttpRequest;if(t.overrideMimeType("text/plain; charset=x-user-defined"),t.open("GET",URL.createObjectURL(e),!1),t.send(),200!==t.status&&0!==t.status)throw new Error("Bad Blob access: "+t.status);return t.responseText}function Lt(e){const t=new Uint8Array(e.length);for(let n=0;n<e.length;++n)t[n]=e.charCodeAt(n);return t.buffer}var Nt={Blob:{test:(e,t)=>"Blob"===t||e instanceof Ot,replace:e=>({$t:"Blob",v:Ze(e instanceof Ot?e.buf:Lt(Rt(e))),type:e.type}),revive:({type:e,v:t})=>{const n=Ye(t);return void 0!==typeof Blob?new Blob([n]):new Ot(n.buffer,e)}}};const jt={...St,...kt,...xt,...Et,...It,...At,...Dt,...Nt};function Wt(e){return new Promise(((t,n)=>{const r=new FileReader;r.onabort=e=>n(new Error("file read aborted")),r.onerror=e=>n(e.target.error),r.onload=e=>t(e.target.result),r.readAsArrayBuffer(e)}))}var Bt={undefined:{replace:()=>({$t:"undefined"}),revive:()=>{}}};const Mt="bigint"==typeof BigInt(0);class Ft{constructor(e){this.v=e}toString(){return this.v}}const Kt={...Bt,...Mt?{}:{bigint:{test:e=>e instanceof Ft,replace:e=>({$t:"bigint",...e}),revive:({v:e})=>new Ft(e)}}},Ht=wt(jt,Kt),qt=function(...e){const t=wt(jt,_t,...e);return{toBinary(e){const[t,n]=this.stringify(e),r=new ArrayBuffer(4);return new DataView(r).setUint32(0,t.size),new Blob([r,t,n])},stringify(e){const n=[],r=t.stringify(e,n),o=new Blob(n.map((e=>{const t=new ArrayBuffer(4);return new DataView(t).setUint32(0,"byteLength"in e?e.byteLength:e.size),new Blob([t,e])})));return[o,r]},async parse(e,n){let r=0;const o=[],s=await Wt(n),i=new DataView(s);for(;r<s.byteLength;){const e=i.getUint32(r);r+=4;const t=s.slice(r,r+e);r+=e,o.push(t)}return t.parse(e,o)},async fromBinary(e){const t=new DataView(await Wt(e.slice(0,4))).getUint32(0),n=e.slice(4,t+4),r=await function(e){return new Promise(((t,n)=>{const r=new FileReader;r.onabort=e=>n(new Error("file read aborted")),r.onerror=e=>n(e.target.error),r.onload=e=>t(e.target.result),r.readAsText(e)}))}(e.slice(t+4));return await this.parse(r,n)}}}(Kt);class zt extends Error{constructor(e,t){super(t||`${e.status} ${e.statusText}`),this.httpStatus=e.status}get name(){return"HttpError"}}function Vt(t,n,r){const o=[];for(let s of r){const{table:r,muts:i}=s,a=t.tables.find((e=>e.name===r));if(!a)throw new Error(`Internal error: table ${r} not found in DBCore schema`);const{primaryKey:c}=a;let u=s;i.forEach(((t,r)=>{const o=!c.outbound&&("upsert"===t.type||"insert"===t.type);t.keys.forEach(((t,i)=>{if(Array.isArray(t)){u===s&&(u=Jt(s,o));const n=u.muts[r],a=JSON.stringify(t);n.keys[i]=a,o&&e.setByKeyPath(n.values[i],c.keyPath,a)}else if("#"===t[0]){u===s&&(u=Jt(s,o));const a=u.muts[r];if(!n.isLoggedIn)throw new Error("Internal error: Cannot sync private IDs before authenticated");const l=`${t}:${n.userId}`;a.keys[i]=l,o&&e.setByKeyPath(a.values[i],c.keyPath,l)}}))})),o.push(u)}return o}function Jt(e,t){return{...e,muts:t?e.muts.map((e=>({...e,keys:e.keys.slice(),values:e.values.slice()}))):e.muts.map((e=>({...e,keys:e.keys.slice()})))}}async function Gt(e,t,n,r,o,s,i,a){const c={Accept:"application/json, application/x-bison, application/x-bison-stream","Content-Type":"application/tson"},u=await async function(e){const t=await e.getCurrentUser(),{accessToken:n,accessTokenExpiration:r,refreshToken:o,refreshTokenExpiration:s,claims:i}=t;if(!n)return;if((r?.getTime()??1/0)>Date.now())return n;if(!o)throw new Error("Refresh token missing");if((s?.getTime()??1/0)<=Date.now())throw new Error("Refresh token has expired");const a=await bt(e.cloud.options.databaseUrl,t);return await e.table("$logins").update(i.sub,{accessToken:a.accessToken,accessTokenExpiration:a.accessTokenExpiration}),a.accessToken}(r);u&&(c.Authorization=`Bearer ${u}`);const l={v:2,dbID:t?.remoteDbId,clientIdentity:i,schema:s||{},lastPull:t?{serverRevision:t.serverRevision,realms:t.realms,inviteRealms:t.inviteRealms}:void 0,baseRevs:n,changes:Vt(r.dx.core.schema,a,e)};console.debug("Sync request",l),r.syncStateChangedEvent.next({phase:"pushing"});const d=await fetch(`${o}/sync`,{method:"post",headers:c,body:Ht.stringify(l)});if(r.syncStateChangedEvent.next({phase:"pulling"}),!d.ok)throw new zt(d);if("application/x-bison"===d.headers.get("content-type"))return qt.fromBinary(await d.blob());{const e=await d.text();return Ht.parse(e)}}function Yt(t){if(t?.cancelled)throw new e.AbortError("Operation was cancelled")}let Zt=navigator.onLine;async function Xt(e,t,n,r){await e.$baseRevs.bulkPut(Object.keys(t).filter((e=>t[e].markedForSync)).map((e=>({tableName:e,clientRev:(n[e]||0)+1,serverRev:r}))))}function Qt(e,t={}){for(const{table:n,muts:r}of e){const e=r.length>0?r[r.length-1].rev:null;t[n]=e||t[n]||0}return t}async function en(n,r,o){const s=await n.bulkGet(r),i=[],a=[];r.forEach(((r,c)=>{const u=s[c];if(u){for(const[s,i]of Object.entries(o[c]))if(s===n.schema.primKey.keyPath){if(0!==t(i,r))throw new Error("Cannot change primary key")}else e.setByKeyPath(u,s,i);i.push(r),a.push(u)}})),await(null==n.schema.primKey.keyPath?n.bulkPut(a,i):n.bulkPut(a))}async function tn(t,n){console.debug("Applying server changes",t,e.currentTransaction);for(const{table:r,muts:o}of t){const t=n.table(r);if(!t)continue;const{primaryKey:s}=t.core.schema,i=e=>{switch(e[0]){case"[":if(e.endsWith("]"))try{return JSON.parse(e)}catch{}return e;case"#":return e.endsWith(":"+n.cloud.currentUserId)?e.substr(0,e.length-n.cloud.currentUserId.length-1):e;default:return e}};for(const n of o){const r=n.keys.map(i);switch(n.type){case"insert":s.outbound?await t.bulkAdd(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),await t.bulkAdd(n.values));break;case"upsert":s.outbound?await t.bulkPut(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),await t.bulkPut(n.values));break;case"modify":1===r.length?await t.update(r[0],n.changeSpec):await t.where(":id").anyOf(r).modify(n.changeSpec);break;case"update":await en(t,r,n.changeSpecs);break;case"delete":await t.bulkDelete(r)}}}}self.addEventListener("online",(()=>Zt=!0)),self.addEventListener("offline",(()=>Zt=!1));function nn(e,t,n,r){return rn.apply(this,arguments).then((()=>{r?.justCheckIfNeeded||e.syncStateChangedEvent.next({phase:"in-sync"})})).catch((async o=>r?.justCheckIfNeeded?Promise.reject(o):(console.debug("Error from _sync",{isOnline:Zt,syncOptions:r,error:o}),Zt&&r?.retryImmediatelyOnFetchError&&"TypeError"===o?.name&&/fetch/.test(o?.message)?(e.syncStateChangedEvent.next({phase:"error",error:o}),await new Promise((e=>setTimeout(e,500))),await nn(e,t,n,{...r,retryImmediatelyOnFetchError:!1})):(await e.$syncState.update("syncState",{timestamp:new Date,error:""+o}),e.syncStateChangedEvent.next({phase:Zt?"error":"offline",error:o}),Promise.reject(o)))))}async function rn(e,t,n,{isInitialSync:r,cancelToken:o,justCheckIfNeeded:s,purpose:i}={isInitialSync:!1}){if(s||console.debug("SYNC STARTED",{isInitialSync:r,purpose:i}),!e.cloud.options?.databaseUrl)throw new Error("Internal error: sync must not be called when no databaseUrl is configured");const{databaseUrl:a}=t,c=await e.getCurrentUser(),u=c.isLoggedIn?Qe(e):[],l=u.map((t=>e.table(et(t.name)))),d=await e.getPersistedSyncState(),f=!r&&c.isLoggedIn?function(e,t){const n=t?.syncedTables||[];return Qe(e).filter((e=>!n.includes(e.name)))}(e,d):[];Yt(o);const p=f.length>0;if(p){if(s)return!0;await e.transaction("rw",f,(async e=>{e.idbtrans.disableChangeTracking=!0,e.idbtrans.disableAccessControl=!0,await async function(e,t,n){const r=new Set(n||[]);for(const n of e)"members"===n.name?await n.toCollection().modify((e=>{r.has(e.realmId)||e.userId&&e.userId!==b.userId||(e.userId=t.userId)})):"roles"===n.name||("realms"===n.name?await n.toCollection().modify((e=>{r.has(e.realmId)||void 0!==e.owner&&e.owner!==b.userId||(e.owner=t.userId)})):await n.toCollection().modify((e=>{e.realmId&&r.has(e.realmId)||(e.owner&&e.owner!==b.userId||(e.owner=t.userId),e.realmId&&e.realmId!==b.userId||(e.realmId=t.userId))})))}(f,c,d?.realms)})),Yt(o)}const[h,y,m]=await e.transaction("r",e.tables,(async()=>{const t=await e.getPersistedSyncState(),r=await e.$baseRevs.toArray();let s=await rt(l);if(Yt(o),p){const e=[...d?.realms||[],...d?.inviteRealms||[]],i=await async function(e,t,n,r){const o=`upload-${ot(8)}`;if(t.isLoggedIn&&e.length>0){const s=new Set(r||[]);return(await Promise.all(e.map((async e=>{const{extractKey:r}=e.core.schema.primaryKey;if(!r)return{table:e.name,muts:[]};const i=n[e.name],a=i?.generatedGlobalId?e.filter((e=>{const t=r(e);return!s.has(e.realmId||"")&&ct(t)})):e.filter((e=>{return r(e),!s.has(e.realmId||"")&&(t=r(e),n=i?.idPrefix,!n||"string"==typeof t&&t.startsWith(n));var t,n})),c=await a.toArray();if(c.length>0){const n={type:"upsert",values:c,keys:c.map(r),userId:t.userId,txid:o};return{table:e.name,muts:[n]}}return{table:e.name,muts:[]}})))).filter((e=>e.muts.length>0))}return[]}(f,c,n,e);return Yt(o),s=s.concat(i),[s,t,r]}return[s,t,r]})),v=h.some((e=>e.muts.some((e=>e.keys.length>0))));if(s)return console.debug("Sync is needed:",v),v;if("push"===i&&!v)return!1;const g=Qt(h,y?.latestRevisions),w=y?.clientIdentity||at(16);Yt(o);const _=await Gt(h,y,m,e,a,n,w,c);console.debug("Sync response",_);const S=await e.transaction("rw",e.tables,(async t=>{t.idbtrans.disableChangeTracking=!0,t.idbtrans.disableAccessControl=!0;for(const e of Object.keys(n))_.schema[e]&&(n[e]=_.schema[e]);await e.$syncState.put(n,"schema");const r=await rt(l,0,{since:g});for(const t of l){const n=tt(t.name);if(r.some((e=>e.table===n&&e.muts.length>0))){if(g[n]){const r=g[n]||0;await Promise.all([t.where("rev").belowOrEqual(r).delete(),e.$baseRevs.where(":id").between([n,-1/0],[n,r+1],!0,!0).reverse().offset(1).delete()])}}else await Promise.all([t.clear(),e.$baseRevs.where({tableName:n}).delete()])}Qt(r,g),await Xt(e,n,g,_.serverRevision);const o=await e.getPersistedSyncState();await async function(e,t,n){const r=new Set,o=new Set,s=n?n.realms:[],i=n?n.inviteRealms:[],a=new Set(t.realms),c=new Set(t.realms.concat(t.inviteRealms));for(const e of s)a.has(e)||(o.add(e),c.has(e)||r.add(e));for(const e of i.concat(s))c.has(e)||r.add(e);if(r.size>0||o.size>0){const t=Qe(e);for(const e of t){let t=["realms","members","roles"].includes(e.name)?r:o;0!==t.size&&(e.schema.indexes.some((e=>"realmId"===e.keyPath||Array.isArray(e.keyPath)&&"realmId"===e.keyPath[0]))?await e.where("realmId").anyOf([...t]).delete():await e.filter((e=>!!e?.realmId&&t.has(e.realmId))).delete())}}}(e,_,o);const s=o||{syncedTables:[],latestRevisions:{},realms:[],inviteRealms:[],clientIdentity:w};s.syncedTables=u.map((e=>e.name)).concat(f.map((e=>e.name))),s.latestRevisions=g,s.remoteDbId=_.dbId,s.initiallySynced=!0,s.realms=_.realms,s.inviteRealms=_.inviteRealms,s.serverRevision=_.serverRevision,s.timestamp=new Date,delete s.error;const i=on(_.changes,r);return await tn(i,e),e.$syncState.put(s,"syncState"),0===r.length}));return S?(console.debug("SYNC DONE",{isInitialSync:r}),!1):(console.debug("MORE SYNC NEEDED. Go for it again!"),await rn(e,t,n,{isInitialSync:r,cancelToken:o}))}function on(e,t){const n={};dt(n,e);const r={};return dt(r,t),function(e,t){var n,r,o;for(const[s,i]of Object.entries(t))for(const[t,a]of Object.entries(i))switch(a.type){case"ups":{const r=null===(n=e[s])||void 0===n?void 0:n[t];if(r)switch(r.type){case"ups":case"upd":delete e[s][t]}}break;case"del":null===(r=e[s])||void 0===r||delete r[t];break;case"upd":{const n=null===(o=e[s])||void 0===o?void 0:o[t];if(n)switch(n.type){case"ups":for(const[e,t]of Object.entries(a.mod))it(n.val,e,t);break;case"del":break;case"upd":for(const e of Object.keys(a.mod))delete n.mod[e]}break}}}(n,r),function(e){const t=at(16),n={};for(const[t,r]of Object.entries(e))for(const[e,o]of Object.entries(r)){const r=n[t]||(n[t]={});(r[o.type]||(r[o.type]=[])).push(Object.assign({key:e},o))}const r=[];for(const[e,o]of Object.entries(n)){const n={table:e,muts:[]};for(const[e,r]of Object.entries(o))switch(e){case"ups":{const e={type:"upsert",keys:r.map((e=>e.key)),values:r.map((e=>e.val)),txid:t};n.muts.push(e);break}case"upd":{const e={type:"update",keys:r.map((e=>e.key)),changeSpecs:r.map((e=>e.mod)),txid:t};n.muts.push(e);break}case"del":{const e={type:"delete",keys:r.map((e=>e.key)),txid:t};n.muts.push(e);break}}r.push(n)}return r}(n)}function sn(t){const n=[],r=new o(!0),s=new o(null);let i=!1,a=0,c=[0,0,0,0,0,0,0,0,0,Date.now()];return s.subscribe((async()=>{if(!i&&n.length>0){i=!0,c.shift(),c.push(Date.now()),r.next(!1);try{await async function(){for(;n.length>0;){const r=n.shift();try{await t.cloud.syncState.pipe(Be((({phase:e})=>"in-sync"===e||"error"===e)),Le(1)).toPromise(),console.debug("processing msg",r);const n=t.cloud.persistedSyncState.value;if(!r)continue;switch(r.type){case"token-expired":console.debug("WebSocket observable: Token expired. Refreshing token...");const o=t.cloud.currentUser.value,s=await bt(t.cloud.options.databaseUrl,o);await t.table("$logins").update(o.userId,{accessToken:s.accessToken,accessTokenExpiration:s.accessTokenExpiration});break;case"realm-added":case"realm-accepted":case"realms-changed":Ge(t,"pull");break;case"realm-removed":n?.realms?.includes(r.realm)||n?.inviteRealms?.includes(r.realm),Ge(t,"pull");break;case"changes":if(console.debug("changes"),"error"===t.cloud.syncState.value?.phase){Ge(t,"pull");break}await t.transaction("rw",t.dx.tables,(async n=>{n.idbtrans.disableChangeTracking=!0,n.idbtrans.disableAccessControl=!0;const[o,s,i]=await Promise.all([t.getSchema(),t.getPersistedSyncState(),t.getCurrentUser()]);if(console.debug("ws message queue: in transaction"),!s||!o||!i)return void console.debug("required vars not present",{syncState:s,schema:o,currentUser:i});if(r.baseRev!==s.serverRevision)return console.debug(`baseRev (${r.baseRev}) differs from our serverRevision in syncState (${s.serverRevision})`),void("string"!=typeof r.baseRev||"bigint"!=typeof s.serverRevision&&"object"!=typeof s.serverRevision||Ge(t,"pull"));const a=await e.waitFor(Xe(s));if(console.debug("ourRealmSetHash",a),a!==r.realmSetHash)return console.debug("not same realmSetHash",r.realmSetHash),void Ge(t,"pull");let c=[];if(i.isLoggedIn){const e=Qe(t).map((e=>t.table(et(e.name))));c=await rt(e),console.debug("msg queue: client changes",c)}if(r.changes.length>0){const e=on(r.changes,c);console.debug("applying filtered server changes",e),await tn(e,t)}s.latestRevisions=Qt(c,s.latestRevisions),s.serverRevision=r.newRev,console.debug("Updating baseRefs",s.latestRevisions),await Xt(t,o,s.latestRevisions,r.newRev),console.debug("Updating syncState",s),await t.$syncState.put(s,"syncState")})),console.debug("msg queue: done with rw transaction")}}catch(e){console.error("Error in msg queue",e)}}}()}finally{c[c.length-1]-c[0]<1e4&&(Date.now()-a<5e3?(console.warn("Slowing down websocket loop for one minute"),a=Date.now()+6e4,await new Promise((e=>setTimeout(e,6e4)))):(console.warn("Slowing down websocket loop for 10 seconds"),a=Date.now()+1e4,await new Promise((e=>setTimeout(e,1e4))))),i=!1,r.next(!0)}}})),{enqueue:function(e){n.push(e),s.next(null)},readyToServe:r}}const an=new WeakMap,cn={members:"@id, [userId+realmId], [email+realmId], realmId",roles:"[realmId+name]",realms:"@realmId",$jobs:"",$syncState:"",$baseRevs:"[tableName+clientRev]",$logins:"claims.sub, lastLogin"};let un=0;function ln(e){"vip"in e&&(e=e.vip);let t=an.get(e.cloud);if(!t){const n=new s;let r=new _(`syncstatechanged-${e.name}`);n.id=++un;let o=!1;t={get name(){return e.name},close:()=>e.close(),transaction:e.transaction.bind(e),table:e.table.bind(e),get tables(){return e.tables},cloud:e.cloud,get $jobs(){return e.table("$jobs")},get $syncState(){return e.table("$syncState")},get $baseRevs(){return e.table("$baseRevs")},get $logins(){return e.table("$logins")},get realms(){return e.realms},get members(){return e.members},get roles(){return e.roles},get initiallySynced(){return o},localSyncEvent:n,get syncStateChangedEvent(){return r},dx:e};const i={getCurrentUser:()=>t.$logins.toArray().then((e=>e.find((e=>e.isLoggedIn))||b)),getPersistedSyncState:()=>t.$syncState.get("syncState"),getSchema:()=>t.$syncState.get("schema"),getOptions:()=>t.$syncState.get("options"),setInitiallySynced(e){o=e},reconfigure(){r=new _(`syncstatechanged-${e.name}`)}};Object.assign(t,i),t.messageConsumer=sn(t),an.set(e.cloud,t)}return t}const dn=new WeakMap;class fn{constructor(e,t){dn.set(this,e),Object.assign(this,t)}static load(e,t){return e.table("$logins").get(t).then((n=>new fn(e,n||{userId:t,claims:{sub:t},lastLogin:new Date(0)})))}async save(){dn.get(this).table("$logins").put(this)}}async function pn(e,t){if((await e.getCurrentUser()).isLoggedIn){if(t){if(t.email&&e.cloud.currentUser.value.email!==t.email)throw new Error("Must logout before changing user");if(t.userId&&e.cloud.currentUserId!==t.userId)throw new Error("Must logout before changing user")}return}const n=new fn(e,{claims:{},lastLogin:new Date(0)});await mt(e.cloud.options.databaseUrl,n,e.cloud.options.fetchTokens||function(e){const{userInteraction:t}=e.cloud;return async function({public_key:n,hints:r}){let o;const s=e.cloud.options?.databaseUrl;if(!s)throw new Error("No database URL given.");o="demo"===r?.grant_type?{demo_user:await ht(t,"Enter a demo user email",r?.email||r?.userId),grant_type:"demo",scopes:["ACCESS_DB"],public_key:n}:{email:await ht(t,"Enter email address",r?.email),grant_type:"otp",scopes:["ACCESS_DB"],public_key:n};const i=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json",mode:"cors"}});if(200!==i.status){const e=await i.text();throw await pt(t,"Token request failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new zt(i,e)}const a=await i.json();if("tokens"===a.type)return a;if("otp"===o.grant_type){if("otp-sent"!==a.type)throw new Error(`Unexpected response from ${s}/token`);const e=await yt(t,o.email);o.otp=e||"",o.otp_id=a.otp_id;let n=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});for(;401===n.status;){const e=await n.text();o.otp=await yt(t,o.email,{type:"error",messageCode:"INVALID_OTP",message:e,messageParams:{}}),n=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"})}if(200!==n.status){const e=await n.text();throw await pt(t,"OTP Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new zt(n,e)}return await n.json()}throw new Error(`Unexpected response from ${s}/token`)}}(e),e.cloud.userInteraction,t),await n.save(),await async function(e,t){if(t.userId===e.cloud.currentUserId)return;const n=e.table("$logins");await e.transaction("rw",n,(async e=>{const r=await n.toArray();await Promise.all(r.filter((e=>e.userId!==t.userId&&e.isLoggedIn)).map((e=>(e.isLoggedIn=!1,n.put(e))))),t.isLoggedIn=!0,t.lastLogin=new Date,await t.save(),console.debug("Saved new user",t.email)})),await new Promise((n=>{if(e.cloud.currentUserId===t.userId)n(null);else{const r=e.cloud.currentUser.subscribe((e=>{e.userId===t.userId&&(r.unsubscribe(),n(null))}))}}))}(e,n),Ge(e,"pull")}const hn="undefined"!=typeof InstallTrigger,yn="undefined"!=typeof navigator&&/Safari\//.test(navigator.userAgent)&&!/Chrom(e|ium)\/|Edge\//.test(navigator.userAgent),mn=yn?[].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1]:NaN,bn=yn&&mn<=605||hn;const vn="undefined"!=typeof self&&"clients"in self&&!self.document;function gn(){throw new e.SchemaError("Version increment needed to allow dexie-cloud change tracking")}const{toString:wn}={};function _n(e){return wn.call(e).slice(8,-1)}function Sn(e,t){return"delete"===t.type?t.keys:t.keys?.slice()||t.values.map(e.extractKey)}const kn=/b|c|d|f|g|h|j|k|l|m|n|p|q|r|s|t|v|x|y|z/i;let xn=0;function En(e,t){const n=new Uint8Array(18),r=new Uint8Array(n.buffer,0,6),o=Date.now();xn>=o?++xn:xn=o,r[0]=xn/1099511627776,r[1]=xn/4294967296,r[2]=xn/16777216,r[3]=xn/65536,r[4]=xn/256,r[5]=xn;const s=new Uint8Array(n.buffer,6);crypto.getRandomValues(s);return e+Tt(new Uint8Array(n.buffer))+(t||"")}function In(t){return{stack:"dbcore",name:"idGenerationMiddleware",level:1,create:n=>({...n,table:r=>{const o=n.table(r);return{...o,mutate:n=>{if(n.trans.disableChangeTracking)return o.mutate(n);if("add"===n.type||"put"===n.type){const s=t.cloud.schema?.[r];if(s?.generatedGlobalId){if(t.cloud.options?.databaseUrl&&!t.initiallySynced){const e=Sn(o.schema.primaryKey,n);return o.getMany({keys:e,trans:n.trans,cache:"immutable"}).then((t=>{if(t.length<e.length)throw new Error("Unable to create new objects without an initial sync having been performed.");return o.mutate(n)}))}return function(n,s){let i=null;const a=Sn(o.schema.primaryKey,n);return a.forEach(((c,u)=>{if(void 0===c){const r=n.values[u].realmId||t.cloud.currentUserId,c=r.substr(r.length-3);a[u]=En(s,c),o.schema.primaryKey.outbound||(i||(i=n.values.slice()),i[u]=e.deepClone(i[u]),e.setByKeyPath(i[u],o.schema.primaryKey.keyPath,a[u]))}else if("string"!=typeof c||!c.startsWith(s)&&!c.startsWith("#"+s))throw new e.ConstraintError(`The ID "${c}" is not valid for table "${r}". Primary '@' keys requires the key to be prefixed with "${s}" (or "#${s}).\nIf you want to generate IDs programmatically, remove '@' from the schema to get rid of this constraint. Dexie Cloud supports custom IDs as long as they are random and globally unique.`)})),o.mutate({...n,keys:a,values:i||n.values})}(n,s.idPrefix)}if(s?.markedForSync){Sn(o.schema.primaryKey,n).forEach(((t,n)=>{if(!ct(t)){const n=Array.isArray(t)?t.map(_n).join(","):_n(t);throw new e.ConstraintError(`Invalid primary key type ${n} for table ${r}. Tables marked for sync has primary keys of type string or Array of string (and optional numbers)`)}}))}}return o.mutate(n)}}}})}}let Cn=0;function An(e,t){return function(n){const{readers:r,writers:o}=n.trans[t]||(n.trans[t]={writers:[],readers:[]}),s=o.length,i=(s>0?o[s-1].then((()=>e(n)),(()=>e(n))):e(n)).finally((()=>r.splice(r.indexOf(i))));return r.push(i),i}}function Tn(e,t){return function(n){const{readers:r,writers:o}=n.trans[t]||(n.trans[t]={writers:[],readers:[]});let s=(o.length>0?o[o.length-1].then((()=>e(n)),(()=>e(n))):r.length>0?(i=r,new Promise((e=>{0===i.length&&e([]);let t=i.length;const n=new Array(t);i.forEach(((r,o)=>Promise.resolve(r).then((e=>n[o]={status:"fulfilled",value:e}),(e=>n[o]={status:"rejected",reason:e})).then((()=>--t||e(n)))))}))).then((()=>e(n))):e(n)).finally((()=>o.shift()));var i;return o.push(s),s}}const Pn=new o(new Set);function Un({currentUserObservable:e,db:t}){return{stack:"dbcore",name:"MutationTrackingMiddleware",level:1,create:n=>{const r=n.schema.tables.filter((e=>!/^\$/.test(e.name)));let o;try{o=new Map(r.map((e=>[e.name,n.table(`$${e.name}_mutations`)])))}catch{gn()}return{...n,transaction:(r,o)=>{let s;if("readwrite"===o){const e=r.filter((e=>t.cloud.schema?.[e]?.markedForSync)).map((e=>et(e)));s=n.transaction([...r,...e],o)}else s=n.transaction(r,o);if("readwrite"===o){s.txid=ot(16),s.currentUser=e.value,Pn.value.add(s),Pn.next(Pn.value);const n=()=>{s.removeEventListener("complete",r),s.removeEventListener("error",n),s.removeEventListener("abort",n),Pn.value.delete(s),Pn.next(Pn.value)},r=()=>{s.mutationsAdded&&t.cloud.options?.databaseUrl&&(t.cloud.usingServiceWorker?(console.debug("registering sync event"),Je(t,"push")):t.localSyncEvent.next({purpose:"push"})),n()};s.addEventListener("complete",r),s.addEventListener("error",n),s.addEventListener("abort",n)}return s},table:e=>{const r=n.table(e);if(/^\$/.test(e))return e.endsWith("_mutations")?{...r,mutate:e=>("add"!==e.type&&"put"!==e.type||(e.trans.mutationsAdded=!0),r.mutate(e))}:"$logins"===e?{...r,mutate:e=>r.mutate(e).then((t=>(e.trans.mutationsAdded=!0,t))).catch((e=>(console.debug("Failed mutation $logins",e),Promise.reject(e))))}:r;const{schema:s}=r,i=o.get(e);return function(e){const t="$lock"+ ++Cn;return{...e,count:An(e.count,t),get:An(e.get,t),getMany:An(e.getMany,t),openCursor:An(e.openCursor,t),query:An(e.query,t),mutate:Tn(e.mutate,t)}}({...r,mutate:n=>{const o=n.trans;return o.txid?o.disableChangeTracking?r.mutate(n):t.cloud.schema?.[e]?.markedForSync&&o.currentUser?.isLoggedIn?"deleteRange"===n.type?r.query({query:{range:n.range,index:s.primaryKey},trans:n.trans,values:!1}).then((e=>a({type:"delete",keys:e.result,trans:n.trans,criteria:{index:null,range:n.range}}))):a(n):r.mutate(n):r.mutate(n)}});function a(e){const t=e.trans;t.mutationsAdded=!0;const{txid:n,currentUser:{userId:o}}=t,{type:s}=e;return r.mutate(e).then((r=>{const{numFailures:a,failures:c}=r;let u="delete"===s?e.keys:r.results,l="values"in e?e.values:[],d="changeSpecs"in e?e.changeSpecs:[];a&&(u=u.filter(((e,t)=>!c[t])),l=l.filter(((e,t)=>!c[t])),d=d.filter(((e,t)=>!c[t])));const f=Date.now(),p="delete"===e.type?{type:"delete",ts:f,keys:u,criteria:e.criteria,txid:n,userId:o}:"add"===e.type?{type:"insert",ts:f,keys:u,txid:n,userId:o,values:l}:e.criteria&&e.changeSpec?{type:"modify",ts:f,keys:u,criteria:e.criteria,changeSpec:e.changeSpec,txid:n,userId:o}:e.changeSpecs?{type:"update",ts:f,keys:u,changeSpecs:d,txid:n,userId:o}:{type:"upsert",ts:f,keys:u,values:l,txid:n,userId:o};return u.length>0||"criteria"in e&&e.criteria?i.mutate({type:"add",trans:t,values:[p]}).then((()=>r)):r}))}}}}}}function $n(e,t){return function(n,r){const o={...cn,...n},s=t.cloud.schema||(t.cloud.schema={}),i=new Set;Object.keys(o).forEach((e=>{const t=o[e],n=s[e]||(s[e]={});null!=t?(/^\@/.test(t)&&(o[e]=o[e].substr(1),n.generatedGlobalId=!0,n.idPrefix=function(e,t){let n=e[0].toLocaleLowerCase();for(let t=1,o=e.length;t<o&&n.length<3;++t)(kn.test(e[t])||(r=e[t])>="A"&&r<="Z")&&(n+=e[t].toLowerCase());for(var r,o,s;t.has(n);){if(/\d/g.test(n)){if(n=n.substr(0,n.length-1)+(n[n.length-1]+1),!(n.length>3))continue;n=n.substr(0,3)}else if(n.length<3){n+="2";continue}let e=1,r=n;for(;t.has(r)&&e<8;)o=n,r=(1&(s=e)?o[0].toUpperCase():o[0].toLowerCase())+(2&s?o[1].toUpperCase():o[1].toLowerCase())+(4&s?o[2].toUpperCase():o[2].toLowerCase()),++e;if(e<8)n=r;else{let e=n.charCodeAt(2)+1&127;n=n.substr(0,2)+String.fromCharCode(e)}}return n}(e,i),i.add(n.idPrefix)),/^\$/.test(e)||(o[`$${e}_mutations`]="++rev",n.markedForSync=!0),n.deleted&&(n.deleted=!1)):(n.deleted=!0,n.markedForSync=!1,o[`$${e}_mutations`]=null)}));return e.call(this,o,r)}}const Dn=ot(16);async function On(e,t,r,o,{awaitRemoteJob:s}={}){const a=e.table(r);if(await async function o(){if(await e.transaction("rw!",r,(async()=>{const e=await a.get(t);return e?e.heartbeat.getTime()<Date.now()-6e4&&(console.warn(`Latest ${t} worker seem to have died.\n`,"The dead job started:",e.started,"\n","Last heart beat was:",e.heartbeat,"\n","We're now taking over!"),await a.put({nodeId:Dn,started:new Date,heartbeat:new Date},t),!0):(await a.add({nodeId:Dn,started:new Date,heartbeat:new Date},t),!0)})))return!0;if(s)try{const e=i(n((()=>a.get(t)))).pipe(function(e,t){var n=_e(e)?{first:e}:"number"==typeof e?{each:e}:e,r=n.first,o=n.each,s=n.with,i=void 0===s?ze:s,a=n.scheduler,c=void 0===a?null!=t?t:ve:a,u=n.meta,l=void 0===u?null:u;if(null==r&&null==o)throw new TypeError("No timeout provided.");return k((function(e,t){var n,s,a=null,u=0,d=function(e){s=ke(t,c,(function(){try{n.unsubscribe(),ue(i({meta:l,lastValue:a,seen:u})).subscribe(t)}catch(e){t.error(e)}}),e)};n=e.subscribe(new de(t,(function(e){null==s||s.unsubscribe(),u++,t.next(a=e),o>0&&d(o)}),void 0,void 0,(function(){(null==s?void 0:s.closed)||null==s||s.unsubscribe(),a=null}))),d(null!=r?"number"==typeof r?r:+r-c.now():o)}))}(6e4),Be((e=>!e)));return await e.toPromise(),!1}catch(e){if("TimeoutError"!==e.name)throw e;return await o()}return!1}()){const n=setInterval((()=>{a.update(t,(e=>{e.nodeId===Dn&&(e.heartbeat=new Date)}))}),1e3);try{return await o()}finally{clearInterval(n),await e.transaction("rw!",r,(async()=>{const e=await a.get(t);e&&e.nodeId===Dn&&a.delete(t)}))}}}const Rn=new o(!0),Ln=new o(!0);var Nn,jn;Rn.pipe(Ke((e=>e?c(!0):c(!1).pipe(je(2e4)))),(void 0===jn&&(jn=X),Nn=null!=Nn?Nn:We,k((function(e,t){var n,r=!0;e.subscribe(new de(t,(function(e){var o=jn(e);!r&&Nn(n,o)||(r=!1,n=o,t.next(e))})))})))).subscribe(Ln);const Wn="undefined"!=typeof document?a(document,"visibilitychange"):c({}),Bn=Wn.pipe(Be((()=>"hidden"===document.visibilityState))),Mn=Wn.pipe(Be((()=>"visible"===document.visibilityState))),Fn="undefined"!=typeof window?u(Mn,a(window,"mousemove"),a(window,"keydown"),a(window,"wheel"),a(window,"touchmove")):c({});"undefined"!=typeof document&&u(c(!0),Bn,Fn).pipe(Pe((()=>"visible"===document.visibilityState)),He((e=>{Rn.value!==e&&Rn.next(e)})),Ke((e=>e?c(0).pipe(je(28e4),He((()=>Rn.next(!1)))):c(0)))).subscribe((()=>{}));class Kn extends Error{constructor(){super(...arguments),this.name="TokenExpiredError"}}class Hn extends r{constructor(e,t,n,r,o,s,i,a){super((c=>new zn(e,t,n,r,i,a,c,o,s)))}}let qn=0;class zn extends l{constructor(e,t,n,r,o,s,i,a,c){super((()=>this.teardown())),this.id=++qn,console.debug("New WebSocket Connection",this.id,o?"authorized":"unauthorized"),this.databaseUrl=e,this.rev=t,this.realmSetHash=n,this.clientIdentity=r,this.token=o,this.tokenExpiration=s,this.subscriber=i,this.lastUserActivity=new Date,this.messageProducer=a,this.messageProducerSubscription=null,this.webSocketStatus=c,this.connect()}teardown(){console.debug("Teardown WebSocket Connection",this.id),this.disconnect()}disconnect(){if(this.webSocketStatus.next("disconnected"),this.pinger&&(clearInterval(this.pinger),this.pinger=null),this.ws)try{this.ws.close()}catch{}this.ws=null,this.messageProducerSubscription&&(this.messageProducerSubscription.unsubscribe(),this.messageProducerSubscription=null)}reconnect(){this.disconnect(),this.connect()}async connect(){if(this.webSocketStatus.next("connecting"),this.lastServerActivity=new Date,this.pauseUntil&&this.pauseUntil>new Date)return void console.debug("WS not reconnecting just yet",{id:this.id,pauseUntil:this.pauseUntil});if(this.ws)throw new Error("Called connect() when a connection is already open");if(!this.databaseUrl)throw new Error("Cannot connect without a database URL");if(this.closed)return;if(this.tokenExpiration&&this.tokenExpiration<new Date)return void this.subscriber.error(new Kn);this.pinger=setInterval((async()=>{if(this.closed)return console.debug("pinger check",this.id,"CLOSED."),void this.teardown();if(this.ws)try{this.ws.send(JSON.stringify({type:"ping"})),setTimeout((()=>{if(console.debug("pinger setTimeout",this.id,this.pinger?"alive":"dead"),this.pinger)return this.closed?(console.debug("pinger setTimeout",this.id,"subscription is closed"),void this.teardown()):void(this.lastServerActivity<new Date(Date.now()-2e4)?(console.debug("pinger: server is inactive"),console.debug("pinger reconnecting"),this.reconnect()):console.debug("pinger: server still active"))}),2e4)}catch{console.debug("pinger catch error",this.id,"reconnecting"),this.reconnect()}else console.debug("pinger",this.id,"reconnecting"),this.reconnect()}),3e4);const e=new URL(this.databaseUrl);e.protocol="http:"===e.protocol?"ws":"wss";const t=new URLSearchParams;if(this.subscriber.closed)return;t.set("v","2"),t.set("rev",this.rev),t.set("realmsHash",this.realmSetHash),t.set("clientId",this.clientIdentity),this.token&&t.set("token",this.token),console.debug("dexie-cloud WebSocket create");const n=this.ws=new WebSocket(`${e}/changes?${t}`);n.onclose=e=>{this.pinger&&(console.debug("dexie-cloud WebSocket onclosed",this.id),this.reconnect())},n.onmessage=e=>{if(this.pinger){console.debug("dexie-cloud WebSocket onmessage",e.data),this.lastServerActivity=new Date;try{const t=Ht.parse(e.data);if("error"===t.type)throw new Error(`Error message from dexie-cloud: ${t.error}`);"rev"===t.type&&(this.rev=t.rev),"pong"!==t.type&&this.subscriber.next(t)}catch(e){this.subscriber.error(e)}}};try{await new Promise(((e,t)=>{n.onopen=t=>{console.debug("dexie-cloud WebSocket onopen"),e(null)},n.onerror=e=>{const n=e.error||new Error("WebSocket Error");this.disconnect(),this.subscriber.error(n),this.webSocketStatus.next("error"),t(n)}})),this.messageProducerSubscription=this.messageProducer.subscribe((e=>{this.closed||("ready"===e.type&&"connected"!==this.webSocketStatus.value&&this.webSocketStatus.next("connected"),this.ws?.send(Ht.stringify(e)))}))}catch(e){this.pauseUntil=new Date(Date.now()+6e4)}}}async function Vn(e){var t;console.error("WebSocket observable: error but revive when user does some active thing...",e),await(t=3e3,new Promise((e=>setTimeout(e,t)))),console.debug("waiting for someone to do something"),await Fn.pipe(Le(1)).toPromise(),console.debug("someone did something!")}async function Jn(e){return!(!e.cloud.options?.databaseUrl||!e.cloud.schema)&&await nn(e,e.cloud.options,e.cloud.schema,{justCheckIfNeeded:!0})}const Gn=new WeakMap;function Yn(e,t,n,r){const o=Gn.get(e);if(o){if(o.pull||"push"===r?.purpose)return console.debug("syncIfPossible(): returning the ongoing sync promise."),o.promise;{let s=!1;const i=e.cloud.syncState.subscribe((e=>{"pulling"===e.phase&&(s=!0)}));return o.promise.then((()=>{i.unsubscribe()})).catch((e=>(i.unsubscribe(),Promise.reject(e)))).then((()=>{if(!s)return Yn(e,t,n,r)}))}}const s=async function(){try{e.cloud.usingServiceWorker?vn&&await nn(e,t,n,r):await On(e,"currentSyncWorker","$jobs",(()=>nn(e,t,n,r))),Gn.delete(e),console.debug("Done sync")}catch(t){throw Gn.delete(e),console.error("Failed to sync client changes",t),t}}();return Gn.set(e,{promise:s,pull:"push"!==r?.purpose}),s}function Zn(e,t,n){let r=null,o={cancelled:!1};function s(r,a=1){setTimeout((()=>{Yn(e,t,n,{cancelToken:o,retryImmediatelyOnFetchError:!0,purpose:r}).catch((e=>{console.error("error in syncIfPossible()",e),o.cancelled?i():a<3&&setTimeout((()=>s(r,a+1)),6e4*[0,5,15][a])}))}),0)}const i=()=>{console.debug("Stopping LocalSyncWorker"),o.cancelled=!0,r&&r.unsubscribe()};return{start:()=>{console.debug("Starting LocalSyncWorker",e.localSyncEvent.id),r=e.localSyncEvent.subscribe((({purpose:e})=>{try{s(e||"pull")}catch(e){console.error("What-the....",e)}}))},stop:i}}function Xn(e,t){if(e&&t&&t.unsyncedTables)for(const n of t.unsyncedTables)e[n]&&(e[n].markedForSync=!1)}var Qn,er,tr,nr,rr={},or=[],sr=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;function ir(e,t){for(var n in t)e[n]=t[n];return e}function ar(e){var t=e.parentNode;t&&t.removeChild(e)}function cr(e,t,n){var r,o,s,i=arguments,a={};for(s in t)"key"==s?r=t[s]:"ref"==s?o=t[s]:a[s]=t[s];if(arguments.length>3)for(n=[n],s=3;s<arguments.length;s++)n.push(i[s]);if(null!=n&&(a.children=n),"function"==typeof e&&null!=e.defaultProps)for(s in e.defaultProps)void 0===a[s]&&(a[s]=e.defaultProps[s]);return ur(e,a,r,o,null)}function ur(e,t,n,r,o){var s={type:e,props:t,key:n,ref:r,__k:null,__:null,__b:0,__e:null,__d:void 0,__c:null,__h:null,constructor:void 0,__v:null==o?++Qn.__v:o};return null!=Qn.vnode&&Qn.vnode(s),s}function lr(e){return e.children}function dr(e,t){this.props=e,this.context=t}function fr(e,t){if(null==t)return e.__?fr(e.__,e.__.__k.indexOf(e)+1):null;for(var n;t<e.__k.length;t++)if(null!=(n=e.__k[t])&&null!=n.__e)return n.__e;return"function"==typeof e.type?fr(e):null}function pr(e){var t,n;if(null!=(e=e.__)&&null!=e.__c){for(e.__e=e.__c.base=null,t=0;t<e.__k.length;t++)if(null!=(n=e.__k[t])&&null!=n.__e){e.__e=e.__c.base=n.__e;break}return pr(e)}}function hr(e){(!e.__d&&(e.__d=!0)&&er.push(e)&&!yr.__r++||nr!==Qn.debounceRendering)&&((nr=Qn.debounceRendering)||tr)(yr)}function yr(){for(var e;yr.__r=er.length;)e=er.sort((function(e,t){return e.__v.__b-t.__v.__b})),er=[],e.some((function(e){var t,n,r,o,s,i;e.__d&&(s=(o=(t=e).__v).__e,(i=t.__P)&&(n=[],(r=ir({},o)).__v=o.__v+1,kr(i,o,r,t.__n,void 0!==i.ownerSVGElement,null!=o.__h?[s]:null,n,null==s?fr(o):s,o.__h),xr(n,o),o.__e!=s&&pr(o)))}))}function mr(e,t,n,r,o,s,i,a,c,u){var l,d,f,p,h,y,m,b=r&&r.__k||or,v=b.length;for(n.__k=[],l=0;l<t.length;l++)if(null!=(p=n.__k[l]=null==(p=t[l])||"boolean"==typeof p?null:"string"==typeof p||"number"==typeof p||"bigint"==typeof p?ur(null,p,null,null,p):Array.isArray(p)?ur(lr,{children:p},null,null,null):p.__b>0?ur(p.type,p.props,p.key,null,p.__v):p)){if(p.__=n,p.__b=n.__b+1,null===(f=b[l])||f&&p.key==f.key&&p.type===f.type)b[l]=void 0;else for(d=0;d<v;d++){if((f=b[d])&&p.key==f.key&&p.type===f.type){b[d]=void 0;break}f=null}kr(e,p,f=f||rr,o,s,i,a,c,u),h=p.__e,(d=p.ref)&&f.ref!=d&&(m||(m=[]),f.ref&&m.push(f.ref,null,p),m.push(d,p.__c||h,p)),null!=h?(null==y&&(y=h),"function"==typeof p.type&&null!=p.__k&&p.__k===f.__k?p.__d=c=br(p,c,e):c=vr(e,p,f,b,h,c),u||"option"!==n.type?"function"==typeof n.type&&(n.__d=c):e.value=""):c&&f.__e==c&&c.parentNode!=e&&(c=fr(f))}for(n.__e=y,l=v;l--;)null!=b[l]&&("function"==typeof n.type&&null!=b[l].__e&&b[l].__e==n.__d&&(n.__d=fr(r,l+1)),Cr(b[l],b[l]));if(m)for(l=0;l<m.length;l++)Ir(m[l],m[++l],m[++l])}function br(e,t,n){var r,o;for(r=0;r<e.__k.length;r++)(o=e.__k[r])&&(o.__=e,t="function"==typeof o.type?br(o,t,n):vr(n,o,o,e.__k,o.__e,t));return t}function vr(e,t,n,r,o,s){var i,a,c;if(void 0!==t.__d)i=t.__d,t.__d=void 0;else if(null==n||o!=s||null==o.parentNode)e:if(null==s||s.parentNode!==e)e.appendChild(o),i=null;else{for(a=s,c=0;(a=a.nextSibling)&&c<r.length;c+=2)if(a==o)break e;e.insertBefore(o,s),i=s}return void 0!==i?i:o.nextSibling}function gr(e,t,n){"-"===t[0]?e.setProperty(t,n):e[t]=null==n?"":"number"!=typeof n||sr.test(t)?n:n+"px"}function wr(e,t,n,r,o){var s;e:if("style"===t)if("string"==typeof n)e.style.cssText=n;else{if("string"==typeof r&&(e.style.cssText=r=""),r)for(t in r)n&&t in n||gr(e.style,t,"");if(n)for(t in n)r&&n[t]===r[t]||gr(e.style,t,n[t])}else if("o"===t[0]&&"n"===t[1])s=t!==(t=t.replace(/Capture$/,"")),t=t.toLowerCase()in e?t.toLowerCase().slice(2):t.slice(2),e.l||(e.l={}),e.l[t+s]=n,n?r||e.addEventListener(t,s?Sr:_r,s):e.removeEventListener(t,s?Sr:_r,s);else if("dangerouslySetInnerHTML"!==t){if(o)t=t.replace(/xlink[H:h]/,"h").replace(/sName$/,"s");else if("href"!==t&&"list"!==t&&"form"!==t&&"tabIndex"!==t&&"download"!==t&&t in e)try{e[t]=null==n?"":n;break e}catch(e){}"function"==typeof n||(null!=n&&(!1!==n||"a"===t[0]&&"r"===t[1])?e.setAttribute(t,n):e.removeAttribute(t))}}function _r(e){this.l[e.type+!1](Qn.event?Qn.event(e):e)}function Sr(e){this.l[e.type+!0](Qn.event?Qn.event(e):e)}function kr(e,t,n,r,o,s,i,a,c){var u,l,d,f,p,h,y,m,b,v,g,w=t.type;if(void 0!==t.constructor)return null;null!=n.__h&&(c=n.__h,a=t.__e=n.__e,t.__h=null,s=[a]),(u=Qn.__b)&&u(t);try{e:if("function"==typeof w){if(m=t.props,b=(u=w.contextType)&&r[u.__c],v=u?b?b.props.value:u.__:r,n.__c?y=(l=t.__c=n.__c).__=l.__E:("prototype"in w&&w.prototype.render?t.__c=l=new w(m,v):(t.__c=l=new dr(m,v),l.constructor=w,l.render=Ar),b&&b.sub(l),l.props=m,l.state||(l.state={}),l.context=v,l.__n=r,d=l.__d=!0,l.__h=[]),null==l.__s&&(l.__s=l.state),null!=w.getDerivedStateFromProps&&(l.__s==l.state&&(l.__s=ir({},l.__s)),ir(l.__s,w.getDerivedStateFromProps(m,l.__s))),f=l.props,p=l.state,d)null==w.getDerivedStateFromProps&&null!=l.componentWillMount&&l.componentWillMount(),null!=l.componentDidMount&&l.__h.push(l.componentDidMount);else{if(null==w.getDerivedStateFromProps&&m!==f&&null!=l.componentWillReceiveProps&&l.componentWillReceiveProps(m,v),!l.__e&&null!=l.shouldComponentUpdate&&!1===l.shouldComponentUpdate(m,l.__s,v)||t.__v===n.__v){l.props=m,l.state=l.__s,t.__v!==n.__v&&(l.__d=!1),l.__v=t,t.__e=n.__e,t.__k=n.__k,t.__k.forEach((function(e){e&&(e.__=t)})),l.__h.length&&i.push(l);break e}null!=l.componentWillUpdate&&l.componentWillUpdate(m,l.__s,v),null!=l.componentDidUpdate&&l.__h.push((function(){l.componentDidUpdate(f,p,h)}))}l.context=v,l.props=m,l.state=l.__s,(u=Qn.__r)&&u(t),l.__d=!1,l.__v=t,l.__P=e,u=l.render(l.props,l.state,l.context),l.state=l.__s,null!=l.getChildContext&&(r=ir(ir({},r),l.getChildContext())),d||null==l.getSnapshotBeforeUpdate||(h=l.getSnapshotBeforeUpdate(f,p)),g=null!=u&&u.type===lr&&null==u.key?u.props.children:u,mr(e,Array.isArray(g)?g:[g],t,n,r,o,s,i,a,c),l.base=t.__e,t.__h=null,l.__h.length&&i.push(l),y&&(l.__E=l.__=null),l.__e=!1}else null==s&&t.__v===n.__v?(t.__k=n.__k,t.__e=n.__e):t.__e=Er(n.__e,t,n,r,o,s,i,c);(u=Qn.diffed)&&u(t)}catch(e){t.__v=null,(c||null!=s)&&(t.__e=a,t.__h=!!c,s[s.indexOf(a)]=null),Qn.__e(e,t,n)}}function xr(e,t){Qn.__c&&Qn.__c(t,e),e.some((function(t){try{e=t.__h,t.__h=[],e.some((function(e){e.call(t)}))}catch(e){Qn.__e(e,t.__v)}}))}function Er(e,t,n,r,o,s,i,a){var c,u,l,d,f=n.props,p=t.props,h=t.type,y=0;if("svg"===h&&(o=!0),null!=s)for(;y<s.length;y++)if((c=s[y])&&(c===e||(h?c.localName==h:3==c.nodeType))){e=c,s[y]=null;break}if(null==e){if(null===h)return document.createTextNode(p);e=o?document.createElementNS("http://www.w3.org/2000/svg",h):document.createElement(h,p.is&&p),s=null,a=!1}if(null===h)f===p||a&&e.data===p||(e.data=p);else{if(s=s&&or.slice.call(e.childNodes),u=(f=n.props||rr).dangerouslySetInnerHTML,l=p.dangerouslySetInnerHTML,!a){if(null!=s)for(f={},d=0;d<e.attributes.length;d++)f[e.attributes[d].name]=e.attributes[d].value;(l||u)&&(l&&(u&&l.__html==u.__html||l.__html===e.innerHTML)||(e.innerHTML=l&&l.__html||""))}if(function(e,t,n,r,o){var s;for(s in n)"children"===s||"key"===s||s in t||wr(e,s,null,n[s],r);for(s in t)o&&"function"!=typeof t[s]||"children"===s||"key"===s||"value"===s||"checked"===s||n[s]===t[s]||wr(e,s,t[s],n[s],r)}(e,p,f,o,a),l)t.__k=[];else if(y=t.props.children,mr(e,Array.isArray(y)?y:[y],t,n,r,o&&"foreignObject"!==h,s,i,e.firstChild,a),null!=s)for(y=s.length;y--;)null!=s[y]&&ar(s[y]);a||("value"in p&&void 0!==(y=p.value)&&(y!==e.value||"progress"===h&&!y)&&wr(e,"value",y,f.value,!1),"checked"in p&&void 0!==(y=p.checked)&&y!==e.checked&&wr(e,"checked",y,f.checked,!1))}return e}function Ir(e,t,n){try{"function"==typeof e?e(t):e.current=t}catch(e){Qn.__e(e,n)}}function Cr(e,t,n){var r,o,s;if(Qn.unmount&&Qn.unmount(e),(r=e.ref)&&(r.current&&r.current!==e.__e||Ir(r,null,t)),n||"function"==typeof e.type||(n=null!=(o=e.__e)),e.__e=e.__d=void 0,null!=(r=e.__c)){if(r.componentWillUnmount)try{r.componentWillUnmount()}catch(e){Qn.__e(e,t)}r.base=r.__P=null}if(r=e.__k)for(s=0;s<r.length;s++)r[s]&&Cr(r[s],t,n);null!=o&&ar(o)}function Ar(e,t,n){return this.constructor(e,n)}Qn={__e:function(e,t){for(var n,r,o;t=t.__;)if((n=t.__c)&&!n.__)try{if((r=n.constructor)&&null!=r.getDerivedStateFromError&&(n.setState(r.getDerivedStateFromError(e)),o=n.__d),null!=n.componentDidCatch&&(n.componentDidCatch(e),o=n.__d),o)return n.__E=n}catch(t){e=t}throw e},__v:0},dr.prototype.setState=function(e,t){var n;n=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=ir({},this.state),"function"==typeof e&&(e=e(ir({},n),this.props)),e&&ir(n,e),null!=e&&this.__v&&(t&&this.__h.push(t),hr(this))},dr.prototype.forceUpdate=function(e){this.__v&&(this.__e=!0,e&&this.__h.push(e),hr(this))},dr.prototype.render=lr,er=[],tr="function"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,yr.__r=0;const Tr={Error:{color:"red"},Alert:{error:{color:"red"},warning:{color:"yellow"},info:{color:"black"}},Darken:{position:"fixed",top:0,left:0,opacity:.5,backgroundColor:"#000",width:"100vw",height:"100vh",zIndex:150,webkitBackdropFilter:"blur(2px)",backdropFilter:"blur(2px)"},DialogOuter:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:150,alignItems:"center",display:"flex",justifyContent:"center"},DialogInner:{position:"relative",color:"#222",backgroundColor:"#fff",padding:"30px",marginBottom:"2em",maxWidth:"90%",maxHeight:"90%",overflowY:"auto",border:"3px solid #3d3d5d",borderRadius:"8px",boxShadow:"0 0 80px 10px #666",width:"auto"},Input:{height:"35px",width:"17em",borderColor:"#ccf4",outline:"none",fontSize:"17pt",padding:"8px"}};function Pr({children:e}){return cr("div",null,cr("div",{style:Tr.Darken}),cr("div",{style:Tr.DialogOuter},cr("div",{style:Tr.DialogInner},e)))}var Ur,$r,Dr,Or=0,Rr=[],Lr=Qn.__b,Nr=Qn.__r,jr=Qn.diffed,Wr=Qn.__c,Br=Qn.unmount;function Mr(e,t){Qn.__h&&Qn.__h($r,e,Or||t),Or=0;var n=$r.__H||($r.__H={__:[],__h:[]});return e>=n.__.length&&n.__.push({}),n.__[e]}function Fr(e){return Or=1,function(e,t,n){var r=Mr(Ur++,2);return r.t=e,r.__c||(r.__=[n?n(t):Gr(void 0,t),function(e){var t=r.t(r.__[0],e);r.__[0]!==t&&(r.__=[t,r.__[1]],r.__c.setState({}))}],r.__c=$r),r.__}(Gr,e)}function Kr(e){return Or=5,function(e,t){var n=Mr(Ur++,7);return Jr(n.__H,t)&&(n.__=e(),n.__H=t,n.__h=e),n.__}((function(){return{current:e}}),[])}function Hr(){Rr.forEach((function(e){if(e.__P)try{e.__H.__h.forEach(zr),e.__H.__h.forEach(Vr),e.__H.__h=[]}catch(t){e.__H.__h=[],Qn.__e(t,e.__v)}})),Rr=[]}Qn.__b=function(e){$r=null,Lr&&Lr(e)},Qn.__r=function(e){Nr&&Nr(e),Ur=0;var t=($r=e.__c).__H;t&&(t.__h.forEach(zr),t.__h.forEach(Vr),t.__h=[])},Qn.diffed=function(e){jr&&jr(e);var t=e.__c;t&&t.__H&&t.__H.__h.length&&(1!==Rr.push(t)&&Dr===Qn.requestAnimationFrame||((Dr=Qn.requestAnimationFrame)||function(e){var t,n=function(){clearTimeout(r),qr&&cancelAnimationFrame(t),setTimeout(e)},r=setTimeout(n,100);qr&&(t=requestAnimationFrame(n))})(Hr)),$r=void 0},Qn.__c=function(e,t){t.some((function(e){try{e.__h.forEach(zr),e.__h=e.__h.filter((function(e){return!e.__||Vr(e)}))}catch(n){t.some((function(e){e.__h&&(e.__h=[])})),t=[],Qn.__e(n,e.__v)}})),Wr&&Wr(e,t)},Qn.unmount=function(e){Br&&Br(e);var t=e.__c;if(t&&t.__H)try{t.__H.__.forEach(zr)}catch(e){Qn.__e(e,t.__v)}};var qr="function"==typeof requestAnimationFrame;function zr(e){var t=$r;"function"==typeof e.__c&&e.__c(),$r=t}function Vr(e){var t=$r;e.__c=e.__(),$r=t}function Jr(e,t){return!e||e.length!==t.length||t.some((function(t,n){return t!==e[n]}))}function Gr(e,t){return"function"==typeof t?t(e):t}function Yr({title:e,alerts:t,fields:n,onCancel:r,onSubmit:o}){const[s,i]=Fr({}),a=Kr();return function(e,t){var n=Mr(Ur++,4);!Qn.__s&&Jr(n.__H,t)&&(n.__=e,n.__H=t,$r.__h.push(n))}((()=>a.current?.focus()),[]),cr(Pr,null,cr(lr,null,cr("h3",{style:Tr.WindowHeader},e),t.map((e=>cr("p",{style:Tr.Alert[e.type]},function({message:e,messageCode:t,messageParams:n}){return e.replace(/\{\w+\}/gi,(e=>n[e.substr(1,e.length-2)]))}(e)))),cr("form",{onSubmit:e=>{e.preventDefault(),o(s)}},Object.entries(n).map((([e,{type:t,label:n,placeholder:r}],o)=>cr("label",{style:Tr.Label},n?`${n}: `:"",cr("input",{ref:0===o?a:void 0,type:t,name:e,autoComplete:"on",style:Tr.Input,autoFocus:!0,placeholder:r,value:s[e]||"",onInput:n=>i({...s,[e]:Zr(t,n.target?.value)})})))))),cr("div",{style:Tr.ButtonsDiv},cr("button",{type:"submit",style:Tr.Button,onClick:()=>o(s)},"Submit"),cr("button",{style:Tr.Button,onClick:r},"Cancel")))}function Zr(e,t){switch(e){case"email":return t.toLowerCase();case"otp":return t.toUpperCase();default:return t}}class Xr extends dr{constructor(e){super(e),this.observer=e=>this.setState({userInteraction:e}),this.state={userInteraction:void 0}}componentDidMount(){this.subscription=i(this.props.db.cloud.userInteraction).subscribe(this.observer)}componentWillUnmount(){this.subscription&&(this.subscription.unsubscribe(),delete this.subscription)}render(e,{userInteraction:t}){return t?cr(Yr,{...t}):null}}function Qr(e){const t=document.createElement("div");document.body.appendChild(t),function(e,t,n){var r,o,s;Qn.__&&Qn.__(e,t),o=(r="function"==typeof n)?null:n&&n.__k||t.__k,s=[],kr(t,e=(!r&&n||t).__k=cr(lr,null,[e]),o||rr,rr,void 0!==t.ownerSVGElement,!r&&n?[n]:o?null:t.firstChild?or.slice.call(t.childNodes):null,s,!r&&n?n:o?o.__e:t.firstChild,r),xr(s,e)}(cr(Xr,{db:e.vip}),t);let n=!1;return{unsubscribe(){t.remove(),n=!0},get closed(){return n}}}function eo(e){const t=new WeakMap;return n=>{let r=t.get(n);return r||(r=e(n),t.set(n,r)),r}}function to(e,t){let n=t,o=i(e).pipe(p((e=>n=e)),h({resetOnRefCountZero:()=>y(1e3)}));const s=new r((e=>{let t=!1;const r=o.subscribe({next(n){t=!0,e.next(n)},error(t){e.error(t)},complete(){e.complete()}});return t||r.closed||e.next(n),r}));return s.getValue=()=>n,s}const no=eo((e=>new o(b))),ro=eo((e=>to(no(e._novip).pipe(Ke((t=>n((()=>e.transaction("r","realms","members",(()=>Promise.all([e.members.where({userId:t.userId}).toArray(),e.realms.toArray(),t.userId]).then((([e,t,n])=>({selfMembers:e,realms:t,userId:n})))))))))),{selfMembers:[],realms:[],get userId(){return e.cloud.currentUserId}})));function oo(...e){if(0===e.length)return{};const t=e.reduce(((e,t)=>{const n={...e};for(const[e,r]of Object.entries(t))if(e in n&&n[e]){if("*"===n[e])continue;if("*"===r)n[e]="*";else if(Array.isArray(r)&&Array.isArray(n[e])){const t=n,o=t[e];t[e]=[...new Set([...o,...r])]}else if("object"==typeof r&&r&&"object"==typeof n[e]){const t=n[e];for(const[e,n]of Object.entries(r))"*"!==t[e]&&("*"===n?t[e]="*":Array.isArray(t[e])&&Array.isArray(n)&&(t[e]=[...new Set([...t[e],...n])]))}}else n[e]=t[e];return n}));return t}const so=eo((e=>function(e,t){let n;const r=e.pipe(p((e=>n=t(e))));return r.getValue=()=>void 0!==n?n:n=t(e.getValue()),r}(ro(e._novip),(({selfMembers:e,realms:t,userId:n})=>{const r=t.map((t=>({...t,permissions:t.owner===n?{manage:"*"}:oo(...e.filter((e=>e.realmId===t.realmId)).map((e=>e.permissions)).filter((e=>e)))}))).reduce(((e,t)=>({...e,[t.realmId]:t})),{[n]:{realmId:n,owner:n,name:n,permissions:{manage:"*"}}});return r}))));class io{constructor(e,t,n){this.permissions=e||{},this.tableName=t,this.isOwner=n}add(...e){return"*"===this.permissions.manage||(!!this.permissions.manage?.includes(this.tableName)||("*"===this.permissions.add||!!e.every((e=>this.permissions.add?.includes(e)))))}update(...e){if(this.isOwner||"*"===this.permissions.manage)return!0;if(this.permissions.manage?.includes(this.tableName))return!0;if("*"===this.permissions.update)return e.every((e=>"owner"!==e));const t=this.permissions.update?.[this.tableName];return"*"===t?e.every((e=>"owner"!==e)):e.every((e=>t?.some((t=>t===e||"*"===t&&"owner"!==e))))}delete(){return!(!this.isOwner&&"*"!==this.permissions.manage)||!!this.permissions.manage?.includes(this.tableName)}}const ao=eo((e=>{const t=no(e._novip).pipe(m((t=>n((()=>e.members.where({email:t.email||""}).toArray()))))),r=so(e._novip),o=ro(e._novip);return to(f([t,o,r]).pipe(p((([e,t,n])=>{const r=(e,t)=>({...e,[t.id]:{...t,realm:n[t.realmId]}}),o=e.reduce(r,{}),s=t.selfMembers.reduce(r,o);return Object.values(s).filter((e=>!e.accepted))}))),[])})),co={nameSuffix:!0};function uo(t){const r=t.name,s=no(t),u=[];let l=null;t.on("ready",(async t=>{try{await async function(t){p=!1;const r=ln(t);vn||(r.cloud.options?.customLoginGui||u.push(Qr(t)),u.push(function(e){let t=e.cloud.webSocketStatus.value;const n=e.cloud.webSocketStatus.pipe(Ke((e=>{const n=t;t=e;const r=c(e);switch(e){case"disconnected":return Rn.value?r.pipe(De(500)):r;case"connecting":return"not-started"===n||"error"===n?r:r.pipe(De(4e3));default:return r}})));return f([n,e.syncStateChangedEvent.pipe(Fe({phase:"initial"})),Ln]).pipe(Pe((([t,n,r])=>{let{phase:o,error:s,progress:i}=n,a=t;return"error"===o&&(a="error"),"not-started"===t&&("pushing"!==o&&"pulling"!==o||(a="connecting")),"error"!==e.cloud.syncState.value.phase||"pushing"!==n.phase&&"pulling"!==n.phase||(a="connecting"),r||(a="disconnected"),{phase:o,error:s,progress:i,status:Zt?a:"offline"}})))}(r).subscribe(t.cloud.syncState)));r.tables.every((e=>e.core))||gn();const o="serviceWorker"in navigator?await navigator.serviceWorker.getRegistrations():[],y=await r.transaction("rw",r.$syncState,(async()=>{const{options:e,schema:t}=r.cloud,[n,s,i]=await Promise.all([r.getOptions(),r.getSchema(),r.getPersistedSyncState()]);if(e?n&&JSON.stringify(n)===JSON.stringify(e)||await r.$syncState.put(e,"options"):r.cloud.options=n||null,r.cloud.options?.tryUseServiceWorker&&"serviceWorker"in navigator&&o.length>0&&!bn?(console.debug("Dexie Cloud Addon: Using service worker"),r.cloud.usingServiceWorker=!0):(r.cloud.options?.tryUseServiceWorker&&!vn&&console.debug("dexie-cloud-addon: Not using service worker.",0===o.length?"No SW registrations found.":"serviceWorker"in navigator&&bn?"Avoiding SW background sync and SW periodic bg sync for this browser due to browser bugs.":"navigator.serviceWorker not present"),r.cloud.usingServiceWorker=!1),Xn(t,r.cloud.options),Xn(s,r.cloud.options),t){if(!s||JSON.stringify(s)!==JSON.stringify(t)){const e=s||{};for(const[n,r]of Object.entries(t)){const t=e[n];t?(t.markedForSync=r.markedForSync,r.deleted=t.deleted,t.generatedGlobalId=r.generatedGlobalId):e[n]={...r}}await r.$syncState.put(e,"schema"),Object.assign(t,e)}}else r.cloud.schema=s||null;return i?.initiallySynced}));y&&r.setInitiallySynced(!0);(function(t){for(const n of t.tables)if(t.cloud.schema?.[n.name]?.markedForSync){if(n.schema.primKey.auto)throw new e.SchemaError(`Table ${n.name} is both autoIncremented and synced. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(n.name)}]}) to blacklist it from sync`);if(!n.schema.primKey.keyPath)throw new e.SchemaError(`Table ${n.name} cannot be both synced and outbound. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(n.name)}]}) to blacklist it from sync`)}})(r),r.cloud.options?.databaseUrl&&!y&&(await async function(e,t,n){console.debug("Performing initial sync"),await On(e,"initialSync","$jobs",(async()=>{(await e.getPersistedSyncState())?.initiallySynced||await nn(e,t,n,{isInitialSync:!0})}),{awaitRemoteJob:!0}),console.debug("Done initial sync")}(r,r.cloud.options,r.cloud.schema),r.setInitiallySynced(!0));h(),vn||(u.push(n((()=>r.getCurrentUser())).subscribe(s)),u.push(n((()=>r.getPersistedSyncState())).subscribe(r.cloud.persistedSyncState)),await f([s.pipe(Me(1),Le(1)),r.cloud.persistedSyncState.pipe(Me(1),Le(1))]).toPromise());r.cloud.options?.requireAuth&&await pn(r);l&&l.stop();l=null,h(),r.cloud.usingServiceWorker&&r.cloud.options?.databaseUrl?(Je(r,"push").catch((()=>{})),async function(e){try{const{periodicSync:t}=await navigator.serviceWorker.ready;if(t)try{await t.register(`dexie-cloud:${e.name}`,e.cloud.options?.periodicSync),console.debug(`Dexie Cloud: Successfully registered periodicsync event for ${e.name}`)}catch(e){console.debug("Dexie Cloud: Failed to register periodic sync. Your PWA must be installed to allow background sync.",e)}else console.debug("Dexie Cloud: periodicSync not supported.")}catch(t){console.debug(`Dexie Cloud: Could not register periodicSync for ${e.name}`,t)}}(r).catch((()=>{}))):r.cloud.options?.databaseUrl&&r.cloud.schema&&!vn&&(l=Zn(r,r.cloud.options,r.cloud.schema),l.start(),Ge(r,"push"));h(),vn||u.push(a(self,"online").subscribe((()=>{console.debug("online!"),r.syncStateChangedEvent.next({phase:"not-in-sync"}),Ge(r,"push")})),a(self,"offline").subscribe((()=>{console.debug("offline!"),r.syncStateChangedEvent.next({phase:"offline"})})));"undefined"!=typeof window&&!vn&&r.cloud.options?.databaseUrl&&u.push(function(e){if(!e.cloud.options?.databaseUrl)throw new Error("No database URL to connect WebSocket to");const t=e.messageConsumer.readyToServe.pipe(Be((e=>e)),Ke((()=>e.getPersistedSyncState())),Be((e=>e&&e.serverRevision)),Pe((e=>({type:"ready",rev:e.serverRevision}))));return function n(){return e.cloud.persistedSyncState.pipe(Be((e=>e?.serverRevision)),Le(1),Ke((t=>e.cloud.currentUser.pipe(Pe((e=>[e,t]))))),Ke((([e,t])=>Ln.pipe(Pe((n=>[n?e:null,t]))))),Ke((async([e,t])=>[e,await Xe(t)])),Ke((([n,r])=>n?new Hn(e.cloud.options.databaseUrl,e.cloud.persistedSyncState.value.serverRevision,r,e.cloud.persistedSyncState.value.clientIdentity,t,e.cloud.webSocketStatus,n.accessToken,n.accessTokenExpiration):i([]))),xe((t=>"TokenExpiredError"===t?.name?(console.debug("WebSocket observable: Token expired. Refreshing token..."),c(!0).pipe(Ke((async()=>{const t=await e.getCurrentUser(),n=await bt(e.cloud.options.databaseUrl,t);await e.table("$logins").update(t.userId,{accessToken:n.accessToken,accessTokenExpiration:n.accessTokenExpiration})})),Ke((()=>n())))):d(t))),xe((e=>i(Vn(e)).pipe(Ke((()=>n()))))))}().subscribe((t=>{t&&(console.debug("WS got message",t),e.messageConsumer.enqueue(t))}),(e=>{console.error("Oops! The main observable errored!",e)}),(()=>{console.error("Oops! The main observable completed!")}))}(r))}(t)}catch(e){console.error(e)}}),!0);let p=!1;function h(){if(p)throw new e.DatabaseClosedError}var y;!function(e,t){e.on.close.subscribe(t);const n=e.close;e.close=function(){n.call(this),t()}}(t,(()=>{u.forEach((e=>e.unsubscribe())),p=!0,l&&l.stop(),l=null,s.next(b)})),t.cloud={version:"4.0.0-beta.13",options:{...co},schema:null,serverState:null,get currentUserId(){return s.value.userId||b.userId},currentUser:s,syncState:new o({phase:"initial",status:"not-started"}),persistedSyncState:new o(void 0),userInteraction:new o(void 0),webSocketStatus:new o("not-started"),async login(e){const n=ln(t);await n.cloud.sync(),await pn(n,e)},invites:ao(t),configure(e){(e=t.cloud.options={...t.cloud.options,...e}).databaseUrl&&e.nameSuffix&&(t.name=`${r}-${function(e){const t=new URL(e);return"/"===t.pathname?t.hostname.split(".")[0]:t.pathname.split("/")[1]}(e.databaseUrl)}`,ln(t).reconfigure()),Xn(t.cloud.schema,t.cloud.options)},async sync({wait:e,purpose:r}={wait:!0,purpose:"push"}){void 0===e&&(e=!0);const o=ln(t);if("pull"===r){const t=o.cloud.persistedSyncState.value;if(Ge(o,r),e){const e=await o.cloud.persistedSyncState.pipe(Be((e=>null!=e?.timestamp&&(!t||e.timestamp>t.timestamp))),Le(1)).toPromise();if(e?.error)throw new Error("Sync error: "+e.error)}}else if(await Jn(o)){const t=o.cloud.persistedSyncState.value;Ge(o,r),e&&(console.debug("db.cloud.login() is waiting for sync completion..."),await i(n((async()=>{const e=await Jn(o),n=await o.getPersistedSyncState();if(n?.timestamp!==t?.timestamp&&n?.error)throw new Error("Sync error: "+n.error);return e}))).pipe(Be((e=>!e)),Le(1)).toPromise(),console.debug("Done waiting for sync completion because we have nothing to push anymore"))}},permissions:(e,n)=>function(e,t,n){if(!t)throw new TypeError("Cannot check permissions of undefined or null. A Dexie Cloud object with realmId and owner expected.");const{owner:r,realmId:o}=t;if(!n){if("function"!=typeof t.table)throw new TypeError("Missing 'table' argument to permissions and table could not be extracted from entity");n=t.table()}const s=so(e),i=t=>{const s=t[o||e.cloud.currentUserId];return new io(s?s.permissions:{},n,!r||r===e.cloud.currentUserId)},a=s.pipe(Pe(i));return a.getValue=()=>i(s.getValue()),a}(t._novip,e,n)},t.Version.prototype._parseStoresSpec=e.override(t.Version.prototype._parseStoresSpec,(e=>$n(e,t))),t.Table.prototype.newId=function({colocateWith:e}={}){const n=e&&e.substr(e.length-3);return En(t.cloud.schema[this.name].idPrefix||"",n)},t.Table.prototype.idPrefix=function(){return this.db.cloud.schema?.[this.name]?.idPrefix||""},t.use(Un({currentUserObservable:t.cloud.currentUser,db:ln(t)})),t.use((y=ln(t),{stack:"dbcore",name:"implicitPropSetterMiddleware",level:1,create:e=>({...e,table:t=>{const n=e.table(t);return{...n,mutate:e=>{if(e.trans.disableChangeTracking)return n.mutate(e);const r=e.trans;if(y.cloud.schema?.[t]?.markedForSync&&("add"===e.type||"put"===e.type))for(const t of e.values){t.owner||(t.owner=r.currentUser.userId),t.realmId||(t.realmId=r.currentUser.userId);const o=n.schema.primaryKey.extractKey?.(t);"string"==typeof o&&"#"===o[0]&&"put"===e.type&&(delete e.criteria,delete e.changeSpec,delete e.changeSpecs,t.$ts=Date.now())}return n.mutate(e)}}}})})),t.use(In(ln(t)))}uo.version="4.0.0-beta.13",e.Cloud=uo;const lo=new Map;function fo(e){return e.startsWith("dexie-cloud:")&&e.split(":")[1]}const po=new Map;function ho(t,n){let r=po.get(t+"/"+n);return r||(r=async function(t,n){let r=lo.get(t);if(!r){console.debug("Dexie Cloud SW: Creating new Dexie instance for",t);const n=new e(t,{addons:[uo]});r=ln(n),n.on("versionchange",o),await r.dx.open(),lo.get(t)||lo.set(t,r)}if(!r.cloud.options?.databaseUrl)return void console.error("Dexie Cloud: No databaseUrl configured");if(!r.cloud.schema)return void console.error("Dexie Cloud: No schema persisted");function o(){return r.dx.on.versionchange.unsubscribe(o),lo.get(r.name)===r&&lo.delete(r.name),console.debug(`Dexie Cloud SW: Closing Dexie instance for ${t}`),r.dx.close(),!1}try{console.debug("Dexie Cloud SW: Syncing"),await Yn(r,r.cloud.options,r.cloud.schema,{retryImmediatelyOnFetchError:!0,purpose:n}),console.debug("Dexie Cloud SW: Done Syncing")}catch(t){if(console.error("Dexie Cloud SW Error",t),o(),t.name!==e.errnames.NoSuchDatabase)throw t}}(t,n).then((()=>{po.delete(t+"/"+n)})).catch((e=>(po.delete(t+"/"+n),Promise.reject(e)))),po.set(t+"/"+n,r)),r}bn||(self.addEventListener("sync",(e=>{console.debug('SW "sync" Event',e.tag);const t=fo(e.tag);t&&e.waitUntil(ho(t,"push"))})),self.addEventListener("periodicsync",(e=>{console.debug('SW "periodicsync" Event',e.tag);const t=fo(e.tag);t&&e.waitUntil(ho(t,"pull"))})),self.addEventListener("message",(e=>{if(console.debug('SW "message" Event',e.data),"dexie-cloud-sync"===e.data.type){const{dbName:t}=e.data,n=(r=1)=>ho(t,e.data.purpose||"pull").catch((async e=>{if(3===r)throw e;var t;await(t=6e4,new Promise((e=>setTimeout(e,t)))),n(r+1)}));"waitUntil"in e?e.waitUntil(n().catch((e=>console.error(e)))):n().catch((e=>console.error(e)))}})));
1
+ import e,{cmp as t,liveQuery as n}from"dexie";import{Observable as r,BehaviorSubject as o,Subject as s,from as i,fromEvent as a,of as c,merge as u,Subscription as l,throwError as d,combineLatest as f,map as p,share as h,timer as y,switchMap as m}from"rxjs";const b={userId:"unauthorized",name:"Unauthorized",claims:{sub:"unauthorized"},lastLogin:new Date(0)};try{Object.freeze(b),Object.freeze(b.claims)}catch{}const v={},g=self.document&&navigator.serviceWorker;g&&g.ready.then((e=>v.registration=e)),"undefined"!=typeof self&&"clients"in self&&!self.document&&addEventListener("message",(e=>{e.data?.type?.startsWith("sw-broadcast-")&&[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.id!==e.source?.id&&t.postMessage(e.data)))}));class w{constructor(e){this.name=e}subscribe(e){if(!g)return()=>{};const t=t=>{t.data?.type===`sw-broadcast-${this.name}`&&e(t.data.message)};return g.addEventListener("message",t),()=>g.removeEventListener("message",t)}postMessage(e){"object"==typeof self.clients?[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))):v.registration&&v.registration.active?.postMessage({type:`sw-broadcast-${this.name}`,message:e})}}class _ extends r{constructor(e){const t="undefined"==typeof BroadcastChannel?new w(e):new BroadcastChannel(e);super((n=>{function r(e){n.next(e.detail)}function o(e){console.debug("BroadcastedAndLocalEvent: onMessageEvent",e),n.next(e.data)}let s;return self.addEventListener(`lbc-${e}`,r),t instanceof w?s=t.subscribe((e=>n.next(e))):(console.debug("BroadcastedAndLocalEvent: bc.addEventListener()",e,"bc is a",t),t.addEventListener("message",o)),()=>{self.removeEventListener(`lbc-${e}`,r),t instanceof w?s():t.removeEventListener("message",o)}})),this.name=e,this.bc=t}next(e){console.debug("BroadcastedAndLocalEvent: bc.postMessage()",{...e},"bc is a",this.bc),this.bc.postMessage(e);const t=new CustomEvent(`lbc-${this.name}`,{detail:e});self.dispatchEvent(t)}}function S(e){return"function"==typeof e}function k(e){return function(t){if(function(e){return S(null==e?void 0:e.lift)}(t))return t.lift((function(t){try{return e(t,this)}catch(e){this.error(e)}}));throw new TypeError("Unable to lift unknown Observable type")}}var x=function(e,t){return x=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])},x(e,t)};function I(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");function n(){this.constructor=e}x(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function E(e,t,n,r){return new(n||(n=Promise))((function(o,s){function i(e){try{c(r.next(e))}catch(e){s(e)}}function a(e){try{c(r.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))}function T(e,t){var n,r,o,s,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return s={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(s[Symbol.iterator]=function(){return this}),s;function a(s){return function(a){return function(s){if(n)throw new TypeError("Generator is already executing.");for(;i;)try{if(n=1,r&&(o=2&s[0]?r.return:s[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,s[1])).done)return o;switch(r=0,o&&(s=[2&s[0],o.value]),s[0]){case 0:case 1:o=s;break;case 4:return i.label++,{value:s[1],done:!1};case 5:i.label++,r=s[1],s=[0];continue;case 7:s=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==s[0]&&2!==s[0])){i=0;continue}if(3===s[0]&&(!o||s[1]>o[0]&&s[1]<o[3])){i.label=s[1];break}if(6===s[0]&&i.label<o[1]){i.label=o[1],o=s;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(s);break}o[2]&&i.ops.pop(),i.trys.pop();continue}s=t.call(e,i)}catch(e){s=[6,e],r=0}finally{n=o=0}if(5&s[0])throw s[1];return{value:s[0]?s[1]:void 0,done:!0}}([s,a])}}}function C(e){var t="function"==typeof Symbol&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function A(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,s=n.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=s.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(n=s.return)&&n.call(s)}finally{if(o)throw o.error}}return i}function P(e,t){for(var n=0,r=t.length,o=e.length;n<r;n++,o++)e[o]=t[n];return e}function U(e){return this instanceof U?(this.v=e,this):new U(e)}function $(e,t,n){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var r,o=n.apply(e,t||[]),s=[];return r={},i("next"),i("throw"),i("return"),r[Symbol.asyncIterator]=function(){return this},r;function i(e){o[e]&&(r[e]=function(t){return new Promise((function(n,r){s.push([e,t,n,r])>1||a(e,t)}))})}function a(e,t){try{!function(e){e.value instanceof U?Promise.resolve(e.value.v).then(c,u):l(s[0][2],e)}(o[e](t))}catch(e){l(s[0][3],e)}}function c(e){a("next",e)}function u(e){a("throw",e)}function l(e,t){e(t),s.shift(),s.length&&a(s[0][0],s[0][1])}}function D(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t,n=e[Symbol.asyncIterator];return n?n.call(e):(e=C(e),t={},r("next"),r("throw"),r("return"),t[Symbol.asyncIterator]=function(){return this},t);function r(n){t[n]=e[n]&&function(t){return new Promise((function(r,o){(function(e,t,n,r){Promise.resolve(r).then((function(t){e({value:t,done:n})}),t)})(r,o,(t=e[n](t)).done,t.value)}))}}}var O=function(e){return e&&"number"==typeof e.length&&"function"!=typeof e};function R(e){return S(null==e?void 0:e.then)}function N(e){var t=e((function(e){Error.call(e),e.stack=(new Error).stack}));return t.prototype=Object.create(Error.prototype),t.prototype.constructor=t,t}var L=N((function(e){return function(t){e(this),this.message=t?t.length+" errors occurred during unsubscription:\n"+t.map((function(e,t){return t+1+") "+e.toString()})).join("\n "):"",this.name="UnsubscriptionError",this.errors=t}}));function j(e,t){if(e){var n=e.indexOf(t);0<=n&&e.splice(n,1)}}var W=function(){function e(e){this.initialTeardown=e,this.closed=!1,this._parentage=null,this._teardowns=null}var t;return e.prototype.unsubscribe=function(){var e,t,n,r,o;if(!this.closed){this.closed=!0;var s=this._parentage;if(s)if(this._parentage=null,Array.isArray(s))try{for(var i=C(s),a=i.next();!a.done;a=i.next()){a.value.remove(this)}}catch(t){e={error:t}}finally{try{a&&!a.done&&(t=i.return)&&t.call(i)}finally{if(e)throw e.error}}else s.remove(this);var c=this.initialTeardown;if(S(c))try{c()}catch(e){o=e instanceof L?e.errors:[e]}var u=this._teardowns;if(u){this._teardowns=null;try{for(var l=C(u),d=l.next();!d.done;d=l.next()){var f=d.value;try{M(f)}catch(e){o=null!=o?o:[],e instanceof L?o=P(P([],A(o)),A(e.errors)):o.push(e)}}}catch(e){n={error:e}}finally{try{d&&!d.done&&(r=l.return)&&r.call(l)}finally{if(n)throw n.error}}}if(o)throw new L(o)}},e.prototype.add=function(t){var n;if(t&&t!==this)if(this.closed)M(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._teardowns=null!==(n=this._teardowns)&&void 0!==n?n:[]).push(t)}},e.prototype._hasParent=function(e){var t=this._parentage;return t===e||Array.isArray(t)&&t.includes(e)},e.prototype._addParent=function(e){var t=this._parentage;this._parentage=Array.isArray(t)?(t.push(e),t):t?[t,e]:e},e.prototype._removeParent=function(e){var t=this._parentage;t===e?this._parentage=null:Array.isArray(t)&&j(t,e)},e.prototype.remove=function(t){var n=this._teardowns;n&&j(n,t),t instanceof e&&t._removeParent(this)},e.EMPTY=((t=new e).closed=!0,t),e}();function B(e){return e instanceof W||e&&"closed"in e&&S(e.remove)&&S(e.add)&&S(e.unsubscribe)}function M(e){S(e)?e():e.unsubscribe()}var F={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1},H={setTimeout:function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var n=H.delegate;return((null==n?void 0:n.setTimeout)||setTimeout).apply(void 0,P([],A(e)))},clearTimeout:function(e){var t=H.delegate;return((null==t?void 0:t.clearTimeout)||clearTimeout)(e)},delegate:void 0};function K(e){H.setTimeout((function(){throw e}))}function q(){}var z=V("C",void 0,void 0);function V(e,t,n){return{kind:e,value:t,error:n}}function J(e){0}var G=function(e){function t(t){var n=e.call(this)||this;return n.isStopped=!1,t?(n.destination=t,B(t)&&t.add(n)):n.destination=ee,n}return I(t,e),t.create=function(e,t,n){return new Y(e,t,n)},t.prototype.next=function(e){this.isStopped?Q(function(e){return V("N",e,void 0)}(e),this):this._next(e)},t.prototype.error=function(e){this.isStopped?Q(V("E",void 0,e),this):(this.isStopped=!0,this._error(e))},t.prototype.complete=function(){this.isStopped?Q(z,this):(this.isStopped=!0,this._complete())},t.prototype.unsubscribe=function(){this.closed||(this.isStopped=!0,e.prototype.unsubscribe.call(this),this.destination=null)},t.prototype._next=function(e){this.destination.next(e)},t.prototype._error=function(e){try{this.destination.error(e)}finally{this.unsubscribe()}},t.prototype._complete=function(){try{this.destination.complete()}finally{this.unsubscribe()}},t}(W),Y=function(e){function t(t,n,r){var o,s=e.call(this)||this;if(S(t))o=t;else if(t){var i;o=t.next,n=t.error,r=t.complete,s&&F.useDeprecatedNextContext?(i=Object.create(t)).unsubscribe=function(){return s.unsubscribe()}:i=t,o=null==o?void 0:o.bind(i),n=null==n?void 0:n.bind(i),r=null==r?void 0:r.bind(i)}return s.destination={next:o?Z(o):q,error:Z(null!=n?n:X),complete:r?Z(r):q},s}return I(t,e),t}(G);function Z(e,t){return function(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];try{e.apply(void 0,P([],A(t)))}catch(e){F.useDeprecatedSynchronousErrorHandling?J():K(e)}}}function X(e){throw e}function Q(e,t){var n=F.onStoppedNotification;n&&H.setTimeout((function(){return n(e,t)}))}var ee={closed:!0,next:q,error:X,complete:q},te="function"==typeof Symbol&&Symbol.observable||"@@observable";function ne(e){return e}function re(e){return 0===e.length?ne:1===e.length?e[0]:function(t){return e.reduce((function(e,t){return t(e)}),t)}}var oe=function(){function e(e){e&&(this._subscribe=e)}return e.prototype.lift=function(t){var n=new e;return n.source=this,n.operator=t,n},e.prototype.subscribe=function(e,t,n){var r,o=this,s=(r=e)&&r instanceof G||function(e){return e&&S(e.next)&&S(e.error)&&S(e.complete)}(r)&&B(r)?e:new Y(e,t,n);return function(){var e=o,t=e.operator,n=e.source;s.add(t?t.call(s,n):n?o._subscribe(s):o._trySubscribe(s))}(),s},e.prototype._trySubscribe=function(e){try{return this._subscribe(e)}catch(t){e.error(t)}},e.prototype.forEach=function(e,t){var n=this;return new(t=se(t))((function(t,r){var o;o=n.subscribe((function(t){try{e(t)}catch(e){r(e),null==o||o.unsubscribe()}}),r,t)}))},e.prototype._subscribe=function(e){var t;return null===(t=this.source)||void 0===t?void 0:t.subscribe(e)},e.prototype[te]=function(){return this},e.prototype.pipe=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return re(e)(this)},e.prototype.toPromise=function(e){var t=this;return new(e=se(e))((function(e,n){var r;t.subscribe((function(e){return r=e}),(function(e){return n(e)}),(function(){return e(r)}))}))},e.create=function(t){return new e(t)},e}();function se(e){var t;return null!==(t=null!=e?e:F.Promise)&&void 0!==t?t:Promise}function ie(e){return S(e[te])}function ae(e){return Symbol.asyncIterator&&S(null==e?void 0:e[Symbol.asyncIterator])}function ce(e){return new TypeError("You provided "+(null!==e&&"object"==typeof e?"an invalid object":"'"+e+"'")+" where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.")}var ue="function"==typeof Symbol&&Symbol.iterator?Symbol.iterator:"@@iterator";function le(e){return S(null==e?void 0:e[ue])}function de(e){return $(this,arguments,(function(){var t,n,r;return T(this,(function(o){switch(o.label){case 0:t=e.getReader(),o.label=1;case 1:o.trys.push([1,,9,10]),o.label=2;case 2:return[4,U(t.read())];case 3:return n=o.sent(),r=n.value,n.done?[4,U(void 0)]:[3,5];case 4:return[2,o.sent()];case 5:return[4,U(r)];case 6:return[4,o.sent()];case 7:return o.sent(),[3,2];case 8:return[3,10];case 9:return t.releaseLock(),[7];case 10:return[2]}}))}))}function fe(e){return S(null==e?void 0:e.getReader)}function pe(e){if(e instanceof oe)return e;if(null!=e){if(ie(e))return o=e,new oe((function(e){var t=o[te]();if(S(t.subscribe))return t.subscribe(e);throw new TypeError("Provided object does not correctly implement Symbol.observable")}));if(O(e))return r=e,new oe((function(e){for(var t=0;t<r.length&&!e.closed;t++)e.next(r[t]);e.complete()}));if(R(e))return n=e,new oe((function(e){n.then((function(t){e.closed||(e.next(t),e.complete())}),(function(t){return e.error(t)})).then(null,K)}));if(ae(e))return he(e);if(le(e))return t=e,new oe((function(e){var n,r;try{for(var o=C(t),s=o.next();!s.done;s=o.next()){var i=s.value;if(e.next(i),e.closed)return}}catch(e){n={error:e}}finally{try{s&&!s.done&&(r=o.return)&&r.call(o)}finally{if(n)throw n.error}}e.complete()}));if(fe(e))return he(de(e))}var t,n,r,o;throw ce(e)}function he(e){return new oe((function(t){(function(e,t){var n,r,o,s;return E(this,void 0,void 0,(function(){var i,a;return T(this,(function(c){switch(c.label){case 0:c.trys.push([0,5,6,11]),n=D(e),c.label=1;case 1:return[4,n.next()];case 2:if((r=c.sent()).done)return[3,4];if(i=r.value,t.next(i),t.closed)return[2];c.label=3;case 3:return[3,1];case 4:return[3,11];case 5:return a=c.sent(),o={error:a},[3,11];case 6:return c.trys.push([6,,9,10]),r&&!r.done&&(s=n.return)?[4,s.call(n)]:[3,8];case 7:c.sent(),c.label=8;case 8:return[3,10];case 9:if(o)throw o.error;return[7];case 10:return[7];case 11:return t.complete(),[2]}}))}))})(e,t).catch((function(e){return t.error(e)}))}))}var ye=function(e){function t(t,n,r,o,s){var i=e.call(this,t)||this;return i.onFinalize=s,i._next=n?function(e){try{n(e)}catch(e){t.error(e)}}:e.prototype._next,i._error=o?function(e){try{o(e)}catch(e){t.error(e)}finally{this.unsubscribe()}}:e.prototype._error,i._complete=r?function(){try{r()}catch(e){t.error(e)}finally{this.unsubscribe()}}:e.prototype._complete,i}return I(t,e),t.prototype.unsubscribe=function(){var t,n=this.closed;e.prototype.unsubscribe.call(this),!n&&(null===(t=this.onFinalize)||void 0===t||t.call(this))},t}(G),me=function(e){function t(t,n){return e.call(this)||this}return I(t,e),t.prototype.schedule=function(e,t){return this},t}(W),be={setInterval:function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var n=be.delegate;return((null==n?void 0:n.setInterval)||setInterval).apply(void 0,P([],A(e)))},clearInterval:function(e){var t=be.delegate;return((null==t?void 0:t.clearInterval)||clearInterval)(e)},delegate:void 0},ve=function(e){function t(t,n){var r=e.call(this,t,n)||this;return r.scheduler=t,r.work=n,r.pending=!1,r}return I(t,e),t.prototype.schedule=function(e,t){if(void 0===t&&(t=0),this.closed)return this;this.state=e;var n=this.id,r=this.scheduler;return null!=n&&(this.id=this.recycleAsyncId(r,n,t)),this.pending=!0,this.delay=t,this.id=this.id||this.requestAsyncId(r,this.id,t),this},t.prototype.requestAsyncId=function(e,t,n){return void 0===n&&(n=0),be.setInterval(e.flush.bind(e,this),n)},t.prototype.recycleAsyncId=function(e,t,n){if(void 0===n&&(n=0),null!=n&&this.delay===n&&!1===this.pending)return t;be.clearInterval(t)},t.prototype.execute=function(e,t){if(this.closed)return new Error("executing a cancelled action");this.pending=!1;var n=this._execute(e,t);if(n)return n;!1===this.pending&&null!=this.id&&(this.id=this.recycleAsyncId(this.scheduler,this.id,null))},t.prototype._execute=function(e,t){var n,r=!1;try{this.work(e)}catch(e){r=!0,n=e||new Error("Scheduled action threw falsy error")}if(r)return this.unsubscribe(),n},t.prototype.unsubscribe=function(){if(!this.closed){var t=this.id,n=this.scheduler,r=n.actions;this.work=this.state=this.scheduler=null,this.pending=!1,j(r,this),null!=t&&(this.id=this.recycleAsyncId(n,t,null)),this.delay=null,e.prototype.unsubscribe.call(this)}},t}(me),ge={now:function(){return(ge.delegate||Date).now()},delegate:void 0},we=function(){function e(t,n){void 0===n&&(n=e.now),this.schedulerActionCtor=t,this.now=n}return e.prototype.schedule=function(e,t,n){return void 0===t&&(t=0),new this.schedulerActionCtor(this,e).schedule(n,t)},e.now=ge.now,e}(),_e=new(function(e){function t(t,n){void 0===n&&(n=we.now);var r=e.call(this,t,n)||this;return r.actions=[],r._active=!1,r._scheduled=void 0,r}return I(t,e),t.prototype.flush=function(e){var t=this.actions;if(this._active)t.push(e);else{var n;this._active=!0;do{if(n=e.execute(e.state,e.delay))break}while(e=t.shift());if(this._active=!1,n){for(;e=t.shift();)e.unsubscribe();throw n}}},t}(we))(ve),Se=_e;function ke(e){return e&&S(e.schedule)}function xe(e){return e instanceof Date&&!isNaN(e)}function Ie(e){return ke((t=e)[t.length-1])?e.pop():void 0;var t}function Ee(e,t,n,r,o){void 0===r&&(r=0),void 0===o&&(o=!1);var s=t.schedule((function(){n(),o?e.add(this.schedule(null,r)):this.unsubscribe()}),r);if(e.add(s),!o)return s}function Te(e){return k((function(t,n){var r,o=null,s=!1;o=t.subscribe(new ye(n,void 0,void 0,(function(i){r=pe(e(i,Te(e)(t))),o?(o.unsubscribe(),o=null,r.subscribe(n)):s=!0}))),s&&(o.unsubscribe(),o=null,r.subscribe(n))}))}function Ce(e,t){return void 0===t&&(t=0),k((function(n,r){n.subscribe(new ye(r,(function(n){return Ee(r,e,(function(){return r.next(n)}),t)}),(function(){return Ee(r,e,(function(){return r.complete()}),t)}),(function(n){return Ee(r,e,(function(){return r.error(n)}),t)})))}))}function Ae(e,t){return void 0===t&&(t=0),k((function(n,r){r.add(e.schedule((function(){return n.subscribe(r)}),t))}))}function Pe(e,t){if(!e)throw new Error("Iterable cannot be null");return new oe((function(n){Ee(n,t,(function(){var r=e[Symbol.asyncIterator]();Ee(n,t,(function(){r.next().then((function(e){e.done?n.complete():n.next(e.value)}))}),0,!0)}))}))}function Ue(e,t){if(null!=e){if(ie(e))return function(e,t){return pe(e).pipe(Ae(t),Ce(t))}(e,t);if(O(e))return function(e,t){return new oe((function(n){var r=0;return t.schedule((function(){r===e.length?n.complete():(n.next(e[r++]),n.closed||this.schedule())}))}))}(e,t);if(R(e))return function(e,t){return pe(e).pipe(Ae(t),Ce(t))}(e,t);if(ae(e))return Pe(e,t);if(le(e))return function(e,t){return new oe((function(n){var r;return Ee(n,t,(function(){r=e[ue](),Ee(n,t,(function(){var e,t,o;try{t=(e=r.next()).value,o=e.done}catch(e){return void n.error(e)}o?n.complete():n.next(t)}),0,!0)})),function(){return S(null==r?void 0:r.return)&&r.return()}}))}(e,t);if(fe(e))return function(e,t){return Pe(de(e),t)}(e,t)}throw ce(e)}function $e(e,t){return t?Ue(e,t):pe(e)}function De(e,t){return k((function(n,r){var o=0;n.subscribe(new ye(r,(function(n){r.next(e.call(t,n,o++))})))}))}function Oe(e,t,n){return void 0===n&&(n=1/0),S(t)?Oe((function(n,r){return De((function(e,o){return t(n,e,r,o)}))(pe(e(n,r)))}),n):("number"==typeof t&&(n=t),k((function(t,r){return function(e,t,n,r,o,s,i,a){var c=[],u=0,l=0,d=!1,f=function(){!d||c.length||u||t.complete()},p=function(e){return u<r?h(e):c.push(e)},h=function(e){s&&t.next(e),u++;var a=!1;pe(n(e,l++)).subscribe(new ye(t,(function(e){null==o||o(e),s?p(e):t.next(e)}),(function(){a=!0}),void 0,(function(){if(a)try{u--;for(var e=function(){var e=c.shift();i?Ee(t,i,(function(){return h(e)})):h(e)};c.length&&u<r;)e();f()}catch(e){t.error(e)}})))};return e.subscribe(new ye(t,p,(function(){d=!0,f()}))),function(){null==a||a()}}(t,r,e,n)})))}function Re(){return void 0===(e=1)&&(e=1/0),Oe(ne,e);var e}function Ne(e,t){return void 0===t&&(t=_e),k((function(n,r){var o=null,s=null,i=null,a=function(){if(o){o.unsubscribe(),o=null;var e=s;s=null,r.next(e)}};function c(){var n=i+e,s=t.now();if(s<n)return o=this.schedule(void 0,n-s),void r.add(o);a()}n.subscribe(new ye(r,(function(n){s=n,i=t.now(),o||(o=t.schedule(c,e),r.add(o))}),(function(){a(),r.complete()}),void 0,(function(){s=o=null})))}))}function Le(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return Re()($e(e,Ie(e)))}var je=new oe((function(e){return e.complete()}));function We(e){return e<=0?function(){return je}:k((function(t,n){var r=0;t.subscribe(new ye(n,(function(t){++r<=e&&(n.next(t),e<=r&&n.complete())})))}))}function Be(e,t){return t?function(n){return Le(t.pipe(We(1),k((function(e,t){e.subscribe(new ye(t,q))}))),n.pipe(Be(e)))}:Oe((function(t,n){return e(t,n).pipe(We(1),function(e){return De((function(){return e}))}(t))}))}function Me(e,t){void 0===t&&(t=_e);var n=function(e,t,n){void 0===e&&(e=0),void 0===n&&(n=Se);var r=-1;return null!=t&&(ke(t)?n=t:r=t),new oe((function(t){var o=xe(e)?+e-n.now():e;o<0&&(o=0);var s=0;return n.schedule((function(){t.closed||(t.next(s++),0<=r?this.schedule(void 0,r):t.complete())}),o)}))}(e,t);return Be((function(){return n}))}function Fe(e,t){return e===t}function He(e,t){return k((function(n,r){var o=0;n.subscribe(new ye(r,(function(n){return e.call(t,n,o++)&&r.next(n)})))}))}function Ke(e){return He((function(t,n){return e<=n}))}function qe(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var n=Ie(e);return k((function(t,r){(n?Le(e,t,n):Le(e,t)).subscribe(r)}))}function ze(e,t){return k((function(n,r){var o=null,s=0,i=!1,a=function(){return i&&!o&&r.complete()};n.subscribe(new ye(r,(function(n){null==o||o.unsubscribe();var i=0,c=s++;pe(e(n,c)).subscribe(o=new ye(r,(function(e){return r.next(t?t(n,e,c,i++):e)}),(function(){o=null,a()})))}),(function(){i=!0,a()})))}))}function Ve(e,t,n){var r=S(e)||t||n?{next:e,error:t,complete:n}:e;return r?k((function(e,t){var n;null===(n=r.subscribe)||void 0===n||n.call(r);var o=!0;e.subscribe(new ye(t,(function(e){var n;null===(n=r.next)||void 0===n||n.call(r,e),t.next(e)}),(function(){var e;o=!1,null===(e=r.complete)||void 0===e||e.call(r),t.complete()}),(function(e){var n;o=!1,null===(n=r.error)||void 0===n||n.call(r,e),t.error(e)}),(function(){var e,t;o&&(null===(e=r.unsubscribe)||void 0===e||e.call(r)),null===(t=r.finalize)||void 0===t||t.call(r)})))})):ne}var Je=N((function(e){return function(t){void 0===t&&(t=null),e(this),this.message="Timeout has occurred",this.name="TimeoutError",this.info=t}}));function Ge(e){throw new Je(e)}let Ye=!1;async function Ze(e,t){try{const n=await navigator.serviceWorker.ready;if("push"===t&&n.sync&&await n.sync.register(`dexie-cloud:${e.name}`),!n.active)throw new Error("Failed to trigger sync - there's no active service worker");return void n.active.postMessage({type:"dexie-cloud-sync",dbName:e.name,purpose:t})}catch(e){Ye||(console.debug("Dexie Cloud: Could not register sync event",e),Ye=!0)}}function Xe(e,t){e.cloud.usingServiceWorker?Ze(e,t):e.localSyncEvent.next({purpose:t})}const Qe="undefined"!=typeof Buffer?e=>Buffer.from(e,"base64"):e=>{const t=atob(e),n=t.length,r=new Uint8Array(n);for(var o=0;o<n;o++)r[o]=t.charCodeAt(o);return r},et="undefined"!=typeof Buffer?e=>ArrayBuffer.isView(e)?Buffer.from(e.buffer,e.byteOffset,e.byteLength).toString("base64"):Buffer.from(e).toString("base64"):e=>btoa(String.fromCharCode.apply(null,e));async function tt({realms:e,inviteRealms:t}){const n=JSON.stringify([...e.map((e=>({realmId:e,accepted:!0}))),...t.map((e=>({realmId:e,accepted:!1})))].sort(((e,t)=>e.realmId<t.realmId?-1:e.realmId>t.realmId?1:0))),r=(new TextEncoder).encode(n),o=await crypto.subtle.digest("SHA-1",r);return et(o)}function nt(e){return Object.entries(e.cloud.schema||{}).filter((([,{markedForSync:e}])=>e)).map((([t])=>e.tables.filter((({name:e})=>e===t))[0])).filter((e=>e))}function rt(e){return`$${e}_mutations`}function ot(e){const t=/^\$(.*)_mutations$/.exec(e)?.[1];if(!t)throw new Error(`Given mutationTable ${e} is not correct`);return t}const st=[].concat;function it(e){return st.apply([],e)}async function at(e,t,{since:n={},limit:r=1/0}={}){const o=it(await Promise.all(e.map((async e=>{const t=ot(e.name),o=n[t];let s=o?e.where("rev").above(o):e;r<1/0&&(s=s.limit(r));return(await s.toArray()).map((e=>({table:t,mut:e})))})))).sort(((e,t)=>e.mut.ts-t.mut.ts)),s=[];let i=null,a=null;for(const{table:e,mut:t}of o)i&&i.table===e&&a===t.txid?i.muts.push(t):(i={table:e,muts:[t]},a=t.txid,s.push(i));return s}function ct(e){const t=new Uint8Array(e);return crypto.getRandomValues(t),btoa(String.fromCharCode.apply(null,t))}const ut=crypto.getRandomValues;function lt(e,t,n){if(e&&void 0!==t&&(!("isFrozen"in Object)||!Object.isFrozen(e)))if("string"!=typeof t&&"length"in t){!function(e){if(!e)throw new Error("Assertion Failed")}("string"!=typeof n&&"length"in n);for(var r=0,o=t.length;r<o;++r)lt(e,t[r],n[r])}else{var s=t.indexOf(".");if(-1!==s){var i=t.substr(0,s),a=t.substr(s+1);if(""===a)void 0===n?Array.isArray(e)?isNaN(parseInt(i))||e.splice(parseInt(i),1):delete e[i]:e[i]=n;else{var c=e[i];c||(c=e[i]={}),lt(c,a,n)}}else void 0===n?Array.isArray(e)&&!isNaN(parseInt(t))?e.splice(t,1):delete e[t]:e[t]=n}}const dt="undefined"==typeof self?e=>{const t=Buffer.alloc(e);return ut(t),t.toString("base64")}:e=>{const t=new Uint8Array(e);return crypto.getRandomValues(t),btoa(String.fromCharCode.apply(null,t))};function ft(e){return"string"==typeof e||!!(Array.isArray(e)&&e.some((e=>ft(e)))&&e.every(pt))}function pt(e){return"string"==typeof e||"number"==typeof e||Array.isArray(e)&&e.every(pt)}function ht(e,t,n){const r=e[t]||(e[t]={}),o=n.keys.map((e=>"string"==typeof e?e:JSON.stringify(e)));switch(n.type){case"insert":case"upsert":o.forEach(((e,t)=>{r[e]={type:"ups",val:n.values[t]}}));break;case"update":case"modify":o.forEach(((e,t)=>{const o="update"===n.type?n.changeSpecs[t]:n.changeSpec,s=r[e];if(s)switch(s.type){case"ups":for(const[e,t]of Object.entries(o))lt(s.val,e,t);break;case"del":break;case"upd":Object.assign(s.mod,o)}else r[e]={type:"upd",mod:o}}));break;case"delete":o.forEach((e=>{r[e]={type:"del"}}))}return e}function yt(e,t){for(const{table:n,muts:r}of t)for(const t of r)ht(e,n,t)}function mt(t,n){let r=!1;return new Promise(((o,s)=>{const i={...n,onSubmit:e=>{t.next(void 0),r=!0,o(e)},onCancel:()=>{t.next(void 0),r=!0,s(new e.AbortError("User cancelled"))}};t.next(i)}))}function bt(e,t,...n){return mt(e,{type:"message-alert",title:t,alerts:n,fields:{}})}async function vt(e,t,n){let r=n||"";for(;!r||!/^[\w-\.]+@([\w-]+\.)+[\w-]{2,10}$/.test(r);)r=(await mt(e,{type:"email",title:t,alerts:r?[{type:"error",messageCode:"INVALID_EMAIL",message:"Please enter a valid email address",messageParams:{}}]:[],fields:{email:{type:"email",placeholder:"you@somedomain.com"}}})).email;return r}async function gt(e,t,n){const r=[{type:"info",messageCode:"OTP_SENT",message:"A One-Time password has been sent to {email}",messageParams:{email:t}}];n&&r.push(n);const{otp:o}=await mt(e,{type:"otp",title:"Enter OTP",alerts:r,fields:{otp:{type:"otp",label:"OTP",placeholder:"Paste OTP here"}}});return o}async function wt(e,t,n,r,o){return t.accessToken&&t.accessTokenExpiration.getTime()>Date.now()?t:t.refreshToken&&(!t.refreshTokenExpiration||t.refreshTokenExpiration.getTime()>Date.now())?await _t(e,t):await async function(e,t,n,r){const{privateKey:o,publicKey:s}=await crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:2048,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!1,["sign","verify"]);if(!o||!s)throw new Error("Could not generate RSA keypair");e.nonExportablePrivateKey=o;const i=function(e){const t=et(e);return function(e){let t="-----BEGIN PUBLIC KEY-----\n";for(;e.length>0;)t+=e.substring(0,64)+"\n",e=e.substring(64);return t+="-----END PUBLIC KEY-----",t}(t)}(await crypto.subtle.exportKey("spki",s));e.publicKey=s;try{const o=await t({public_key:i,hints:r});if("tokens"!==o.type)throw new Error(`Unexpected response type from token endpoint: ${o.type}`);return e.accessToken=o.accessToken,e.accessTokenExpiration=new Date(o.accessTokenExpiration),e.refreshToken=o.refreshToken,o.refreshTokenExpiration&&(e.refreshTokenExpiration=new Date(o.refreshTokenExpiration)),e.userId=o.claims.sub,e.email=o.claims.email,e.name=o.claims.name,e.claims=o.claims,o.alerts&&o.alerts.length>0&&await mt(n,{type:"message-alert",title:"Authentication Alert",fields:{},alerts:o.alerts}),e}catch(e){throw await bt(n,"Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:"We're having a problem authenticating right now.",messageParams:{}}).catch((()=>{})),e}}(t,n,r,o)}async function _t(e,t){if(!t.refreshToken)throw new Error("Cannot refresh token - refresh token is missing.");if(!t.nonExportablePrivateKey)throw new Error("login.nonExportablePrivateKey is missing - cannot sign refresh token without a private key.");const n=Date.now(),r="RSASSA-PKCS1-v1_5",o=(new TextEncoder).encode(t.refreshToken+n),s=await crypto.subtle.sign(r,t.nonExportablePrivateKey,o),i=et(s),a={grant_type:"refresh_token",refresh_token:t.refreshToken,scopes:["ACCESS_DB"],signature:i,signing_algorithm:r,time_stamp:n},c=await fetch(`${e}/token`,{body:JSON.stringify(a),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});if(200!==c.status)throw new Error(`RefreshToken: Status ${c.status} from ${e}/token`);const u=await c.json();return t.accessToken=u.accessToken,t.accessTokenExpiration=u.accessTokenExpiration?new Date(u.accessTokenExpiration):void 0,t}const{toString:St}={};const kt={replace:function(e){const t=Object.keys(e);let n=null;for(let e=0,r=t.length;e<r;++e)"$"===t[e][0]&&(n=n||[],n.push(t[e]));if(!n)return e;const r={...e};for(const e of n)delete r[e];for(const t of n)r["$"+t]=e[t];return r}};function xt(...e){const t=e.reduce(((e,t)=>({...e,...t})),e.reduce(((e,t)=>({...t,...e})),{})),n=new WeakMap;return{stringify(e,r,o){const s=JSON.stringify(e,(function(e){const o=this[e],s=function(e){const r=typeof e;switch(typeof e){case"object":case"function":{if(null===e)return null;const r=Object.getPrototypeOf(e);if(!r)return kt;let s=n.get(r);if(void 0!==s)return s;const i=(o=e,St.call(o).slice(8,-1)),a=Object.entries(t).find((([t,n])=>{var r,o;return null!==(o=null===(r=null==n?void 0:n.test)||void 0===r?void 0:r.call(n,e,i))&&void 0!==o?o:t===i}));return s=null==a?void 0:a[1],s||(s=Array.isArray(e)?null:"function"==typeof e?t.function||null:kt),n.set(r,s),s}default:return t[r]}var o}(o);return s?s.replace(o,r,t):o}),o);return s},parse(e,n){const r=[];return JSON.parse(e,(function(e,o){const s=null==o?void 0:o.$t;if(s){const e=t[s];o=e?e.revive(o,n,t):o}let i=r[r.length-1];if(i&&i[0]===o){o={...o};for(const e of i[1])delete o[e];for(const[e,t]of Object.entries(i[2]))o[e]=t;r.pop()}if(void 0===o||"$"===e[0]&&"$t"!==e){let t,n;i=r[r.length-1],i&&i[0]===this?(t=i[1],n=i[2]):r.push([this,t=[],n={}]),"$"===e[0]&&"$t"!==e?(t.push(e),n[e.substr(1)]=o):n[e]=void 0}return o}))}}}const It={Blob:{test:(e,t)=>"Blob"===t,replace:(e,t)=>{const n=t.length;return t.push(e),{$t:"Blob",mimeType:e.type,i:n}},revive:({i:e,mimeType:t},n)=>new Blob([n[e]],{type:t})}};var Et={number:{replace:e=>{switch(!0){case isNaN(e):return{$t:"number",v:"NaN"};case e===1/0:return{$t:"number",v:"Infinity"};case e===-1/0:return{$t:"number",v:"-Infinity"};default:return e}},revive:({v:e})=>Number(e)}};const Tt={bigint:{replace:e=>({$t:"bigint",v:""+e}),revive:e=>BigInt(e.v)}};var Ct={Date:{replace:e=>({$t:"Date",v:isNaN(e.getTime())?"NaN":e.toISOString()}),revive:({v:e})=>new Date("NaN"===e?NaN:Date.parse(e))}},At={Set:{replace:e=>({$t:"Set",v:Array.from(e.entries())}),revive:({v:e})=>new Set(e)}},Pt={Map:{replace:e=>({$t:"Map",v:Array.from(e.entries())}),revive:({v:e})=>new Map(e)}};const Ut="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"==typeof global?global:void 0;var $t=["Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","DataView","BigInt64Array","BigUint64Array"].reduce(((e,t)=>({...e,[t]:{replace:(e,n,r)=>({$t:t,v:r.ArrayBuffer.replace(0===e.byteOffset&&e.byteLength===e.buffer.byteLength?e.buffer:e.buffer.slice(e.byteOffset,e.byteOffset+e.byteLength),n,r).v}),revive:({v:e},n,r)=>{const o=Ut[t];return o&&new o(r.ArrayBuffer.revive({v:e},n,r))}}})),{});function Dt(e){return function(e){for(var t="",n=0,r=e.length;n<r;n++)t+=Nt[e[n]];return t}(et(e))}function Ot(e){return Qe(function(e){if("string"!=typeof e)throw new Error("invalid decoder input: "+e);for(var t="",n=0,r=e.length;n<r;n++)t+=Rt[e[n]];return t}(e))}const Rt={"-":"=",0:"A",1:"B",2:"C",3:"D",4:"E",5:"F",6:"G",7:"H",8:"I",9:"J",A:"K",B:"L",C:"M",D:"N",E:"O",F:"P",G:"Q",H:"R",I:"S",J:"T",K:"U",L:"V",M:"W",N:"X",O:"Y",P:"Z",Q:"a",R:"b",S:"c",T:"d",U:"e",V:"f",W:"g",X:"h",Y:"i",Z:"j",_:"k",a:"l",b:"m",c:"n",d:"o",e:"p",f:"q",g:"r",h:"s",i:"t",j:"u",k:"v",l:"w",m:"x",n:"y",o:"z",p:"0",q:"1",r:"2",s:"3",t:"4",u:"5",v:"6",w:"7",x:"8",y:"9",z:"+","|":"/"},Nt={};for(const e of Object.keys(Rt))Nt[Rt[e]]=e;var Lt={ArrayBuffer:{replace:e=>({$t:"ArrayBuffer",v:Dt(e)}),revive:({v:e})=>{const t=Ot(e);return t.buffer.byteLength===t.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength)}}};class jt{constructor(e,t){this.buf=e,this.type=t}}function Wt(e){const t=new XMLHttpRequest;if(t.overrideMimeType("text/plain; charset=x-user-defined"),t.open("GET",URL.createObjectURL(e),!1),t.send(),200!==t.status&&0!==t.status)throw new Error("Bad Blob access: "+t.status);return t.responseText}function Bt(e){const t=new Uint8Array(e.length);for(let n=0;n<e.length;++n)t[n]=e.charCodeAt(n);return t.buffer}var Mt={Blob:{test:(e,t)=>"Blob"===t||e instanceof jt,replace:e=>({$t:"Blob",v:et(e instanceof jt?e.buf:Bt(Wt(e))),type:e.type}),revive:({type:e,v:t})=>{const n=Qe(t);return void 0!==typeof Blob?new Blob([n]):new jt(n.buffer,e)}}};const Ft={...Et,...Tt,...Ct,...At,...Pt,...$t,...Lt,...Mt};function Ht(e){return new Promise(((t,n)=>{const r=new FileReader;r.onabort=e=>n(new Error("file read aborted")),r.onerror=e=>n(e.target.error),r.onload=e=>t(e.target.result),r.readAsArrayBuffer(e)}))}var Kt={undefined:{replace:()=>({$t:"undefined"}),revive:()=>{}}};const qt="bigint"==typeof BigInt(0);class zt{constructor(e){this.v=e}toString(){return this.v}}const Vt={...Kt,...qt?{}:{bigint:{test:e=>e instanceof zt,replace:e=>({$t:"bigint",...e}),revive:({v:e})=>new zt(e)}}},Jt=xt(Ft,Vt),Gt=function(...e){const t=xt(Ft,It,...e);return{toBinary(e){const[t,n]=this.stringify(e),r=new ArrayBuffer(4);return new DataView(r).setUint32(0,t.size),new Blob([r,t,n])},stringify(e){const n=[],r=t.stringify(e,n),o=new Blob(n.map((e=>{const t=new ArrayBuffer(4);return new DataView(t).setUint32(0,"byteLength"in e?e.byteLength:e.size),new Blob([t,e])})));return[o,r]},async parse(e,n){let r=0;const o=[],s=await Ht(n),i=new DataView(s);for(;r<s.byteLength;){const e=i.getUint32(r);r+=4;const t=s.slice(r,r+e);r+=e,o.push(t)}return t.parse(e,o)},async fromBinary(e){const t=new DataView(await Ht(e.slice(0,4))).getUint32(0),n=e.slice(4,t+4),r=await function(e){return new Promise(((t,n)=>{const r=new FileReader;r.onabort=e=>n(new Error("file read aborted")),r.onerror=e=>n(e.target.error),r.onload=e=>t(e.target.result),r.readAsText(e)}))}(e.slice(t+4));return await this.parse(r,n)}}}(Vt);class Yt extends Error{constructor(e,t){super(t||`${e.status} ${e.statusText}`),this.httpStatus=e.status}get name(){return"HttpError"}}function Zt(t,n,r){const o=[];for(let s of r){const{table:r,muts:i}=s,a=t.tables.find((e=>e.name===r));if(!a)throw new Error(`Internal error: table ${r} not found in DBCore schema`);const{primaryKey:c}=a;let u=s;i.forEach(((t,r)=>{const o=!c.outbound&&("upsert"===t.type||"insert"===t.type);t.keys.forEach(((t,i)=>{if(Array.isArray(t)){u===s&&(u=Xt(s,o));const n=u.muts[r],a=JSON.stringify(t);n.keys[i]=a,o&&e.setByKeyPath(n.values[i],c.keyPath,a)}else if("#"===t[0]){u===s&&(u=Xt(s,o));const a=u.muts[r];if(!n.isLoggedIn)throw new Error("Internal error: Cannot sync private IDs before authenticated");const l=`${t}:${n.userId}`;a.keys[i]=l,o&&e.setByKeyPath(a.values[i],c.keyPath,l)}}))})),o.push(u)}return o}function Xt(e,t){return{...e,muts:t?e.muts.map((e=>({...e,keys:e.keys.slice(),values:e.values.slice()}))):e.muts.map((e=>({...e,keys:e.keys.slice()})))}}async function Qt(e,t,n,r,o,s,i,a){const c={Accept:"application/json, application/x-bison, application/x-bison-stream","Content-Type":"application/tson"},u=await async function(e){const t=await e.getCurrentUser(),{accessToken:n,accessTokenExpiration:r,refreshToken:o,refreshTokenExpiration:s,claims:i}=t;if(!n)return;if((r?.getTime()??1/0)>Date.now())return n;if(!o)throw new Error("Refresh token missing");if((s?.getTime()??1/0)<=Date.now())throw new Error("Refresh token has expired");const a=await _t(e.cloud.options.databaseUrl,t);return await e.table("$logins").update(i.sub,{accessToken:a.accessToken,accessTokenExpiration:a.accessTokenExpiration}),a.accessToken}(r);u&&(c.Authorization=`Bearer ${u}`);const l={v:2,dbID:t?.remoteDbId,clientIdentity:i,schema:s||{},lastPull:t?{serverRevision:t.serverRevision,realms:t.realms,inviteRealms:t.inviteRealms}:void 0,baseRevs:n,changes:Zt(r.dx.core.schema,a,e)};console.debug("Sync request",l),r.syncStateChangedEvent.next({phase:"pushing"});const d=await fetch(`${o}/sync`,{method:"post",headers:c,body:Jt.stringify(l)});if(r.syncStateChangedEvent.next({phase:"pulling"}),!d.ok)throw new Yt(d);if("application/x-bison"===d.headers.get("content-type"))return Gt.fromBinary(await d.blob());{const e=await d.text();return Jt.parse(e)}}function en(t){if(t?.cancelled)throw new e.AbortError("Operation was cancelled")}let tn=navigator.onLine;async function nn(e,t,n,r){await e.$baseRevs.bulkPut(Object.keys(t).filter((e=>t[e].markedForSync)).map((e=>({tableName:e,clientRev:(n[e]||0)+1,serverRev:r}))))}function rn(e,t={}){for(const{table:n,muts:r}of e){const e=r.length>0?r[r.length-1].rev:null;t[n]=e||t[n]||0}return t}async function on(n,r,o){const s=await n.bulkGet(r),i=[],a=[];r.forEach(((r,c)=>{const u=s[c];if(u){for(const[s,i]of Object.entries(o[c]))if(s===n.schema.primKey.keyPath){if(0!==t(i,r))throw new Error("Cannot change primary key")}else e.setByKeyPath(u,s,i);i.push(r),a.push(u)}})),await(null==n.schema.primKey.keyPath?n.bulkPut(a,i):n.bulkPut(a))}async function sn(t,n){console.debug("Applying server changes",t,e.currentTransaction);for(const{table:r,muts:o}of t){const t=n.table(r);if(!t)continue;const{primaryKey:s}=t.core.schema,i=e=>{switch(e[0]){case"[":if(e.endsWith("]"))try{return JSON.parse(e)}catch{}return e;case"#":return e.endsWith(":"+n.cloud.currentUserId)?e.substr(0,e.length-n.cloud.currentUserId.length-1):e;default:return e}};for(const n of o){const r=n.keys.map(i);switch(n.type){case"insert":s.outbound?await t.bulkAdd(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),await t.bulkAdd(n.values));break;case"upsert":s.outbound?await t.bulkPut(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),await t.bulkPut(n.values));break;case"modify":1===r.length?await t.update(r[0],n.changeSpec):await t.where(":id").anyOf(r).modify(n.changeSpec);break;case"update":await on(t,r,n.changeSpecs);break;case"delete":await t.bulkDelete(r)}}}}self.addEventListener("online",(()=>tn=!0)),self.addEventListener("offline",(()=>tn=!1));function an(e,t,n,r){return cn.apply(this,arguments).then((()=>{r?.justCheckIfNeeded||e.syncStateChangedEvent.next({phase:"in-sync"})})).catch((async o=>r?.justCheckIfNeeded?Promise.reject(o):(console.debug("Error from _sync",{isOnline:tn,syncOptions:r,error:o}),tn&&r?.retryImmediatelyOnFetchError&&"TypeError"===o?.name&&/fetch/.test(o?.message)?(e.syncStateChangedEvent.next({phase:"error",error:o}),await new Promise((e=>setTimeout(e,500))),await an(e,t,n,{...r,retryImmediatelyOnFetchError:!1})):(await e.$syncState.update("syncState",{timestamp:new Date,error:""+o}),e.syncStateChangedEvent.next({phase:tn?"error":"offline",error:o}),Promise.reject(o)))))}async function cn(e,t,n,{isInitialSync:r,cancelToken:o,justCheckIfNeeded:s,purpose:i}={isInitialSync:!1}){if(s||console.debug("SYNC STARTED",{isInitialSync:r,purpose:i}),!e.cloud.options?.databaseUrl)throw new Error("Internal error: sync must not be called when no databaseUrl is configured");const{databaseUrl:a}=t,c=await e.getCurrentUser(),u=c.isLoggedIn?nt(e):[],l=u.map((t=>e.table(rt(t.name)))),d=await e.getPersistedSyncState(),f=!r&&c.isLoggedIn?function(e,t){const n=t?.syncedTables||[];return nt(e).filter((e=>!n.includes(e.name)))}(e,d):[];en(o);const p=f.length>0;if(p){if(s)return!0;await e.transaction("rw",f,(async e=>{e.idbtrans.disableChangeTracking=!0,e.idbtrans.disableAccessControl=!0,await async function(e,t,n){const r=new Set(n||[]);for(const n of e)"members"===n.name?await n.toCollection().modify((e=>{r.has(e.realmId)||e.userId&&e.userId!==b.userId||(e.userId=t.userId)})):"roles"===n.name||("realms"===n.name?await n.toCollection().modify((e=>{r.has(e.realmId)||void 0!==e.owner&&e.owner!==b.userId||(e.owner=t.userId)})):await n.toCollection().modify((e=>{e.realmId&&r.has(e.realmId)||(e.owner&&e.owner!==b.userId||(e.owner=t.userId),e.realmId&&e.realmId!==b.userId||(e.realmId=t.userId))})))}(f,c,d?.realms)})),en(o)}const[h,y,m]=await e.transaction("r",e.tables,(async()=>{const t=await e.getPersistedSyncState(),r=await e.$baseRevs.toArray();let s=await at(l);if(en(o),p){const e=[...d?.realms||[],...d?.inviteRealms||[]],i=await async function(e,t,n,r){const o=`upload-${ct(8)}`;if(t.isLoggedIn&&e.length>0){const s=new Set(r||[]);return(await Promise.all(e.map((async e=>{const{extractKey:r}=e.core.schema.primaryKey;if(!r)return{table:e.name,muts:[]};const i=n[e.name],a=i?.generatedGlobalId?e.filter((e=>{const t=r(e);return!s.has(e.realmId||"")&&ft(t)})):e.filter((e=>{return r(e),!s.has(e.realmId||"")&&(t=r(e),n=i?.idPrefix,!n||"string"==typeof t&&t.startsWith(n));var t,n})),c=await a.toArray();if(c.length>0){const n={type:"upsert",values:c,keys:c.map(r),userId:t.userId,txid:o};return{table:e.name,muts:[n]}}return{table:e.name,muts:[]}})))).filter((e=>e.muts.length>0))}return[]}(f,c,n,e);return en(o),s=s.concat(i),[s,t,r]}return[s,t,r]})),v=h.some((e=>e.muts.some((e=>e.keys.length>0))));if(s)return console.debug("Sync is needed:",v),v;if("push"===i&&!v)return!1;const g=rn(h,y?.latestRevisions),w=y?.clientIdentity||dt(16);en(o);const _=await Qt(h,y,m,e,a,n,w,c);console.debug("Sync response",_);const S=await e.transaction("rw",e.tables,(async t=>{t.idbtrans.disableChangeTracking=!0,t.idbtrans.disableAccessControl=!0;for(const e of Object.keys(n))_.schema[e]&&(n[e]=_.schema[e]);await e.$syncState.put(n,"schema");const r=await at(l,0,{since:g});for(const t of l){const n=ot(t.name);if(r.some((e=>e.table===n&&e.muts.length>0))){if(g[n]){const r=g[n]||0;await Promise.all([t.where("rev").belowOrEqual(r).delete(),e.$baseRevs.where(":id").between([n,-1/0],[n,r+1],!0,!0).reverse().offset(1).delete()])}}else await Promise.all([t.clear(),e.$baseRevs.where({tableName:n}).delete()])}rn(r,g),await nn(e,n,g,_.serverRevision);const o=await e.getPersistedSyncState();await async function(e,t,n){const r=new Set,o=new Set,s=n?n.realms:[],i=n?n.inviteRealms:[],a=new Set(t.realms),c=new Set(t.realms.concat(t.inviteRealms));for(const e of s)a.has(e)||(o.add(e),c.has(e)||r.add(e));for(const e of i.concat(s))c.has(e)||r.add(e);if(r.size>0||o.size>0){const t=nt(e);for(const e of t){let t=["realms","members","roles"].includes(e.name)?r:o;0!==t.size&&(e.schema.indexes.some((e=>"realmId"===e.keyPath||Array.isArray(e.keyPath)&&"realmId"===e.keyPath[0]))?await e.where("realmId").anyOf([...t]).delete():await e.filter((e=>!!e?.realmId&&t.has(e.realmId))).delete())}}}(e,_,o);const s=o||{syncedTables:[],latestRevisions:{},realms:[],inviteRealms:[],clientIdentity:w};s.syncedTables=u.map((e=>e.name)).concat(f.map((e=>e.name))),s.latestRevisions=g,s.remoteDbId=_.dbId,s.initiallySynced=!0,s.realms=_.realms,s.inviteRealms=_.inviteRealms,s.serverRevision=_.serverRevision,s.timestamp=new Date,delete s.error;const i=un(_.changes,r);return await sn(i,e),e.$syncState.put(s,"syncState"),0===r.length}));return S?(console.debug("SYNC DONE",{isInitialSync:r}),!1):(console.debug("MORE SYNC NEEDED. Go for it again!"),await cn(e,t,n,{isInitialSync:r,cancelToken:o}))}function un(e,t){const n={};yt(n,e);const r={};return yt(r,t),function(e,t){var n,r,o;for(const[s,i]of Object.entries(t))for(const[t,a]of Object.entries(i))switch(a.type){case"ups":{const r=null===(n=e[s])||void 0===n?void 0:n[t];if(r)switch(r.type){case"ups":case"upd":delete e[s][t]}}break;case"del":null===(r=e[s])||void 0===r||delete r[t];break;case"upd":{const n=null===(o=e[s])||void 0===o?void 0:o[t];if(n)switch(n.type){case"ups":for(const[e,t]of Object.entries(a.mod))lt(n.val,e,t);break;case"del":break;case"upd":for(const e of Object.keys(a.mod))delete n.mod[e]}break}}}(n,r),function(e){const t=dt(16),n={};for(const[t,r]of Object.entries(e))for(const[e,o]of Object.entries(r)){const r=n[t]||(n[t]={});(r[o.type]||(r[o.type]=[])).push(Object.assign({key:e},o))}const r=[];for(const[e,o]of Object.entries(n)){const n={table:e,muts:[]};for(const[e,r]of Object.entries(o))switch(e){case"ups":{const e={type:"upsert",keys:r.map((e=>e.key)),values:r.map((e=>e.val)),txid:t};n.muts.push(e);break}case"upd":{const e={type:"update",keys:r.map((e=>e.key)),changeSpecs:r.map((e=>e.mod)),txid:t};n.muts.push(e);break}case"del":{const e={type:"delete",keys:r.map((e=>e.key)),txid:t};n.muts.push(e);break}}r.push(n)}return r}(n)}function ln(t){const n=[],r=new o(!0),s=new o(null);let i=!1,a=0,c=[0,0,0,0,0,0,0,0,0,Date.now()];return s.subscribe((async()=>{if(!i&&n.length>0){i=!0,c.shift(),c.push(Date.now()),r.next(!1);try{await async function(){for(;n.length>0;){const r=n.shift();try{await t.cloud.syncState.pipe(He((({phase:e})=>"in-sync"===e||"error"===e)),We(1)).toPromise(),console.debug("processing msg",r);const n=t.cloud.persistedSyncState.value;if(!r)continue;switch(r.type){case"token-expired":console.debug("WebSocket observable: Token expired. Refreshing token...");const o=t.cloud.currentUser.value,s=await _t(t.cloud.options.databaseUrl,o);await t.table("$logins").update(o.userId,{accessToken:s.accessToken,accessTokenExpiration:s.accessTokenExpiration});break;case"realm-added":case"realm-accepted":case"realms-changed":Xe(t,"pull");break;case"realm-removed":n?.realms?.includes(r.realm)||n?.inviteRealms?.includes(r.realm),Xe(t,"pull");break;case"changes":if(console.debug("changes"),"error"===t.cloud.syncState.value?.phase){Xe(t,"pull");break}await t.transaction("rw",t.dx.tables,(async n=>{n.idbtrans.disableChangeTracking=!0,n.idbtrans.disableAccessControl=!0;const[o,s,i]=await Promise.all([t.getSchema(),t.getPersistedSyncState(),t.getCurrentUser()]);if(console.debug("ws message queue: in transaction"),!s||!o||!i)return void console.debug("required vars not present",{syncState:s,schema:o,currentUser:i});if(r.baseRev!==s.serverRevision)return console.debug(`baseRev (${r.baseRev}) differs from our serverRevision in syncState (${s.serverRevision})`),void("string"!=typeof r.baseRev||"bigint"!=typeof s.serverRevision&&"object"!=typeof s.serverRevision||Xe(t,"pull"));const a=await e.waitFor(tt(s));if(console.debug("ourRealmSetHash",a),a!==r.realmSetHash)return console.debug("not same realmSetHash",r.realmSetHash),void Xe(t,"pull");let c=[];if(i.isLoggedIn){const e=nt(t).map((e=>t.table(rt(e.name))));c=await at(e),console.debug("msg queue: client changes",c)}if(r.changes.length>0){const e=un(r.changes,c);console.debug("applying filtered server changes",e),await sn(e,t)}s.latestRevisions=rn(c,s.latestRevisions),s.serverRevision=r.newRev,console.debug("Updating baseRefs",s.latestRevisions),await nn(t,o,s.latestRevisions,r.newRev),console.debug("Updating syncState",s),await t.$syncState.put(s,"syncState")})),console.debug("msg queue: done with rw transaction")}}catch(e){console.error("Error in msg queue",e)}}}()}finally{c[c.length-1]-c[0]<1e4&&(Date.now()-a<5e3?(console.warn("Slowing down websocket loop for one minute"),a=Date.now()+6e4,await new Promise((e=>setTimeout(e,6e4)))):(console.warn("Slowing down websocket loop for 10 seconds"),a=Date.now()+1e4,await new Promise((e=>setTimeout(e,1e4))))),i=!1,r.next(!0)}}})),{enqueue:function(e){n.push(e),s.next(null)},readyToServe:r}}const dn=new WeakMap,fn={members:"@id, [userId+realmId], [email+realmId], realmId",roles:"[realmId+name]",realms:"@realmId",$jobs:"",$syncState:"",$baseRevs:"[tableName+clientRev]",$logins:"claims.sub, lastLogin"};let pn=0;function hn(e){"vip"in e&&(e=e.vip);let t=dn.get(e.cloud);if(!t){const n=new s;let r=new _(`syncstatechanged-${e.name}`);n.id=++pn;let o=!1;t={get name(){return e.name},close:()=>e.close(),transaction:e.transaction.bind(e),table:e.table.bind(e),get tables(){return e.tables},cloud:e.cloud,get $jobs(){return e.table("$jobs")},get $syncState(){return e.table("$syncState")},get $baseRevs(){return e.table("$baseRevs")},get $logins(){return e.table("$logins")},get realms(){return e.realms},get members(){return e.members},get roles(){return e.roles},get initiallySynced(){return o},localSyncEvent:n,get syncStateChangedEvent(){return r},dx:e};const i={getCurrentUser:()=>t.$logins.toArray().then((e=>e.find((e=>e.isLoggedIn))||b)),getPersistedSyncState:()=>t.$syncState.get("syncState"),getSchema:()=>t.$syncState.get("schema"),getOptions:()=>t.$syncState.get("options"),setInitiallySynced(e){o=e},reconfigure(){r=new _(`syncstatechanged-${e.name}`)}};Object.assign(t,i),t.messageConsumer=ln(t),dn.set(e.cloud,t)}return t}const yn=new WeakMap;class mn{constructor(e,t){yn.set(this,e),Object.assign(this,t)}static load(e,t){return e.table("$logins").get(t).then((n=>new mn(e,n||{userId:t,claims:{sub:t},lastLogin:new Date(0)})))}async save(){yn.get(this).table("$logins").put(this)}}async function bn(e,t){if((await e.getCurrentUser()).isLoggedIn){if(t){if(t.email&&e.cloud.currentUser.value.email!==t.email)throw new Error("Must logout before changing user");if(t.userId&&e.cloud.currentUserId!==t.userId)throw new Error("Must logout before changing user")}return}const n=new mn(e,{claims:{},lastLogin:new Date(0)});await wt(e.cloud.options.databaseUrl,n,e.cloud.options.fetchTokens||function(e){const{userInteraction:t}=e.cloud;return async function({public_key:n,hints:r}){let o;const s=e.cloud.options?.databaseUrl;if(!s)throw new Error("No database URL given.");o="demo"===r?.grant_type?{demo_user:await vt(t,"Enter a demo user email",r?.email||r?.userId),grant_type:"demo",scopes:["ACCESS_DB"],public_key:n}:{email:await vt(t,"Enter email address",r?.email),grant_type:"otp",scopes:["ACCESS_DB"],public_key:n};const i=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json",mode:"cors"}});if(200!==i.status){const e=await i.text();throw await bt(t,"Token request failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Yt(i,e)}const a=await i.json();if("tokens"===a.type)return a;if("otp"===o.grant_type){if("otp-sent"!==a.type)throw new Error(`Unexpected response from ${s}/token`);const e=await gt(t,o.email);o.otp=e||"",o.otp_id=a.otp_id;let n=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});for(;401===n.status;){const e=await n.text();o.otp=await gt(t,o.email,{type:"error",messageCode:"INVALID_OTP",message:e,messageParams:{}}),n=await fetch(`${s}/token`,{body:JSON.stringify(o),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"})}if(200!==n.status){const e=await n.text();throw await bt(t,"OTP Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Yt(n,e)}return await n.json()}throw new Error(`Unexpected response from ${s}/token`)}}(e),e.cloud.userInteraction,t),await n.save(),await async function(e,t){if(t.userId===e.cloud.currentUserId)return;const n=e.table("$logins");await e.transaction("rw",n,(async e=>{const r=await n.toArray();await Promise.all(r.filter((e=>e.userId!==t.userId&&e.isLoggedIn)).map((e=>(e.isLoggedIn=!1,n.put(e))))),t.isLoggedIn=!0,t.lastLogin=new Date,await t.save(),console.debug("Saved new user",t.email)})),await new Promise((n=>{if(e.cloud.currentUserId===t.userId)n(null);else{const r=e.cloud.currentUser.subscribe((e=>{e.userId===t.userId&&(r.unsubscribe(),n(null))}))}}))}(e,n),Xe(e,"pull")}const vn="undefined"!=typeof InstallTrigger,gn="undefined"!=typeof navigator&&/Safari\//.test(navigator.userAgent)&&!/Chrom(e|ium)\/|Edge\//.test(navigator.userAgent),wn=gn?[].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1]:NaN,_n=gn&&wn<=605||vn;const Sn="undefined"!=typeof self&&"clients"in self&&!self.document;function kn(){throw new e.SchemaError("Version increment needed to allow dexie-cloud change tracking")}const{toString:xn}={};function In(e){return xn.call(e).slice(8,-1)}function En(e,t){return"delete"===t.type?t.keys:t.keys?.slice()||t.values.map(e.extractKey)}const Tn=/b|c|d|f|g|h|j|k|l|m|n|p|q|r|s|t|v|x|y|z/i;let Cn=0;function An(e,t){const n=new Uint8Array(18),r=new Uint8Array(n.buffer,0,6),o=Date.now();Cn>=o?++Cn:Cn=o,r[0]=Cn/1099511627776,r[1]=Cn/4294967296,r[2]=Cn/16777216,r[3]=Cn/65536,r[4]=Cn/256,r[5]=Cn;const s=new Uint8Array(n.buffer,6);crypto.getRandomValues(s);return e+Dt(new Uint8Array(n.buffer))+(t||"")}function Pn(t){return{stack:"dbcore",name:"idGenerationMiddleware",level:1,create:n=>({...n,table:r=>{const o=n.table(r);return{...o,mutate:n=>{if(n.trans.disableChangeTracking)return o.mutate(n);if("add"===n.type||"put"===n.type){const s=t.cloud.schema?.[r];if(s?.generatedGlobalId){if(t.cloud.options?.databaseUrl&&!t.initiallySynced){const e=En(o.schema.primaryKey,n);return o.getMany({keys:e,trans:n.trans,cache:"immutable"}).then((t=>{if(t.length<e.length)throw new Error("Unable to create new objects without an initial sync having been performed.");return o.mutate(n)}))}return function(n,s){let i=null;const a=En(o.schema.primaryKey,n);return a.forEach(((c,u)=>{if(void 0===c){const r=n.values[u].realmId||t.cloud.currentUserId,c=r.substr(r.length-3);a[u]=An(s,c),o.schema.primaryKey.outbound||(i||(i=n.values.slice()),i[u]=e.deepClone(i[u]),e.setByKeyPath(i[u],o.schema.primaryKey.keyPath,a[u]))}else if("string"!=typeof c||!c.startsWith(s)&&!c.startsWith("#"+s))throw new e.ConstraintError(`The ID "${c}" is not valid for table "${r}". Primary '@' keys requires the key to be prefixed with "${s}" (or "#${s}).\nIf you want to generate IDs programmatically, remove '@' from the schema to get rid of this constraint. Dexie Cloud supports custom IDs as long as they are random and globally unique.`)})),o.mutate({...n,keys:a,values:i||n.values})}(n,s.idPrefix)}if(s?.markedForSync){En(o.schema.primaryKey,n).forEach(((t,n)=>{if(!ft(t)){const n=Array.isArray(t)?t.map(In).join(","):In(t);throw new e.ConstraintError(`Invalid primary key type ${n} for table ${r}. Tables marked for sync has primary keys of type string or Array of string (and optional numbers)`)}}))}}return o.mutate(n)}}}})}}let Un=0;function $n(e,t){return function(n){const{readers:r,writers:o}=n.trans[t]||(n.trans[t]={writers:[],readers:[]}),s=o.length,i=(s>0?o[s-1].then((()=>e(n)),(()=>e(n))):e(n)).finally((()=>r.splice(r.indexOf(i))));return r.push(i),i}}function Dn(e,t){return function(n){const{readers:r,writers:o}=n.trans[t]||(n.trans[t]={writers:[],readers:[]});let s=(o.length>0?o[o.length-1].then((()=>e(n)),(()=>e(n))):r.length>0?(i=r,new Promise((e=>{0===i.length&&e([]);let t=i.length;const n=new Array(t);i.forEach(((r,o)=>Promise.resolve(r).then((e=>n[o]={status:"fulfilled",value:e}),(e=>n[o]={status:"rejected",reason:e})).then((()=>--t||e(n)))))}))).then((()=>e(n))):e(n)).finally((()=>o.shift()));var i;return o.push(s),s}}const On=new o(new Set);function Rn({currentUserObservable:e,db:t}){return{stack:"dbcore",name:"MutationTrackingMiddleware",level:1,create:n=>{const r=n.schema.tables.filter((e=>!/^\$/.test(e.name)));let o;try{o=new Map(r.map((e=>[e.name,n.table(`$${e.name}_mutations`)])))}catch{kn()}return{...n,transaction:(r,o)=>{let s;if("readwrite"===o){const e=r.filter((e=>t.cloud.schema?.[e]?.markedForSync)).map((e=>rt(e)));s=n.transaction([...r,...e],o)}else s=n.transaction(r,o);if("readwrite"===o){s.txid=ct(16),s.currentUser=e.value,On.value.add(s),On.next(On.value);const n=()=>{s.removeEventListener("complete",r),s.removeEventListener("error",n),s.removeEventListener("abort",n),On.value.delete(s),On.next(On.value)},r=()=>{s.mutationsAdded&&t.cloud.options?.databaseUrl&&(t.cloud.usingServiceWorker?(console.debug("registering sync event"),Ze(t,"push")):t.localSyncEvent.next({purpose:"push"})),n()};s.addEventListener("complete",r),s.addEventListener("error",n),s.addEventListener("abort",n)}return s},table:e=>{const r=n.table(e);if(/^\$/.test(e))return e.endsWith("_mutations")?{...r,mutate:e=>("add"!==e.type&&"put"!==e.type||(e.trans.mutationsAdded=!0),r.mutate(e))}:"$logins"===e?{...r,mutate:e=>r.mutate(e).then((t=>(e.trans.mutationsAdded=!0,t))).catch((e=>(console.debug("Failed mutation $logins",e),Promise.reject(e))))}:r;const{schema:s}=r,i=o.get(e);return function(e){const t="$lock"+ ++Un;return{...e,count:$n(e.count,t),get:$n(e.get,t),getMany:$n(e.getMany,t),openCursor:$n(e.openCursor,t),query:$n(e.query,t),mutate:Dn(e.mutate,t)}}({...r,mutate:n=>{const o=n.trans;return o.txid?o.disableChangeTracking?r.mutate(n):t.cloud.schema?.[e]?.markedForSync&&o.currentUser?.isLoggedIn?"deleteRange"===n.type?r.query({query:{range:n.range,index:s.primaryKey},trans:n.trans,values:!1}).then((e=>a({type:"delete",keys:e.result,trans:n.trans,criteria:{index:null,range:n.range}}))):a(n):r.mutate(n):r.mutate(n)}});function a(e){const t=e.trans;t.mutationsAdded=!0;const{txid:n,currentUser:{userId:o}}=t,{type:s}=e;return r.mutate(e).then((r=>{const{numFailures:a,failures:c}=r;let u="delete"===s?e.keys:r.results,l="values"in e?e.values:[],d="changeSpecs"in e?e.changeSpecs:[];a&&(u=u.filter(((e,t)=>!c[t])),l=l.filter(((e,t)=>!c[t])),d=d.filter(((e,t)=>!c[t])));const f=Date.now(),p="delete"===e.type?{type:"delete",ts:f,keys:u,criteria:e.criteria,txid:n,userId:o}:"add"===e.type?{type:"insert",ts:f,keys:u,txid:n,userId:o,values:l}:e.criteria&&e.changeSpec?{type:"modify",ts:f,keys:u,criteria:e.criteria,changeSpec:e.changeSpec,txid:n,userId:o}:e.changeSpecs?{type:"update",ts:f,keys:u,changeSpecs:d,txid:n,userId:o}:{type:"upsert",ts:f,keys:u,values:l,txid:n,userId:o};return u.length>0||"criteria"in e&&e.criteria?i.mutate({type:"add",trans:t,values:[p]}).then((()=>r)):r}))}}}}}}function Nn(e,t){return function(n,r){const o={...fn,...n},s=t.cloud.schema||(t.cloud.schema={}),i=new Set;Object.keys(o).forEach((e=>{const t=o[e],n=s[e]||(s[e]={});null!=t?(/^\@/.test(t)&&(o[e]=o[e].substr(1),n.generatedGlobalId=!0,n.idPrefix=function(e,t){let n=e[0].toLocaleLowerCase();for(let t=1,o=e.length;t<o&&n.length<3;++t)(Tn.test(e[t])||(r=e[t])>="A"&&r<="Z")&&(n+=e[t].toLowerCase());for(var r,o,s;t.has(n);){if(/\d/g.test(n)){if(n=n.substr(0,n.length-1)+(n[n.length-1]+1),!(n.length>3))continue;n=n.substr(0,3)}else if(n.length<3){n+="2";continue}let e=1,r=n;for(;t.has(r)&&e<8;)o=n,r=(1&(s=e)?o[0].toUpperCase():o[0].toLowerCase())+(2&s?o[1].toUpperCase():o[1].toLowerCase())+(4&s?o[2].toUpperCase():o[2].toLowerCase()),++e;if(e<8)n=r;else{let e=n.charCodeAt(2)+1&127;n=n.substr(0,2)+String.fromCharCode(e)}}return n}(e,i),i.add(n.idPrefix)),/^\$/.test(e)||(o[`$${e}_mutations`]="++rev",n.markedForSync=!0),n.deleted&&(n.deleted=!1)):(n.deleted=!0,n.markedForSync=!1,o[`$${e}_mutations`]=null)}));return e.call(this,o,r)}}const Ln=ct(16);async function jn(e,t,r,o,{awaitRemoteJob:s}={}){const a=e.table(r);if(await async function o(){if(await e.transaction("rw!",r,(async()=>{const e=await a.get(t);return e?e.heartbeat.getTime()<Date.now()-6e4&&(console.warn(`Latest ${t} worker seem to have died.\n`,"The dead job started:",e.started,"\n","Last heart beat was:",e.heartbeat,"\n","We're now taking over!"),await a.put({nodeId:Ln,started:new Date,heartbeat:new Date},t),!0):(await a.add({nodeId:Ln,started:new Date,heartbeat:new Date},t),!0)})))return!0;if(s)try{const e=i(n((()=>a.get(t)))).pipe(function(e,t){var n=xe(e)?{first:e}:"number"==typeof e?{each:e}:e,r=n.first,o=n.each,s=n.with,i=void 0===s?Ge:s,a=n.scheduler,c=void 0===a?null!=t?t:_e:a,u=n.meta,l=void 0===u?null:u;if(null==r&&null==o)throw new TypeError("No timeout provided.");return k((function(e,t){var n,s,a=null,u=0,d=function(e){s=Ee(t,c,(function(){try{n.unsubscribe(),pe(i({meta:l,lastValue:a,seen:u})).subscribe(t)}catch(e){t.error(e)}}),e)};n=e.subscribe(new ye(t,(function(e){null==s||s.unsubscribe(),u++,t.next(a=e),o>0&&d(o)}),void 0,void 0,(function(){(null==s?void 0:s.closed)||null==s||s.unsubscribe(),a=null}))),d(null!=r?"number"==typeof r?r:+r-c.now():o)}))}(6e4),He((e=>!e)));return await e.toPromise(),!1}catch(e){if("TimeoutError"!==e.name)throw e;return await o()}return!1}()){const n=setInterval((()=>{a.update(t,(e=>{e.nodeId===Ln&&(e.heartbeat=new Date)}))}),1e3);try{return await o()}finally{clearInterval(n),await e.transaction("rw!",r,(async()=>{const e=await a.get(t);e&&e.nodeId===Ln&&a.delete(t)}))}}}const Wn=new o(!0),Bn=new o(!0);var Mn,Fn;Wn.pipe(ze((e=>e?c(!0):c(!1).pipe(Me(2e4)))),(void 0===Fn&&(Fn=ne),Mn=null!=Mn?Mn:Fe,k((function(e,t){var n,r=!0;e.subscribe(new ye(t,(function(e){var o=Fn(e);!r&&Mn(n,o)||(r=!1,n=o,t.next(e))})))})))).subscribe(Bn);const Hn="undefined"!=typeof document?a(document,"visibilitychange"):c({}),Kn=Hn.pipe(He((()=>"hidden"===document.visibilityState))),qn=Hn.pipe(He((()=>"visible"===document.visibilityState))),zn="undefined"!=typeof window?u(qn,a(window,"mousedown"),a(window,"mousemove"),a(window,"keydown"),a(window,"wheel"),a(window,"touchmove")):c({});"undefined"!=typeof document&&u(c(!0),Kn,zn).pipe(De((()=>"visible"===document.visibilityState)),Ve((e=>{Wn.value!==e&&Wn.next(e)})),ze((e=>e?c(0).pipe(Me(16e4),Ve((()=>Wn.next(!1)))):c(0)))).subscribe((()=>{}));class Vn extends Error{constructor(){super(...arguments),this.name="TokenExpiredError"}}class Jn extends r{constructor(e,t,n,r,o,s,i,a){super((c=>new Yn(e,t,n,r,i,a,c,o,s)))}}let Gn=0;class Yn extends l{constructor(e,t,n,r,o,s,i,a,c){super((()=>this.teardown())),this.id=++Gn,this.reconnecting=!1,console.debug("New WebSocket Connection",this.id,o?"authorized":"unauthorized"),this.databaseUrl=e,this.rev=t,this.realmSetHash=n,this.clientIdentity=r,this.token=o,this.tokenExpiration=s,this.subscriber=i,this.lastUserActivity=new Date,this.messageProducer=a,this.messageProducerSubscription=null,this.webSocketStatus=c,this.connect()}teardown(){console.debug("Teardown WebSocket Connection",this.id),this.disconnect()}disconnect(){if(this.webSocketStatus.next("disconnected"),this.pinger&&(clearInterval(this.pinger),this.pinger=null),this.ws)try{this.ws.close()}catch{}this.ws=null,this.messageProducerSubscription&&(this.messageProducerSubscription.unsubscribe(),this.messageProducerSubscription=null)}reconnect(){if(!this.reconnecting){this.reconnecting=!0;try{this.disconnect()}catch{}this.connect().catch((()=>{})).then((()=>this.reconnecting=!1))}}async connect(){if(this.lastServerActivity=new Date,this.pauseUntil&&this.pauseUntil>new Date)return void console.debug("WS not reconnecting just yet",{id:this.id,pauseUntil:this.pauseUntil});if(this.ws)throw new Error("Called connect() when a connection is already open");if(!this.databaseUrl)throw new Error("Cannot connect without a database URL");if(this.closed)return;if(this.tokenExpiration&&this.tokenExpiration<new Date)return void this.subscriber.error(new Vn);this.webSocketStatus.next("connecting"),this.pinger=setInterval((async()=>{if(this.closed)return console.debug("pinger check",this.id,"CLOSED."),void this.teardown();if(this.ws)try{this.ws.send(JSON.stringify({type:"ping"})),setTimeout((()=>{if(console.debug("pinger setTimeout",this.id,this.pinger?"alive":"dead"),this.pinger)return this.closed?(console.debug("pinger setTimeout",this.id,"subscription is closed"),void this.teardown()):void(this.lastServerActivity<new Date(Date.now()-2e4)?(console.debug("pinger: server is inactive"),console.debug("pinger reconnecting"),this.reconnect()):console.debug("pinger: server still active"))}),2e4)}catch{console.debug("pinger catch error",this.id,"reconnecting"),this.reconnect()}else console.debug("pinger",this.id,"reconnecting"),this.reconnect()}),3e4);const e=new URL(this.databaseUrl);e.protocol="http:"===e.protocol?"ws":"wss";const t=new URLSearchParams;if(this.subscriber.closed)return;t.set("v","2"),t.set("rev",this.rev),t.set("realmsHash",this.realmSetHash),t.set("clientId",this.clientIdentity),this.token&&t.set("token",this.token),console.debug("dexie-cloud WebSocket create");const n=this.ws=new WebSocket(`${e}/changes?${t}`);n.onclose=e=>{this.pinger&&(console.debug("dexie-cloud WebSocket onclosed",this.id),this.reconnect())},n.onmessage=e=>{if(this.pinger){console.debug("dexie-cloud WebSocket onmessage",e.data),this.lastServerActivity=new Date;try{const t=Jt.parse(e.data);if("error"===t.type)throw new Error(`Error message from dexie-cloud: ${t.error}`);"rev"===t.type&&(this.rev=t.rev),"pong"!==t.type&&this.subscriber.next(t)}catch(e){this.subscriber.error(e)}}};try{let e=!1;await new Promise(((t,r)=>{n.onopen=n=>{console.debug("dexie-cloud WebSocket onopen"),e=!0,t(null)},n.onerror=t=>{if(e)this.reconnect();else{const e=t.error||new Error("WebSocket Error");this.subscriber.error(e),this.webSocketStatus.next("error"),r(e)}}})),this.messageProducerSubscription=this.messageProducer.subscribe((e=>{this.closed||("ready"===e.type&&"connected"!==this.webSocketStatus.value&&this.webSocketStatus.next("connected"),this.ws?.send(Jt.stringify(e)))}))}catch(e){this.pauseUntil=new Date(Date.now()+6e4)}}}async function Zn(e){var t;console.error("WebSocket observable: error but revive when user does some active thing...",e),await(t=3e3,new Promise((e=>setTimeout(e,t)))),console.debug("waiting for someone to do something"),await zn.pipe(We(1)).toPromise(),console.debug("someone did something!")}async function Xn(e){return!(!e.cloud.options?.databaseUrl||!e.cloud.schema)&&await an(e,e.cloud.options,e.cloud.schema,{justCheckIfNeeded:!0})}const Qn=new WeakMap;function er(e,t,n,r){const o=Qn.get(e);if(o){if(o.pull||"push"===r?.purpose)return console.debug("syncIfPossible(): returning the ongoing sync promise."),o.promise;{let s=!1;const i=e.cloud.syncState.subscribe((e=>{"pulling"===e.phase&&(s=!0)}));return o.promise.then((()=>{i.unsubscribe()})).catch((e=>(i.unsubscribe(),Promise.reject(e)))).then((()=>{if(!s)return er(e,t,n,r)}))}}const s=async function(){try{e.cloud.usingServiceWorker?Sn&&await an(e,t,n,r):await jn(e,"currentSyncWorker","$jobs",(()=>an(e,t,n,r))),Qn.delete(e),console.debug("Done sync")}catch(t){throw Qn.delete(e),console.error("Failed to sync client changes",t),t}}();return Qn.set(e,{promise:s,pull:"push"!==r?.purpose}),s}function tr(e,t,n){let r=null,o={cancelled:!1};function s(r,a=1){setTimeout((()=>{er(e,t,n,{cancelToken:o,retryImmediatelyOnFetchError:!0,purpose:r}).catch((e=>{console.error("error in syncIfPossible()",e),o.cancelled?i():a<3&&setTimeout((()=>s(r,a+1)),6e4*[0,5,15][a])}))}),0)}const i=()=>{console.debug("Stopping LocalSyncWorker"),o.cancelled=!0,r&&r.unsubscribe()};return{start:()=>{console.debug("Starting LocalSyncWorker",e.localSyncEvent.id),r=e.localSyncEvent.subscribe((({purpose:e})=>{try{s(e||"pull")}catch(e){console.error("What-the....",e)}}))},stop:i}}function nr(e,t){if(e&&t&&t.unsyncedTables)for(const n of t.unsyncedTables)e[n]&&(e[n].markedForSync=!1)}var rr,or,sr,ir,ar={},cr=[],ur=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;function lr(e,t){for(var n in t)e[n]=t[n];return e}function dr(e){var t=e.parentNode;t&&t.removeChild(e)}function fr(e,t,n){var r,o,s,i=arguments,a={};for(s in t)"key"==s?r=t[s]:"ref"==s?o=t[s]:a[s]=t[s];if(arguments.length>3)for(n=[n],s=3;s<arguments.length;s++)n.push(i[s]);if(null!=n&&(a.children=n),"function"==typeof e&&null!=e.defaultProps)for(s in e.defaultProps)void 0===a[s]&&(a[s]=e.defaultProps[s]);return pr(e,a,r,o,null)}function pr(e,t,n,r,o){var s={type:e,props:t,key:n,ref:r,__k:null,__:null,__b:0,__e:null,__d:void 0,__c:null,__h:null,constructor:void 0,__v:null==o?++rr.__v:o};return null!=rr.vnode&&rr.vnode(s),s}function hr(e){return e.children}function yr(e,t){this.props=e,this.context=t}function mr(e,t){if(null==t)return e.__?mr(e.__,e.__.__k.indexOf(e)+1):null;for(var n;t<e.__k.length;t++)if(null!=(n=e.__k[t])&&null!=n.__e)return n.__e;return"function"==typeof e.type?mr(e):null}function br(e){var t,n;if(null!=(e=e.__)&&null!=e.__c){for(e.__e=e.__c.base=null,t=0;t<e.__k.length;t++)if(null!=(n=e.__k[t])&&null!=n.__e){e.__e=e.__c.base=n.__e;break}return br(e)}}function vr(e){(!e.__d&&(e.__d=!0)&&or.push(e)&&!gr.__r++||ir!==rr.debounceRendering)&&((ir=rr.debounceRendering)||sr)(gr)}function gr(){for(var e;gr.__r=or.length;)e=or.sort((function(e,t){return e.__v.__b-t.__v.__b})),or=[],e.some((function(e){var t,n,r,o,s,i;e.__d&&(s=(o=(t=e).__v).__e,(i=t.__P)&&(n=[],(r=lr({},o)).__v=o.__v+1,Tr(i,o,r,t.__n,void 0!==i.ownerSVGElement,null!=o.__h?[s]:null,n,null==s?mr(o):s,o.__h),Cr(n,o),o.__e!=s&&br(o)))}))}function wr(e,t,n,r,o,s,i,a,c,u){var l,d,f,p,h,y,m,b=r&&r.__k||cr,v=b.length;for(n.__k=[],l=0;l<t.length;l++)if(null!=(p=n.__k[l]=null==(p=t[l])||"boolean"==typeof p?null:"string"==typeof p||"number"==typeof p||"bigint"==typeof p?pr(null,p,null,null,p):Array.isArray(p)?pr(hr,{children:p},null,null,null):p.__b>0?pr(p.type,p.props,p.key,null,p.__v):p)){if(p.__=n,p.__b=n.__b+1,null===(f=b[l])||f&&p.key==f.key&&p.type===f.type)b[l]=void 0;else for(d=0;d<v;d++){if((f=b[d])&&p.key==f.key&&p.type===f.type){b[d]=void 0;break}f=null}Tr(e,p,f=f||ar,o,s,i,a,c,u),h=p.__e,(d=p.ref)&&f.ref!=d&&(m||(m=[]),f.ref&&m.push(f.ref,null,p),m.push(d,p.__c||h,p)),null!=h?(null==y&&(y=h),"function"==typeof p.type&&null!=p.__k&&p.__k===f.__k?p.__d=c=_r(p,c,e):c=Sr(e,p,f,b,h,c),u||"option"!==n.type?"function"==typeof n.type&&(n.__d=c):e.value=""):c&&f.__e==c&&c.parentNode!=e&&(c=mr(f))}for(n.__e=y,l=v;l--;)null!=b[l]&&("function"==typeof n.type&&null!=b[l].__e&&b[l].__e==n.__d&&(n.__d=mr(r,l+1)),Ur(b[l],b[l]));if(m)for(l=0;l<m.length;l++)Pr(m[l],m[++l],m[++l])}function _r(e,t,n){var r,o;for(r=0;r<e.__k.length;r++)(o=e.__k[r])&&(o.__=e,t="function"==typeof o.type?_r(o,t,n):Sr(n,o,o,e.__k,o.__e,t));return t}function Sr(e,t,n,r,o,s){var i,a,c;if(void 0!==t.__d)i=t.__d,t.__d=void 0;else if(null==n||o!=s||null==o.parentNode)e:if(null==s||s.parentNode!==e)e.appendChild(o),i=null;else{for(a=s,c=0;(a=a.nextSibling)&&c<r.length;c+=2)if(a==o)break e;e.insertBefore(o,s),i=s}return void 0!==i?i:o.nextSibling}function kr(e,t,n){"-"===t[0]?e.setProperty(t,n):e[t]=null==n?"":"number"!=typeof n||ur.test(t)?n:n+"px"}function xr(e,t,n,r,o){var s;e:if("style"===t)if("string"==typeof n)e.style.cssText=n;else{if("string"==typeof r&&(e.style.cssText=r=""),r)for(t in r)n&&t in n||kr(e.style,t,"");if(n)for(t in n)r&&n[t]===r[t]||kr(e.style,t,n[t])}else if("o"===t[0]&&"n"===t[1])s=t!==(t=t.replace(/Capture$/,"")),t=t.toLowerCase()in e?t.toLowerCase().slice(2):t.slice(2),e.l||(e.l={}),e.l[t+s]=n,n?r||e.addEventListener(t,s?Er:Ir,s):e.removeEventListener(t,s?Er:Ir,s);else if("dangerouslySetInnerHTML"!==t){if(o)t=t.replace(/xlink[H:h]/,"h").replace(/sName$/,"s");else if("href"!==t&&"list"!==t&&"form"!==t&&"tabIndex"!==t&&"download"!==t&&t in e)try{e[t]=null==n?"":n;break e}catch(e){}"function"==typeof n||(null!=n&&(!1!==n||"a"===t[0]&&"r"===t[1])?e.setAttribute(t,n):e.removeAttribute(t))}}function Ir(e){this.l[e.type+!1](rr.event?rr.event(e):e)}function Er(e){this.l[e.type+!0](rr.event?rr.event(e):e)}function Tr(e,t,n,r,o,s,i,a,c){var u,l,d,f,p,h,y,m,b,v,g,w=t.type;if(void 0!==t.constructor)return null;null!=n.__h&&(c=n.__h,a=t.__e=n.__e,t.__h=null,s=[a]),(u=rr.__b)&&u(t);try{e:if("function"==typeof w){if(m=t.props,b=(u=w.contextType)&&r[u.__c],v=u?b?b.props.value:u.__:r,n.__c?y=(l=t.__c=n.__c).__=l.__E:("prototype"in w&&w.prototype.render?t.__c=l=new w(m,v):(t.__c=l=new yr(m,v),l.constructor=w,l.render=$r),b&&b.sub(l),l.props=m,l.state||(l.state={}),l.context=v,l.__n=r,d=l.__d=!0,l.__h=[]),null==l.__s&&(l.__s=l.state),null!=w.getDerivedStateFromProps&&(l.__s==l.state&&(l.__s=lr({},l.__s)),lr(l.__s,w.getDerivedStateFromProps(m,l.__s))),f=l.props,p=l.state,d)null==w.getDerivedStateFromProps&&null!=l.componentWillMount&&l.componentWillMount(),null!=l.componentDidMount&&l.__h.push(l.componentDidMount);else{if(null==w.getDerivedStateFromProps&&m!==f&&null!=l.componentWillReceiveProps&&l.componentWillReceiveProps(m,v),!l.__e&&null!=l.shouldComponentUpdate&&!1===l.shouldComponentUpdate(m,l.__s,v)||t.__v===n.__v){l.props=m,l.state=l.__s,t.__v!==n.__v&&(l.__d=!1),l.__v=t,t.__e=n.__e,t.__k=n.__k,t.__k.forEach((function(e){e&&(e.__=t)})),l.__h.length&&i.push(l);break e}null!=l.componentWillUpdate&&l.componentWillUpdate(m,l.__s,v),null!=l.componentDidUpdate&&l.__h.push((function(){l.componentDidUpdate(f,p,h)}))}l.context=v,l.props=m,l.state=l.__s,(u=rr.__r)&&u(t),l.__d=!1,l.__v=t,l.__P=e,u=l.render(l.props,l.state,l.context),l.state=l.__s,null!=l.getChildContext&&(r=lr(lr({},r),l.getChildContext())),d||null==l.getSnapshotBeforeUpdate||(h=l.getSnapshotBeforeUpdate(f,p)),g=null!=u&&u.type===hr&&null==u.key?u.props.children:u,wr(e,Array.isArray(g)?g:[g],t,n,r,o,s,i,a,c),l.base=t.__e,t.__h=null,l.__h.length&&i.push(l),y&&(l.__E=l.__=null),l.__e=!1}else null==s&&t.__v===n.__v?(t.__k=n.__k,t.__e=n.__e):t.__e=Ar(n.__e,t,n,r,o,s,i,c);(u=rr.diffed)&&u(t)}catch(e){t.__v=null,(c||null!=s)&&(t.__e=a,t.__h=!!c,s[s.indexOf(a)]=null),rr.__e(e,t,n)}}function Cr(e,t){rr.__c&&rr.__c(t,e),e.some((function(t){try{e=t.__h,t.__h=[],e.some((function(e){e.call(t)}))}catch(e){rr.__e(e,t.__v)}}))}function Ar(e,t,n,r,o,s,i,a){var c,u,l,d,f=n.props,p=t.props,h=t.type,y=0;if("svg"===h&&(o=!0),null!=s)for(;y<s.length;y++)if((c=s[y])&&(c===e||(h?c.localName==h:3==c.nodeType))){e=c,s[y]=null;break}if(null==e){if(null===h)return document.createTextNode(p);e=o?document.createElementNS("http://www.w3.org/2000/svg",h):document.createElement(h,p.is&&p),s=null,a=!1}if(null===h)f===p||a&&e.data===p||(e.data=p);else{if(s=s&&cr.slice.call(e.childNodes),u=(f=n.props||ar).dangerouslySetInnerHTML,l=p.dangerouslySetInnerHTML,!a){if(null!=s)for(f={},d=0;d<e.attributes.length;d++)f[e.attributes[d].name]=e.attributes[d].value;(l||u)&&(l&&(u&&l.__html==u.__html||l.__html===e.innerHTML)||(e.innerHTML=l&&l.__html||""))}if(function(e,t,n,r,o){var s;for(s in n)"children"===s||"key"===s||s in t||xr(e,s,null,n[s],r);for(s in t)o&&"function"!=typeof t[s]||"children"===s||"key"===s||"value"===s||"checked"===s||n[s]===t[s]||xr(e,s,t[s],n[s],r)}(e,p,f,o,a),l)t.__k=[];else if(y=t.props.children,wr(e,Array.isArray(y)?y:[y],t,n,r,o&&"foreignObject"!==h,s,i,e.firstChild,a),null!=s)for(y=s.length;y--;)null!=s[y]&&dr(s[y]);a||("value"in p&&void 0!==(y=p.value)&&(y!==e.value||"progress"===h&&!y)&&xr(e,"value",y,f.value,!1),"checked"in p&&void 0!==(y=p.checked)&&y!==e.checked&&xr(e,"checked",y,f.checked,!1))}return e}function Pr(e,t,n){try{"function"==typeof e?e(t):e.current=t}catch(e){rr.__e(e,n)}}function Ur(e,t,n){var r,o,s;if(rr.unmount&&rr.unmount(e),(r=e.ref)&&(r.current&&r.current!==e.__e||Pr(r,null,t)),n||"function"==typeof e.type||(n=null!=(o=e.__e)),e.__e=e.__d=void 0,null!=(r=e.__c)){if(r.componentWillUnmount)try{r.componentWillUnmount()}catch(e){rr.__e(e,t)}r.base=r.__P=null}if(r=e.__k)for(s=0;s<r.length;s++)r[s]&&Ur(r[s],t,n);null!=o&&dr(o)}function $r(e,t,n){return this.constructor(e,n)}rr={__e:function(e,t){for(var n,r,o;t=t.__;)if((n=t.__c)&&!n.__)try{if((r=n.constructor)&&null!=r.getDerivedStateFromError&&(n.setState(r.getDerivedStateFromError(e)),o=n.__d),null!=n.componentDidCatch&&(n.componentDidCatch(e),o=n.__d),o)return n.__E=n}catch(t){e=t}throw e},__v:0},yr.prototype.setState=function(e,t){var n;n=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=lr({},this.state),"function"==typeof e&&(e=e(lr({},n),this.props)),e&&lr(n,e),null!=e&&this.__v&&(t&&this.__h.push(t),vr(this))},yr.prototype.forceUpdate=function(e){this.__v&&(this.__e=!0,e&&this.__h.push(e),vr(this))},yr.prototype.render=hr,or=[],sr="function"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,gr.__r=0;const Dr={Error:{color:"red"},Alert:{error:{color:"red"},warning:{color:"yellow"},info:{color:"black"}},Darken:{position:"fixed",top:0,left:0,opacity:.5,backgroundColor:"#000",width:"100vw",height:"100vh",zIndex:150,webkitBackdropFilter:"blur(2px)",backdropFilter:"blur(2px)"},DialogOuter:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:150,alignItems:"center",display:"flex",justifyContent:"center"},DialogInner:{position:"relative",color:"#222",backgroundColor:"#fff",padding:"30px",marginBottom:"2em",maxWidth:"90%",maxHeight:"90%",overflowY:"auto",border:"3px solid #3d3d5d",borderRadius:"8px",boxShadow:"0 0 80px 10px #666",width:"auto"},Input:{height:"35px",width:"17em",borderColor:"#ccf4",outline:"none",fontSize:"17pt",padding:"8px"}};function Or({children:e}){return fr("div",null,fr("div",{style:Dr.Darken}),fr("div",{style:Dr.DialogOuter},fr("div",{style:Dr.DialogInner},e)))}var Rr,Nr,Lr,jr=0,Wr=[],Br=rr.__b,Mr=rr.__r,Fr=rr.diffed,Hr=rr.__c,Kr=rr.unmount;function qr(e,t){rr.__h&&rr.__h(Nr,e,jr||t),jr=0;var n=Nr.__H||(Nr.__H={__:[],__h:[]});return e>=n.__.length&&n.__.push({}),n.__[e]}function zr(e){return jr=1,function(e,t,n){var r=qr(Rr++,2);return r.t=e,r.__c||(r.__=[n?n(t):Qr(void 0,t),function(e){var t=r.t(r.__[0],e);r.__[0]!==t&&(r.__=[t,r.__[1]],r.__c.setState({}))}],r.__c=Nr),r.__}(Qr,e)}function Vr(e){return jr=5,function(e,t){var n=qr(Rr++,7);return Xr(n.__H,t)&&(n.__=e(),n.__H=t,n.__h=e),n.__}((function(){return{current:e}}),[])}function Jr(){Wr.forEach((function(e){if(e.__P)try{e.__H.__h.forEach(Yr),e.__H.__h.forEach(Zr),e.__H.__h=[]}catch(t){e.__H.__h=[],rr.__e(t,e.__v)}})),Wr=[]}rr.__b=function(e){Nr=null,Br&&Br(e)},rr.__r=function(e){Mr&&Mr(e),Rr=0;var t=(Nr=e.__c).__H;t&&(t.__h.forEach(Yr),t.__h.forEach(Zr),t.__h=[])},rr.diffed=function(e){Fr&&Fr(e);var t=e.__c;t&&t.__H&&t.__H.__h.length&&(1!==Wr.push(t)&&Lr===rr.requestAnimationFrame||((Lr=rr.requestAnimationFrame)||function(e){var t,n=function(){clearTimeout(r),Gr&&cancelAnimationFrame(t),setTimeout(e)},r=setTimeout(n,100);Gr&&(t=requestAnimationFrame(n))})(Jr)),Nr=void 0},rr.__c=function(e,t){t.some((function(e){try{e.__h.forEach(Yr),e.__h=e.__h.filter((function(e){return!e.__||Zr(e)}))}catch(n){t.some((function(e){e.__h&&(e.__h=[])})),t=[],rr.__e(n,e.__v)}})),Hr&&Hr(e,t)},rr.unmount=function(e){Kr&&Kr(e);var t=e.__c;if(t&&t.__H)try{t.__H.__.forEach(Yr)}catch(e){rr.__e(e,t.__v)}};var Gr="function"==typeof requestAnimationFrame;function Yr(e){var t=Nr;"function"==typeof e.__c&&e.__c(),Nr=t}function Zr(e){var t=Nr;e.__c=e.__(),Nr=t}function Xr(e,t){return!e||e.length!==t.length||t.some((function(t,n){return t!==e[n]}))}function Qr(e,t){return"function"==typeof t?t(e):t}function eo({title:e,alerts:t,fields:n,onCancel:r,onSubmit:o}){const[s,i]=zr({}),a=Vr();return function(e,t){var n=qr(Rr++,4);!rr.__s&&Xr(n.__H,t)&&(n.__=e,n.__H=t,Nr.__h.push(n))}((()=>a.current?.focus()),[]),fr(Or,null,fr(hr,null,fr("h3",{style:Dr.WindowHeader},e),t.map((e=>fr("p",{style:Dr.Alert[e.type]},function({message:e,messageCode:t,messageParams:n}){return e.replace(/\{\w+\}/gi,(e=>n[e.substr(1,e.length-2)]))}(e)))),fr("form",{onSubmit:e=>{e.preventDefault(),o(s)}},Object.entries(n).map((([e,{type:t,label:n,placeholder:r}],o)=>fr("label",{style:Dr.Label},n?`${n}: `:"",fr("input",{ref:0===o?a:void 0,type:t,name:e,autoComplete:"on",style:Dr.Input,autoFocus:!0,placeholder:r,value:s[e]||"",onInput:n=>i({...s,[e]:to(t,n.target?.value)})})))))),fr("div",{style:Dr.ButtonsDiv},fr("button",{type:"submit",style:Dr.Button,onClick:()=>o(s)},"Submit"),fr("button",{style:Dr.Button,onClick:r},"Cancel")))}function to(e,t){switch(e){case"email":return t.toLowerCase();case"otp":return t.toUpperCase();default:return t}}class no extends yr{constructor(e){super(e),this.observer=e=>this.setState({userInteraction:e}),this.state={userInteraction:void 0}}componentDidMount(){this.subscription=i(this.props.db.cloud.userInteraction).subscribe(this.observer)}componentWillUnmount(){this.subscription&&(this.subscription.unsubscribe(),delete this.subscription)}render(e,{userInteraction:t}){return t?fr(eo,{...t}):null}}function ro(e){const t=document.createElement("div");document.body.appendChild(t),function(e,t,n){var r,o,s;rr.__&&rr.__(e,t),o=(r="function"==typeof n)?null:n&&n.__k||t.__k,s=[],Tr(t,e=(!r&&n||t).__k=fr(hr,null,[e]),o||ar,ar,void 0!==t.ownerSVGElement,!r&&n?[n]:o?null:t.firstChild?cr.slice.call(t.childNodes):null,s,!r&&n?n:o?o.__e:t.firstChild,r),Cr(s,e)}(fr(no,{db:e.vip}),t);let n=!1;return{unsubscribe(){t.remove(),n=!0},get closed(){return n}}}function oo(e){const t=new WeakMap;return n=>{let r=t.get(n);return r||(r=e(n),t.set(n,r)),r}}function so(e,t){let n=t,o=i(e).pipe(p((e=>n=e)),h({resetOnRefCountZero:()=>y(1e3)}));const s=new r((e=>{let t=!1;const r=o.subscribe({next(n){t=!0,e.next(n)},error(t){e.error(t)},complete(){e.complete()}});return t||r.closed||e.next(n),r}));return s.getValue=()=>n,s}const io=oo((e=>so(n((()=>e.roles.where({realmId:"rlm-public"}).toArray().then((e=>{const t={};for(const n of e.slice().sort(((e,t)=>(e.sortOrder||0)-(t.sortOrder||0))))t[n.name]=n;return t})))),{}))),ao=oo((e=>new o(b))),co=oo((e=>so(ao(e._novip).pipe(ze((t=>n((()=>e.transaction("r","realms","members",(()=>Promise.all([e.members.where({userId:t.userId}).toArray(),e.realms.toArray(),t.userId]).then((([e,t,n])=>({selfMembers:e,realms:t,userId:n})))))))))),{selfMembers:[],realms:[],get userId(){return e.cloud.currentUserId}})));function uo(...e){if(0===e.length)return{};const t=e.reduce(((e,t)=>{const n={...e};for(const[e,r]of Object.entries(t))if(e in n&&n[e]){if("*"===n[e])continue;if("*"===r)n[e]="*";else if(Array.isArray(r)&&Array.isArray(n[e])){const t=n,o=t[e];t[e]=[...new Set([...o,...r])]}else if("object"==typeof r&&r&&"object"==typeof n[e]){const t=n[e];for(const[e,n]of Object.entries(r))"*"!==t[e]&&("*"===n?t[e]="*":Array.isArray(t[e])&&Array.isArray(n)&&(t[e]=[...new Set([...t[e],...n])]))}}else n[e]=t[e];return n}));return t}const lo=oo((e=>function(e,t){let n;const r=e.pipe(p((e=>n=t(e))));return r.getValue=()=>void 0!==n?n:n=t(e.getValue()),r}(so(f([co(e._novip),io(e._novip)]).pipe(De((([{selfMembers:e,realms:t,userId:n},r])=>({selfMembers:e,realms:t,userId:n,globalRoles:r})))),{selfMembers:[],realms:[],userId:b.userId,globalRoles:{}}),(({selfMembers:e,realms:t,userId:n,globalRoles:r})=>{const o=t.map((t=>{const o=e.filter((e=>e.realmId===t.realmId)),s=o.map((e=>e.permissions)).filter((e=>e)),i=it(o.map((e=>e.roles)).filter((e=>e))).map((e=>r[e])).filter((e=>e)).map((e=>e.permissions));return{...t,permissions:t.owner===n?{manage:"*"}:uo(...s,...i)}})).reduce(((e,t)=>({...e,[t.realmId]:t})),{[n]:{realmId:n,owner:n,name:n,permissions:{manage:"*"}}});return o}))));class fo{constructor(e,t,n){this.permissions=e||{},this.tableName=t,this.isOwner=n}add(...e){return"*"===this.permissions.manage||(!!this.permissions.manage?.includes(this.tableName)||("*"===this.permissions.add||!!e.every((e=>this.permissions.add?.includes(e)))))}update(...e){if(this.isOwner||"*"===this.permissions.manage)return!0;if(this.permissions.manage?.includes(this.tableName))return!0;if("*"===this.permissions.update)return e.every((e=>"owner"!==e));const t=this.permissions.update?.[this.tableName];return"*"===t?e.every((e=>"owner"!==e)):e.every((e=>t?.some((t=>t===e||"*"===t&&"owner"!==e))))}delete(){return!(!this.isOwner&&"*"!==this.permissions.manage)||!!this.permissions.manage?.includes(this.tableName)}}const po=oo((e=>{const t=ao(e._novip).pipe(m((t=>n((()=>e.members.where({email:t.email||""}).toArray()))))),r=lo(e._novip),o=co(e._novip);return so(f([t,o,r]).pipe(p((([e,t,n])=>{const r=(e,t)=>({...e,[t.id]:{...t,realm:n[t.realmId]}}),o=e.reduce(r,{}),s=t.selfMembers.reduce(r,o);return Object.values(s).filter((e=>!e.accepted))}))),[])})),ho={nameSuffix:!0};function yo(t){const r=t.name,s=ao(t),u=[];let l=!1,p=null;t.on("ready",(async t=>{try{await async function(t){h=!1;const r=hn(t);Sn||(r.cloud.options?.customLoginGui||u.push(ro(t)),u.push(function(e){let t=e.cloud.webSocketStatus.value;const n=e.cloud.webSocketStatus.pipe(ze((e=>{const n=t;t=e;const r=c(e);switch(e){case"disconnected":return Wn.value?r.pipe(Ne(500)):r;case"connecting":return"not-started"===n||"error"===n?r:r.pipe(Ne(4e3));default:return r}})));return f([n,e.syncStateChangedEvent.pipe(qe({phase:"initial"})),Bn]).pipe(De((([t,n,r])=>{let{phase:o,error:s,progress:i}=n,a=t;return"error"===o&&(a="error"),"not-started"===t&&("pushing"!==o&&"pulling"!==o||(a="connecting")),"error"!==e.cloud.syncState.value.phase||"pushing"!==n.phase&&"pulling"!==n.phase||(a="connecting"),r||(a="disconnected"),{phase:o,error:s,progress:i,status:tn?a:"offline"}})))}(r).subscribe(t.cloud.syncState)));r.tables.every((e=>e.core))||kn();const o="serviceWorker"in navigator?await navigator.serviceWorker.getRegistrations():[],m=await r.transaction("rw",r.$syncState,(async()=>{const{options:e,schema:t}=r.cloud,[n,s,i]=await Promise.all([r.getOptions(),r.getSchema(),r.getPersistedSyncState()]);if(l){if(!n||JSON.stringify(n)!==JSON.stringify(e)){if(!e)throw new Error("Internal error");await r.$syncState.put(e,"options")}}else r.cloud.options=n||null;if(r.cloud.options?.tryUseServiceWorker&&"serviceWorker"in navigator&&o.length>0&&!_n?(console.debug("Dexie Cloud Addon: Using service worker"),r.cloud.usingServiceWorker=!0):(r.cloud.options?.tryUseServiceWorker&&!Sn&&console.debug("dexie-cloud-addon: Not using service worker.",0===o.length?"No SW registrations found.":"serviceWorker"in navigator&&_n?"Avoiding SW background sync and SW periodic bg sync for this browser due to browser bugs.":"navigator.serviceWorker not present"),r.cloud.usingServiceWorker=!1),nr(t,r.cloud.options),nr(s,r.cloud.options),t){if(!s||JSON.stringify(s)!==JSON.stringify(t)){const e=s||{};for(const[n,r]of Object.entries(t)){const t=e[n];t?(t.markedForSync=r.markedForSync,r.deleted=t.deleted,t.generatedGlobalId=r.generatedGlobalId):e[n]={...r}}await r.$syncState.put(e,"schema"),Object.assign(t,e)}}else r.cloud.schema=s||null;return i?.initiallySynced}));m&&r.setInitiallySynced(!0);(function(t){for(const n of t.tables)if(t.cloud.schema?.[n.name]?.markedForSync){if(n.schema.primKey.auto)throw new e.SchemaError(`Table ${n.name} is both autoIncremented and synced. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(n.name)}]}) to blacklist it from sync`);if(!n.schema.primKey.keyPath)throw new e.SchemaError(`Table ${n.name} cannot be both synced and outbound. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(n.name)}]}) to blacklist it from sync`)}})(r),r.cloud.options?.databaseUrl&&!m&&(await async function(e,t,n){console.debug("Performing initial sync"),await jn(e,"initialSync","$jobs",(async()=>{(await e.getPersistedSyncState())?.initiallySynced||await an(e,t,n,{isInitialSync:!0})}),{awaitRemoteJob:!0}),console.debug("Done initial sync")}(r,r.cloud.options,r.cloud.schema),r.setInitiallySynced(!0));y(),Sn||(u.push(n((()=>r.getCurrentUser())).subscribe(s)),u.push(n((()=>r.getPersistedSyncState())).subscribe(r.cloud.persistedSyncState)),await f([s.pipe(Ke(1),We(1)),r.cloud.persistedSyncState.pipe(Ke(1),We(1))]).toPromise());r.cloud.options?.requireAuth&&await bn(r);p&&p.stop();p=null,y(),r.cloud.usingServiceWorker&&r.cloud.options?.databaseUrl?(Ze(r,"push").catch((()=>{})),async function(e){try{const{periodicSync:t}=await navigator.serviceWorker.ready;if(t)try{await t.register(`dexie-cloud:${e.name}`,e.cloud.options?.periodicSync),console.debug(`Dexie Cloud: Successfully registered periodicsync event for ${e.name}`)}catch(e){console.debug("Dexie Cloud: Failed to register periodic sync. Your PWA must be installed to allow background sync.",e)}else console.debug("Dexie Cloud: periodicSync not supported.")}catch(t){console.debug(`Dexie Cloud: Could not register periodicSync for ${e.name}`,t)}}(r).catch((()=>{}))):r.cloud.options?.databaseUrl&&r.cloud.schema&&!Sn&&(p=tr(r,r.cloud.options,r.cloud.schema),p.start(),Xe(r,"push"));y(),Sn||u.push(a(self,"online").subscribe((()=>{console.debug("online!"),r.syncStateChangedEvent.next({phase:"not-in-sync"}),Xe(r,"push")})),a(self,"offline").subscribe((()=>{console.debug("offline!"),r.syncStateChangedEvent.next({phase:"offline"})})));"undefined"!=typeof window&&!Sn&&r.cloud.options?.databaseUrl&&u.push(function(e){if(!e.cloud.options?.databaseUrl)throw new Error("No database URL to connect WebSocket to");const t=e.messageConsumer.readyToServe.pipe(He((e=>e)),ze((()=>e.getPersistedSyncState())),He((e=>e&&e.serverRevision)),De((e=>({type:"ready",rev:e.serverRevision}))));return function n(){return e.cloud.persistedSyncState.pipe(He((e=>e?.serverRevision)),We(1),ze((t=>e.cloud.currentUser.pipe(De((e=>[e,t]))))),ze((([e,t])=>Bn.pipe(De((n=>[n?e:null,t]))))),ze((async([e,t])=>[e,await tt(t)])),ze((([n,r])=>n?new Jn(e.cloud.options.databaseUrl,e.cloud.persistedSyncState.value.serverRevision,r,e.cloud.persistedSyncState.value.clientIdentity,t,e.cloud.webSocketStatus,n.accessToken,n.accessTokenExpiration):i([]))),Te((t=>"TokenExpiredError"===t?.name?(console.debug("WebSocket observable: Token expired. Refreshing token..."),c(!0).pipe(ze((async()=>{const t=await e.getCurrentUser(),n=await _t(e.cloud.options.databaseUrl,t);await e.table("$logins").update(t.userId,{accessToken:n.accessToken,accessTokenExpiration:n.accessTokenExpiration})})),ze((()=>n())))):d(t))),Te((t=>(e.cloud.webSocketStatus.next("error"),i(Zn(t)).pipe(ze((()=>n())))))))}().subscribe((t=>{t&&(console.debug("WS got message",t),e.messageConsumer.enqueue(t))}),(e=>{console.error("Oops! The main observable errored!",e)}),(()=>{console.error("Oops! The main observable completed!")}))}(r))}(t)}catch(e){console.error(e)}}),!0);let h=!1;function y(){if(h)throw new e.DatabaseClosedError}var m;!function(e,t){e.on.close.subscribe(t);const n=e.close;e.close=function(){n.call(this),t()}}(t,(()=>{u.forEach((e=>e.unsubscribe())),h=!0,p&&p.stop(),p=null,s.next(b)})),t.cloud={version:"4.0.0-beta.16",options:{...ho},schema:null,serverState:null,get currentUserId(){return s.value.userId||b.userId},currentUser:s,syncState:new o({phase:"initial",status:"not-started"}),persistedSyncState:new o(void 0),userInteraction:new o(void 0),webSocketStatus:new o("not-started"),async login(e){const n=hn(t);await n.cloud.sync(),await bn(n,e)},invites:po(t),roles:io(t),configure(e){e=t.cloud.options={...t.cloud.options,...e},l=!0,e.databaseUrl&&e.nameSuffix&&(t.name=`${r}-${function(e){const t=new URL(e);return"/"===t.pathname?t.hostname.split(".")[0]:t.pathname.split("/")[1]}(e.databaseUrl)}`,hn(t).reconfigure()),nr(t.cloud.schema,t.cloud.options)},async sync({wait:e,purpose:r}={wait:!0,purpose:"push"}){void 0===e&&(e=!0);const o=hn(t);if("pull"===r){const t=o.cloud.persistedSyncState.value;if(Xe(o,r),e){const e=await o.cloud.persistedSyncState.pipe(He((e=>null!=e?.timestamp&&(!t||e.timestamp>t.timestamp))),We(1)).toPromise();if(e?.error)throw new Error("Sync error: "+e.error)}}else if(await Xn(o)){const t=o.cloud.persistedSyncState.value;Xe(o,r),e&&(console.debug("db.cloud.login() is waiting for sync completion..."),await i(n((async()=>{const e=await Xn(o),n=await o.getPersistedSyncState();if(n?.timestamp!==t?.timestamp&&n?.error)throw new Error("Sync error: "+n.error);return e}))).pipe(He((e=>!e)),We(1)).toPromise(),console.debug("Done waiting for sync completion because we have nothing to push anymore"))}},permissions:(e,n)=>function(e,t,n){if(!t)throw new TypeError("Cannot check permissions of undefined or null. A Dexie Cloud object with realmId and owner expected.");const{owner:r,realmId:o}=t;if(!n){if("function"!=typeof t.table)throw new TypeError("Missing 'table' argument to permissions and table could not be extracted from entity");n=t.table()}const s=lo(e),i=t=>{const s=t[o||e.cloud.currentUserId];return s?new fo(s.permissions,n,o===e.cloud.currentUserId||r===e.cloud.currentUserId):new fo({},n,!r||r===e.cloud.currentUserId)},a=s.pipe(De(i));return a.getValue=()=>i(s.getValue()),a}(t._novip,e,n)},t.Version.prototype._parseStoresSpec=e.override(t.Version.prototype._parseStoresSpec,(e=>Nn(e,t))),t.Table.prototype.newId=function({colocateWith:e}={}){const n=e&&e.substr(e.length-3);return An(t.cloud.schema[this.name].idPrefix||"",n)},t.Table.prototype.idPrefix=function(){return this.db.cloud.schema?.[this.name]?.idPrefix||""},t.use(Rn({currentUserObservable:t.cloud.currentUser,db:hn(t)})),t.use((m=hn(t),{stack:"dbcore",name:"implicitPropSetterMiddleware",level:1,create:e=>({...e,table:t=>{const n=e.table(t);return{...n,mutate:e=>{if(e.trans.disableChangeTracking)return n.mutate(e);const r=e.trans;if(m.cloud.schema?.[t]?.markedForSync&&("add"===e.type||"put"===e.type))for(const t of e.values){t.owner||(t.owner=r.currentUser.userId),t.realmId||(t.realmId=r.currentUser.userId);const o=n.schema.primaryKey.extractKey?.(t);"string"==typeof o&&"#"===o[0]&&"put"===e.type&&(delete e.criteria,delete e.changeSpec,delete e.changeSpecs,t.$ts=Date.now())}return n.mutate(e)}}}})})),t.use(Pn(hn(t)))}yo.version="4.0.0-beta.16",e.Cloud=yo;const mo=new Map;function bo(e){return e.startsWith("dexie-cloud:")&&e.split(":")[1]}const vo=new Map;function go(t,n){let r=vo.get(t+"/"+n);return r||(r=async function(t,n){let r=mo.get(t);if(!r){console.debug("Dexie Cloud SW: Creating new Dexie instance for",t);const n=new e(t,{addons:[yo]});r=hn(n),n.on("versionchange",o),await r.dx.open(),mo.get(t)||mo.set(t,r)}if(!r.cloud.options?.databaseUrl)return void console.error("Dexie Cloud: No databaseUrl configured");if(!r.cloud.schema)return void console.error("Dexie Cloud: No schema persisted");function o(){return r.dx.on.versionchange.unsubscribe(o),mo.get(r.name)===r&&mo.delete(r.name),console.debug(`Dexie Cloud SW: Closing Dexie instance for ${t}`),r.dx.close(),!1}try{console.debug("Dexie Cloud SW: Syncing"),await er(r,r.cloud.options,r.cloud.schema,{retryImmediatelyOnFetchError:!0,purpose:n}),console.debug("Dexie Cloud SW: Done Syncing")}catch(t){if(console.error("Dexie Cloud SW Error",t),o(),t.name!==e.errnames.NoSuchDatabase)throw t}}(t,n).then((()=>{vo.delete(t+"/"+n)})).catch((e=>(vo.delete(t+"/"+n),Promise.reject(e)))),vo.set(t+"/"+n,r)),r}_n||(self.addEventListener("sync",(e=>{console.debug('SW "sync" Event',e.tag);const t=bo(e.tag);t&&e.waitUntil(go(t,"push"))})),self.addEventListener("periodicsync",(e=>{console.debug('SW "periodicsync" Event',e.tag);const t=bo(e.tag);t&&e.waitUntil(go(t,"pull"))})),self.addEventListener("message",(e=>{if(console.debug('SW "message" Event',e.data),"dexie-cloud-sync"===e.data.type){const{dbName:t}=e.data,n=(r=1)=>go(t,e.data.purpose||"pull").catch((async e=>{if(3===r)throw e;var t;await(t=6e4,new Promise((e=>setTimeout(e,t)))),n(r+1)}));"waitUntil"in e?e.waitUntil(n().catch((e=>console.error(e)))):n().catch((e=>console.error(e)))}})));