dexie-cloud-addon 4.0.1-beta.39 → 4.0.1-beta.40

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.
@@ -1,2 +1,2 @@
1
- import e,{cmp as t,liveQuery as n}from"dexie";import{Observable as r,BehaviorSubject as o,Subject as s,of as i,fromEvent as a,merge as c,Subscription as l,from as u,throwError as d,combineLatest as f,map as p,share as h,timer as y}from"rxjs";import{filter as m,take as v,switchMap as b,delay as g,distinctUntilChanged as _,map as w,tap as S,catchError as k,timeout as E,debounceTime as I,startWith as x,skip as C}from"rxjs/operators";function O(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())}))}const T={userId:"unauthorized",name:"Unauthorized",claims:{sub:"unauthorized"},lastLogin:new Date(0)};try{Object.freeze(T),Object.freeze(T.claims)}catch(e){}const A={},j="undefined"!=typeof self&&self.document&&"undefined"!=typeof navigator&&navigator.serviceWorker;j&&j.ready.then((e=>A.registration=e)),"undefined"!=typeof self&&"clients"in self&&!self.document&&addEventListener("message",(e=>{var t,n;(null===(n=null===(t=e.data)||void 0===t?void 0:t.type)||void 0===n?void 0:n.startsWith("sw-broadcast-"))&&[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>{var n;return t.id!==(null===(n=e.source)||void 0===n?void 0:n.id)&&t.postMessage(e.data)}))}));class ${constructor(e){this.name=e}subscribe(e){if(!j)return()=>{};const t=t=>{var n;(null===(n=t.data)||void 0===n?void 0:n.type)===`sw-broadcast-${this.name}`&&e(t.data.message)};return j.addEventListener("message",t),()=>j.removeEventListener("message",t)}postMessage(e){var t;"object"==typeof self.clients?[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))):A.registration&&(null===(t=A.registration.active)||void 0===t||t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))}}const P=globalThis["lbc-events"]||(globalThis["lbc-events"]=new Map);class U extends r{constructor(e){const t="undefined"==typeof BroadcastChannel?new $(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;!function(e,t){P.has(e)?P.get(e).push(t):P.set(e,[t])}(`lbc-${e}`,r);try{t instanceof $?s=t.subscribe((e=>n.next(e))):(console.debug("BroadcastedAndLocalEvent: bc.addEventListener()",e,"bc is a",t),t.addEventListener("message",o))}catch(e){console.warn("Failed to subscribe to broadcast channel",e)}return()=>{!function(e,t){const n=P.get(e);if(n){const e=n.indexOf(t);-1!==e&&n.splice(e,1)}}(`lbc-${e}`,r),t instanceof $?s():t.removeEventListener("message",o)}})),this.name=e,this.bc=t}next(e){console.debug("BroadcastedAndLocalEvent: bc.postMessage()",Object.assign({},e),"bc is a",this.bc),this.bc.postMessage(e);!function(e){const t=P.get(e.type);t&&t.forEach((t=>{try{t(e)}catch(e){}}))}(new CustomEvent(`lbc-${this.name}`,{detail:e}))}}let D=!1;function N(e,t){return O(this,void 0,void 0,(function*(){try{const n=yield navigator.serviceWorker.ready;if("push"===t&&n.sync&&(yield 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){D||(console.debug("Dexie Cloud: Could not register sync event",e),D=!0)}}))}function R(e,t){e.cloud.usingServiceWorker?N(e,t):e.localSyncEvent.next({purpose:t})}const L="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},W="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,ArrayBuffer.isView(e)?e:new Uint8Array(e)));function B({realms:e,inviteRealms:t}){return O(this,void 0,void 0,(function*(){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=yield crypto.subtle.digest("SHA-1",r);return W(o)}))}function M(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 F(e){return`$${e}_mutations`}function K(e){var t;const n=null===(t=/^\$(.*)_mutations$/.exec(e))||void 0===t?void 0:t[1];if(!n)throw new Error(`Given mutationTable ${e} is not correct`);return n}const H=[].concat;function V(e){return H.apply([],e)}function q(e,t,{since:n={},limit:r=1/0}={}){return O(this,void 0,void 0,(function*(){const t=V(yield Promise.all(e.map((e=>O(this,void 0,void 0,(function*(){const t=K(e.name),o=n[t];let s=o?e.where("rev").above(o):e;r<1/0&&(s=s.limit(r));return(yield s.toArray()).map((e=>({table:t,mut:e})))})))))).sort(((e,t)=>e.mut.ts-t.mut.ts)),o=[];let s=null,i=null;for(const{table:e,mut:n}of t)s&&s.table===e&&i===n.txid?s.muts.push(n):(s={table:e,muts:[n]},i=n.txid,o.push(s));return o}))}function J(e){const t=new Uint8Array(e);if("undefined"!=typeof crypto)crypto.getRandomValues(t);else for(let n=0;n<e;n++)t[n]=Math.floor(256*Math.random());if("undefined"!=typeof Buffer&&Buffer.from)return Buffer.from(t).toString("base64");if("undefined"!=typeof btoa)return btoa(String.fromCharCode.apply(null,t));throw new Error("No btoa or Buffer available")}function z(e){if(!e)throw new Error("Assertion Failed")}const G={}.hasOwnProperty;function Y(e,t,n){if(e&&void 0!==t&&(!("isFrozen"in Object)||!Object.isFrozen(e)))if("string"!=typeof t&&"length"in t){z("string"!=typeof n&&"length"in n);for(var r=0,o=t.length;r<o;++r)Y(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&&function(e,t){return G.call(e,t)}(e,i)||(c=e[i]={}),Y(c,a,n)}}else void 0===n?Array.isArray(e)&&!isNaN(parseInt(t))?e.splice(t,1):delete e[t]:e[t]=n}}const Z="undefined"!=typeof self&&"undefined"!=typeof crypto?(e,t=crypto.getRandomValues.bind(crypto))=>{const n=new Uint8Array(e);return t(n),self.btoa(String.fromCharCode.apply(null,n))}:"undefined"!=typeof Buffer?(e,t=X)=>{const n=Buffer.alloc(e);return t(n),n.toString("base64")}:()=>{throw new Error("No implementation of randomString was found")};function X(e){for(let t=0;t<e.length;++t)e[t]=Math.floor(256*Math.random())}function Q(e){return"string"==typeof e||!!(Array.isArray(e)&&e.some((e=>Q(e)))&&e.every(ee))}function ee(e){return"string"==typeof e||"number"==typeof e||Array.isArray(e)&&e.every(ee)}function te(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))Y(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 ne(e,t){for(const{table:n,muts:r}of t)for(const t of r)te(e,n,t)}function re(t,n){return new Promise(((r,o)=>{const s=Object.assign(Object.assign({},n),{onSubmit:e=>{t.next(void 0),r(e)},onCancel:()=>{t.next(void 0),o(new e.AbortError("User cancelled"))}});t.next(s)}))}function oe(e,t,...n){return re(e,{type:"message-alert",title:t,alerts:n,fields:{}})}function se(e,t,n){return O(this,void 0,void 0,(function*(){let r=n||"";for(;!r||!/^[\w-\.]+@([\w-]+\.)+[\w-]{2,10}$/.test(r);)r=(yield re(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}))}function ie(e,t,n){return O(this,void 0,void 0,(function*(){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}=yield re(e,{type:"otp",title:"Enter OTP",alerts:r,fields:{otp:{type:"otp",label:"OTP",placeholder:"Paste OTP here"}}});return o}))}function ae(e,t,n,r,o){return O(this,void 0,void 0,(function*(){return t.accessToken&&t.accessTokenExpiration.getTime()>Date.now()?t:t.refreshToken&&(!t.refreshTokenExpiration||t.refreshTokenExpiration.getTime()>Date.now())?yield ce(e,t):yield function(e,t,n,r){return O(this,void 0,void 0,(function*(){if(!crypto.subtle)throw"undefined"!=typeof location&&"http:"===location.protocol?new Error("Dexie Cloud Addon needs to use WebCrypto, but your browser has disabled it due to being served from an insecure location. Please serve it from https or http://localhost:<port> (See https://stackoverflow.com/questions/46670556/how-to-enable-crypto-subtle-for-unsecure-origins-in-chrome/46671627#46671627)"):new Error("This browser does not support WebCrypto.");const{privateKey:o,publicKey:s}=yield 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=W(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)}(yield crypto.subtle.exportKey("spki",s));e.publicKey=s;try{const o=yield 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&&(yield re(n,{type:"message-alert",title:"Authentication Alert",fields:{},alerts:o.alerts})),e}catch(e){throw yield oe(n,"Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:"We're having a problem authenticating right now.",messageParams:{}}).catch((()=>{})),e}}))}(t,n,r,o)}))}function ce(e,t){return O(this,void 0,void 0,(function*(){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=yield crypto.subtle.sign(r,t.nonExportablePrivateKey,o),i=W(s),a={grant_type:"refresh_token",refresh_token:t.refreshToken,scopes:["ACCESS_DB"],signature:i,signing_algorithm:r,time_stamp:n},c=yield 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 l=yield c.json();return t.accessToken=l.accessToken,t.accessTokenExpiration=l.accessTokenExpiration?new Date(l.accessTokenExpiration):void 0,t}))}const{toString:le}={};const ue={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 de(...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 ue;let s=n.get(r);if(void 0!==s)return s;const i=(o=e,le.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:ue),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 fe={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 pe={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 he={bigint:{replace:e=>({$t:"bigint",v:""+e}),revive:e=>BigInt(e.v)}};var ye={Date:{replace:e=>({$t:"Date",v:isNaN(e.getTime())?"NaN":e.toISOString()}),revive:({v:e})=>new Date("NaN"===e?NaN:Date.parse(e))}},me={Set:{replace:e=>({$t:"Set",v:Array.from(e.entries())}),revive:({v:e})=>new Set(e)}},ve={Map:{replace:e=>({$t:"Map",v:Array.from(e.entries())}),revive:({v:e})=>new Map(e)}};const be="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"==typeof global?global:void 0;var ge=["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=be[t];return o&&new o(r.ArrayBuffer.revive({v:e},n,r))}}})),{});function _e(e){return function(e){for(var t="",n=0,r=e.length;n<r;n++)t+=ke[e[n]];return t}(W(e))}function we(e){return L(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+=Se[e[n]];return t}(e))}const Se={"-":"=",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:"+","|":"/"},ke={};for(const e of Object.keys(Se))ke[Se[e]]=e;var Ee={ArrayBuffer:{replace:e=>({$t:"ArrayBuffer",v:_e(e)}),revive:({v:e})=>{const t=we(e);return t.buffer.byteLength===t.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength)}}};class Ie{constructor(e,t){this.buf=e,this.type=t}}function xe(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 Ce(e){const t=new Uint8Array(e.length);for(let n=0;n<e.length;++n)t[n]=e.charCodeAt(n);return t.buffer}var Oe={Blob:{test:(e,t)=>"Blob"===t||e instanceof Ie,replace:e=>({$t:"Blob",v:W(e instanceof Ie?e.buf:Ce(xe(e))),type:e.type}),revive:({type:e,v:t})=>{const n=L(t);return void 0!==typeof Blob?new Blob([n]):new Ie(n.buffer,e)}}};const Te={...pe,...he,...ye,...me,...ve,...ge,...Ee,...Oe};function Ae(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 je={undefined:{replace:()=>({$t:"undefined"}),revive:()=>{}}};const $e="function"==typeof BigInt&&"bigint"==typeof BigInt(0);class Pe{toString(){return this.v}constructor(e){this.v=e}}const Ue=Object.assign(Object.assign({},je),$e?{}:{bigint:{test:e=>e instanceof Pe,replace:e=>Object.assign({$t:"bigint"},e),revive:({v:e})=>new Pe(e)}}),De=de(Te,Ue),Ne=function(...e){const t=de(Te,fe,...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 Ae(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 Ae(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)}}}(Ue);class Re extends Error{constructor(e,t){super(t||`${e.status} ${e.statusText}`),this.httpStatus=e.status}get name(){return"HttpError"}}function Le(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 l=s;i.forEach(((t,r)=>{const o=!c.outbound&&("upsert"===t.type||"insert"===t.type);t.keys.forEach(((t,i)=>{if(Array.isArray(t)){l===s&&(l=We(s,o));const n=l.muts[r],a=JSON.stringify(t);n.keys[i]=a,o&&e.setByKeyPath(n.values[i],c.keyPath,a)}else if("#"===t[0]){l===s&&(l=We(s,o));const a=l.muts[r];if(!n.isLoggedIn)throw new Error("Internal error: Cannot sync private IDs before authenticated");const u=`${t}:${n.userId}`;a.keys[i]=u,o&&e.setByKeyPath(a.values[i],c.keyPath,u)}}))})),o.push(l)}return o}function We(e,t){return Object.assign(Object.assign({},e),{muts:t?e.muts.map((e=>"insert"!==e.type&&"upsert"!==e.type||!e.values?Object.assign(Object.assign({},e),{keys:e.keys.slice()}):Object.assign(Object.assign({},e),{keys:e.keys.slice(),values:e.values.slice()}))):e.muts.map((e=>Object.assign(Object.assign({},e),{keys:e.keys.slice()})))})}function Be(e,t,n,r,o,s,i,a){return O(this,void 0,void 0,(function*(){const c={Accept:"application/json, application/x-bison, application/x-bison-stream","Content-Type":"application/tson"},l=yield function(e){var t,n;return O(this,void 0,void 0,(function*(){const r=yield e.getCurrentUser(),{accessToken:o,accessTokenExpiration:s,refreshToken:i,refreshTokenExpiration:a,claims:c}=r;if(!o)return;if((null!==(t=null==s?void 0:s.getTime())&&void 0!==t?t:1/0)>Date.now())return o;if(!i)throw new Error("Refresh token missing");if((null!==(n=null==a?void 0:a.getTime())&&void 0!==n?n:1/0)<=Date.now())throw new Error("Refresh token has expired");const l=yield ce(e.cloud.options.databaseUrl,r);return yield e.table("$logins").update(c.sub,{accessToken:l.accessToken,accessTokenExpiration:l.accessTokenExpiration}),l.accessToken}))}(r);l&&(c.Authorization=`Bearer ${l}`);const u={v:2,dbID:null==t?void 0:t.remoteDbId,clientIdentity:i,schema:s||{},lastPull:t?{serverRevision:t.serverRevision,realms:t.realms,inviteRealms:t.inviteRealms}:void 0,baseRevs:n,changes:Le(r.dx.core.schema,a,e)};console.debug("Sync request",u),r.syncStateChangedEvent.next({phase:"pushing"});const d=yield fetch(`${o}/sync`,{method:"post",headers:c,body:De.stringify(u)});if(r.syncStateChangedEvent.next({phase:"pulling"}),!d.ok)throw new Re(d);if("application/x-bison"===d.headers.get("content-type"))return Ne.fromBinary(yield d.blob());{const e=yield d.text();return De.parse(e)}}))}function Me(t){if(null==t?void 0:t.cancelled)throw new e.AbortError("Operation was cancelled")}let Fe=!1;function Ke(e,t,n,r){return O(this,void 0,void 0,(function*(){yield e.$baseRevs.bulkPut(Object.keys(t).filter((e=>t[e].markedForSync)).map((e=>({tableName:e,clientRev:(n[e]||0)+1,serverRev:r}))))}))}function He(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}function Ve(n,r,o){return O(this,void 0,void 0,(function*(){const s=yield n.bulkGet(r),i=[],a=[];r.forEach(((r,c)=>{const l=s[c];if(l){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(l,s,i);i.push(r),a.push(l)}})),yield null==n.schema.primKey.keyPath?n.bulkPut(a,i):n.bulkPut(a)}))}function qe(t,n){return O(this,void 0,void 0,(function*(){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(e){}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?yield t.bulkAdd(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),yield t.bulkAdd(n.values));break;case"upsert":s.outbound?yield t.bulkPut(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),yield t.bulkPut(n.values));break;case"modify":1===r.length?yield t.update(r[0],n.changeSpec):yield t.where(":id").anyOf(r).modify(n.changeSpec);break;case"update":yield Ve(t,r,n.changeSpecs);break;case"delete":yield t.bulkDelete(r)}}}}))}"undefined"!=typeof self&&"undefined"!=typeof navigator&&(Fe=navigator.onLine,self.addEventListener("online",(()=>Fe=!0)),self.addEventListener("offline",(()=>Fe=!1)));function Je(e,t,n,r){return ze.apply(this,arguments).then((()=>{(null==r?void 0:r.justCheckIfNeeded)||e.syncStateChangedEvent.next({phase:"in-sync"})})).catch((o=>O(this,void 0,void 0,(function*(){return(null==r?void 0:r.justCheckIfNeeded)?Promise.reject(o):(console.debug("Error from _sync",{isOnline:Fe,syncOptions:r,error:o}),Fe&&(null==r?void 0:r.retryImmediatelyOnFetchError)&&"TypeError"===(null==o?void 0:o.name)&&/fetch/.test(null==o?void 0:o.message)?(e.syncStateChangedEvent.next({phase:"error",error:o}),yield new Promise((e=>setTimeout(e,500))),yield Je(e,t,n,Object.assign(Object.assign({},r),{retryImmediatelyOnFetchError:!1}))):(yield e.$syncState.update("syncState",{timestamp:new Date,error:""+o}),e.syncStateChangedEvent.next({phase:Fe?"error":"offline",error:o}),Promise.reject(o)))}))))}function ze(e,t,n,{isInitialSync:r,cancelToken:o,justCheckIfNeeded:s,purpose:i}={isInitialSync:!1}){var a;return O(this,void 0,void 0,(function*(){if(s||console.debug("SYNC STARTED",{isInitialSync:r,purpose:i}),!(null===(a=e.cloud.options)||void 0===a?void 0:a.databaseUrl))throw new Error("Internal error: sync must not be called when no databaseUrl is configured");const{databaseUrl:c}=t,l=yield e.getCurrentUser(),u=l.isLoggedIn?M(e):[],d=u.map((t=>e.table(F(t.name)))),f=yield e.getPersistedSyncState(),p=!r&&l.isLoggedIn,h=p?function(e,t){const n=(null==t?void 0:t.syncedTables)||[];return M(e).filter((e=>!n.includes(e.name)))}(e,f):[];Me(o);const y=h.length>0;if(y){if(s)return!0;yield e.transaction("rw",h,(e=>O(this,void 0,void 0,(function*(){e.idbtrans.disableChangeTracking=!0,e.idbtrans.disableAccessControl=!0,yield function(e,t,n){return O(this,void 0,void 0,(function*(){const r=new Set(n||[]);for(const n of e)"members"===n.name?yield n.toCollection().modify((e=>{r.has(e.realmId)||e.userId&&e.userId!==T.userId||(e.userId=t.userId)})):"roles"===n.name||("realms"===n.name?yield n.toCollection().modify((e=>{r.has(e.realmId)||void 0!==e.owner&&e.owner!==T.userId||(e.owner=t.userId)})):yield n.toCollection().modify((e=>{e.realmId&&r.has(e.realmId)||(e.owner&&e.owner!==T.userId||(e.owner=t.userId),e.realmId&&e.realmId!==T.userId||(e.realmId=t.userId))})))}))}(h,l,null==f?void 0:f.realms)})))),Me(o)}const[m,v,b]=yield e.transaction("r",e.tables,(()=>O(this,void 0,void 0,(function*(){const t=yield e.getPersistedSyncState(),r=yield e.$baseRevs.toArray();let s=yield q(d);if(Me(o),y){const e=[...(null==f?void 0:f.realms)||[],...(null==f?void 0:f.inviteRealms)||[]],i=yield function(e,t,n,r){return O(this,void 0,void 0,(function*(){const o=`upload-${J(8)}`;if(t.isLoggedIn&&e.length>0){const s=new Set(r||[]);return(yield Promise.all(e.map((e=>O(this,void 0,void 0,(function*(){const{extractKey:r}=e.core.schema.primaryKey;if(!r)return{table:e.name,muts:[]};const i=n[e.name],a=(null==i?void 0:i.generatedGlobalId)?e.filter((e=>{return r(e),!s.has(e.realmId||"")&&(t=r(e),!(n=null==i?void 0:i.idPrefix)||"string"==typeof t&&t.startsWith(n));var t,n})):e.filter((e=>{const t=r(e);return!s.has(e.realmId||"")&&Q(t)})),c=yield 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[]}))}(h,l,n,e);return Me(o),s=s.concat(i),[s,t,r]}return[s,t,r]})))),g=m.some((e=>e.muts.some((e=>e.keys.length>0))));if(s)return console.debug("Sync is needed:",g),g;if("push"===i&&!g)return!1;const _=He(m,null==v?void 0:v.latestRevisions),w=(null==v?void 0:v.clientIdentity)||Z(16);Me(o);const S=yield Be(m,v,b,e,c,n,w,l);console.debug("Sync response",S);const k=yield e.transaction("rw",e.tables,(t=>O(this,void 0,void 0,(function*(){t.idbtrans.disableChangeTracking=!0,t.idbtrans.disableAccessControl=!0;for(const e of Object.keys(n))S.schema[e]&&(n[e]=S.schema[e]);yield e.$syncState.put(n,"schema");const r=yield q(d,0,{since:_});for(const t of d){const n=K(t.name);if(r.some((e=>e.table===n&&e.muts.length>0))){if(_[n]){const r=_[n]||0;yield 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 yield Promise.all([t.clear(),e.$baseRevs.where({tableName:n}).delete()])}He(r,_),yield Ke(e,n,_,S.serverRevision);const o=yield e.getPersistedSyncState();yield function(e,t,n){return O(this,void 0,void 0,(function*(){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=M(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]))?yield e.where("realmId").anyOf([...t]).delete():yield e.filter((e=>!!(null==e?void 0:e.realmId)&&t.has(e.realmId))).delete())}}}))}(e,S,o);const s=o||{syncedTables:[],latestRevisions:{},realms:[],inviteRealms:[],clientIdentity:w};p&&(s.syncedTables=u.map((e=>e.name)).concat(h.map((e=>e.name)))),s.latestRevisions=_,s.remoteDbId=S.dbId,s.initiallySynced=!0,s.realms=S.realms,s.inviteRealms=S.inviteRealms,s.serverRevision=S.serverRevision,s.timestamp=new Date,delete s.error;const i=Ge(S.changes,r);return yield qe(i,e),e.$syncState.put(s,"syncState"),0===r.length}))));return k?(console.debug("SYNC DONE",{isInitialSync:r}),e.syncCompleteEvent.next(),!1):(console.debug("MORE SYNC NEEDED. Go for it again!"),yield ze(e,t,n,{isInitialSync:r,cancelToken:o}))}))}function Ge(e,t){const n={};ne(n,e);const r={};return ne(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))Y(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,t=""){t||(t=Z(16));const 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 Ye(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((()=>O(this,void 0,void 0,(function*(){if(!i&&n.length>0){i=!0,c.shift(),c.push(Date.now()),r.next(!1);try{yield function(){var r,o,s;return O(this,void 0,void 0,(function*(){for(;n.length>0;){const i=n.shift();try{yield t.cloud.syncState.pipe(m((({phase:e})=>"in-sync"===e||"error"===e)),v(1)).toPromise(),console.debug("processing msg",i);const n=t.cloud.persistedSyncState.value;if(!i)continue;switch(i.type){case"token-expired":console.debug("WebSocket observable: Token expired. Refreshing token...");const a=t.cloud.currentUser.value,c=yield ce(t.cloud.options.databaseUrl,a);yield t.table("$logins").update(a.userId,{accessToken:c.accessToken,accessTokenExpiration:c.accessTokenExpiration});break;case"realm-added":case"realm-accepted":case"realms-changed":R(t,"pull");break;case"realm-removed":(null===(r=null==n?void 0:n.realms)||void 0===r?void 0:r.includes(i.realm))||null===(o=null==n?void 0:n.inviteRealms)||void 0===o||o.includes(i.realm),R(t,"pull");break;case"changes":if(console.debug("changes"),"error"===(null===(s=t.cloud.syncState.value)||void 0===s?void 0:s.phase)){R(t,"pull");break}yield t.transaction("rw",t.dx.tables,(n=>O(this,void 0,void 0,(function*(){n.idbtrans.disableChangeTracking=!0,n.idbtrans.disableAccessControl=!0;const[r,o,s]=yield Promise.all([t.getSchema(),t.getPersistedSyncState(),t.getCurrentUser()]);if(console.debug("ws message queue: in transaction"),!o||!r||!s)return void console.debug("required vars not present",{syncState:o,schema:r,currentUser:s});if(i.baseRev!==o.serverRevision)return console.debug(`baseRev (${i.baseRev}) differs from our serverRevision in syncState (${o.serverRevision})`),void("string"!=typeof i.baseRev||"bigint"!=typeof o.serverRevision&&"object"!=typeof o.serverRevision||R(t,"pull"));const a=yield e.waitFor(B(o));if(console.debug("ourRealmSetHash",a),a!==i.realmSetHash)return console.debug("not same realmSetHash",i.realmSetHash),void R(t,"pull");let c=[];if(s.isLoggedIn){const e=M(t).map((e=>t.table(F(e.name))));c=yield q(e),console.debug("msg queue: client changes",c)}if(i.changes.length>0){const e=Ge(i.changes,c);console.debug("applying filtered server changes",e),yield qe(e,t)}o.latestRevisions=He(c,o.latestRevisions),o.serverRevision=i.newRev,console.debug("Updating baseRefs",o.latestRevisions),yield Ke(t,r,o.latestRevisions,i.newRev),console.debug("Updating syncState",o),yield t.$syncState.put(o,"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,yield new Promise((e=>setTimeout(e,6e4)))):(console.warn("Slowing down websocket loop for 10 seconds"),a=Date.now()+1e4,yield new Promise((e=>setTimeout(e,1e4))))),i=!1,r.next(!0)}}})))),{enqueue:function(e){n.push(e),s.next(null)},readyToServe:r}}const Ze=new WeakMap,Xe={members:"@id, [userId+realmId], [email+realmId], realmId",roles:"[realmId+name]",realms:"@realmId",$jobs:"",$syncState:"",$baseRevs:"[tableName+clientRev]",$logins:"claims.sub, lastLogin"};let Qe=0;function et(e){"vip"in e&&(e=e.vip);let t=Ze.get(e.cloud);if(!t){const n=new s;let r=new U(`syncstatechanged-${e.name}`),o=new U(`synccomplete-${e.name}`);n.id=++Qe;let i=!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 i},localSyncEvent:n,get syncStateChangedEvent(){return r},get syncCompleteEvent(){return o},dx:e};const a={getCurrentUser:()=>t.$logins.toArray().then((e=>e.find((e=>e.isLoggedIn))||T)),getPersistedSyncState:()=>t.$syncState.get("syncState"),getSchema:()=>t.$syncState.get("schema").then((e=>{if(e)for(const r of t.tables)r.schema.primKey&&r.schema.primKey.keyPath&&e[r.name]&&(e[r.name].primaryKey="string"==typeof(n=r.schema.primKey.keyPath)?n:n?"["+[].join.call(n,"+")+"]":"");var n;return e})),getOptions:()=>t.$syncState.get("options"),setInitiallySynced(e){i=e},reconfigure(){r=new U(`syncstatechanged-${e.name}`),o=new U(`synccomplete-${e.name}`)}};Object.assign(t,a),t.messageConsumer=Ye(t),Ze.set(e.cloud,t)}return t}const tt=new WeakMap;class nt{constructor(e,t){tt.set(this,e),Object.assign(this,t)}static load(e,t){return e.table("$logins").get(t).then((n=>new nt(e,n||{userId:t,claims:{sub:t},lastLogin:new Date(0)})))}save(){return O(this,void 0,void 0,(function*(){tt.get(this).table("$logins").put(this)}))}}function rt(e,t){return O(this,void 0,void 0,(function*(){if((yield 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!1}const n=new nt(e,{claims:{},lastLogin:new Date(0)});yield ae(e.cloud.options.databaseUrl,n,e.cloud.options.fetchTokens||function(e){const{userInteraction:t}=e.cloud;return function({public_key:n,hints:r}){var o;return O(this,void 0,void 0,(function*(){let s;const i=null===(o=e.cloud.options)||void 0===o?void 0:o.databaseUrl;if(!i)throw new Error("No database URL given.");s="demo"===(null==r?void 0:r.grant_type)?{demo_user:yield se(t,"Enter a demo user email",(null==r?void 0:r.email)||(null==r?void 0:r.userId)),grant_type:"demo",scopes:["ACCESS_DB"],public_key:n}:{email:yield se(t,"Enter email address",null==r?void 0:r.email),grant_type:"otp",scopes:["ACCESS_DB"],public_key:n};const a=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json",mode:"cors"}});if(200!==a.status){const e=yield a.text();throw yield oe(t,"Token request failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Re(a,e)}const c=yield a.json();if("tokens"===c.type)return c;if("otp"===s.grant_type){if("otp-sent"!==c.type)throw new Error(`Unexpected response from ${i}/token`);const e=yield ie(t,s.email);s.otp=e||"",s.otp_id=c.otp_id;let n=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});for(;401===n.status;){const e=yield n.text();s.otp=yield ie(t,s.email,{type:"error",messageCode:"INVALID_OTP",message:e,messageParams:{}}),n=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"})}if(200!==n.status){const e=yield n.text();throw yield oe(t,"OTP Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Re(n,e)}return yield n.json()}throw new Error(`Unexpected response from ${i}/token`)}))}}(e),e.cloud.userInteraction,t);try{yield n.save()}catch(e){try{"DataCloneError"===e.name&&(console.debug("Login context property names:",Object.keys(n)),console.debug("Login context:",n),console.debug("Login context JSON:",JSON.stringify(n)))}catch(e){}throw e}return yield function(e,t){return O(this,void 0,void 0,(function*(){if(t.userId===e.cloud.currentUserId)return;const n=e.table("$logins");yield e.transaction("rw",n,(e=>O(this,void 0,void 0,(function*(){const e=yield n.toArray();yield Promise.all(e.filter((e=>e.userId!==t.userId&&e.isLoggedIn)).map((e=>(e.isLoggedIn=!1,n.put(e))))),t.isLoggedIn=!0,t.lastLogin=new Date,yield t.save(),console.debug("Saved new user",t.email)})))),yield 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),R(e,"pull"),!0}))}const ot="undefined"!=typeof InstallTrigger,st="undefined"!=typeof navigator&&/Safari\//.test(navigator.userAgent)&&!/Chrom(e|ium)\/|Edge\//.test(navigator.userAgent),it=st?[].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1]:NaN,at=st&&it<=605||ot;const ct="undefined"!=typeof self&&"clients"in self&&!self.document;function lt(){throw new e.SchemaError("Version increment needed to allow dexie-cloud change tracking")}const{toString:ut}={};function dt(e){return ut.call(e).slice(8,-1)}function ft(e,t){var n;return"delete"===t.type?t.keys:(null===(n=t.keys)||void 0===n?void 0:n.slice())||t.values.map(e.extractKey)}const pt=/b|c|d|f|g|h|j|k|l|m|n|p|q|r|s|t|v|x|y|z/i;let ht=0;function yt(e,t){const n=new Uint8Array(18),r=new Uint8Array(n.buffer,0,6),o=Date.now();ht>=o?++ht:ht=o,r[0]=ht/1099511627776,r[1]=ht/4294967296,r[2]=ht/16777216,r[3]=ht/65536,r[4]=ht/256,r[5]=ht;const s=new Uint8Array(n.buffer,6);crypto.getRandomValues(s);return e+_e(new Uint8Array(n.buffer))+(t||"")}function mt(t){return{stack:"dbcore",name:"idGenerationMiddleware",level:1,create:n=>Object.assign(Object.assign({},n),{table:r=>{const o=n.table(r);return Object.assign(Object.assign({},o),{mutate:n=>{var s,i;if(n.trans.disableChangeTracking)return o.mutate(n);if("add"===n.type||"put"===n.type){const a=null===(s=t.cloud.schema)||void 0===s?void 0:s[r];if(null==a?void 0:a.generatedGlobalId){if((null===(i=t.cloud.options)||void 0===i?void 0:i.databaseUrl)&&!t.initiallySynced){const e=ft(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=ft(o.schema.primaryKey,n);return a.forEach(((c,l)=>{if(void 0===c){const r=n.values[l].realmId||t.cloud.currentUserId,c=r.substr(r.length-3);a[l]=yt(s,c),o.schema.primaryKey.outbound||(i||(i=n.values.slice()),i[l]=e.deepClone(i[l]),e.setByKeyPath(i[l],o.schema.primaryKey.keyPath,a[l]))}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(Object.assign(Object.assign({},n),{keys:a,values:i||n.values}))}(n,a.idPrefix)}if(null==a?void 0:a.markedForSync){ft(o.schema.primaryKey,n).forEach(((t,n)=>{if(!Q(t)){const n=Array.isArray(t)?t.map(dt).join(","):dt(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 vt=0;function bt(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 gt(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 _t=new o(new Set);function wt({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(e){lt()}return Object.assign(Object.assign({},n),{transaction:(r,o)=>{let s;if("readwrite"===o){const e=r.filter((e=>{var n,r;return null===(r=null===(n=t.cloud.schema)||void 0===n?void 0:n[e])||void 0===r?void 0:r.markedForSync})).map((e=>F(e)));s=n.transaction([...r,...e],o)}else s=n.transaction(r,o);if("readwrite"===o){s.txid=J(16),s.currentUser=e.value,_t.value.add(s),_t.next(_t.value);const n=()=>{s.removeEventListener("complete",r),s.removeEventListener("error",n),s.removeEventListener("abort",n),_t.value.delete(s),_t.next(_t.value)},r=()=>{var e;s.mutationsAdded&&(null===(e=t.cloud.options)||void 0===e?void 0:e.databaseUrl)&&(t.cloud.usingServiceWorker?(console.debug("registering sync event"),N(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")?Object.assign(Object.assign({},r),{mutate:e=>("add"!==e.type&&"put"!==e.type||(e.trans.mutationsAdded=!0),r.mutate(e))}):"$logins"===e?Object.assign(Object.assign({},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"+ ++vt;return Object.assign(Object.assign({},e),{count:bt(e.count,t),get:bt(e.get,t),getMany:bt(e.getMany,t),openCursor:bt(e.openCursor,t),query:bt(e.query,t),mutate:gt(e.mutate,t)})}(Object.assign(Object.assign({},r),{mutate:n=>{var o,i,c;const l=n.trans;return l.txid?l.disableChangeTracking?r.mutate(n):(null===(i=null===(o=t.cloud.schema)||void 0===o?void 0:o[e])||void 0===i?void 0:i.markedForSync)&&(null===(c=l.currentUser)||void 0===c?void 0:c.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 l="delete"===s?e.keys:r.results,u="values"in e?e.values:[],d="updates"in e&&e.updates;a&&(l=l.filter(((e,t)=>!c[t])),u=u.filter(((e,t)=>!c[t])));const f=Date.now(),p="delete"===e.type?{type:"delete",ts:f,keys:l,criteria:e.criteria,txid:n,userId:o}:"add"===e.type?{type:"insert",ts:f,keys:l,txid:n,userId:o,values:u}:e.criteria&&e.changeSpec?{type:"modify",ts:f,keys:l,criteria:e.criteria,changeSpec:e.changeSpec,txid:n,userId:o}:d?{type:"update",ts:f,keys:d.keys,changeSpecs:d.changeSpecs,txid:n,userId:o}:{type:"upsert",ts:f,keys:l,values:u,txid:n,userId:o};return l.length>0||"criteria"in e&&e.criteria?i.mutate({type:"add",trans:t,values:[p]}).then((()=>r)):r}))}}})}}}function St(e,t){return function(n,r){const o=Object.assign(Object.assign({},Xe),n);Object.keys(Xe).forEach((e=>{const t=o[e];if(null==t)throw new Error(`Cannot delete table ${e} as it is needed for access control of Dexie Cloud`);if(!n[e])return;const r=t.split(",").map((e=>e.trim())),s=Xe[e].split(",").map((e=>e.trim())),i=new Set(r.map((e=>e.replace(/([&*]|\+\+)/g,""))));if(r[0]!==s[0])throw new Error(`Cannot override primary key of table ${e}. Please declare it as {${e}: ${JSON.stringify(Xe[e])}`);for(let t=1;t<s.length;++t){const n=s[t];i.has(n.replace(/([&*]|\+\+)/g,""))||(o[e]+=`,${n}`)}}));const 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)(pt.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 kt=new o(!0),Et=new o(!0);kt.pipe(b((e=>e?i(!0):i(!1).pipe(g(2e4)))),_()).subscribe(Et);const It="undefined"!=typeof document?a(document,"visibilitychange"):i({}),xt=It.pipe(m((()=>"hidden"===document.visibilityState))),Ct=It.pipe(m((()=>"visible"===document.visibilityState))),Ot="undefined"!=typeof window?c(Ct,a(window,"mousedown"),a(window,"mousemove"),a(window,"keydown"),a(window,"wheel"),a(window,"touchmove")):i({});"undefined"!=typeof document&&c(i(!0),xt,Ot).pipe(w((()=>"visible"===document.visibilityState)),S((e=>{kt.value!==e&&kt.next(e)})),b((e=>e?i(0).pipe(g(16e4),S((()=>kt.next(!1)))):i(0)))).subscribe((()=>{}));class Tt extends Error{constructor(){super(...arguments),this.name="TokenExpiredError"}}class At extends r{constructor(e,t,n,r,o,s,i,a){super((c=>new $t(e,t,n,r,i,a,c,o,s)))}}let jt=0;class $t extends l{constructor(e,t,n,r,o,s,i,a,c){super((()=>this.teardown())),this.id=++jt,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(e){}this.ws=null,this.messageProducerSubscription&&(this.messageProducerSubscription.unsubscribe(),this.messageProducerSubscription=null)}reconnect(){if(!this.reconnecting){this.reconnecting=!0;try{this.disconnect()}catch(e){}this.connect().catch((()=>{})).then((()=>this.reconnecting=!1))}}connect(){return O(this,void 0,void 0,(function*(){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 Tt);this.webSocketStatus.next("connecting"),this.pinger=setInterval((()=>O(this,void 0,void 0,(function*(){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(e){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=De.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;yield 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=>{var t;this.closed||("ready"===e.type&&"connected"!==this.webSocketStatus.value&&this.webSocketStatus.next("connected"),null===(t=this.ws)||void 0===t||t.send(De.stringify(e)))}))}catch(e){this.pauseUntil=new Date(Date.now()+6e4)}}))}}function Pt(e){return O(this,void 0,void 0,(function*(){var t;console.error("WebSocket observable: error but revive when user does some active thing...",e),yield(t=3e3,new Promise((e=>setTimeout(e,t)))),console.debug("waiting for someone to do something"),yield Ot.pipe(v(1)).toPromise(),console.debug("someone did something!")}))}function Ut(e){var t;return O(this,void 0,void 0,(function*(){return!(!(null===(t=e.cloud.options)||void 0===t?void 0:t.databaseUrl)||!e.cloud.schema)&&(yield Je(e,e.cloud.options,e.cloud.schema,{justCheckIfNeeded:!0}))}))}const Dt=J(16);const Nt=new WeakMap;function Rt(e,t,r,o){const s=Nt.get(e);if(s){if(s.pull||"push"===(null==o?void 0:o.purpose))return console.debug("syncIfPossible(): returning the ongoing sync promise."),s.promise;{let n=!1;const i=e.cloud.syncState.subscribe((e=>{"pulling"===e.phase&&(n=!0)}));return s.promise.then((()=>{i.unsubscribe()})).catch((e=>(i.unsubscribe(),Promise.reject(e)))).then((()=>{if(!n)return Rt(e,t,r,o)}))}}const i=function(){return O(this,void 0,void 0,(function*(){try{if(e.cloud.isServiceWorkerDB)yield Je(e,t,r,o);else{if(e.cloud.usingServiceWorker)throw z(!1),new Error("Internal _syncIfPossible() - invalid precondition - should not have been called.");yield function(e,t,r,o,{awaitRemoteJob:s}={}){return O(this,void 0,void 0,(function*(){const i=e.table(r);if(yield function o(){return O(this,void 0,void 0,(function*(){if(yield e.transaction("rw!",r,(()=>O(this,void 0,void 0,(function*(){const e=yield i.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!"),yield i.put({nodeId:Dt,started:new Date,heartbeat:new Date},t),!0):(yield i.add({nodeId:Dt,started:new Date,heartbeat:new Date},t),!0)})))))return!0;if(s)try{const e=u(n((()=>i.get(t)))).pipe(E(6e4),m((e=>!e)));return yield e.toPromise(),!1}catch(e){if("TimeoutError"!==e.name)throw e;return yield o()}return!1}))}()){const n=setInterval((()=>{i.update(t,(e=>{e.nodeId===Dt&&(e.heartbeat=new Date)}))}),1e3);try{return yield o()}finally{clearInterval(n),yield e.transaction("rw!",r,(()=>O(this,void 0,void 0,(function*(){const e=yield i.get(t);e&&e.nodeId===Dt&&(yield i.delete(t))}))))}}}))}(e,"currentSyncWorker","$jobs",(()=>Je(e,t,r,o)))}Nt.delete(e),console.debug("Done sync")}catch(t){throw Nt.delete(e),console.error("Failed to sync client changes",t),t}}))}();return Nt.set(e,{promise:i,pull:"push"!==(null==o?void 0:o.purpose)}),i}function Lt(e,t,n){let r=null,o={cancelled:!1};function s(r,a=1){setTimeout((()=>{Rt(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 Wt(e,t){if(e&&t&&t.unsyncedTables)for(const n of t.unsyncedTables)e[n]&&(e[n].markedForSync=!1)}var Bt,Mt,Ft,Kt,Ht,Vt={},qt=[],Jt=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;function zt(e,t){for(var n in t)e[n]=t[n];return e}function Gt(e){var t=e.parentNode;t&&t.removeChild(e)}function Yt(e,t,n){var r,o,s,i={};for(s in t)"key"==s?r=t[s]:"ref"==s?o=t[s]:i[s]=t[s];if(arguments.length>2&&(i.children=arguments.length>3?Bt.call(arguments,2):n),"function"==typeof e&&null!=e.defaultProps)for(s in e.defaultProps)void 0===i[s]&&(i[s]=e.defaultProps[s]);return Zt(e,i,r,o,null)}function Zt(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?++Ft:o};return null==o&&null!=Mt.vnode&&Mt.vnode(s),s}function Xt(e){return e.children}function Qt(e,t){this.props=e,this.context=t}function en(e,t){if(null==t)return e.__?en(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?en(e):null}function tn(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 tn(e)}}function nn(e){(!e.__d&&(e.__d=!0)&&Kt.push(e)&&!rn.__r++||Ht!==Mt.debounceRendering)&&((Ht=Mt.debounceRendering)||setTimeout)(rn)}function rn(){for(var e;rn.__r=Kt.length;)e=Kt.sort((function(e,t){return e.__v.__b-t.__v.__b})),Kt=[],e.some((function(e){var t,n,r,o,s,i;e.__d&&(s=(o=(t=e).__v).__e,(i=t.__P)&&(n=[],(r=zt({},o)).__v=o.__v+1,fn(i,o,r,t.__n,void 0!==i.ownerSVGElement,null!=o.__h?[s]:null,n,null==s?en(o):s,o.__h),pn(n,o),o.__e!=s&&tn(o)))}))}function on(e,t,n,r,o,s,i,a,c,l){var u,d,f,p,h,y,m,v=r&&r.__k||qt,b=v.length;for(n.__k=[],u=0;u<t.length;u++)if(null!=(p=n.__k[u]=null==(p=t[u])||"boolean"==typeof p?null:"string"==typeof p||"number"==typeof p||"bigint"==typeof p?Zt(null,p,null,null,p):Array.isArray(p)?Zt(Xt,{children:p},null,null,null):p.__b>0?Zt(p.type,p.props,p.key,null,p.__v):p)){if(p.__=n,p.__b=n.__b+1,null===(f=v[u])||f&&p.key==f.key&&p.type===f.type)v[u]=void 0;else for(d=0;d<b;d++){if((f=v[d])&&p.key==f.key&&p.type===f.type){v[d]=void 0;break}f=null}fn(e,p,f=f||Vt,o,s,i,a,c,l),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&&p.__k===f.__k?p.__d=c=sn(p,c,e):c=an(e,p,f,v,h,c),"function"==typeof n.type&&(n.__d=c)):c&&f.__e==c&&c.parentNode!=e&&(c=en(f))}for(n.__e=y,u=b;u--;)null!=v[u]&&("function"==typeof n.type&&null!=v[u].__e&&v[u].__e==n.__d&&(n.__d=en(r,u+1)),mn(v[u],v[u]));if(m)for(u=0;u<m.length;u++)yn(m[u],m[++u],m[++u])}function sn(e,t,n){for(var r,o=e.__k,s=0;o&&s<o.length;s++)(r=o[s])&&(r.__=e,t="function"==typeof r.type?sn(r,t,n):an(n,r,r,o,r.__e,t));return t}function an(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 cn(e,t,n){"-"===t[0]?e.setProperty(t,n):e[t]=null==n?"":"number"!=typeof n||Jt.test(t)?n:n+"px"}function ln(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||cn(e.style,t,"");if(n)for(t in n)r&&n[t]===r[t]||cn(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?dn:un,s):e.removeEventListener(t,s?dn:un,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 un(e){this.l[e.type+!1](Mt.event?Mt.event(e):e)}function dn(e){this.l[e.type+!0](Mt.event?Mt.event(e):e)}function fn(e,t,n,r,o,s,i,a,c){var l,u,d,f,p,h,y,m,v,b,g,_,w,S=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]),(l=Mt.__b)&&l(t);try{e:if("function"==typeof S){if(m=t.props,v=(l=S.contextType)&&r[l.__c],b=l?v?v.props.value:l.__:r,n.__c?y=(u=t.__c=n.__c).__=u.__E:("prototype"in S&&S.prototype.render?t.__c=u=new S(m,b):(t.__c=u=new Qt(m,b),u.constructor=S,u.render=vn),v&&v.sub(u),u.props=m,u.state||(u.state={}),u.context=b,u.__n=r,d=u.__d=!0,u.__h=[]),null==u.__s&&(u.__s=u.state),null!=S.getDerivedStateFromProps&&(u.__s==u.state&&(u.__s=zt({},u.__s)),zt(u.__s,S.getDerivedStateFromProps(m,u.__s))),f=u.props,p=u.state,d)null==S.getDerivedStateFromProps&&null!=u.componentWillMount&&u.componentWillMount(),null!=u.componentDidMount&&u.__h.push(u.componentDidMount);else{if(null==S.getDerivedStateFromProps&&m!==f&&null!=u.componentWillReceiveProps&&u.componentWillReceiveProps(m,b),!u.__e&&null!=u.shouldComponentUpdate&&!1===u.shouldComponentUpdate(m,u.__s,b)||t.__v===n.__v){u.props=m,u.state=u.__s,t.__v!==n.__v&&(u.__d=!1),u.__v=t,t.__e=n.__e,t.__k=n.__k,t.__k.forEach((function(e){e&&(e.__=t)})),u.__h.length&&i.push(u);break e}null!=u.componentWillUpdate&&u.componentWillUpdate(m,u.__s,b),null!=u.componentDidUpdate&&u.__h.push((function(){u.componentDidUpdate(f,p,h)}))}if(u.context=b,u.props=m,u.__v=t,u.__P=e,g=Mt.__r,_=0,"prototype"in S&&S.prototype.render)u.state=u.__s,u.__d=!1,g&&g(t),l=u.render(u.props,u.state,u.context);else do{u.__d=!1,g&&g(t),l=u.render(u.props,u.state,u.context),u.state=u.__s}while(u.__d&&++_<25);u.state=u.__s,null!=u.getChildContext&&(r=zt(zt({},r),u.getChildContext())),d||null==u.getSnapshotBeforeUpdate||(h=u.getSnapshotBeforeUpdate(f,p)),w=null!=l&&l.type===Xt&&null==l.key?l.props.children:l,on(e,Array.isArray(w)?w:[w],t,n,r,o,s,i,a,c),u.base=t.__e,t.__h=null,u.__h.length&&i.push(u),y&&(u.__E=u.__=null),u.__e=!1}else null==s&&t.__v===n.__v?(t.__k=n.__k,t.__e=n.__e):t.__e=hn(n.__e,t,n,r,o,s,i,c);(l=Mt.diffed)&&l(t)}catch(e){t.__v=null,(c||null!=s)&&(t.__e=a,t.__h=!!c,s[s.indexOf(a)]=null),Mt.__e(e,t,n)}}function pn(e,t){Mt.__c&&Mt.__c(t,e),e.some((function(t){try{e=t.__h,t.__h=[],e.some((function(e){e.call(t)}))}catch(e){Mt.__e(e,t.__v)}}))}function hn(e,t,n,r,o,s,i,a){var c,l,u,d=n.props,f=t.props,p=t.type,h=0;if("svg"===p&&(o=!0),null!=s)for(;h<s.length;h++)if((c=s[h])&&"setAttribute"in c==!!p&&(p?c.localName===p:3===c.nodeType)){e=c,s[h]=null;break}if(null==e){if(null===p)return document.createTextNode(f);e=o?document.createElementNS("http://www.w3.org/2000/svg",p):document.createElement(p,f.is&&f),s=null,a=!1}if(null===p)d===f||a&&e.data===f||(e.data=f);else{if(s=s&&Bt.call(e.childNodes),l=(d=n.props||Vt).dangerouslySetInnerHTML,u=f.dangerouslySetInnerHTML,!a){if(null!=s)for(d={},h=0;h<e.attributes.length;h++)d[e.attributes[h].name]=e.attributes[h].value;(u||l)&&(u&&(l&&u.__html==l.__html||u.__html===e.innerHTML)||(e.innerHTML=u&&u.__html||""))}if(function(e,t,n,r,o){var s;for(s in n)"children"===s||"key"===s||s in t||ln(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]||ln(e,s,t[s],n[s],r)}(e,f,d,o,a),u)t.__k=[];else if(h=t.props.children,on(e,Array.isArray(h)?h:[h],t,n,r,o&&"foreignObject"!==p,s,i,s?s[0]:n.__k&&en(n,0),a),null!=s)for(h=s.length;h--;)null!=s[h]&&Gt(s[h]);a||("value"in f&&void 0!==(h=f.value)&&(h!==e.value||"progress"===p&&!h||"option"===p&&h!==d.value)&&ln(e,"value",h,d.value,!1),"checked"in f&&void 0!==(h=f.checked)&&h!==e.checked&&ln(e,"checked",h,d.checked,!1))}return e}function yn(e,t,n){try{"function"==typeof e?e(t):e.current=t}catch(e){Mt.__e(e,n)}}function mn(e,t,n){var r,o;if(Mt.unmount&&Mt.unmount(e),(r=e.ref)&&(r.current&&r.current!==e.__e||yn(r,null,t)),null!=(r=e.__c)){if(r.componentWillUnmount)try{r.componentWillUnmount()}catch(e){Mt.__e(e,t)}r.base=r.__P=null}if(r=e.__k)for(o=0;o<r.length;o++)r[o]&&mn(r[o],t,"function"!=typeof e.type);n||null==e.__e||Gt(e.__e),e.__e=e.__d=void 0}function vn(e,t,n){return this.constructor(e,n)}function bn(e,t,n){var r,o,s;Mt.__&&Mt.__(e,t),o=(r="function"==typeof n)?null:n&&n.__k||t.__k,s=[],fn(t,e=(!r&&n||t).__k=Yt(Xt,null,[e]),o||Vt,Vt,void 0!==t.ownerSVGElement,!r&&n?[n]:o?null:t.firstChild?Bt.call(t.childNodes):null,s,!r&&n?n:o?o.__e:t.firstChild,r),pn(s,e)}Bt=qt.slice,Mt={__e:function(e,t,n,r){for(var o,s,i;t=t.__;)if((o=t.__c)&&!o.__)try{if((s=o.constructor)&&null!=s.getDerivedStateFromError&&(o.setState(s.getDerivedStateFromError(e)),i=o.__d),null!=o.componentDidCatch&&(o.componentDidCatch(e,r||{}),i=o.__d),i)return o.__E=o}catch(t){e=t}throw e}},Ft=0,Qt.prototype.setState=function(e,t){var n;n=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=zt({},this.state),"function"==typeof e&&(e=e(zt({},n),this.props)),e&&zt(n,e),null!=e&&this.__v&&(t&&this.__h.push(t),nn(this))},Qt.prototype.forceUpdate=function(e){this.__v&&(this.__e=!0,e&&this.__h.push(e),nn(this))},Qt.prototype.render=Xt,Kt=[],rn.__r=0;const gn={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 _n({children:e,className:t}){return Yt("div",{className:t},Yt("div",{style:gn.Darken}),Yt("div",{style:gn.DialogOuter},Yt("div",{style:gn.DialogInner},e)))}var wn,Sn,kn,En,In=0,xn=[],Cn=[],On=Mt.__b,Tn=Mt.__r,An=Mt.diffed,jn=Mt.__c,$n=Mt.unmount;function Pn(e,t){Mt.__h&&Mt.__h(Sn,e,In||t),In=0;var n=Sn.__H||(Sn.__H={__:[],__h:[]});return e>=n.__.length&&n.__.push({__V:Cn}),n.__[e]}function Un(e){return In=1,function(e,t,n){var r=Pn(wn++,2);if(r.t=e,!r.__c&&(r.__=[n?n(t):Mn(void 0,t),function(e){var t=r.__N?r.__N[0]:r.__[0],n=r.t(t,e);t!==n&&(r.__N=[n,r.__[1]],r.__c.setState({}))}],r.__c=Sn,!Sn.u)){Sn.u=!0;var o=Sn.shouldComponentUpdate;Sn.shouldComponentUpdate=function(e,t,n){if(!r.__c.__H)return!0;var s=r.__c.__H.__.filter((function(e){return e.__c}));if(s.every((function(e){return!e.__N})))return!o||o.call(this,e,t,n);var i=!1;return s.forEach((function(e){if(e.__N){var t=e.__[0];e.__=e.__N,e.__N=void 0,t!==e.__[0]&&(i=!0)}})),!!i&&(!o||o.call(this,e,t,n))}}return r.__N||r.__}(Mn,e)}function Dn(e){return In=5,function(e,t){var n=Pn(wn++,7);return Bn(n.__H,t)?(n.__V=e(),n.i=t,n.__h=e,n.__V):n.__}((function(){return{current:e}}),[])}function Nn(){for(var e;e=xn.shift();)if(e.__P&&e.__H)try{e.__H.__h.forEach(Ln),e.__H.__h.forEach(Wn),e.__H.__h=[]}catch(t){e.__H.__h=[],Mt.__e(t,e.__v)}}Mt.__b=function(e){Sn=null,On&&On(e)},Mt.__r=function(e){Tn&&Tn(e),wn=0;var t=(Sn=e.__c).__H;t&&(kn===Sn?(t.__h=[],Sn.__h=[],t.__.forEach((function(e){e.__N&&(e.__=e.__N),e.__V=Cn,e.__N=e.i=void 0}))):(t.__h.forEach(Ln),t.__h.forEach(Wn),t.__h=[])),kn=Sn},Mt.diffed=function(e){An&&An(e);var t=e.__c;t&&t.__H&&(t.__H.__h.length&&(1!==xn.push(t)&&En===Mt.requestAnimationFrame||((En=Mt.requestAnimationFrame)||function(e){var t,n=function(){clearTimeout(r),Rn&&cancelAnimationFrame(t),setTimeout(e)},r=setTimeout(n,100);Rn&&(t=requestAnimationFrame(n))})(Nn)),t.__H.__.forEach((function(e){e.i&&(e.__H=e.i),e.__V!==Cn&&(e.__=e.__V),e.i=void 0,e.__V=Cn}))),kn=Sn=null},Mt.__c=function(e,t){t.some((function(e){try{e.__h.forEach(Ln),e.__h=e.__h.filter((function(e){return!e.__||Wn(e)}))}catch(n){t.some((function(e){e.__h&&(e.__h=[])})),t=[],Mt.__e(n,e.__v)}})),jn&&jn(e,t)},Mt.unmount=function(e){$n&&$n(e);var t,n=e.__c;n&&n.__H&&(n.__H.__.forEach((function(e){try{Ln(e)}catch(e){t=e}})),t&&Mt.__e(t,n.__v))};var Rn="function"==typeof requestAnimationFrame;function Ln(e){var t=Sn,n=e.__c;"function"==typeof n&&(e.__c=void 0,n()),Sn=t}function Wn(e){var t=Sn;e.__c=e.__(),Sn=t}function Bn(e,t){return!e||e.length!==t.length||t.some((function(t,n){return t!==e[n]}))}function Mn(e,t){return"function"==typeof t?t(e):t}function Fn({title:e,alerts:t,fields:n,onCancel:r,onSubmit:o}){const[s,i]=Un({}),a=Dn(null);return function(e,t){var n=Pn(wn++,4);!Mt.__s&&Bn(n.__H,t)&&(n.__=e,n.i=t,Sn.__h.push(n))}((()=>{var e;return null===(e=a.current)||void 0===e?void 0:e.focus()}),[]),Yt(_n,{className:"dxc-login-dlg"},Yt(Xt,null,Yt("h3",{style:gn.WindowHeader},e),t.map((e=>Yt("p",{style:gn.Alert[e.type]},function({message:e,messageCode:t,messageParams:n}){return e.replace(/\{\w+\}/gi,(e=>n[e.substr(1,e.length-2)]))}(e)))),Yt("form",{onSubmit:e=>{e.preventDefault(),o(s)}},Object.entries(n).map((([e,{type:t,label:n,placeholder:r}],o)=>Yt("label",{style:gn.Label},n?`${n}: `:"",Yt("input",{ref:0===o?a:void 0,type:t,name:e,autoComplete:"on",style:gn.Input,autoFocus:!0,placeholder:r,value:s[e]||"",onInput:n=>{var r;return i(Object.assign(Object.assign({},s),{[e]:Kn(t,null===(r=n.target)||void 0===r?void 0:r.value)}))}})))))),Yt("div",{style:gn.ButtonsDiv},Yt("button",{type:"submit",style:gn.Button,onClick:()=>o(s)},"Submit"),Yt("button",{style:gn.Button,onClick:r},"Cancel")))}function Kn(e,t){switch(e){case"email":return t.toLowerCase();case"otp":return t.toUpperCase();default:return t}}class Hn extends Qt{constructor(e){super(e),this.observer=e=>this.setState({userInteraction:e}),this.state={userInteraction:void 0}}componentDidMount(){this.subscription=u(this.props.db.cloud.userInteraction).subscribe(this.observer)}componentWillUnmount(){this.subscription&&(this.subscription.unsubscribe(),delete this.subscription)}render(e,{userInteraction:t}){return t?Yt(Fn,Object.assign({},t)):null}}function Vn(e){const t=new WeakMap;return n=>{let r=t.get(n);return r||(r=e(n),t.set(n,r)),r}}function qn(e,t){let n=t,o=u(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 Jn=Vn((e=>qn(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})))),{}))),zn=Vn((e=>new o(T))),Gn=Vn((e=>qn(zn(e._novip).pipe(b((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 Yn(...e){if(0===e.length)return{};const t=e.reduce(((e,t)=>{const n=Object.assign({},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 Zn=Vn((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}(qn(f([Gn(e._novip),Jn(e._novip)]).pipe(w((([{selfMembers:e,realms:t,userId:n},r])=>({selfMembers:e,realms:t,userId:n,globalRoles:r})))),{selfMembers:[],realms:[],userId:T.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=V(o.map((e=>e.roles)).filter((e=>e))).map((e=>r[e])).filter((e=>e)).map((e=>e.permissions));return Object.assign(Object.assign({},t),{permissions:t.owner===n?{manage:"*"}:Yn(...s,...i)})})).reduce(((e,t)=>Object.assign(Object.assign({},e),{[t.realmId]:t})),{[n]:{realmId:n,owner:n,name:n,permissions:{manage:"*"}}});return o}))));class Xn{constructor(e,t,n){this.permissions=e||{},this.tableName=t,this.isOwner=n}add(...e){var t;return"*"===this.permissions.manage||(!!(null===(t=this.permissions.manage)||void 0===t?void 0:t.includes(this.tableName))||("*"===this.permissions.add||!!e.every((e=>{var t;return null===(t=this.permissions.add)||void 0===t?void 0:t.includes(e)}))))}update(...e){var t,n;if(this.isOwner||"*"===this.permissions.manage)return!0;if(null===(t=this.permissions.manage)||void 0===t?void 0:t.includes(this.tableName))return!0;if("*"===this.permissions.update)return e.every((e=>"owner"!==e));const r=null===(n=this.permissions.update)||void 0===n?void 0:n[this.tableName];return"*"===r?e.every((e=>"owner"!==e)):e.every((e=>null==r?void 0:r.some((t=>t===e||"*"===t&&"owner"!==e))))}delete(){var e;return!(!this.isOwner&&"*"!==this.permissions.manage)||!!(null===(e=this.permissions.manage)||void 0===e?void 0:e.includes(this.tableName))}}const Qn=Vn((e=>{const t=zn(e._novip).pipe(b((t=>n((()=>e.members.where({email:t.email||""}).toArray()))))),r=Zn(e._novip),o=Gn(e._novip);return qn(f([t,o,r]).pipe(w((([t,n,r])=>{const o=(e,t)=>Object.assign(Object.assign({},e),{[t.id]:Object.assign(Object.assign({},t),{realm:r[t.realmId]})}),s=t.reduce(o,{}),i=n.selfMembers.reduce(o,s);return Object.values(i).filter((e=>!e.accepted&&!e.rejected)).map((t=>Object.assign(Object.assign({},t),{accept(){return O(this,void 0,void 0,(function*(){yield e.members.update(t.id,{accepted:new Date})}))},reject(){return O(this,void 0,void 0,(function*(){yield e.members.update(t.id,{rejected:new Date})}))}})))}))),[])})),er={nameSuffix:!0};function tr(t){const r=t.name,c=zn(t),l=[];let p=!1,h=null;t.on("ready",(t=>O(this,void 0,void 0,(function*(){try{yield function(t){var r,s,S,E,T,A,j;return O(this,void 0,void 0,(function*(){y=!1;const $=et(t);"undefined"!=typeof window&&"undefined"!=typeof document&&((null===(r=$.cloud.options)||void 0===r?void 0:r.customLoginGui)||l.push(function(e){let t=!1;const n=document.createElement("div");return document.body?(document.body.appendChild(n),bn(Yt(Hn,{db:e.vip}),n)):addEventListener("DOMContentLoaded",(()=>{t||(document.body.appendChild(n),bn(Yt(Hn,{db:e.vip}),n))})),{unsubscribe(){try{n.remove()}catch(e){}t=!0},get closed(){return t}}}(t))),$.cloud.isServiceWorkerDB||l.push(function(e){let t=e.cloud.webSocketStatus.value;const n=e.cloud.webSocketStatus.pipe(b((e=>{const n=t;t=e;const r=i(e);switch(e){case"disconnected":return kt.value?r.pipe(I(500)):r;case"connecting":return"not-started"===n||"error"===n?r:r.pipe(I(4e3));default:return r}})));return f([n,e.syncStateChangedEvent.pipe(x({phase:"initial"})),Et]).pipe(w((([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:Fe?a:"offline"}})))}($).subscribe(t.cloud.syncState)),l.push($.syncCompleteEvent.subscribe(_)),$.tables.every((e=>e.core))||lt();const P="serviceWorker"in navigator?yield navigator.serviceWorker.getRegistrations():[],U=yield $.transaction("rw",$.$syncState,(()=>O(this,void 0,void 0,(function*(){var e,t;const{options:n,schema:r}=$.cloud,[o,s,i]=yield Promise.all([$.getOptions(),$.getSchema(),$.getPersistedSyncState()]);if(p){if(!o||JSON.stringify(o)!==JSON.stringify(n)){if(!n)throw new Error("Internal error");const e=Object.assign({},n);delete e.fetchTokens,yield $.$syncState.put(e,"options")}}else $.cloud.options=o||null;if((null===(e=$.cloud.options)||void 0===e?void 0:e.tryUseServiceWorker)&&"serviceWorker"in navigator&&P.length>0&&!at?(console.debug("Dexie Cloud Addon: Using service worker"),$.cloud.usingServiceWorker=!0):((null===(t=$.cloud.options)||void 0===t?void 0:t.tryUseServiceWorker)&&!$.cloud.isServiceWorkerDB&&console.debug("dexie-cloud-addon: Not using service worker.",0===P.length?"No SW registrations found.":"serviceWorker"in navigator&&at?"Avoiding SW background sync and SW periodic bg sync for this browser due to browser bugs.":"navigator.serviceWorker not present"),$.cloud.usingServiceWorker=!1),Wt(r,$.cloud.options),Wt(s,$.cloud.options),r){if(!s||JSON.stringify(s)!==JSON.stringify(r)){const e=s||{};for(const[t,n]of Object.entries(r)){const r=e[t];r?(r.markedForSync=n.markedForSync,n.deleted=r.deleted,r.generatedGlobalId=n.generatedGlobalId):e[t]=Object.assign({},n)}yield $.$syncState.put(e,"schema"),Object.assign(r,e)}}else $.cloud.schema=s||null;return null==i?void 0:i.initiallySynced}))));U&&$.setInitiallySynced(!0),function(t){var n,r;for(const o of t.tables)if(null===(r=null===(n=t.cloud.schema)||void 0===n?void 0:n[o.name])||void 0===r?void 0:r.markedForSync){if(o.schema.primKey.auto)throw new e.SchemaError(`Table ${o.name} is both autoIncremented and synced. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(o.name)}]}) to blacklist it from sync`);if(!o.schema.primKey.keyPath)throw new e.SchemaError(`Table ${o.name} cannot be both synced and outbound. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(o.name)}]}) to blacklist it from sync`)}}($),(null===(s=$.cloud.options)||void 0===s?void 0:s.databaseUrl)&&!U&&(yield function(e,t,n){return O(this,void 0,void 0,(function*(){console.debug("Performing initial sync"),yield Je(e,t,n,{isInitialSync:!0}),console.debug("Done initial sync")}))}($,$.cloud.options,$.cloud.schema),$.setInitiallySynced(!0)),g(),$.cloud.isServiceWorkerDB||(l.push(n((()=>$.getCurrentUser())).subscribe(c)),l.push(n((()=>$.getPersistedSyncState())).subscribe($.cloud.persistedSyncState)),yield f([c.pipe(C(1),v(1)),$.cloud.persistedSyncState.pipe(C(1),v(1))]).toPromise());let D=!1;(null===(S=$.cloud.options)||void 0===S?void 0:S.requireAuth)&&(D=yield rt($)),h&&h.stop(),h=null,g(),$.cloud.usingServiceWorker&&(null===(E=$.cloud.options)||void 0===E?void 0:E.databaseUrl)?(N($,D?"pull":"push").catch((()=>{})),function(e){var t;return O(this,void 0,void 0,(function*(){try{const{periodicSync:n}=yield navigator.serviceWorker.ready;if(n)try{yield n.register(`dexie-cloud:${e.name}`,null===(t=e.cloud.options)||void 0===t?void 0:t.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)}}))}($).catch((()=>{}))):(null===(T=$.cloud.options)||void 0===T?void 0:T.databaseUrl)&&$.cloud.schema&&!$.cloud.isServiceWorkerDB&&(h=Lt($,$.cloud.options,$.cloud.schema),h.start(),R($,D?"pull":"push")),g(),$.cloud.isServiceWorkerDB||l.push(a(self,"online").subscribe((()=>{console.debug("online!"),$.syncStateChangedEvent.next({phase:"not-in-sync"}),R($,"push")})),a(self,"offline").subscribe((()=>{console.debug("offline!"),$.syncStateChangedEvent.next({phase:"offline"})}))),!(null===(A=$.cloud.options)||void 0===A?void 0:A.databaseUrl)||(null===(j=$.cloud.options)||void 0===j?void 0:j.disableWebSocket)||ct||l.push(function(e){var t;if(!(null===(t=e.cloud.options)||void 0===t?void 0:t.databaseUrl))throw new Error("No database URL to connect WebSocket to");const n=e.messageConsumer.readyToServe.pipe(m((e=>e)),b((()=>e.getPersistedSyncState())),m((e=>e&&e.serverRevision)),w((e=>({type:"ready",rev:e.serverRevision}))));return function t(){return e.cloud.persistedSyncState.pipe(m((e=>null==e?void 0:e.serverRevision)),v(1),b((t=>e.cloud.currentUser.pipe(w((e=>[e,t]))))),b((([e,t])=>Et.pipe(w((n=>[n?e:null,t]))))),b((([t,n])=>(null==t?void 0:t.isLoggedIn)&&!(null==n?void 0:n.realms.includes(t.userId))?e.cloud.persistedSyncState.pipe(m((e=>(null==e?void 0:e.realms.includes(t.userId))||!1)),v(1),w((e=>[t,e]))):new o([t,n]))),b((([e,t])=>O(this,void 0,void 0,(function*(){return[e,yield B(t)]})))),b((([t,r])=>t?new At(e.cloud.options.databaseUrl,e.cloud.persistedSyncState.value.serverRevision,r,e.cloud.persistedSyncState.value.clientIdentity,n,e.cloud.webSocketStatus,t.accessToken,t.accessTokenExpiration):u([]))),k((n=>"TokenExpiredError"===(null==n?void 0:n.name)?(console.debug("WebSocket observable: Token expired. Refreshing token..."),i(!0).pipe(b((()=>O(this,void 0,void 0,(function*(){const t=yield e.getCurrentUser(),n=yield ce(e.cloud.options.databaseUrl,t);yield e.table("$logins").update(t.userId,{accessToken:n.accessToken,accessTokenExpiration:n.accessTokenExpiration})})))),b((()=>t())))):d(n))),k((n=>(e.cloud.webSocketStatus.next("error"),u(Pt(n)).pipe(b((()=>t())))))))}().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!")}))}($))}))}(t)}catch(e){console.error(e)}}))),!0);let y=!1;function g(){if(y)throw new e.DatabaseClosedError}!function(e,t){e.on.close.subscribe(t);const n=e.close;e.close=function(){n.call(this),t()}}(t,(()=>{l.forEach((e=>e.unsubscribe())),y=!0,h&&h.stop(),h=null,c.next(T)}));const _=new s;var S;t.cloud={version:"4.0.1-beta.39",options:Object.assign({},er),schema:null,get currentUserId(){return c.value.userId||T.userId},currentUser:c,syncState:new o({phase:"initial",status:"not-started"}),events:{syncComplete:_},persistedSyncState:new o(void 0),userInteraction:new o(void 0),webSocketStatus:new o("not-started"),login(e){return O(this,void 0,void 0,(function*(){const n=et(t);yield n.cloud.sync(),yield rt(n,e)}))},invites:Qn(t),roles:Jn(t),configure(e){e=t.cloud.options=Object.assign(Object.assign({},t.cloud.options),e),p=!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)}`,et(t).reconfigure()),Wt(t.cloud.schema,t.cloud.options)},sync({wait:e,purpose:r}={wait:!0,purpose:"push"}){return O(this,void 0,void 0,(function*(){void 0===e&&(e=!0);const o=et(t);if("pull"===r){const t=o.cloud.persistedSyncState.value;if(R(o,r),e){const e=yield o.cloud.persistedSyncState.pipe(m((e=>null!=(null==e?void 0:e.timestamp)&&(!t||e.timestamp>t.timestamp))),v(1)).toPromise();if(null==e?void 0:e.error)throw new Error("Sync error: "+e.error)}}else if(yield Ut(o)){const t=o.cloud.persistedSyncState.value;R(o,r),e&&(console.debug("db.cloud.login() is waiting for sync completion..."),yield u(n((()=>O(this,void 0,void 0,(function*(){const e=yield Ut(o),n=yield o.getPersistedSyncState();if((null==n?void 0:n.timestamp)!==(null==t?void 0:t.timestamp)&&(null==n?void 0:n.error))throw new Error("Sync error: "+n.error);return e}))))).pipe(m((e=>!e)),v(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=Zn(e),i=t=>{const s=t[o||e.cloud.currentUserId];return s?new Xn(s.permissions,n,o===e.cloud.currentUserId||r===e.cloud.currentUserId):new Xn({},n,!r||r===e.cloud.currentUserId)},a=s.pipe(w(i));return a.getValue=()=>i(s.getValue()),a}(t._novip,e,n)},t.Version.prototype._parseStoresSpec=e.override(t.Version.prototype._parseStoresSpec,(e=>St(e,t))),t.Table.prototype.newId=function({colocateWith:e}={}){const n=e&&e.substr(e.length-3);return yt(t.cloud.schema[this.name].idPrefix||"",n)},t.Table.prototype.idPrefix=function(){var e,t;return(null===(t=null===(e=this.db.cloud.schema)||void 0===e?void 0:e[this.name])||void 0===t?void 0:t.idPrefix)||""},t.use(wt({currentUserObservable:t.cloud.currentUser,db:et(t)})),t.use((S=et(t),{stack:"dbcore",name:"implicitPropSetterMiddleware",level:1,create:e=>Object.assign(Object.assign({},e),{table:t=>{const n=e.table(t);return Object.assign(Object.assign({},n),{mutate:e=>{var r,o,s,i;if(e.trans.disableChangeTracking)return n.mutate(e);const a=e.trans;if((null===(o=null===(r=S.cloud.schema)||void 0===r?void 0:r[t])||void 0===o?void 0:o.markedForSync)&&("add"===e.type||"put"===e.type))for(const t of e.values){t.owner||(t.owner=a.currentUser.userId),t.realmId||(t.realmId=a.currentUser.userId);const r=null===(i=(s=n.schema.primaryKey).extractKey)||void 0===i?void 0:i.call(s,t);"string"==typeof r&&"#"===r[0]&&"put"===e.type&&(delete e.criteria,delete e.changeSpec,delete e.updates,t.$ts=Date.now())}return n.mutate(e)}})}})})),t.use(mt(et(t)))}tr.version="4.0.1-beta.39",e.Cloud=tr;const nr=new Map;function rr(e){return e.startsWith("dexie-cloud:")&&e.split(":")[1]}const or=new Map;function sr(t,n){let r=or.get(t+"/"+n);return r||(r=function t(n,r){var o;return O(this,void 0,void 0,(function*(){let s=nr.get(n);if(!s){console.debug("Dexie Cloud SW: Creating new Dexie instance for",n);const o=new e(n,{addons:[tr]});if(s=et(o),s.cloud.isServiceWorkerDB=!0,o.on("versionchange",i),yield s.dx.open(),nr.get(n))return s.close(),yield t(n,r);nr.set(n,s)}if(null===(o=s.cloud.options)||void 0===o?void 0:o.databaseUrl)if(s.cloud.schema)try{console.debug("Dexie Cloud SW: Syncing"),yield Rt(s,s.cloud.options,s.cloud.schema,{retryImmediatelyOnFetchError:!0,purpose:r}),console.debug("Dexie Cloud SW: Done Syncing")}catch(t){if(console.error("Dexie Cloud SW Error",t),i(),t.name!==e.errnames.NoSuchDatabase)throw t}else console.error("Dexie Cloud: No schema persisted");else console.error("Dexie Cloud: No databaseUrl configured");function i(){return s.dx.on.versionchange.unsubscribe(i),nr.get(s.name)===s&&nr.delete(s.name),console.debug(`Dexie Cloud SW: Closing Dexie instance for ${n}`),s.dx.close(),!1}}))}(t,n).then((()=>{or.delete(t+"/"+n)})).catch((e=>(or.delete(t+"/"+n),Promise.reject(e)))),or.set(t+"/"+n,r)),r}at||(self.addEventListener("sync",(e=>{console.debug('SW "sync" Event',e.tag);const t=rr(e.tag);t&&e.waitUntil(sr(t,"push"))})),self.addEventListener("periodicsync",(e=>{console.debug('SW "periodicsync" Event',e.tag);const t=rr(e.tag);t&&e.waitUntil(sr(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)=>sr(t,e.data.purpose||"pull").catch((e=>O(void 0,void 0,void 0,(function*(){if(3===r)throw e;var t;yield(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,of as i,fromEvent as a,merge as c,Subscription as l,from as u,throwError as d,combineLatest as f,map as p,share as h,timer as y}from"rxjs";import{filter as m,take as v,switchMap as b,delay as g,distinctUntilChanged as _,map as w,tap as S,catchError as k,timeout as E,debounceTime as I,startWith as x,skip as C}from"rxjs/operators";function O(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())}))}const T={userId:"unauthorized",name:"Unauthorized",claims:{sub:"unauthorized"},lastLogin:new Date(0)};try{Object.freeze(T),Object.freeze(T.claims)}catch(e){}const A={},j="undefined"!=typeof self&&self.document&&"undefined"!=typeof navigator&&navigator.serviceWorker;j&&j.ready.then((e=>A.registration=e)),"undefined"!=typeof self&&"clients"in self&&!self.document&&addEventListener("message",(e=>{var t,n;(null===(n=null===(t=e.data)||void 0===t?void 0:t.type)||void 0===n?void 0:n.startsWith("sw-broadcast-"))&&[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>{var n;return t.id!==(null===(n=e.source)||void 0===n?void 0:n.id)&&t.postMessage(e.data)}))}));class ${constructor(e){this.name=e}subscribe(e){if(!j)return()=>{};const t=t=>{var n;(null===(n=t.data)||void 0===n?void 0:n.type)===`sw-broadcast-${this.name}`&&e(t.data.message)};return j.addEventListener("message",t),()=>j.removeEventListener("message",t)}postMessage(e){var t;"object"==typeof self.clients?[...self.clients.matchAll({includeUncontrolled:!0})].forEach((t=>t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))):A.registration&&(null===(t=A.registration.active)||void 0===t||t.postMessage({type:`sw-broadcast-${this.name}`,message:e}))}}const P=globalThis["lbc-events"]||(globalThis["lbc-events"]=new Map);class U extends r{constructor(e){const t="undefined"==typeof BroadcastChannel?new $(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;!function(e,t){P.has(e)?P.get(e).push(t):P.set(e,[t])}(`lbc-${e}`,r);try{t instanceof $?s=t.subscribe((e=>n.next(e))):(console.debug("BroadcastedAndLocalEvent: bc.addEventListener()",e,"bc is a",t),t.addEventListener("message",o))}catch(e){console.warn("Failed to subscribe to broadcast channel",e)}return()=>{!function(e,t){const n=P.get(e);if(n){const e=n.indexOf(t);-1!==e&&n.splice(e,1)}}(`lbc-${e}`,r),t instanceof $?s():t.removeEventListener("message",o)}})),this.name=e,this.bc=t}next(e){console.debug("BroadcastedAndLocalEvent: bc.postMessage()",Object.assign({},e),"bc is a",this.bc),this.bc.postMessage(e);!function(e){const t=P.get(e.type);t&&t.forEach((t=>{try{t(e)}catch(e){}}))}(new CustomEvent(`lbc-${this.name}`,{detail:e}))}}let D=!1;function N(e,t){return O(this,void 0,void 0,(function*(){try{const n=yield navigator.serviceWorker.ready;if("push"===t&&n.sync&&(yield 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){D||(console.debug("Dexie Cloud: Could not register sync event",e),D=!0)}}))}function R(e,t){e.cloud.usingServiceWorker?N(e,t):e.localSyncEvent.next({purpose:t})}const L="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},W="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,ArrayBuffer.isView(e)?e:new Uint8Array(e)));function B({realms:e,inviteRealms:t}){return O(this,void 0,void 0,(function*(){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=yield crypto.subtle.digest("SHA-1",r);return W(o)}))}function M(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 F(e){return`$${e}_mutations`}function K(e){var t;const n=null===(t=/^\$(.*)_mutations$/.exec(e))||void 0===t?void 0:t[1];if(!n)throw new Error(`Given mutationTable ${e} is not correct`);return n}const H=[].concat;function V(e){return H.apply([],e)}function q(e,t,{since:n={},limit:r=1/0}={}){return O(this,void 0,void 0,(function*(){const t=V(yield Promise.all(e.map((e=>O(this,void 0,void 0,(function*(){const t=K(e.name),o=n[t];let s=o?e.where("rev").above(o):e;r<1/0&&(s=s.limit(r));return(yield s.toArray()).map((e=>({table:t,mut:e})))})))))).sort(((e,t)=>e.mut.ts-t.mut.ts)),o=[];let s=null,i=null;for(const{table:e,mut:n}of t)s&&s.table===e&&i===n.txid?s.muts.push(n):(s={table:e,muts:[n]},i=n.txid,o.push(s));return o}))}function J(e){const t=new Uint8Array(e);if("undefined"!=typeof crypto)crypto.getRandomValues(t);else for(let n=0;n<e;n++)t[n]=Math.floor(256*Math.random());if("undefined"!=typeof Buffer&&Buffer.from)return Buffer.from(t).toString("base64");if("undefined"!=typeof btoa)return btoa(String.fromCharCode.apply(null,t));throw new Error("No btoa or Buffer available")}function z(e){if(!e)throw new Error("Assertion Failed")}const G={}.hasOwnProperty;function Y(e,t,n){if(e&&void 0!==t&&(!("isFrozen"in Object)||!Object.isFrozen(e)))if("string"!=typeof t&&"length"in t){z("string"!=typeof n&&"length"in n);for(var r=0,o=t.length;r<o;++r)Y(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&&function(e,t){return G.call(e,t)}(e,i)||(c=e[i]={}),Y(c,a,n)}}else void 0===n?Array.isArray(e)&&!isNaN(parseInt(t))?e.splice(t,1):delete e[t]:e[t]=n}}const Z="undefined"!=typeof self&&"undefined"!=typeof crypto?(e,t=crypto.getRandomValues.bind(crypto))=>{const n=new Uint8Array(e);return t(n),self.btoa(String.fromCharCode.apply(null,n))}:"undefined"!=typeof Buffer?(e,t=X)=>{const n=Buffer.alloc(e);return t(n),n.toString("base64")}:()=>{throw new Error("No implementation of randomString was found")};function X(e){for(let t=0;t<e.length;++t)e[t]=Math.floor(256*Math.random())}function Q(e){return"string"==typeof e||!!(Array.isArray(e)&&e.some((e=>Q(e)))&&e.every(ee))}function ee(e){return"string"==typeof e||"number"==typeof e||Array.isArray(e)&&e.every(ee)}function te(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))Y(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 ne(e,t){for(const{table:n,muts:r}of t)for(const t of r)te(e,n,t)}function re(t,n){return new Promise(((r,o)=>{const s=Object.assign(Object.assign({},n),{onSubmit:e=>{t.next(void 0),r(e)},onCancel:()=>{t.next(void 0),o(new e.AbortError("User cancelled"))}});t.next(s)}))}function oe(e,t,...n){return re(e,{type:"message-alert",title:t,alerts:n,fields:{}})}function se(e,t,n){return O(this,void 0,void 0,(function*(){let r=n||"";for(;!r||!/^[\w-\.]+@([\w-]+\.)+[\w-]{2,10}$/.test(r);)r=(yield re(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}))}function ie(e,t,n){return O(this,void 0,void 0,(function*(){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}=yield re(e,{type:"otp",title:"Enter OTP",alerts:r,fields:{otp:{type:"otp",label:"OTP",placeholder:"Paste OTP here"}}});return o}))}function ae(e,t,n,r,o){return O(this,void 0,void 0,(function*(){return t.accessToken&&t.accessTokenExpiration.getTime()>Date.now()?t:t.refreshToken&&(!t.refreshTokenExpiration||t.refreshTokenExpiration.getTime()>Date.now())?yield ce(e,t):yield function(e,t,n,r){return O(this,void 0,void 0,(function*(){if(!crypto.subtle)throw"undefined"!=typeof location&&"http:"===location.protocol?new Error("Dexie Cloud Addon needs to use WebCrypto, but your browser has disabled it due to being served from an insecure location. Please serve it from https or http://localhost:<port> (See https://stackoverflow.com/questions/46670556/how-to-enable-crypto-subtle-for-unsecure-origins-in-chrome/46671627#46671627)"):new Error("This browser does not support WebCrypto.");const{privateKey:o,publicKey:s}=yield 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=W(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)}(yield crypto.subtle.exportKey("spki",s));e.publicKey=s;try{const o=yield 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&&(yield re(n,{type:"message-alert",title:"Authentication Alert",fields:{},alerts:o.alerts})),e}catch(e){throw yield oe(n,"Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:"We're having a problem authenticating right now.",messageParams:{}}).catch((()=>{})),e}}))}(t,n,r,o)}))}function ce(e,t){return O(this,void 0,void 0,(function*(){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=yield crypto.subtle.sign(r,t.nonExportablePrivateKey,o),i=W(s),a={grant_type:"refresh_token",refresh_token:t.refreshToken,scopes:["ACCESS_DB"],signature:i,signing_algorithm:r,time_stamp:n},c=yield 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 l=yield c.json();return t.accessToken=l.accessToken,t.accessTokenExpiration=l.accessTokenExpiration?new Date(l.accessTokenExpiration):void 0,t}))}const{toString:le}={};const ue={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 de(...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 ue;let s=n.get(r);if(void 0!==s)return s;const i=(o=e,le.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:ue),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 fe={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 pe={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 he={bigint:{replace:e=>({$t:"bigint",v:""+e}),revive:e=>BigInt(e.v)}};var ye={Date:{replace:e=>({$t:"Date",v:isNaN(e.getTime())?"NaN":e.toISOString()}),revive:({v:e})=>new Date("NaN"===e?NaN:Date.parse(e))}},me={Set:{replace:e=>({$t:"Set",v:Array.from(e.entries())}),revive:({v:e})=>new Set(e)}},ve={Map:{replace:e=>({$t:"Map",v:Array.from(e.entries())}),revive:({v:e})=>new Map(e)}};const be="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:"undefined"==typeof global?global:void 0;var ge=["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=be[t];return o&&new o(r.ArrayBuffer.revive({v:e},n,r))}}})),{});function _e(e){return function(e){for(var t="",n=0,r=e.length;n<r;n++)t+=ke[e[n]];return t}(W(e))}function we(e){return L(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+=Se[e[n]];return t}(e))}const Se={"-":"=",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:"+","|":"/"},ke={};for(const e of Object.keys(Se))ke[Se[e]]=e;var Ee={ArrayBuffer:{replace:e=>({$t:"ArrayBuffer",v:_e(e)}),revive:({v:e})=>{const t=we(e);return t.buffer.byteLength===t.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength)}}};class Ie{constructor(e,t){this.buf=e,this.type=t}}function xe(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 Ce(e){const t=new Uint8Array(e.length);for(let n=0;n<e.length;++n)t[n]=e.charCodeAt(n);return t.buffer}var Oe={Blob:{test:(e,t)=>"Blob"===t||e instanceof Ie,replace:e=>({$t:"Blob",v:W(e instanceof Ie?e.buf:Ce(xe(e))),type:e.type}),revive:({type:e,v:t})=>{const n=L(t);return void 0!==typeof Blob?new Blob([n]):new Ie(n.buffer,e)}}};const Te={...pe,...he,...ye,...me,...ve,...ge,...Ee,...Oe};function Ae(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 je={undefined:{replace:()=>({$t:"undefined"}),revive:()=>{}}};const $e="function"==typeof BigInt&&"bigint"==typeof BigInt(0);class Pe{toString(){return this.v}constructor(e){this.v=e}}const Ue=Object.assign(Object.assign({},je),$e?{}:{bigint:{test:e=>e instanceof Pe,replace:e=>Object.assign({$t:"bigint"},e),revive:({v:e})=>new Pe(e)}}),De=de(Te,Ue),Ne=function(...e){const t=de(Te,fe,...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 Ae(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 Ae(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)}}}(Ue);class Re extends Error{constructor(e,t){super(t||`${e.status} ${e.statusText}`),this.httpStatus=e.status}get name(){return"HttpError"}}function Le(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 l=s;i.forEach(((t,r)=>{const o=!c.outbound&&("upsert"===t.type||"insert"===t.type);t.keys.forEach(((t,i)=>{if(Array.isArray(t)){l===s&&(l=We(s,o));const n=l.muts[r],a=JSON.stringify(t);n.keys[i]=a,o&&e.setByKeyPath(n.values[i],c.keyPath,a)}else if("#"===t[0]){l===s&&(l=We(s,o));const a=l.muts[r];if(!n.isLoggedIn)throw new Error("Internal error: Cannot sync private IDs before authenticated");const u=`${t}:${n.userId}`;a.keys[i]=u,o&&e.setByKeyPath(a.values[i],c.keyPath,u)}}))})),o.push(l)}return o}function We(e,t){return Object.assign(Object.assign({},e),{muts:t?e.muts.map((e=>"insert"!==e.type&&"upsert"!==e.type||!e.values?Object.assign(Object.assign({},e),{keys:e.keys.slice()}):Object.assign(Object.assign({},e),{keys:e.keys.slice(),values:e.values.slice()}))):e.muts.map((e=>Object.assign(Object.assign({},e),{keys:e.keys.slice()})))})}function Be(e,t,n,r,o,s,i,a){return O(this,void 0,void 0,(function*(){const c={Accept:"application/json, application/x-bison, application/x-bison-stream","Content-Type":"application/tson"},l=yield function(e){var t,n;return O(this,void 0,void 0,(function*(){const r=yield e.getCurrentUser(),{accessToken:o,accessTokenExpiration:s,refreshToken:i,refreshTokenExpiration:a,claims:c}=r;if(!o)return;if((null!==(t=null==s?void 0:s.getTime())&&void 0!==t?t:1/0)>Date.now())return o;if(!i)throw new Error("Refresh token missing");if((null!==(n=null==a?void 0:a.getTime())&&void 0!==n?n:1/0)<=Date.now())throw new Error("Refresh token has expired");const l=yield ce(e.cloud.options.databaseUrl,r);return yield e.table("$logins").update(c.sub,{accessToken:l.accessToken,accessTokenExpiration:l.accessTokenExpiration}),l.accessToken}))}(r);l&&(c.Authorization=`Bearer ${l}`);const u={v:2,dbID:null==t?void 0:t.remoteDbId,clientIdentity:i,schema:s||{},lastPull:t?{serverRevision:t.serverRevision,realms:t.realms,inviteRealms:t.inviteRealms}:void 0,baseRevs:n,changes:Le(r.dx.core.schema,a,e)};console.debug("Sync request",u),r.syncStateChangedEvent.next({phase:"pushing"});const d=yield fetch(`${o}/sync`,{method:"post",headers:c,body:De.stringify(u)});if(r.syncStateChangedEvent.next({phase:"pulling"}),!d.ok)throw new Re(d);if("application/x-bison"===d.headers.get("content-type"))return Ne.fromBinary(yield d.blob());{const e=yield d.text();return De.parse(e)}}))}function Me(t){if(null==t?void 0:t.cancelled)throw new e.AbortError("Operation was cancelled")}let Fe=!1;function Ke(e,t,n,r){return O(this,void 0,void 0,(function*(){yield e.$baseRevs.bulkPut(Object.keys(t).filter((e=>t[e].markedForSync)).map((e=>({tableName:e,clientRev:(n[e]||0)+1,serverRev:r}))))}))}function He(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}function Ve(n,r,o){return O(this,void 0,void 0,(function*(){const s=yield n.bulkGet(r),i=[],a=[];r.forEach(((r,c)=>{const l=s[c];if(l){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(l,s,i);i.push(r),a.push(l)}})),yield null==n.schema.primKey.keyPath?n.bulkPut(a,i):n.bulkPut(a)}))}function qe(t,n){return O(this,void 0,void 0,(function*(){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(e){}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?yield t.bulkAdd(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),yield t.bulkAdd(n.values));break;case"upsert":s.outbound?yield t.bulkPut(n.values,r):(r.forEach(((t,r)=>{e.setByKeyPath(n.values[r],s.keyPath,t)})),yield t.bulkPut(n.values));break;case"modify":1===r.length?yield t.update(r[0],n.changeSpec):yield t.where(":id").anyOf(r).modify(n.changeSpec);break;case"update":yield Ve(t,r,n.changeSpecs);break;case"delete":yield t.bulkDelete(r)}}}}))}"undefined"!=typeof self&&"undefined"!=typeof navigator&&(Fe=navigator.onLine,self.addEventListener("online",(()=>Fe=!0)),self.addEventListener("offline",(()=>Fe=!1)));function Je(e,t,n,r){return ze.apply(this,arguments).then((()=>{(null==r?void 0:r.justCheckIfNeeded)||e.syncStateChangedEvent.next({phase:"in-sync"})})).catch((o=>O(this,void 0,void 0,(function*(){return(null==r?void 0:r.justCheckIfNeeded)?Promise.reject(o):(console.debug("Error from _sync",{isOnline:Fe,syncOptions:r,error:o}),Fe&&(null==r?void 0:r.retryImmediatelyOnFetchError)&&"TypeError"===(null==o?void 0:o.name)&&/fetch/.test(null==o?void 0:o.message)?(e.syncStateChangedEvent.next({phase:"error",error:o}),yield new Promise((e=>setTimeout(e,500))),yield Je(e,t,n,Object.assign(Object.assign({},r),{retryImmediatelyOnFetchError:!1}))):(yield e.$syncState.update("syncState",{timestamp:new Date,error:""+o}),e.syncStateChangedEvent.next({phase:Fe?"error":"offline",error:o}),Promise.reject(o)))}))))}function ze(e,t,n,{isInitialSync:r,cancelToken:o,justCheckIfNeeded:s,purpose:i}={isInitialSync:!1}){var a;return O(this,void 0,void 0,(function*(){if(s||console.debug("SYNC STARTED",{isInitialSync:r,purpose:i}),!(null===(a=e.cloud.options)||void 0===a?void 0:a.databaseUrl))throw new Error("Internal error: sync must not be called when no databaseUrl is configured");const{databaseUrl:c}=t,l=yield e.getCurrentUser(),u=l.isLoggedIn?M(e):[],d=u.map((t=>e.table(F(t.name)))),f=yield e.getPersistedSyncState(),p=!r&&l.isLoggedIn,h=p?function(e,t){const n=(null==t?void 0:t.syncedTables)||[];return M(e).filter((e=>!n.includes(e.name)))}(e,f):[];Me(o);const y=h.length>0;if(y){if(s)return!0;yield e.transaction("rw",h,(e=>O(this,void 0,void 0,(function*(){e.idbtrans.disableChangeTracking=!0,e.idbtrans.disableAccessControl=!0,yield function(e,t,n){return O(this,void 0,void 0,(function*(){const r=new Set(n||[]);for(const n of e)"members"===n.name?yield n.toCollection().modify((e=>{r.has(e.realmId)||e.userId&&e.userId!==T.userId||(e.userId=t.userId)})):"roles"===n.name||("realms"===n.name?yield n.toCollection().modify((e=>{r.has(e.realmId)||void 0!==e.owner&&e.owner!==T.userId||(e.owner=t.userId)})):yield n.toCollection().modify((e=>{e.realmId&&r.has(e.realmId)||(e.owner&&e.owner!==T.userId||(e.owner=t.userId),e.realmId&&e.realmId!==T.userId||(e.realmId=t.userId))})))}))}(h,l,null==f?void 0:f.realms)})))),Me(o)}const[m,v,b]=yield e.transaction("r",e.tables,(()=>O(this,void 0,void 0,(function*(){const t=yield e.getPersistedSyncState(),r=yield e.$baseRevs.toArray();let s=yield q(d);if(Me(o),y){const e=[...(null==f?void 0:f.realms)||[],...(null==f?void 0:f.inviteRealms)||[]],i=yield function(e,t,n,r){return O(this,void 0,void 0,(function*(){const o=`upload-${J(8)}`;if(t.isLoggedIn&&e.length>0){const s=new Set(r||[]);return(yield Promise.all(e.map((e=>O(this,void 0,void 0,(function*(){const{extractKey:r}=e.core.schema.primaryKey;if(!r)return{table:e.name,muts:[]};const i=n[e.name],a=(null==i?void 0:i.generatedGlobalId)?e.filter((e=>{return r(e),!s.has(e.realmId||"")&&(t=r(e),!(n=null==i?void 0:i.idPrefix)||"string"==typeof t&&t.startsWith(n));var t,n})):e.filter((e=>{const t=r(e);return!s.has(e.realmId||"")&&Q(t)})),c=yield 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[]}))}(h,l,n,e);return Me(o),s=s.concat(i),[s,t,r]}return[s,t,r]})))),g=m.some((e=>e.muts.some((e=>e.keys.length>0))));if(s)return console.debug("Sync is needed:",g),g;if("push"===i&&!g)return!1;const _=He(m,null==v?void 0:v.latestRevisions),w=(null==v?void 0:v.clientIdentity)||Z(16);Me(o);const S=yield Be(m,v,b,e,c,n,w,l);console.debug("Sync response",S);const k=yield e.transaction("rw",e.tables,(t=>O(this,void 0,void 0,(function*(){t.idbtrans.disableChangeTracking=!0,t.idbtrans.disableAccessControl=!0;for(const e of Object.keys(n))S.schema[e]&&(n[e]=S.schema[e]);yield e.$syncState.put(n,"schema");const r=yield q(d,0,{since:_});for(const t of d){const n=K(t.name);if(r.some((e=>e.table===n&&e.muts.length>0))){if(_[n]){const r=_[n]||0;yield 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 yield Promise.all([t.clear(),e.$baseRevs.where({tableName:n}).delete()])}He(r,_),yield Ke(e,n,_,S.serverRevision);const o=yield e.getPersistedSyncState();yield function(e,t,n){return O(this,void 0,void 0,(function*(){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=M(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]))?yield e.where("realmId").anyOf([...t]).delete():yield e.filter((e=>!!(null==e?void 0:e.realmId)&&t.has(e.realmId))).delete())}}}))}(e,S,o);const s=o||{syncedTables:[],latestRevisions:{},realms:[],inviteRealms:[],clientIdentity:w};p&&(s.syncedTables=u.map((e=>e.name)).concat(h.map((e=>e.name)))),s.latestRevisions=_,s.remoteDbId=S.dbId,s.initiallySynced=!0,s.realms=S.realms,s.inviteRealms=S.inviteRealms,s.serverRevision=S.serverRevision,s.timestamp=new Date,delete s.error;const i=Ge(S.changes,r);return yield qe(i,e),e.$syncState.put(s,"syncState"),0===r.length}))));return k?(console.debug("SYNC DONE",{isInitialSync:r}),e.syncCompleteEvent.next(),!1):(console.debug("MORE SYNC NEEDED. Go for it again!"),yield ze(e,t,n,{isInitialSync:r,cancelToken:o}))}))}function Ge(e,t){const n={};ne(n,e);const r={};return ne(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))Y(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,t=""){t||(t=Z(16));const 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 Ye(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((()=>O(this,void 0,void 0,(function*(){if(!i&&n.length>0){i=!0,c.shift(),c.push(Date.now()),r.next(!1);try{yield function(){var r,o,s,i,a,c;return O(this,void 0,void 0,(function*(){for(;n.length>0;){const l=n.shift();try{yield t.cloud.syncState.pipe(m((({phase:e})=>"in-sync"===e||"error"===e)),v(1)).toPromise(),console.debug("processing msg",l);const n=t.cloud.persistedSyncState.value;if(!l)continue;switch(l.type){case"token-expired":console.debug("WebSocket observable: Token expired. Refreshing token...");const u=t.cloud.currentUser.value,d=yield ce(t.cloud.options.databaseUrl,u);yield t.table("$logins").update(u.userId,{accessToken:d.accessToken,accessTokenExpiration:d.accessTokenExpiration});break;case"realm-added":(null===(r=null==n?void 0:n.realms)||void 0===r?void 0:r.includes(l.realm))||(null===(o=null==n?void 0:n.inviteRealms)||void 0===o?void 0:o.includes(l.realm))||(yield t.cloud.sync({purpose:"pull",wait:!0}));break;case"realm-accepted":(null===(s=null==n?void 0:n.realms)||void 0===s?void 0:s.includes(l.realm))||(yield t.cloud.sync({purpose:"pull",wait:!0}));break;case"realm-removed":((null===(i=null==n?void 0:n.realms)||void 0===i?void 0:i.includes(l.realm))||(null===(a=null==n?void 0:n.inviteRealms)||void 0===a?void 0:a.includes(l.realm)))&&(yield t.cloud.sync({purpose:"pull",wait:!0}));break;case"realms-changed":yield t.cloud.sync({purpose:"pull",wait:!0});break;case"changes":if(console.debug("changes"),"error"===(null===(c=t.cloud.syncState.value)||void 0===c?void 0:c.phase)){R(t,"pull");break}yield t.transaction("rw",t.dx.tables,(n=>O(this,void 0,void 0,(function*(){n.idbtrans.disableChangeTracking=!0,n.idbtrans.disableAccessControl=!0;const[r,o,s]=yield Promise.all([t.getSchema(),t.getPersistedSyncState(),t.getCurrentUser()]);if(console.debug("ws message queue: in transaction"),!o||!r||!s)return void console.debug("required vars not present",{syncState:o,schema:r,currentUser:s});if(l.baseRev!==o.serverRevision)return console.debug(`baseRev (${l.baseRev}) differs from our serverRevision in syncState (${o.serverRevision})`),void("string"!=typeof l.baseRev||"bigint"!=typeof o.serverRevision&&"object"!=typeof o.serverRevision||R(t,"pull"));const i=yield e.waitFor(B(o));if(console.debug("ourRealmSetHash",i),i!==l.realmSetHash)return console.debug("not same realmSetHash",l.realmSetHash),void R(t,"pull");let a=[];if(s.isLoggedIn){const e=M(t).map((e=>t.table(F(e.name))));a=yield q(e),console.debug("msg queue: client changes",a)}if(l.changes.length>0){const e=Ge(l.changes,a);console.debug("applying filtered server changes",e),yield qe(e,t)}o.latestRevisions=He(a,o.latestRevisions),o.serverRevision=l.newRev,console.debug("Updating baseRefs",o.latestRevisions),yield Ke(t,r,o.latestRevisions,l.newRev),console.debug("Updating syncState",o),yield t.$syncState.put(o,"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,yield new Promise((e=>setTimeout(e,6e4)))):(console.warn("Slowing down websocket loop for 10 seconds"),a=Date.now()+1e4,yield new Promise((e=>setTimeout(e,1e4))))),i=!1,r.next(!0)}}})))),{enqueue:function(e){n.push(e),s.next(null)},readyToServe:r}}const Ze=new WeakMap,Xe={members:"@id, [userId+realmId], [email+realmId], realmId",roles:"[realmId+name]",realms:"@realmId",$jobs:"",$syncState:"",$baseRevs:"[tableName+clientRev]",$logins:"claims.sub, lastLogin"};let Qe=0;function et(e){"vip"in e&&(e=e.vip);let t=Ze.get(e.cloud);if(!t){const n=new s;let r=new U(`syncstatechanged-${e.name}`),o=new U(`synccomplete-${e.name}`);n.id=++Qe;let i=!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 i},localSyncEvent:n,get syncStateChangedEvent(){return r},get syncCompleteEvent(){return o},dx:e};const a={getCurrentUser:()=>t.$logins.toArray().then((e=>e.find((e=>e.isLoggedIn))||T)),getPersistedSyncState:()=>t.$syncState.get("syncState"),getSchema:()=>t.$syncState.get("schema").then((e=>{if(e)for(const r of t.tables)r.schema.primKey&&r.schema.primKey.keyPath&&e[r.name]&&(e[r.name].primaryKey="string"==typeof(n=r.schema.primKey.keyPath)?n:n?"["+[].join.call(n,"+")+"]":"");var n;return e})),getOptions:()=>t.$syncState.get("options"),setInitiallySynced(e){i=e},reconfigure(){r=new U(`syncstatechanged-${e.name}`),o=new U(`synccomplete-${e.name}`)}};Object.assign(t,a),t.messageConsumer=Ye(t),Ze.set(e.cloud,t)}return t}const tt=new WeakMap;class nt{constructor(e,t){tt.set(this,e),Object.assign(this,t)}static load(e,t){return e.table("$logins").get(t).then((n=>new nt(e,n||{userId:t,claims:{sub:t},lastLogin:new Date(0)})))}save(){return O(this,void 0,void 0,(function*(){tt.get(this).table("$logins").put(this)}))}}function rt(e,t){return O(this,void 0,void 0,(function*(){if((yield 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!1}const n=new nt(e,{claims:{},lastLogin:new Date(0)});yield ae(e.cloud.options.databaseUrl,n,e.cloud.options.fetchTokens||function(e){const{userInteraction:t}=e.cloud;return function({public_key:n,hints:r}){var o;return O(this,void 0,void 0,(function*(){let s;const i=null===(o=e.cloud.options)||void 0===o?void 0:o.databaseUrl;if(!i)throw new Error("No database URL given.");s="demo"===(null==r?void 0:r.grant_type)?{demo_user:yield se(t,"Enter a demo user email",(null==r?void 0:r.email)||(null==r?void 0:r.userId)),grant_type:"demo",scopes:["ACCESS_DB"],public_key:n}:{email:yield se(t,"Enter email address",null==r?void 0:r.email),grant_type:"otp",scopes:["ACCESS_DB"],public_key:n};const a=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json",mode:"cors"}});if(200!==a.status){const e=yield a.text();throw yield oe(t,"Token request failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Re(a,e)}const c=yield a.json();if("tokens"===c.type)return c;if("otp"===s.grant_type){if("otp-sent"!==c.type)throw new Error(`Unexpected response from ${i}/token`);const e=yield ie(t,s.email);s.otp=e||"",s.otp_id=c.otp_id;let n=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"});for(;401===n.status;){const e=yield n.text();s.otp=yield ie(t,s.email,{type:"error",messageCode:"INVALID_OTP",message:e,messageParams:{}}),n=yield fetch(`${i}/token`,{body:JSON.stringify(s),method:"post",headers:{"Content-Type":"application/json"},mode:"cors"})}if(200!==n.status){const e=yield n.text();throw yield oe(t,"OTP Authentication Failed",{type:"error",messageCode:"GENERIC_ERROR",message:e,messageParams:{}}).catch((()=>{})),new Re(n,e)}return yield n.json()}throw new Error(`Unexpected response from ${i}/token`)}))}}(e),e.cloud.userInteraction,t);try{yield n.save()}catch(e){try{"DataCloneError"===e.name&&(console.debug("Login context property names:",Object.keys(n)),console.debug("Login context:",n),console.debug("Login context JSON:",JSON.stringify(n)))}catch(e){}throw e}return yield function(e,t){return O(this,void 0,void 0,(function*(){if(t.userId===e.cloud.currentUserId)return;const n=e.table("$logins");yield e.transaction("rw",n,(e=>O(this,void 0,void 0,(function*(){const e=yield n.toArray();yield Promise.all(e.filter((e=>e.userId!==t.userId&&e.isLoggedIn)).map((e=>(e.isLoggedIn=!1,n.put(e))))),t.isLoggedIn=!0,t.lastLogin=new Date,yield t.save(),console.debug("Saved new user",t.email)})))),yield 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),R(e,"pull"),!0}))}const ot="undefined"!=typeof InstallTrigger,st="undefined"!=typeof navigator&&/Safari\//.test(navigator.userAgent)&&!/Chrom(e|ium)\/|Edge\//.test(navigator.userAgent),it=st?[].concat(navigator.userAgent.match(/Safari\/(\d*)/))[1]:NaN,at=st&&it<=605||ot;const ct="undefined"!=typeof self&&"clients"in self&&!self.document;function lt(){throw new e.SchemaError("Version increment needed to allow dexie-cloud change tracking")}const{toString:ut}={};function dt(e){return ut.call(e).slice(8,-1)}function ft(e,t){var n;return"delete"===t.type?t.keys:(null===(n=t.keys)||void 0===n?void 0:n.slice())||t.values.map(e.extractKey)}const pt=/b|c|d|f|g|h|j|k|l|m|n|p|q|r|s|t|v|x|y|z/i;let ht=0;function yt(e,t){const n=new Uint8Array(18),r=new Uint8Array(n.buffer,0,6),o=Date.now();ht>=o?++ht:ht=o,r[0]=ht/1099511627776,r[1]=ht/4294967296,r[2]=ht/16777216,r[3]=ht/65536,r[4]=ht/256,r[5]=ht;const s=new Uint8Array(n.buffer,6);crypto.getRandomValues(s);return e+_e(new Uint8Array(n.buffer))+(t||"")}function mt(t){return{stack:"dbcore",name:"idGenerationMiddleware",level:1,create:n=>Object.assign(Object.assign({},n),{table:r=>{const o=n.table(r);return Object.assign(Object.assign({},o),{mutate:n=>{var s,i;if(n.trans.disableChangeTracking)return o.mutate(n);if("add"===n.type||"put"===n.type){const a=null===(s=t.cloud.schema)||void 0===s?void 0:s[r];if(null==a?void 0:a.generatedGlobalId){if((null===(i=t.cloud.options)||void 0===i?void 0:i.databaseUrl)&&!t.initiallySynced){const e=ft(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=ft(o.schema.primaryKey,n);return a.forEach(((c,l)=>{if(void 0===c){const r=n.values[l].realmId||t.cloud.currentUserId,c=r.substr(r.length-3);a[l]=yt(s,c),o.schema.primaryKey.outbound||(i||(i=n.values.slice()),i[l]=e.deepClone(i[l]),e.setByKeyPath(i[l],o.schema.primaryKey.keyPath,a[l]))}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(Object.assign(Object.assign({},n),{keys:a,values:i||n.values}))}(n,a.idPrefix)}if(null==a?void 0:a.markedForSync){ft(o.schema.primaryKey,n).forEach(((t,n)=>{if(!Q(t)){const n=Array.isArray(t)?t.map(dt).join(","):dt(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 vt=0;function bt(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 gt(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 _t=new o(new Set);function wt({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(e){lt()}return Object.assign(Object.assign({},n),{transaction:(r,o)=>{let s;if("readwrite"===o){const e=r.filter((e=>{var n,r;return null===(r=null===(n=t.cloud.schema)||void 0===n?void 0:n[e])||void 0===r?void 0:r.markedForSync})).map((e=>F(e)));s=n.transaction([...r,...e],o)}else s=n.transaction(r,o);if("readwrite"===o){s.txid=J(16),s.currentUser=e.value,_t.value.add(s),_t.next(_t.value);const n=()=>{s.removeEventListener("complete",r),s.removeEventListener("error",n),s.removeEventListener("abort",n),_t.value.delete(s),_t.next(_t.value)},r=()=>{var e;s.mutationsAdded&&(null===(e=t.cloud.options)||void 0===e?void 0:e.databaseUrl)&&(t.cloud.usingServiceWorker?(console.debug("registering sync event"),N(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")?Object.assign(Object.assign({},r),{mutate:e=>("add"!==e.type&&"put"!==e.type||(e.trans.mutationsAdded=!0),r.mutate(e))}):"$logins"===e?Object.assign(Object.assign({},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"+ ++vt;return Object.assign(Object.assign({},e),{count:bt(e.count,t),get:bt(e.get,t),getMany:bt(e.getMany,t),openCursor:bt(e.openCursor,t),query:bt(e.query,t),mutate:gt(e.mutate,t)})}(Object.assign(Object.assign({},r),{mutate:n=>{var o,i,c;const l=n.trans;return l.txid?l.disableChangeTracking?r.mutate(n):(null===(i=null===(o=t.cloud.schema)||void 0===o?void 0:o[e])||void 0===i?void 0:i.markedForSync)&&(null===(c=l.currentUser)||void 0===c?void 0:c.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 l="delete"===s?e.keys:r.results,u="values"in e?e.values:[],d="updates"in e&&e.updates;a&&(l=l.filter(((e,t)=>!c[t])),u=u.filter(((e,t)=>!c[t])));const f=Date.now(),p="delete"===e.type?{type:"delete",ts:f,keys:l,criteria:e.criteria,txid:n,userId:o}:"add"===e.type?{type:"insert",ts:f,keys:l,txid:n,userId:o,values:u}:e.criteria&&e.changeSpec?{type:"modify",ts:f,keys:l,criteria:e.criteria,changeSpec:e.changeSpec,txid:n,userId:o}:d?{type:"update",ts:f,keys:d.keys,changeSpecs:d.changeSpecs,txid:n,userId:o}:{type:"upsert",ts:f,keys:l,values:u,txid:n,userId:o};return l.length>0||"criteria"in e&&e.criteria?i.mutate({type:"add",trans:t,values:[p]}).then((()=>r)):r}))}}})}}}function St(e,t){return function(n,r){const o=Object.assign(Object.assign({},Xe),n);Object.keys(Xe).forEach((e=>{const t=o[e];if(null==t)throw new Error(`Cannot delete table ${e} as it is needed for access control of Dexie Cloud`);if(!n[e])return;const r=t.split(",").map((e=>e.trim())),s=Xe[e].split(",").map((e=>e.trim())),i=new Set(r.map((e=>e.replace(/([&*]|\+\+)/g,""))));if(r[0]!==s[0])throw new Error(`Cannot override primary key of table ${e}. Please declare it as {${e}: ${JSON.stringify(Xe[e])}`);for(let t=1;t<s.length;++t){const n=s[t];i.has(n.replace(/([&*]|\+\+)/g,""))||(o[e]+=`,${n}`)}}));const 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)(pt.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 kt=new o(!0),Et=new o(!0);kt.pipe(b((e=>e?i(!0):i(!1).pipe(g(2e4)))),_()).subscribe(Et);const It="undefined"!=typeof document?a(document,"visibilitychange"):i({}),xt=It.pipe(m((()=>"hidden"===document.visibilityState))),Ct=It.pipe(m((()=>"visible"===document.visibilityState))),Ot="undefined"!=typeof window?c(Ct,a(window,"mousedown"),a(window,"mousemove"),a(window,"keydown"),a(window,"wheel"),a(window,"touchmove")):i({});"undefined"!=typeof document&&c(i(!0),xt,Ot).pipe(w((()=>"visible"===document.visibilityState)),S((e=>{kt.value!==e&&kt.next(e)})),b((e=>e?i(0).pipe(g(16e4),S((()=>kt.next(!1)))):i(0)))).subscribe((()=>{}));class Tt extends Error{constructor(){super(...arguments),this.name="TokenExpiredError"}}class At extends r{constructor(e,t,n,r,o,s,i,a){super((c=>new $t(e,t,n,r,i,a,c,o,s)))}}let jt=0;class $t extends l{constructor(e,t,n,r,o,s,i,a,c){super((()=>this.teardown())),this.id=++jt,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(e){}this.ws=null,this.messageProducerSubscription&&(this.messageProducerSubscription.unsubscribe(),this.messageProducerSubscription=null)}reconnect(){if(!this.reconnecting){this.reconnecting=!0;try{this.disconnect()}catch(e){}this.connect().catch((()=>{})).then((()=>this.reconnecting=!1))}}connect(){return O(this,void 0,void 0,(function*(){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 Tt);this.webSocketStatus.next("connecting"),this.pinger=setInterval((()=>O(this,void 0,void 0,(function*(){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(e){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=De.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;yield 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=>{var t;this.closed||("ready"===e.type&&"connected"!==this.webSocketStatus.value&&this.webSocketStatus.next("connected"),null===(t=this.ws)||void 0===t||t.send(De.stringify(e)))}))}catch(e){this.pauseUntil=new Date(Date.now()+6e4)}}))}}function Pt(e){return O(this,void 0,void 0,(function*(){var t;console.error("WebSocket observable: error but revive when user does some active thing...",e),yield(t=3e3,new Promise((e=>setTimeout(e,t)))),console.debug("waiting for someone to do something"),yield Ot.pipe(v(1)).toPromise(),console.debug("someone did something!")}))}function Ut(e){var t;return O(this,void 0,void 0,(function*(){return!(!(null===(t=e.cloud.options)||void 0===t?void 0:t.databaseUrl)||!e.cloud.schema)&&(yield Je(e,e.cloud.options,e.cloud.schema,{justCheckIfNeeded:!0}))}))}const Dt=J(16);const Nt=new WeakMap;function Rt(e,t,r,o){const s=Nt.get(e);if(s){if(s.pull||"push"===(null==o?void 0:o.purpose))return console.debug("syncIfPossible(): returning the ongoing sync promise."),s.promise;{let n=!1;const i=e.cloud.syncState.subscribe((e=>{"pulling"===e.phase&&(n=!0)}));return s.promise.then((()=>{i.unsubscribe()})).catch((e=>(i.unsubscribe(),Promise.reject(e)))).then((()=>{if(!n)return Rt(e,t,r,o)}))}}const i=function(){return O(this,void 0,void 0,(function*(){try{if(e.cloud.isServiceWorkerDB)yield Je(e,t,r,o);else{if(e.cloud.usingServiceWorker)throw z(!1),new Error("Internal _syncIfPossible() - invalid precondition - should not have been called.");yield function(e,t,r,o,{awaitRemoteJob:s}={}){return O(this,void 0,void 0,(function*(){const i=e.table(r);if(yield function o(){return O(this,void 0,void 0,(function*(){if(yield e.transaction("rw!",r,(()=>O(this,void 0,void 0,(function*(){const e=yield i.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!"),yield i.put({nodeId:Dt,started:new Date,heartbeat:new Date},t),!0):(yield i.add({nodeId:Dt,started:new Date,heartbeat:new Date},t),!0)})))))return!0;if(s)try{const e=u(n((()=>i.get(t)))).pipe(E(6e4),m((e=>!e)));return yield e.toPromise(),!1}catch(e){if("TimeoutError"!==e.name)throw e;return yield o()}return!1}))}()){const n=setInterval((()=>{i.update(t,(e=>{e.nodeId===Dt&&(e.heartbeat=new Date)}))}),1e3);try{return yield o()}finally{clearInterval(n),yield e.transaction("rw!",r,(()=>O(this,void 0,void 0,(function*(){const e=yield i.get(t);e&&e.nodeId===Dt&&(yield i.delete(t))}))))}}}))}(e,"currentSyncWorker","$jobs",(()=>Je(e,t,r,o)))}Nt.delete(e),console.debug("Done sync")}catch(t){throw Nt.delete(e),console.error("Failed to sync client changes",t),t}}))}();return Nt.set(e,{promise:i,pull:"push"!==(null==o?void 0:o.purpose)}),i}function Lt(e,t,n){let r=null,o={cancelled:!1};function s(r,a=1){setTimeout((()=>{Rt(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 Wt(e,t){if(e&&t&&t.unsyncedTables)for(const n of t.unsyncedTables)e[n]&&(e[n].markedForSync=!1)}var Bt,Mt,Ft,Kt,Ht,Vt={},qt=[],Jt=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;function zt(e,t){for(var n in t)e[n]=t[n];return e}function Gt(e){var t=e.parentNode;t&&t.removeChild(e)}function Yt(e,t,n){var r,o,s,i={};for(s in t)"key"==s?r=t[s]:"ref"==s?o=t[s]:i[s]=t[s];if(arguments.length>2&&(i.children=arguments.length>3?Bt.call(arguments,2):n),"function"==typeof e&&null!=e.defaultProps)for(s in e.defaultProps)void 0===i[s]&&(i[s]=e.defaultProps[s]);return Zt(e,i,r,o,null)}function Zt(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?++Ft:o};return null==o&&null!=Mt.vnode&&Mt.vnode(s),s}function Xt(e){return e.children}function Qt(e,t){this.props=e,this.context=t}function en(e,t){if(null==t)return e.__?en(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?en(e):null}function tn(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 tn(e)}}function nn(e){(!e.__d&&(e.__d=!0)&&Kt.push(e)&&!rn.__r++||Ht!==Mt.debounceRendering)&&((Ht=Mt.debounceRendering)||setTimeout)(rn)}function rn(){for(var e;rn.__r=Kt.length;)e=Kt.sort((function(e,t){return e.__v.__b-t.__v.__b})),Kt=[],e.some((function(e){var t,n,r,o,s,i;e.__d&&(s=(o=(t=e).__v).__e,(i=t.__P)&&(n=[],(r=zt({},o)).__v=o.__v+1,fn(i,o,r,t.__n,void 0!==i.ownerSVGElement,null!=o.__h?[s]:null,n,null==s?en(o):s,o.__h),pn(n,o),o.__e!=s&&tn(o)))}))}function on(e,t,n,r,o,s,i,a,c,l){var u,d,f,p,h,y,m,v=r&&r.__k||qt,b=v.length;for(n.__k=[],u=0;u<t.length;u++)if(null!=(p=n.__k[u]=null==(p=t[u])||"boolean"==typeof p?null:"string"==typeof p||"number"==typeof p||"bigint"==typeof p?Zt(null,p,null,null,p):Array.isArray(p)?Zt(Xt,{children:p},null,null,null):p.__b>0?Zt(p.type,p.props,p.key,null,p.__v):p)){if(p.__=n,p.__b=n.__b+1,null===(f=v[u])||f&&p.key==f.key&&p.type===f.type)v[u]=void 0;else for(d=0;d<b;d++){if((f=v[d])&&p.key==f.key&&p.type===f.type){v[d]=void 0;break}f=null}fn(e,p,f=f||Vt,o,s,i,a,c,l),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&&p.__k===f.__k?p.__d=c=sn(p,c,e):c=an(e,p,f,v,h,c),"function"==typeof n.type&&(n.__d=c)):c&&f.__e==c&&c.parentNode!=e&&(c=en(f))}for(n.__e=y,u=b;u--;)null!=v[u]&&("function"==typeof n.type&&null!=v[u].__e&&v[u].__e==n.__d&&(n.__d=en(r,u+1)),mn(v[u],v[u]));if(m)for(u=0;u<m.length;u++)yn(m[u],m[++u],m[++u])}function sn(e,t,n){for(var r,o=e.__k,s=0;o&&s<o.length;s++)(r=o[s])&&(r.__=e,t="function"==typeof r.type?sn(r,t,n):an(n,r,r,o,r.__e,t));return t}function an(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 cn(e,t,n){"-"===t[0]?e.setProperty(t,n):e[t]=null==n?"":"number"!=typeof n||Jt.test(t)?n:n+"px"}function ln(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||cn(e.style,t,"");if(n)for(t in n)r&&n[t]===r[t]||cn(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?dn:un,s):e.removeEventListener(t,s?dn:un,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 un(e){this.l[e.type+!1](Mt.event?Mt.event(e):e)}function dn(e){this.l[e.type+!0](Mt.event?Mt.event(e):e)}function fn(e,t,n,r,o,s,i,a,c){var l,u,d,f,p,h,y,m,v,b,g,_,w,S=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]),(l=Mt.__b)&&l(t);try{e:if("function"==typeof S){if(m=t.props,v=(l=S.contextType)&&r[l.__c],b=l?v?v.props.value:l.__:r,n.__c?y=(u=t.__c=n.__c).__=u.__E:("prototype"in S&&S.prototype.render?t.__c=u=new S(m,b):(t.__c=u=new Qt(m,b),u.constructor=S,u.render=vn),v&&v.sub(u),u.props=m,u.state||(u.state={}),u.context=b,u.__n=r,d=u.__d=!0,u.__h=[]),null==u.__s&&(u.__s=u.state),null!=S.getDerivedStateFromProps&&(u.__s==u.state&&(u.__s=zt({},u.__s)),zt(u.__s,S.getDerivedStateFromProps(m,u.__s))),f=u.props,p=u.state,d)null==S.getDerivedStateFromProps&&null!=u.componentWillMount&&u.componentWillMount(),null!=u.componentDidMount&&u.__h.push(u.componentDidMount);else{if(null==S.getDerivedStateFromProps&&m!==f&&null!=u.componentWillReceiveProps&&u.componentWillReceiveProps(m,b),!u.__e&&null!=u.shouldComponentUpdate&&!1===u.shouldComponentUpdate(m,u.__s,b)||t.__v===n.__v){u.props=m,u.state=u.__s,t.__v!==n.__v&&(u.__d=!1),u.__v=t,t.__e=n.__e,t.__k=n.__k,t.__k.forEach((function(e){e&&(e.__=t)})),u.__h.length&&i.push(u);break e}null!=u.componentWillUpdate&&u.componentWillUpdate(m,u.__s,b),null!=u.componentDidUpdate&&u.__h.push((function(){u.componentDidUpdate(f,p,h)}))}if(u.context=b,u.props=m,u.__v=t,u.__P=e,g=Mt.__r,_=0,"prototype"in S&&S.prototype.render)u.state=u.__s,u.__d=!1,g&&g(t),l=u.render(u.props,u.state,u.context);else do{u.__d=!1,g&&g(t),l=u.render(u.props,u.state,u.context),u.state=u.__s}while(u.__d&&++_<25);u.state=u.__s,null!=u.getChildContext&&(r=zt(zt({},r),u.getChildContext())),d||null==u.getSnapshotBeforeUpdate||(h=u.getSnapshotBeforeUpdate(f,p)),w=null!=l&&l.type===Xt&&null==l.key?l.props.children:l,on(e,Array.isArray(w)?w:[w],t,n,r,o,s,i,a,c),u.base=t.__e,t.__h=null,u.__h.length&&i.push(u),y&&(u.__E=u.__=null),u.__e=!1}else null==s&&t.__v===n.__v?(t.__k=n.__k,t.__e=n.__e):t.__e=hn(n.__e,t,n,r,o,s,i,c);(l=Mt.diffed)&&l(t)}catch(e){t.__v=null,(c||null!=s)&&(t.__e=a,t.__h=!!c,s[s.indexOf(a)]=null),Mt.__e(e,t,n)}}function pn(e,t){Mt.__c&&Mt.__c(t,e),e.some((function(t){try{e=t.__h,t.__h=[],e.some((function(e){e.call(t)}))}catch(e){Mt.__e(e,t.__v)}}))}function hn(e,t,n,r,o,s,i,a){var c,l,u,d=n.props,f=t.props,p=t.type,h=0;if("svg"===p&&(o=!0),null!=s)for(;h<s.length;h++)if((c=s[h])&&"setAttribute"in c==!!p&&(p?c.localName===p:3===c.nodeType)){e=c,s[h]=null;break}if(null==e){if(null===p)return document.createTextNode(f);e=o?document.createElementNS("http://www.w3.org/2000/svg",p):document.createElement(p,f.is&&f),s=null,a=!1}if(null===p)d===f||a&&e.data===f||(e.data=f);else{if(s=s&&Bt.call(e.childNodes),l=(d=n.props||Vt).dangerouslySetInnerHTML,u=f.dangerouslySetInnerHTML,!a){if(null!=s)for(d={},h=0;h<e.attributes.length;h++)d[e.attributes[h].name]=e.attributes[h].value;(u||l)&&(u&&(l&&u.__html==l.__html||u.__html===e.innerHTML)||(e.innerHTML=u&&u.__html||""))}if(function(e,t,n,r,o){var s;for(s in n)"children"===s||"key"===s||s in t||ln(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]||ln(e,s,t[s],n[s],r)}(e,f,d,o,a),u)t.__k=[];else if(h=t.props.children,on(e,Array.isArray(h)?h:[h],t,n,r,o&&"foreignObject"!==p,s,i,s?s[0]:n.__k&&en(n,0),a),null!=s)for(h=s.length;h--;)null!=s[h]&&Gt(s[h]);a||("value"in f&&void 0!==(h=f.value)&&(h!==e.value||"progress"===p&&!h||"option"===p&&h!==d.value)&&ln(e,"value",h,d.value,!1),"checked"in f&&void 0!==(h=f.checked)&&h!==e.checked&&ln(e,"checked",h,d.checked,!1))}return e}function yn(e,t,n){try{"function"==typeof e?e(t):e.current=t}catch(e){Mt.__e(e,n)}}function mn(e,t,n){var r,o;if(Mt.unmount&&Mt.unmount(e),(r=e.ref)&&(r.current&&r.current!==e.__e||yn(r,null,t)),null!=(r=e.__c)){if(r.componentWillUnmount)try{r.componentWillUnmount()}catch(e){Mt.__e(e,t)}r.base=r.__P=null}if(r=e.__k)for(o=0;o<r.length;o++)r[o]&&mn(r[o],t,"function"!=typeof e.type);n||null==e.__e||Gt(e.__e),e.__e=e.__d=void 0}function vn(e,t,n){return this.constructor(e,n)}function bn(e,t,n){var r,o,s;Mt.__&&Mt.__(e,t),o=(r="function"==typeof n)?null:n&&n.__k||t.__k,s=[],fn(t,e=(!r&&n||t).__k=Yt(Xt,null,[e]),o||Vt,Vt,void 0!==t.ownerSVGElement,!r&&n?[n]:o?null:t.firstChild?Bt.call(t.childNodes):null,s,!r&&n?n:o?o.__e:t.firstChild,r),pn(s,e)}Bt=qt.slice,Mt={__e:function(e,t,n,r){for(var o,s,i;t=t.__;)if((o=t.__c)&&!o.__)try{if((s=o.constructor)&&null!=s.getDerivedStateFromError&&(o.setState(s.getDerivedStateFromError(e)),i=o.__d),null!=o.componentDidCatch&&(o.componentDidCatch(e,r||{}),i=o.__d),i)return o.__E=o}catch(t){e=t}throw e}},Ft=0,Qt.prototype.setState=function(e,t){var n;n=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=zt({},this.state),"function"==typeof e&&(e=e(zt({},n),this.props)),e&&zt(n,e),null!=e&&this.__v&&(t&&this.__h.push(t),nn(this))},Qt.prototype.forceUpdate=function(e){this.__v&&(this.__e=!0,e&&this.__h.push(e),nn(this))},Qt.prototype.render=Xt,Kt=[],rn.__r=0;const gn={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 _n({children:e,className:t}){return Yt("div",{className:t},Yt("div",{style:gn.Darken}),Yt("div",{style:gn.DialogOuter},Yt("div",{style:gn.DialogInner},e)))}var wn,Sn,kn,En,In=0,xn=[],Cn=[],On=Mt.__b,Tn=Mt.__r,An=Mt.diffed,jn=Mt.__c,$n=Mt.unmount;function Pn(e,t){Mt.__h&&Mt.__h(Sn,e,In||t),In=0;var n=Sn.__H||(Sn.__H={__:[],__h:[]});return e>=n.__.length&&n.__.push({__V:Cn}),n.__[e]}function Un(e){return In=1,function(e,t,n){var r=Pn(wn++,2);if(r.t=e,!r.__c&&(r.__=[n?n(t):Mn(void 0,t),function(e){var t=r.__N?r.__N[0]:r.__[0],n=r.t(t,e);t!==n&&(r.__N=[n,r.__[1]],r.__c.setState({}))}],r.__c=Sn,!Sn.u)){Sn.u=!0;var o=Sn.shouldComponentUpdate;Sn.shouldComponentUpdate=function(e,t,n){if(!r.__c.__H)return!0;var s=r.__c.__H.__.filter((function(e){return e.__c}));if(s.every((function(e){return!e.__N})))return!o||o.call(this,e,t,n);var i=!1;return s.forEach((function(e){if(e.__N){var t=e.__[0];e.__=e.__N,e.__N=void 0,t!==e.__[0]&&(i=!0)}})),!!i&&(!o||o.call(this,e,t,n))}}return r.__N||r.__}(Mn,e)}function Dn(e){return In=5,function(e,t){var n=Pn(wn++,7);return Bn(n.__H,t)?(n.__V=e(),n.i=t,n.__h=e,n.__V):n.__}((function(){return{current:e}}),[])}function Nn(){for(var e;e=xn.shift();)if(e.__P&&e.__H)try{e.__H.__h.forEach(Ln),e.__H.__h.forEach(Wn),e.__H.__h=[]}catch(t){e.__H.__h=[],Mt.__e(t,e.__v)}}Mt.__b=function(e){Sn=null,On&&On(e)},Mt.__r=function(e){Tn&&Tn(e),wn=0;var t=(Sn=e.__c).__H;t&&(kn===Sn?(t.__h=[],Sn.__h=[],t.__.forEach((function(e){e.__N&&(e.__=e.__N),e.__V=Cn,e.__N=e.i=void 0}))):(t.__h.forEach(Ln),t.__h.forEach(Wn),t.__h=[])),kn=Sn},Mt.diffed=function(e){An&&An(e);var t=e.__c;t&&t.__H&&(t.__H.__h.length&&(1!==xn.push(t)&&En===Mt.requestAnimationFrame||((En=Mt.requestAnimationFrame)||function(e){var t,n=function(){clearTimeout(r),Rn&&cancelAnimationFrame(t),setTimeout(e)},r=setTimeout(n,100);Rn&&(t=requestAnimationFrame(n))})(Nn)),t.__H.__.forEach((function(e){e.i&&(e.__H=e.i),e.__V!==Cn&&(e.__=e.__V),e.i=void 0,e.__V=Cn}))),kn=Sn=null},Mt.__c=function(e,t){t.some((function(e){try{e.__h.forEach(Ln),e.__h=e.__h.filter((function(e){return!e.__||Wn(e)}))}catch(n){t.some((function(e){e.__h&&(e.__h=[])})),t=[],Mt.__e(n,e.__v)}})),jn&&jn(e,t)},Mt.unmount=function(e){$n&&$n(e);var t,n=e.__c;n&&n.__H&&(n.__H.__.forEach((function(e){try{Ln(e)}catch(e){t=e}})),t&&Mt.__e(t,n.__v))};var Rn="function"==typeof requestAnimationFrame;function Ln(e){var t=Sn,n=e.__c;"function"==typeof n&&(e.__c=void 0,n()),Sn=t}function Wn(e){var t=Sn;e.__c=e.__(),Sn=t}function Bn(e,t){return!e||e.length!==t.length||t.some((function(t,n){return t!==e[n]}))}function Mn(e,t){return"function"==typeof t?t(e):t}function Fn({title:e,alerts:t,fields:n,onCancel:r,onSubmit:o}){const[s,i]=Un({}),a=Dn(null);return function(e,t){var n=Pn(wn++,4);!Mt.__s&&Bn(n.__H,t)&&(n.__=e,n.i=t,Sn.__h.push(n))}((()=>{var e;return null===(e=a.current)||void 0===e?void 0:e.focus()}),[]),Yt(_n,{className:"dxc-login-dlg"},Yt(Xt,null,Yt("h3",{style:gn.WindowHeader},e),t.map((e=>Yt("p",{style:gn.Alert[e.type]},function({message:e,messageCode:t,messageParams:n}){return e.replace(/\{\w+\}/gi,(e=>n[e.substr(1,e.length-2)]))}(e)))),Yt("form",{onSubmit:e=>{e.preventDefault(),o(s)}},Object.entries(n).map((([e,{type:t,label:n,placeholder:r}],o)=>Yt("label",{style:gn.Label},n?`${n}: `:"",Yt("input",{ref:0===o?a:void 0,type:t,name:e,autoComplete:"on",style:gn.Input,autoFocus:!0,placeholder:r,value:s[e]||"",onInput:n=>{var r;return i(Object.assign(Object.assign({},s),{[e]:Kn(t,null===(r=n.target)||void 0===r?void 0:r.value)}))}})))))),Yt("div",{style:gn.ButtonsDiv},Yt("button",{type:"submit",style:gn.Button,onClick:()=>o(s)},"Submit"),Yt("button",{style:gn.Button,onClick:r},"Cancel")))}function Kn(e,t){switch(e){case"email":return t.toLowerCase();case"otp":return t.toUpperCase();default:return t}}class Hn extends Qt{constructor(e){super(e),this.observer=e=>this.setState({userInteraction:e}),this.state={userInteraction:void 0}}componentDidMount(){this.subscription=u(this.props.db.cloud.userInteraction).subscribe(this.observer)}componentWillUnmount(){this.subscription&&(this.subscription.unsubscribe(),delete this.subscription)}render(e,{userInteraction:t}){return t?Yt(Fn,Object.assign({},t)):null}}function Vn(e){const t=new WeakMap;return n=>{let r=t.get(n);return r||(r=e(n),t.set(n,r)),r}}function qn(e,t){let n=t,o=u(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 Jn=Vn((e=>qn(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})))),{}))),zn=Vn((e=>new o(T))),Gn=Vn((e=>qn(zn(e._novip).pipe(b((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 Yn(...e){if(0===e.length)return{};const t=e.reduce(((e,t)=>{const n=Object.assign({},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 Zn=Vn((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}(qn(f([Gn(e._novip),Jn(e._novip)]).pipe(w((([{selfMembers:e,realms:t,userId:n},r])=>({selfMembers:e,realms:t,userId:n,globalRoles:r})))),{selfMembers:[],realms:[],userId:T.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=V(o.map((e=>e.roles)).filter((e=>e))).map((e=>r[e])).filter((e=>e)).map((e=>e.permissions));return Object.assign(Object.assign({},t),{permissions:t.owner===n?{manage:"*"}:Yn(...s,...i)})})).reduce(((e,t)=>Object.assign(Object.assign({},e),{[t.realmId]:t})),{[n]:{realmId:n,owner:n,name:n,permissions:{manage:"*"}}});return o}))));class Xn{constructor(e,t,n){this.permissions=e||{},this.tableName=t,this.isOwner=n}add(...e){var t;return"*"===this.permissions.manage||(!!(null===(t=this.permissions.manage)||void 0===t?void 0:t.includes(this.tableName))||("*"===this.permissions.add||!!e.every((e=>{var t;return null===(t=this.permissions.add)||void 0===t?void 0:t.includes(e)}))))}update(...e){var t,n;if(this.isOwner||"*"===this.permissions.manage)return!0;if(null===(t=this.permissions.manage)||void 0===t?void 0:t.includes(this.tableName))return!0;if("*"===this.permissions.update)return e.every((e=>"owner"!==e));const r=null===(n=this.permissions.update)||void 0===n?void 0:n[this.tableName];return"*"===r?e.every((e=>"owner"!==e)):e.every((e=>null==r?void 0:r.some((t=>t===e||"*"===t&&"owner"!==e))))}delete(){var e;return!(!this.isOwner&&"*"!==this.permissions.manage)||!!(null===(e=this.permissions.manage)||void 0===e?void 0:e.includes(this.tableName))}}const Qn=Vn((e=>{const t=zn(e._novip).pipe(b((t=>n((()=>e.members.where({email:t.email||""}).toArray()))))),r=Zn(e._novip),o=Gn(e._novip);return qn(f([t,o,r]).pipe(w((([t,n,r])=>{const o=(e,t)=>Object.assign(Object.assign({},e),{[t.id]:Object.assign(Object.assign({},t),{realm:r[t.realmId]})}),s=t.reduce(o,{}),i=n.selfMembers.reduce(o,s);return Object.values(i).filter((e=>!e.accepted&&!e.rejected)).map((t=>Object.assign(Object.assign({},t),{accept(){return O(this,void 0,void 0,(function*(){yield e.members.update(t.id,{accepted:new Date})}))},reject(){return O(this,void 0,void 0,(function*(){yield e.members.update(t.id,{rejected:new Date})}))}})))}))),[])})),er={nameSuffix:!0};function tr(t){const r=t.name,c=zn(t),l=[];let p=!1,h=null;t.on("ready",(t=>O(this,void 0,void 0,(function*(){try{yield function(t){var r,s,S,E,T,A,j;return O(this,void 0,void 0,(function*(){y=!1;const $=et(t);"undefined"!=typeof window&&"undefined"!=typeof document&&((null===(r=$.cloud.options)||void 0===r?void 0:r.customLoginGui)||l.push(function(e){let t=!1;const n=document.createElement("div");return document.body?(document.body.appendChild(n),bn(Yt(Hn,{db:e.vip}),n)):addEventListener("DOMContentLoaded",(()=>{t||(document.body.appendChild(n),bn(Yt(Hn,{db:e.vip}),n))})),{unsubscribe(){try{n.remove()}catch(e){}t=!0},get closed(){return t}}}(t))),$.cloud.isServiceWorkerDB||l.push(function(e){let t=e.cloud.webSocketStatus.value;const n=e.cloud.webSocketStatus.pipe(b((e=>{const n=t;t=e;const r=i(e);switch(e){case"disconnected":return kt.value?r.pipe(I(500)):r;case"connecting":return"not-started"===n||"error"===n?r:r.pipe(I(4e3));default:return r}})));return f([n,e.syncStateChangedEvent.pipe(x({phase:"initial"})),Et]).pipe(w((([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:Fe?a:"offline"}})))}($).subscribe(t.cloud.syncState)),l.push($.syncCompleteEvent.subscribe(_)),$.tables.every((e=>e.core))||lt();const P="serviceWorker"in navigator?yield navigator.serviceWorker.getRegistrations():[],U=yield $.transaction("rw",$.$syncState,(()=>O(this,void 0,void 0,(function*(){var e,t;const{options:n,schema:r}=$.cloud,[o,s,i]=yield Promise.all([$.getOptions(),$.getSchema(),$.getPersistedSyncState()]);if(p){if(!o||JSON.stringify(o)!==JSON.stringify(n)){if(!n)throw new Error("Internal error");const e=Object.assign({},n);delete e.fetchTokens,yield $.$syncState.put(e,"options")}}else $.cloud.options=o||null;if((null===(e=$.cloud.options)||void 0===e?void 0:e.tryUseServiceWorker)&&"serviceWorker"in navigator&&P.length>0&&!at?(console.debug("Dexie Cloud Addon: Using service worker"),$.cloud.usingServiceWorker=!0):((null===(t=$.cloud.options)||void 0===t?void 0:t.tryUseServiceWorker)&&!$.cloud.isServiceWorkerDB&&console.debug("dexie-cloud-addon: Not using service worker.",0===P.length?"No SW registrations found.":"serviceWorker"in navigator&&at?"Avoiding SW background sync and SW periodic bg sync for this browser due to browser bugs.":"navigator.serviceWorker not present"),$.cloud.usingServiceWorker=!1),Wt(r,$.cloud.options),Wt(s,$.cloud.options),r){if(!s||JSON.stringify(s)!==JSON.stringify(r)){const e=s||{};for(const[t,n]of Object.entries(r)){const r=e[t];r?(r.markedForSync=n.markedForSync,n.deleted=r.deleted,r.generatedGlobalId=n.generatedGlobalId):e[t]=Object.assign({},n)}yield $.$syncState.put(e,"schema"),Object.assign(r,e)}}else $.cloud.schema=s||null;return null==i?void 0:i.initiallySynced}))));U&&$.setInitiallySynced(!0),function(t){var n,r;for(const o of t.tables)if(null===(r=null===(n=t.cloud.schema)||void 0===n?void 0:n[o.name])||void 0===r?void 0:r.markedForSync){if(o.schema.primKey.auto)throw new e.SchemaError(`Table ${o.name} is both autoIncremented and synced. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(o.name)}]}) to blacklist it from sync`);if(!o.schema.primKey.keyPath)throw new e.SchemaError(`Table ${o.name} cannot be both synced and outbound. Use db.cloud.configure({unsyncedTables: [${JSON.stringify(o.name)}]}) to blacklist it from sync`)}}($),(null===(s=$.cloud.options)||void 0===s?void 0:s.databaseUrl)&&!U&&(yield function(e,t,n){return O(this,void 0,void 0,(function*(){console.debug("Performing initial sync"),yield Je(e,t,n,{isInitialSync:!0}),console.debug("Done initial sync")}))}($,$.cloud.options,$.cloud.schema),$.setInitiallySynced(!0)),g(),$.cloud.isServiceWorkerDB||(l.push(n((()=>$.getCurrentUser())).subscribe(c)),l.push(n((()=>$.getPersistedSyncState())).subscribe($.cloud.persistedSyncState)),yield f([c.pipe(C(1),v(1)),$.cloud.persistedSyncState.pipe(C(1),v(1))]).toPromise());let D=!1;(null===(S=$.cloud.options)||void 0===S?void 0:S.requireAuth)&&(D=yield rt($)),h&&h.stop(),h=null,g(),$.cloud.usingServiceWorker&&(null===(E=$.cloud.options)||void 0===E?void 0:E.databaseUrl)?(N($,D?"pull":"push").catch((()=>{})),function(e){var t;return O(this,void 0,void 0,(function*(){try{const{periodicSync:n}=yield navigator.serviceWorker.ready;if(n)try{yield n.register(`dexie-cloud:${e.name}`,null===(t=e.cloud.options)||void 0===t?void 0:t.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)}}))}($).catch((()=>{}))):(null===(T=$.cloud.options)||void 0===T?void 0:T.databaseUrl)&&$.cloud.schema&&!$.cloud.isServiceWorkerDB&&(h=Lt($,$.cloud.options,$.cloud.schema),h.start(),R($,D?"pull":"push")),g(),$.cloud.isServiceWorkerDB||l.push(a(self,"online").subscribe((()=>{console.debug("online!"),$.syncStateChangedEvent.next({phase:"not-in-sync"}),R($,"push")})),a(self,"offline").subscribe((()=>{console.debug("offline!"),$.syncStateChangedEvent.next({phase:"offline"})}))),!(null===(A=$.cloud.options)||void 0===A?void 0:A.databaseUrl)||(null===(j=$.cloud.options)||void 0===j?void 0:j.disableWebSocket)||ct||l.push(function(e){var t;if(!(null===(t=e.cloud.options)||void 0===t?void 0:t.databaseUrl))throw new Error("No database URL to connect WebSocket to");const n=e.messageConsumer.readyToServe.pipe(m((e=>e)),b((()=>e.getPersistedSyncState())),m((e=>e&&e.serverRevision)),b((e=>O(this,void 0,void 0,(function*(){return{type:"ready",rev:e.serverRevision,realmSetHash:yield B(e)}})))));return function t(){return e.cloud.persistedSyncState.pipe(m((e=>null==e?void 0:e.serverRevision)),v(1),b((t=>e.cloud.currentUser.pipe(w((e=>[e,t]))))),b((([e,t])=>Et.pipe(w((n=>[n?e:null,t]))))),b((([t,n])=>(null==t?void 0:t.isLoggedIn)&&!(null==n?void 0:n.realms.includes(t.userId))?e.cloud.persistedSyncState.pipe(m((e=>(null==e?void 0:e.realms.includes(t.userId))||!1)),v(1),w((e=>[t,e]))):new o([t,n]))),b((([e,t])=>O(this,void 0,void 0,(function*(){return[e,yield B(t)]})))),b((([t,r])=>t?new At(e.cloud.options.databaseUrl,e.cloud.persistedSyncState.value.serverRevision,r,e.cloud.persistedSyncState.value.clientIdentity,n,e.cloud.webSocketStatus,t.accessToken,t.accessTokenExpiration):u([]))),k((n=>"TokenExpiredError"===(null==n?void 0:n.name)?(console.debug("WebSocket observable: Token expired. Refreshing token..."),i(!0).pipe(b((()=>O(this,void 0,void 0,(function*(){const t=yield e.getCurrentUser(),n=yield ce(e.cloud.options.databaseUrl,t);yield e.table("$logins").update(t.userId,{accessToken:n.accessToken,accessTokenExpiration:n.accessTokenExpiration})})))),b((()=>t())))):d(n))),k((n=>(e.cloud.webSocketStatus.next("error"),u(Pt(n)).pipe(b((()=>t())))))))}().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!")}))}($))}))}(t)}catch(e){console.error(e)}}))),!0);let y=!1;function g(){if(y)throw new e.DatabaseClosedError}!function(e,t){e.on.close.subscribe(t);const n=e.close;e.close=function(){n.call(this),t()}}(t,(()=>{l.forEach((e=>e.unsubscribe())),y=!0,h&&h.stop(),h=null,c.next(T)}));const _=new s;var S;t.cloud={version:"4.0.1-beta.40",options:Object.assign({},er),schema:null,get currentUserId(){return c.value.userId||T.userId},currentUser:c,syncState:new o({phase:"initial",status:"not-started"}),events:{syncComplete:_},persistedSyncState:new o(void 0),userInteraction:new o(void 0),webSocketStatus:new o("not-started"),login(e){return O(this,void 0,void 0,(function*(){const n=et(t);yield n.cloud.sync(),yield rt(n,e)}))},invites:Qn(t),roles:Jn(t),configure(e){e=t.cloud.options=Object.assign(Object.assign({},t.cloud.options),e),p=!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)}`,et(t).reconfigure()),Wt(t.cloud.schema,t.cloud.options)},sync({wait:e,purpose:r}={wait:!0,purpose:"push"}){return O(this,void 0,void 0,(function*(){void 0===e&&(e=!0);const o=et(t);if("pull"===r){const t=o.cloud.persistedSyncState.value;if(R(o,r),e){const e=yield o.cloud.persistedSyncState.pipe(m((e=>null!=(null==e?void 0:e.timestamp)&&(!t||e.timestamp>t.timestamp))),v(1)).toPromise();if(null==e?void 0:e.error)throw new Error("Sync error: "+e.error)}}else if(yield Ut(o)){const t=o.cloud.persistedSyncState.value;R(o,r),e&&(console.debug("db.cloud.login() is waiting for sync completion..."),yield u(n((()=>O(this,void 0,void 0,(function*(){const e=yield Ut(o),n=yield o.getPersistedSyncState();if((null==n?void 0:n.timestamp)!==(null==t?void 0:t.timestamp)&&(null==n?void 0:n.error))throw new Error("Sync error: "+n.error);return e}))))).pipe(m((e=>!e)),v(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=Zn(e),i=t=>{const s=t[o||e.cloud.currentUserId];return s?new Xn(s.permissions,n,o===e.cloud.currentUserId||r===e.cloud.currentUserId):new Xn({},n,!r||r===e.cloud.currentUserId)},a=s.pipe(w(i));return a.getValue=()=>i(s.getValue()),a}(t._novip,e,n)},t.Version.prototype._parseStoresSpec=e.override(t.Version.prototype._parseStoresSpec,(e=>St(e,t))),t.Table.prototype.newId=function({colocateWith:e}={}){const n=e&&e.substr(e.length-3);return yt(t.cloud.schema[this.name].idPrefix||"",n)},t.Table.prototype.idPrefix=function(){var e,t;return(null===(t=null===(e=this.db.cloud.schema)||void 0===e?void 0:e[this.name])||void 0===t?void 0:t.idPrefix)||""},t.use(wt({currentUserObservable:t.cloud.currentUser,db:et(t)})),t.use((S=et(t),{stack:"dbcore",name:"implicitPropSetterMiddleware",level:1,create:e=>Object.assign(Object.assign({},e),{table:t=>{const n=e.table(t);return Object.assign(Object.assign({},n),{mutate:e=>{var r,o,s,i;if(e.trans.disableChangeTracking)return n.mutate(e);const a=e.trans;if((null===(o=null===(r=S.cloud.schema)||void 0===r?void 0:r[t])||void 0===o?void 0:o.markedForSync)&&("add"===e.type||"put"===e.type))for(const t of e.values){t.owner||(t.owner=a.currentUser.userId),t.realmId||(t.realmId=a.currentUser.userId);const r=null===(i=(s=n.schema.primaryKey).extractKey)||void 0===i?void 0:i.call(s,t);"string"==typeof r&&"#"===r[0]&&"put"===e.type&&(delete e.criteria,delete e.changeSpec,delete e.updates,t.$ts=Date.now())}return n.mutate(e)}})}})})),t.use(mt(et(t)))}tr.version="4.0.1-beta.40",e.Cloud=tr;const nr=new Map;function rr(e){return e.startsWith("dexie-cloud:")&&e.split(":")[1]}const or=new Map;function sr(t,n){let r=or.get(t+"/"+n);return r||(r=function t(n,r){var o;return O(this,void 0,void 0,(function*(){let s=nr.get(n);if(!s){console.debug("Dexie Cloud SW: Creating new Dexie instance for",n);const o=new e(n,{addons:[tr]});if(s=et(o),s.cloud.isServiceWorkerDB=!0,o.on("versionchange",i),yield s.dx.open(),nr.get(n))return s.close(),yield t(n,r);nr.set(n,s)}if(null===(o=s.cloud.options)||void 0===o?void 0:o.databaseUrl)if(s.cloud.schema)try{console.debug("Dexie Cloud SW: Syncing"),yield Rt(s,s.cloud.options,s.cloud.schema,{retryImmediatelyOnFetchError:!0,purpose:r}),console.debug("Dexie Cloud SW: Done Syncing")}catch(t){if(console.error("Dexie Cloud SW Error",t),i(),t.name!==e.errnames.NoSuchDatabase)throw t}else console.error("Dexie Cloud: No schema persisted");else console.error("Dexie Cloud: No databaseUrl configured");function i(){return s.dx.on.versionchange.unsubscribe(i),nr.get(s.name)===s&&nr.delete(s.name),console.debug(`Dexie Cloud SW: Closing Dexie instance for ${n}`),s.dx.close(),!1}}))}(t,n).then((()=>{or.delete(t+"/"+n)})).catch((e=>(or.delete(t+"/"+n),Promise.reject(e)))),or.set(t+"/"+n,r)),r}at||(self.addEventListener("sync",(e=>{console.debug('SW "sync" Event',e.tag);const t=rr(e.tag);t&&e.waitUntil(sr(t,"push"))})),self.addEventListener("periodicsync",(e=>{console.debug('SW "periodicsync" Event',e.tag);const t=rr(e.tag);t&&e.waitUntil(sr(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)=>sr(t,e.data.purpose||"pull").catch((e=>O(void 0,void 0,void 0,(function*(){if(3===r)throw e;var t;yield(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)))}})));
2
2
  //# sourceMappingURL=service-worker.min.js.map