@instantdb/core 0.22.140 → 0.22.141
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.
package/dist/standalone/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
(function(A,C){typeof exports=="object"&&typeof module<"u"?C(exports):typeof define=="function"&&define.amd?define(["exports"],C):(A=typeof globalThis<"u"?globalThis:A||self,C(A.instant={}))})(this,function(A){"use strict";var ra=Object.defineProperty;var sa=(A,C,M)=>C in A?ra(A,C,{enumerable:!0,configurable:!0,writable:!0,value:M}):A[C]=M;var h=(A,C,M)=>sa(A,typeof C!="symbol"?C+"":C,M);function C(n){if(typeof n=="number")return(Math.abs(n*2654435761)>>>0).toString(16);if(typeof n=="boolean")return n?"1":"0";if(n===null)return"null";if(n===void 0)return"undefined";if(typeof n=="string"){let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(n)){let e=2166136261;for(let t=0;t<n.length;t++){e^=(t+1)*2654435761;const r=C(n[t]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof n=="object"){let e=2166136261;const t=Object.keys(n).sort();for(let r=0;r<t.length;r++){const s=t[r],i=C(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=C(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return C(String(n))}const M={Remove:"remove",Replace:"replace",Add:"add"},Kt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),gr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),$e=Symbol.iterator,B={mutable:"mutable",immutable:"immutable"},Ye={};function Te(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function zt(n,e){if(e in n){let t=Reflect.getPrototypeOf(n);for(;t;){const r=Reflect.getOwnPropertyDescriptor(t,e);if(r)return r;t=Reflect.getPrototypeOf(t)}}}function Ze(n){return Object.getPrototypeOf(n)===Set.prototype}function Xe(n){return Object.getPrototypeOf(n)===Map.prototype}function G(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function ue(n){return!!I(n)}function I(n){return typeof n!="object"?null:n==null?void 0:n[Kt]}function et(n){var e;const t=I(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function J(n,e){if(!n||typeof n!="object")return!1;let t;return Object.getPrototypeOf(n)===Object.prototype||Array.isArray(n)||n instanceof Map||n instanceof Set||!!(e!=null&&e.mark)&&((t=e.mark(n,B))===B.immutable||typeof t=="function")}function Wt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=I(re(t,n.key));if(r!==null&&(r==null?void 0:r.original)!==n.original)return null;const s=n.parent.type===3,i=s?Array.from(n.parent.setMap.keys()).indexOf(n.key):n.key;if(!(s&&t.size>i||Te(t,i)))return null;e.push(i)}if(n.parent)return Wt(n.parent,e);e.reverse();try{mr(n.copy,e)}catch{return null}return e}function le(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function re(n,e){return le(n)===2?n.get(e):n[e]}function Se(n,e,t){le(n)===2?n.set(e,t):n[e]=t}function tt(n,e){const t=I(n);return(t?G(t):n)[e]}function se(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function nt(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function de(n,e){return e?n:[""].concat(n).map(t=>{const r=`${t}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function mr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=re(le(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function _r(n){const e=Object.create(Object.getPrototypeOf(n));return Reflect.ownKeys(n).forEach(t=>{let r=Reflect.getOwnPropertyDescriptor(n,t);if(r.enumerable&&r.configurable&&r.writable){e[t]=n[t];return}r.writable||(r.writable=!0,r.configurable=!0),(r.get||r.set)&&(r={configurable:!0,writable:!0,enumerable:r.enumerable,value:n[t]}),Reflect.defineProperty(e,t,r)}),e}const wr=Object.prototype.propertyIsEnumerable;function Vt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!Ze(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n.values())}return Set.prototype.difference?Set.prototype.difference.call(n,new Set):new Set(n.values())}else if(n instanceof Map){if(!Xe(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e!=null&&e.mark&&(t=e.mark(n,B),t!==void 0)&&t!==B.mutable){if(t===B.immutable)return _r(n);if(typeof t=="function"){if(e.enablePatches||e.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return t()}throw new Error(`Unsupported mark result: ${t}`)}else if(typeof n=="object"&&Object.getPrototypeOf(n)===Object.prototype){const r={};return Object.keys(n).forEach(s=>{r[s]=n[s]}),Object.getOwnPropertySymbols(n).forEach(s=>{wr.call(n,s)&&(r[s]=n[s])}),r}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function F(n){n.copy||(n.copy=Vt(n.original,n.options))}function Ae(n){if(!J(n))return et(n);if(Array.isArray(n))return n.map(Ae);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ae(s)]);if(!Xe(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Map(t)}if(n instanceof Set){const t=Array.from(n).map(Ae);if(!Ze(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Set(t)}const e=Object.create(Object.getPrototypeOf(n));for(const t in n)e[t]=Ae(n[t]);return e}function Re(n){return ue(n)?Ae(n):n}function te(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&te(n.parent))}function Qt(){throw new Error("Cannot modify frozen object")}function pe(n,e,t,r,s){{t=t??new WeakMap,r=r??[],s=s??[];const o=t.has(n)?t.get(n):n;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(n)||ue(n)){r.pop(),s.pop();return}switch(le(n)){case 2:for(const[a,c]of n)pe(a,a,t,r,s),pe(c,a,t,r,s);n.set=n.clear=n.delete=Qt;break;case 3:for(const a of n)pe(a,a,t,r,s);n.add=n.clear=n.delete=Qt;break;case 1:Object.freeze(n);let o=0;for(const a of n)pe(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];pe(c,a,t,r,s)})}r.pop(),s.pop()}function rt(n,e){const t=le(n);if(t===0)Reflect.ownKeys(n).forEach(r=>{e(r,n[r],n)});else if(t===1){let r=0;for(const s of n)e(r,s,n),r+=1}else n.forEach((r,s)=>e(s,r,n))}function Bt(n,e,t){if(ue(n)||!J(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),rt(n,(i,o)=>{var a;if(ue(o)){const c=I(o);F(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Se(r?s:n,i,u)}else Bt(o,e,t)}),s){const i=n,o=Array.from(i);i.clear(),o.forEach(a=>{i.add(s.has(a)?s.get(a):a)})}}function Tr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Bt(re(t,e),n.finalities.handledSet,n.options)}function st(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(et(e))}))}function it(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Wt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ot(n,e,t,r){const s=I(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(se(re(c,e),t)){let u=s.original;s.copy&&(u=s.copy),st(n),it(n,r,i,o),n.options.enableAutoFreeze&&(n.options.updatedValues=(a=n.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,n.options.updatedValues.set(u,s.original)),Se(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),J(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;se(re(i,e),t)&&Tr(n,e)})}function Sr(n,e,t,r,s){let{original:i,assignedMap:o,options:a}=n,c=n.copy;c.length<i.length&&([i,c]=[c,i],[t,r]=[r,t]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),d=de(l,s);t.push({op:M.Replace,path:d,value:Re(c[u])}),r.push({op:M.Replace,path:d,value:Re(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),d=de(l,s);t.push({op:M.Add,path:d,value:Re(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),d=de(l,s);r.push({op:M.Replace,path:d,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const d=e.concat([l-1]),f=de(d,s);r.push({op:M.Remove,path:f})}}}function Ar({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=re(n,c),l=Re(re(e,c)),d=a?Te(n,c)?M.Replace:M.Add:M.Remove;if(se(u,l)&&d===M.Replace)return;const f=r.concat(c),p=de(f,o);s.push(d===M.Remove?{op:d,path:p}:{op:d,path:p,value:l}),i.push(d===M.Add?{op:M.Remove,path:p}:d===M.Remove?{op:M.Add,path:p,value:u}:{op:M.Replace,path:p,value:u})})}function vr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=de(c,i);r.push({op:M.Remove,path:u,value:a}),s.unshift({op:M.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=de(c,i);r.push({op:M.Add,path:u,value:a}),s.unshift({op:M.Remove,path:u,value:a})}o+=1})}function ve(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return Ar(n,e,t,r,s);case 1:return Sr(n,e,t,r,s);case 3:return vr(n,e,t,r,s)}}const xe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!J(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},at={get size(){return G(I(this)).size},has(n){return G(I(this)).has(n)},set(n,e){const t=I(this),r=G(t);return(!r.has(n)||!se(r.get(n),e))&&(F(t),te(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ot(t,n,e,ve)),this},delete(n){if(!this.has(n))return!1;const e=I(this);return F(e),te(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=I(this);if(this.size){F(n),te(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=I(this);G(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=I(this),s=G(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,B))===B.mutable;if(r.options.strict&&xe(s,r.options,i),i||r.finalized||!J(s,r.options)||s!==r.original.get(n))return s;const o=Ye.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return F(r),r.copy.set(n,o),o},keys(){return G(I(this)).keys()},values(){const n=this.keys();return{[$e]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[$e]:()=>this.entries(),next:()=>{const e=n.next();if(e.done)return e;const t=this.get(e.value);return{done:!1,value:[e.value,t]}}}},[$e](){return this.entries()}},kr=Reflect.ownKeys(at),Gt=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=I(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,B))===B.mutable;if(n.options.strict&&xe(o,n.options,u),!u&&!c&&J(o,n.options)&&!n.finalized&&n.original.has(o)){const l=Ye.createDraft({original:o,parentDraft:n,key:o,finalities:n.finalities,options:n.options});n.setMap.set(o,l),a=l}else c&&(a=c.proxy);return{done:!1,value:t?a:[a,a]}},Ue={get size(){return I(this).setMap.size},has(n){const e=I(this);if(e.setMap.has(n))return!0;F(e);const t=I(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=I(this);return this.has(n)||(F(e),te(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ot(e,n,n,ve)),this},delete(n){if(!this.has(n))return!1;const e=I(this);F(e),te(e);const t=I(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=I(this);F(n),te(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Gt(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Gt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[$e](){return this.values()},forEach(n,e){const t=this.values();let r=t.next();for(;!r.done;)n.call(e,r.value,r.value,this),r=t.next()}};Set.prototype.difference&&Object.assign(Ue,{intersection(n){return Set.prototype.intersection.call(new Set(this.values()),n)},union(n){return Set.prototype.union.call(new Set(this.values()),n)},difference(n){return Set.prototype.difference.call(new Set(this.values()),n)},symmetricDifference(n){return Set.prototype.symmetricDifference.call(new Set(this.values()),n)},isSubsetOf(n){return Set.prototype.isSubsetOf.call(new Set(this.values()),n)},isSupersetOf(n){return Set.prototype.isSupersetOf.call(new Set(this.values()),n)},isDisjointFrom(n){return Set.prototype.isDisjointFrom.call(new Set(this.values()),n)}});const Or=Reflect.ownKeys(Ue),Ht=new WeakSet,Jt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Ht.has(i))return i;if(e===Kt)return n;let o;if(n.options.mark){const u=e==="size"&&(n.original instanceof Map||n.original instanceof Set)?Reflect.get(n.original,e):Reflect.get(n.original,e,t);if(o=n.options.mark(u,B),o===B.mutable)return n.options.strict&&xe(u,n.options,!0),u}const a=G(n);if(a instanceof Map&&kr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(at,"size").get.call(n.proxy);const u=at[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Or.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(Ue,"size").get.call(n.proxy);const u=Ue[e];if(u)return u.bind(n.proxy)}if(!Te(a,e)){const u=zt(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(n.proxy):void 0}const c=a[e];if(n.options.strict&&xe(c,n.options),n.finalized||!J(c,n.options))return c;if(c===tt(n.original,e)){if(F(n),n.copy[e]=ct({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=I(n.copy[e]);return F(u),te(u),u.copy}return n.copy[e]}return c},set(n,e,t){var r;if(n.type===3||n.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(n.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=zt(G(n),e);if(i!=null&&i.set)return i.set.call(n.proxy,t),!0;const o=tt(G(n),e),a=I(o);return a&&se(a.original,t)?(n.copy[e]=t,n.assignedMap=(r=n.assignedMap)!==null&&r!==void 0?r:new Map,n.assignedMap.set(e,!1),!0):(se(t,o)&&(t!==void 0||Te(n.original,e))||(F(n),te(n),Te(n.original,e)&&se(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ot(n,e,t,ve)),!0)},has(n,e){return e in G(n)},ownKeys(n){return Reflect.ownKeys(G(n))},getOwnPropertyDescriptor(n,e){const t=G(n),r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:n.type!==1||e!=="length",enumerable:r.enumerable,value:t[e]}},getPrototypeOf(n){return Reflect.getPrototypeOf(n.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(n,e){var t;return n.type===1?Jt.set.call(this,n,e,void 0,n.proxy):(tt(n.original,e)!==void 0||e in n.original?(F(n),te(n),n.assignedMap.set(e,!1)):(n.assignedMap=(t=n.assignedMap)!==null&&t!==void 0?t:new Map,n.assignedMap.delete(e)),n.copy&&delete n.copy[e],!0)}};function ct(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=le(e),a={type:o,finalized:!1,parent:t,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in n)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,Jt);if(s.revoke.push(u),Ht.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((d,f)=>{var p,y;const g=I(c);let m=l.type===3?l.setMap:l.copy;const w=re(m,r),b=I(w);if(b){let _=b.original;b.operated&&(_=et(w)),st(b),it(b,ve,d,f),l.options.enableAutoFreeze&&(l.options.updatedValues=(p=l.options.updatedValues)!==null&&p!==void 0?p:new WeakMap,l.options.updatedValues.set(_,b.original)),Se(m,r,_)}(y=g.callbacks)===null||y===void 0||y.forEach(_=>{_(d,f)})})}else{const l=I(c);l.finalities.draft.push((d,f)=>{st(l),it(l,ve,d,f)})}return c}Ye.createDraft=ct;function Ir(n,e,t,r,s){var i;const o=I(n),a=(i=o==null?void 0:o.original)!==null&&i!==void 0?i:n,c=!!e.length;if(o!=null&&o.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(t,r);const u=c?e[0]:o?o.operated?o.copy:o.original:n;return o&&nt(o),s&&pe(u,u,o==null?void 0:o.options.updatedValues),[u,t&&c?[{op:M.Replace,path:[],value:e[0]}]:t,r&&c?[{op:M.Replace,path:[],value:a}]:r]}function Er(n,e){var t;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((t=e.mark)===null||t===void 0?void 0:t.call(e,n,B))===B.mutable||!J(n,e)?n:ct({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=Ir(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function ut(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;rt(t,(i,o,a)=>{const c=I(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(d=>a.add(i===d?u:d))}else Se(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ut(n))}),s&&(n.isContainDraft||console.warn("The return value does not contain any draft, please use 'rawReturn()' to wrap the return value to improve performance."),r&&console.warn("The return value contains drafts, please don't use 'rawReturn()' to wrap the return value."))}function Yt(n){var e;const t=I(n);if(!J(n,t==null?void 0:t.options))return n;const r=le(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?Xe(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Vt(n,t==null?void 0:t.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(rt(s,(o,a)=>{if(t&&se(re(t.original,o),a))return;const c=Yt(a);c!==a&&(s===n&&i(),Se(s,o,c))}),r===3){const o=(e=t==null?void 0:t.original)!==null&&e!==void 0?e:s;return Ze(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function Zt(n){if(!ue(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return Yt(n)}const Le=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(T,...S){return e(T,v=>t.call(this,v,...S),r)};const c=t,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},n),l);const d=ue(c)?Zt(c):c,f=Array.isArray(l.mark)?(T,S)=>{for(const v of l.mark){if(typeof v!="function")throw new Error(`Invalid mark: ${v}, 'mark' should be a function.`);const D=v(T,S);if(D)return D}}:l.mark,p=(i=l.enablePatches)!==null&&i!==void 0?i:!1,y=(o=l.strict)!==null&&o!==void 0?o:!1,m={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:f,strict:y,enablePatches:p};if(!J(d,m)&&typeof d=="object"&&d!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[w,b]=Er(d,m);if(typeof r!="function"){if(!J(d,m))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[w,b]}let _;try{_=u(w)}catch(T){throw nt(I(w)),T}const k=T=>{const S=I(w);if(!ue(T)){if(T!==void 0&&!se(T,w)&&(S!=null&&S.operated))throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const D=T==null?void 0:T[gr];if(D){const U=D[0];return m.strict&&typeof T=="object"&&T!==null&&ut({rootDraft:S,value:T,useRawReturn:!0}),b([U])}if(T!==void 0)return typeof T=="object"&&T!==null&&ut({rootDraft:S,value:T}),b([T])}if(T===w||T===void 0)return b([]);const v=I(T);if(m===v.options){if(v.operated)throw new Error("Cannot return a modified child draft.");return b([Zt(T)])}return b([T])};return _ instanceof Promise?_.then(k,T=>{throw nt(I(w)),T}):k(_)})();Object.prototype.constructor.toString();function Xt(n,e){const t=Object.keys(n),r=Object.keys(e);return t.length===r.length&&Object.keys(n).every(s=>e.hasOwnProperty(s))}function en(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function Fe(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:Xt(n,e)?Object.keys(n).every(t=>Fe(n[t],e[t])):!1}function lt(n){if(!ke(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function tn(n,e){if(!ke(n)||!ke(e))return e;const t={...n};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete t[r];continue}const s=ke(n[r])&&ke(e[r]);t[r]=s?tn(n[r],e[r]):e[r]}return t}function ke(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Cr(n,e,t){if(!n||e.length===0)return;let r=n||{};for(let i=0;i<e.length-1;i++){const o=e[i];(!(o in r)||typeof r[o]!="object")&&(r[o]=typeof e[i+1]=="number"?[]:{}),r=r[o]}const s=e[e.length-1];Array.isArray(r)&&typeof s=="number"?r.splice(s,0,t):r[s]=t}function nn(n,e,t){if(!n||e.length===0)return;let r=n||{};for(let s=0;s<e.length-1;s++){const i=e[s];(!(i in r)||typeof r[i]!="object")&&(r[i]=typeof e[s+1]=="number"?[]:{}),r=r[i]}r[e[e.length-1]]=t}function rn(n,e){if(!n||e.length===0)return;const[t,...r]=e;if(t in n){if(r.length===0){Array.isArray(n)?n.splice(t,1):delete n[t];return}rn(n[t],r),Mr(n[t])&&delete n[t]}}function Mr(n){return n&&Object.keys(n).length===0}const sn=/ZULU|YEKT|YEKST|YAPT|YAKT|YAKST|XJT|WGT|WGST|WFT|WETDST|WET|WDT|WAT|WAST|WAKT|WADT|VUT|VOLT|VLAT|VLAST|VET|UZT|UZST|UYT|UYST|UTC|UT|ULAT|ULAST|UCT|TVT|TRUT|TOT|TMT|TKT|TJT|TFT|TAHT|SGT|SCT|SAST|SADT|RET|PYT|PYST|PWT|PST|PONT|PMST|PMDT|PKT|PKST|PHT|PGT|PETT|PETST|PET|PDT|OMST|OMSST|NZT|NZST|NZDT|NUT|NST|NPT|NOVT|NOVST|NFT|NDT|MYT|MVT|MUT|MUST|MST|MSK|MSD|MPT|MMT|MHT|MEZ|METDST|MET|MESZ|MEST|MDT|MAWT|MART|MAGT|MAGST|LKT|LINT|LIGT|LHST|LHDT|KST|KRAT|KRAST|KOST|KGT|KGST|KDT|JST|JAYT|IST|IRT|IRKT|IRKST|IOT|IDT|ICT|HST|HKT|GYT|GMT|GILT|GFT|GET|GEST|GAMT|GALT|FNT|FNST|FKT|FKST|FJT|FJST|FET|EST|EGT|EGST|EETDST|EET|EEST|EDT|EAT|EAST|EASST|DDUT|DAVT|CXT|CST|COT|CLT|CLST|CKT|CHUT|CHAST|CHADT|CETDST|CET|CEST|CDT|CCT|CAST|CADT|BTT|BST|BRT|BRST|BRA|BOT|BORT|BNT|BDT|BDST|AZT|AZST|AZOT|AZOST|AWST|AWSST|AST|ART|ARST|ANAT|ANAST|AMT|AMST|ALMT|ALMST|AKST|AKDT|AFT|AEST|AESST|AEDT|ADT|ACWST|ACT|ACST|ACSST|ACDT$/,Pr={ZULU:0,YEKT:18e3,YEKST:21600,YAPT:36e3,YAKT:32400,YAKST:32400,XJT:21600,WGT:-10800,WGST:-7200,WFT:43200,WETDST:3600,WET:0,WDT:32400,WAT:3600,WAST:25200,WAKT:43200,WADT:28800,VUT:39600,VOLT:10800,VLAT:36e3,VLAST:36e3,VET:-14400,UZT:18e3,UZST:21600,UYT:-10800,UYST:-7200,UTC:0,UT:0,ULAT:28800,ULAST:32400,UCT:0,TVT:43200,TRUT:36e3,TOT:46800,TMT:18e3,TKT:46800,TJT:18e3,TFT:18e3,TAHT:-36e3,SGT:28800,SCT:14400,SAST:7200,SADT:37800,RET:14400,PYT:-14400,PYST:-10800,PWT:32400,PST:-28800,PONT:39600,PMST:-10800,PMDT:-7200,PKT:18e3,PKST:21600,PHT:28800,PGT:36e3,PETT:43200,PETST:43200,PET:-18e3,PDT:-25200,OMST:21600,OMSST:21600,NZT:43200,NZST:43200,NZDT:46800,NUT:-39600,NST:-12600,NPT:20700,NOVT:25200,NOVST:25200,NFT:-12600,NDT:-9e3,MYT:28800,MVT:18e3,MUT:14400,MUST:18e3,MST:-25200,MSK:10800,MSD:14400,MPT:36e3,MMT:23400,MHT:43200,MEZ:3600,METDST:7200,MET:3600,MESZ:7200,MEST:7200,MDT:-21600,MAWT:18e3,MART:-34200,MAGT:39600,MAGST:39600,LKT:19800,LINT:50400,LIGT:36e3,LHST:37800,LHDT:37800,KST:32400,KRAT:25200,KRAST:25200,KOST:39600,KGT:21600,KGST:21600,KDT:36e3,JST:32400,JAYT:32400,IST:7200,IRT:12600,IRKT:28800,IRKST:28800,IOT:21600,IDT:10800,ICT:25200,HST:-36e3,HKT:28800,GYT:-14400,GMT:0,GILT:43200,GFT:-10800,GET:14400,GEST:14400,GAMT:-32400,GALT:-21600,FNT:-7200,FNST:-3600,FKT:-10800,FKST:-10800,FJT:43200,FJST:46800,FET:10800,EST:-18e3,EGT:-3600,EGST:0,EETDST:10800,EET:7200,EEST:10800,EDT:-14400,EAT:10800,EAST:-21600,EASST:-21600,DDUT:36e3,DAVT:25200,CXT:25200,CST:-21600,COT:-18e3,CLT:-14400,CLST:-10800,CKT:-36e3,CHUT:36e3,CHAST:45900,CHADT:49500,CETDST:7200,CET:3600,CEST:7200,CDT:-18e3,CCT:28800,CAST:34200,CADT:37800,BTT:21600,BST:3600,BRT:-10800,BRST:-7200,BRA:-10800,BOT:-14400,BORT:28800,BNT:28800,BDT:21600,BDST:7200,AZT:14400,AZST:14400,AZOT:-3600,AZOST:0,AWST:28800,AWSST:32400,AST:-14400,ART:-10800,ARST:-10800,ANAT:43200,ANAST:43200,AMT:-14400,AMST:14400,ALMT:21600,ALMST:25200,AKST:-32400,AKDT:-28800,AFT:16200,AEST:36e3,AESST:39600,AEDT:39600,ADT:-10800,ACWST:31500,ACT:-18e3,ACST:34200,ACSST:37800,ACDT:37800};function jr(n){return new Date(n)}function Dr(n){return new Date(n+"Z")}const $r=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Rr(n){const e=n.match($r);if(!e)return null;const[t,r,s,i]=e;return r<=0||s<=0||i<=0?null:r>999?new Date(Date.UTC(r,s-1,i,0,0,0,0)):new Date(Date.UTC(i,r-1,s,0,0,0,0))}function xr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Ur(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Lr(n){return new Date(n)}function Fr(n){const e=/^(\w{3}) (\w{3}) (\d{2}) (\d{4})$/;if(!n.match(e))throw new Error(`Unable to parse \`${n}\` as a date.`);const r=new Date(n+" UTC");return new Date(Date.UTC(r.getUTCFullYear(),r.getUTCMonth(),r.getUTCDate(),0,0,0,0))}function Nr(n){const e=/^(.+T.+)([+-])(\d{2})$/,t=n.match(e);if(t){const[,r,s,i]=t,o=`${r}${s}${i}:00`;return new Date(o)}return null}function qr(n){const e=/^(\d+)-(\d{1,2})-(\d{1,2})([ T])(.+)$/,t=n.match(e);if(t){const[,r,s,i,o,a]=t,c=s.padStart(2,"0"),u=i.padStart(2,"0"),l=`${r}-${c}-${u}T${a}`;return new Date(l)}return null}function Kr(n){const[e,t]=n.split(", "),[r,s,i]=e.split("/").map(Number),o=t.match(/(\d{1,2}):(\d{2}):(\d{2}) (AM|PM)/);if(!o)throw new Error(`Unable to parse time from: ${n}`);let[,a,c,u,l]=o;return a=Number(a),c=Number(c),u=Number(u),l==="PM"&&a!==12?a+=12:l==="AM"&&a===12&&(a=0),new Date(Date.UTC(i,r-1,s,a,c,u))}function zr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Wr(n){const e=n.match(sn);if(!e)return null;const[t]=e,r=Pr[t],s=new Date(n.replace(sn,"Z"));return new Date(s.getTime()-r*1e3)}const Vr=[Rr,Ur,Fr,Kr,Lr,Dr,Nr,xr,jr,zr,Wr,qr];function Qr(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function dt(n){for(const e of Vr){const t=Qr(e,n);if(t)return t}return null}function Br(n){try{const e=JSON.parse(n);return typeof e=="string"?dt(e):null}catch{return null}}function Oe(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=dt(n)||Br(n)||dt(n.trim());if(!e)throw new Error(`Unable to parse \`${n}\` as a date.`);return e}else if(typeof n=="number")return new Date(n);throw new Error(`Invalid date value \`${n}\`. Expected a date, number, or string, got type ${typeof n}.`)}}class oe{constructor(e,t){h(this,"attrs");h(this,"linkIndex");h(this,"_blobAttrs",null);h(this,"_primaryKeys",null);h(this,"_forwardIdents",null);h(this,"_revIdents",null);this.attrs=e,this.linkIndex=t}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const t=this.attrs[e.id];t&&(this.attrs[e.id]={...t,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(ht(e)){const[t,r,s]=e["forward-identity"];z(this.blobAttrs,[r,s],e)}return this._blobAttrs}get primaryKeys(){if(this._primaryKeys)return this._primaryKeys;this._primaryKeys=new Map;for(const e of Object.values(this.attrs))if(e["primary?"]){const[t,r]=e["forward-identity"];z(this._primaryKeys,[r],e)}return this._primaryKeys}get forwardIdents(){if(this._forwardIdents)return this._forwardIdents;this._forwardIdents=new Map;for(const e of Object.values(this.attrs)){const t=e["forward-identity"],[r,s,i]=t;z(this._forwardIdents,[s,i],e)}return this._forwardIdents}get revIdents(){if(this._revIdents)return this._revIdents;this._revIdents=new Map;for(const e of Object.values(this.attrs)){const t=e["reverse-identity"];if(t){const[r,s,i]=t;z(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function Gr(n){return n.cardinality==="one"}function ft(n){return n["value-type"]==="ref"}function ht(n){return n["value-type"]==="blob"}function ye(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function Y(n,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){n.delete(e[0]);return}const[t,...r]=e;n.has(t)&&Y(n.get(t),r)}function z(n,e,t){let r=n;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],t)}function on(n,e,t){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=n.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&t&&(u=Oe(u),o[2]=u),ft(l)&&z(i,[u,c,a],o),z(r,[a,c,u],o),z(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function an(n){return{triples:W(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function cn(n,e){return be(n,e.triples,e.cardinalityInference,e.useDateObjects)}function un(n,e){if(n)return new oe(n.attrs,n.linkIndex);if(e&&"__type"in e)return new oe(e.attrs,e.linkIndex)}function Hr(n,e){return ye(n.eav,[e])!==void 0}function be(n,e,t,r){const s=on(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Ie(n,e){var s,i;let t;if(Array.isArray(e[0])){const[o,a]=e[0],c=n.aev.get(o);if(!c)return null;t=(s=W(c,2).find(l=>l[2]===a))==null?void 0:s[0]}else t=e[0];if(!t)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&n.aev.get(r[0])){const[o,a]=r,c=n.aev.get(o);if(!c)return null;const l=(i=W(c,2).find(g=>g[2]===a))==null?void 0:i[0];if(!l)return null;const[d,f,p,...y]=e;return[t,f,l,...y]}else{const[o,...a]=e;return[t,...a]}}function ln(n,e,t){const r=Ie(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(Y(n.eav,[s,i,o]),Y(n.aev,[i,s,o]),ft(a)&&Y(n.vae,[o,i,s]))}let Jr=0;function dn(n,e,t){const[r,s,i]=t;let o;const a=ye(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+Jr++}function fn(n,e,t){const r=Ie(n,t);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&n.useDateObjects&&(o=Oe(o));const c=ye(n.eav,[s,i,o]),u=(c==null?void 0:c[3])??dn(n,a,r),l=[s,i,o,u];Gr(a)?(z(n.eav,[s,i],new Map([[o,l]])),z(n.aev,[i,s],new Map([[o,l]]))):(z(n.eav,[s,i,o],l),z(n.aev,[i,s,o],l)),ft(a)&&z(n.vae,[o,i,s],l)}function Yr(n,e,t){var p;const r=Ie(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!ht(a))throw new Error("merge operation is not supported for links");const c=ye(n.eav,[s,i]);if(!c)return;const u=(p=c.values().next())==null?void 0:p.value;if(!u)return;const l=u[2],d=tn(l,o),f=[s,i,d,dn(n,a,u)];z(n.eav,[s,i],new Map([[d,f]])),z(n.aev,[i,s],new Map([[d,f]]))}function pt(n,e,t){var u,l;const[r,s]=t,i=Ie(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const d of a.keys()){const f=e.getAttr(d);f&&f["on-delete-reverse"]==="cascade"&&W(a.get(d),1).forEach(([p,y,g])=>{var m;return pt(n,e,[g,(m=f["reverse-identity"])==null?void 0:m[1]])}),(!s||!f||((u=f["forward-identity"])==null?void 0:u[1])===s)&&(Y(n.aev,[d,o]),Y(n.eav,[o,d]))}a.size===0&&Y(n.eav,[o])}const c=n.vae.get(o)&&W(n.vae.get(o),2);c&&c.forEach(d=>{var m,w,b;const[f,p,y]=d,g=e.getAttr(p);(!s||!g||((m=g["reverse-identity"])==null?void 0:m[1])===s)&&(Y(n.eav,[f,p,y]),Y(n.aev,[p,f,y]),Y(n.vae,[y,p,f])),g&&g["on-delete"]==="cascade"&&((w=g["reverse-identity"])==null?void 0:w[1])===s&&pt(n,e,[f,(b=g["forward-identity"])==null?void 0:b[1]])}),((l=n.vae.get(o))==null?void 0:l.size)===0&&Y(n.vae,[o])}function hn(n,e,t){const r=on(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function Zr(n,[e]){n.addAttr(e)}function pn(n){return W(n.eav,3)}function Xr(n,e,[t]){if(!e.getAttr(t))return;const r=pn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),hn(n,e,r)}function es(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),hn(n,e,pn(n)))}function ts(n,e,t){const[r,...s]=t;switch(r){case"add-triple":fn(n,e,s);break;case"deep-merge-triple":Yr(n,e,s);break;case"retract-triple":ln(n,e,s);break;case"delete-entity":pt(n,e,s);break;case"add-attr":Zr(e,s);break;case"delete-attr":Xr(n,e,s);break;case"update-attr":es(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function W(n,e,t=[]){if(!n||e===0)return t;if(e===1){for(const r of n.values())t.push(r);return t}for(const r of n.values())W(r,e-1,t);return t}function Ne(n,e,t){var i;const r=[];if(t!=null&&t.hasOwnProperty("$not")){for(const o of e.keys())t.$not!==o&&r.push(e.get(o));return r}if(t!=null&&t.hasOwnProperty("$isNull")){const{attrId:o,isNull:a,reverse:c}=t.$isNull;if(c)for(const u of e.keys()){const l=n.vae.get(u),d=!l||!l.get(o);(a?d:!d)&&r.push(e.get(u))}else{const u=n.aev.get(o);for(const l of e.keys()){const d=!u||((i=u.get(l))==null?void 0:i.get(null))||!u.get(l);(a?d:!d)&&r.push(e.get(l))}}return r}if(t!=null&&t.$comparator)return W(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const o of s){const a=e.get(o);a&&r.push(a)}return r}function ns(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function rs(n,[e,t,r]){var i,o;switch(ns(e,t,r)){case"e":{const a=n.eav.get(e);return W(a,2)}case"ea":{const a=(i=n.eav.get(e))==null?void 0:i.get(t);return W(a,1)}case"eav":{const a=(o=n.eav.get(e))==null?void 0:o.get(t);return a?Ne(n,a,r):[]}case"ev":{const a=n.eav.get(e);if(!a)return[];const c=[];for(const u of a.values())c.push(...Ne(n,u,r));return c}case"a":{const a=n.aev.get(t);return W(a,2)}case"av":{const a=n.aev.get(t);if(!a)return[];const c=[];for(const u of a.values())c.push(...Ne(n,u,r));return c}case"v":{const a=[];for(const c of n.eav.values())for(const u of c.values())a.push(...Ne(n,u,r));return a}default:return W(n.eav,3)}}function ss(n,e,t){var s;const r={};if(!e)return r;for(const[i,o]of e.entries()){const a=(s=n.eav.get(t))==null?void 0:s.get(o.id),c=W(a,1);for(const u of c)r[i]=u[2]}return r}function R(n,e,t){var r;return(r=n.forwardIdents.get(e))==null?void 0:r.get(t)}function fe(n,e,t){var r;return(r=n.revIdents.get(e))==null?void 0:r.get(t)}function is(n,e){return n.blobAttrs.get(e)}function yn(n,e){var r;const t=n.primaryKeys.get(e);return t||((r=n.forwardIdents.get(e))==null?void 0:r.get("id"))}function os(n,e,t){const r=Ie(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return ye(n.eav,[s,i])}function as(n,e,t){const r=t.filter(([s,i,o,a,c])=>{if(s!=="add-triple"&&s!=="deep-merge-triple")return!0;const u=c==null?void 0:c.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const d=e.getAttr(o);if(d){const f=yn(e,d["forward-identity"][1]);l=!!os(n,e,[i,f==null?void 0:f.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Le({store:n,attrsStore:e},s=>{r.forEach(i=>{ts(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof oe)return"immutable"}})}function cs(n){return typeof n=="string"&&n.startsWith("?")}function us(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return gn(r,e,t)}return{...t,[n]:e}}function bn(n,e,t){return n===e?t:null}function ls(n){switch(typeof n){case"string":return n.startsWith("?")?us:bn;default:return bn}}const ds=["in","$in","$not","$isNull","$comparator"];function fs(n){for(const e of ds)if(n.hasOwnProperty(e))return!0;return!1}function gn(n,e,t){return t?typeof n=="object"?fs(n)?t:null:ls(n)(n,e,t):null}function hs(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return gn(s,o,r)},t)}function ps(n,e,t){return gs(n,e,t).map(r=>hs(e,r,t)).filter(r=>r)}function ys(n,e,t){return e.or?e.or.patterns.flatMap(r=>yt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>yt(n,s,r),t):t.flatMap(r=>ps(n,e,r))}function yt(n,e,t=[{}]){return e.reduce((r,s)=>ys(n,s,r),t)}function bt(n,e){return Array.isArray(e)?e.map(t=>bt(n,t)):cs(e)?n[e]:e}function bs(n,{find:e,where:t}){return yt(n,t).map(s=>bt(s,e))}function gs(n,e,t){return rs(n,bt(t,e))}const ms=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function ge(n){return typeof n=="string"&&ms.test(n)}const x=[];for(let n=0;n<256;++n)x.push((n+256).toString(16).slice(1));function _s(n,e=0){return(x[n[e+0]]+x[n[e+1]]+x[n[e+2]]+x[n[e+3]]+"-"+x[n[e+4]]+x[n[e+5]]+"-"+x[n[e+6]]+x[n[e+7]]+"-"+x[n[e+8]]+x[n[e+9]]+"-"+x[n[e+10]]+x[n[e+11]]+x[n[e+12]]+x[n[e+13]]+x[n[e+14]]+x[n[e+15]]).toLowerCase()}let gt;const ws=new Uint8Array(16);function Ts(){if(!gt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");gt=crypto.getRandomValues.bind(crypto)}return gt(ws)}const mn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ss(n,e,t){var s;if(mn.randomUUID&&!n)return mn.randomUUID();n=n||{};const r=n.random??((s=n.rng)==null?void 0:s.call(n))??Ts();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,_s(r)}function _n(n){const e=n.replace(/-/g,""),t=[];for(let r=0;r<e.length;r+=2)t.push(parseInt(e.substring(r,r+2),16));return t}function As(n,e){for(let t=0;t<n.length;t++){if(n[t]<e[t])return-1;if(n[t]>e[t])return 1}return 0}function vs(n,e){return As(_n(n),_n(e))}function j(){return Ss()}function ks(n,e){return n.localeCompare(e)}function Os(){let n=ks;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Is=Os();let wn=!0;const Es=n=>{wn=n};let Cs=0;function Ee(n){return qe(`_${n}`,Cs++)}function qe(n,e){return`?${n}-${e}`}class me extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Ms(n,e){const t=yn(n,e);if(!t)throw new me(`Could not find id attr for ${e}`);return t}function Tn(n,e,t,r){return[Ps(n,e,t,r)]}function Ps(n,e,t,r){return[n(t,r),Ms(e,t).id,n(t,r),n("time",r)]}function js(n,e,t){return n.map(r=>r===e?t:r)}function Sn(n,e,t,r,s){const i=R(e,t,s),o=fe(e,t,s),a=i||o;if(!a)throw new me(`Could not find attr for ${[t,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,d]=a["reverse-identity"],f=r+1,p=i?[n(u,r),a.id,n(d,f),Ee("time")]:[n(u,f),a.id,n(d,r),Ee("time")];return[i?d:u,f,p,a,!!i]}function An(n,e){if(typeof e!="string")return function(o){return!1};const r=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/%/g,".*").replace(/_/g,"."),s=new RegExp(`^${r}$`,n?void 0:"i");return function(o){return typeof o!="string"?!1:s.test(o)}}function Ds(n,e){if(typeof e!="object"||e.hasOwnProperty("$in")||e.hasOwnProperty("in"))return e;const t=n["checked-data-type"]==="date";if(e.hasOwnProperty("$gt"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])>new Date(e.$gt)}:function(s){return s[2]>e.$gt}};if(e.hasOwnProperty("$gte"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])>=new Date(e.$gte)}:function(s){return s[2]>=e.$gte}};if(e.hasOwnProperty("$lt"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])<new Date(e.$lt)}:function(s){return s[2]<e.$lt}};if(e.hasOwnProperty("$lte"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])<=new Date(e.$lte)}:function(s){return s[2]<=e.$lte}};if(e.hasOwnProperty("$like")){const r=An(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=An(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function $s(n,e,t,r,s,i){const o=R(e,t,s),a=fe(e,t,s),c=o||a;if(!c)throw new me(`No attr for etype = ${t} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=R(e,t,"id");if(!u)throw new me(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Ee("time")]}return o?[n(t,r),c.id,Ds(c,i),Ee("time")]:[i,c.id,n(t,r),Ee("time")]}function Rs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,f]=c,[p,y,g]=Sn(n,e,l,d,u);return[p,y,[...f,g]]},[t,r,[]]);return[i,o,a]}function mt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Rs(n,e,t,r,o),d=$s(n,e,c,u,a,i);return l.concat([d])}function xs(n,e){return e?[e].concat(n):n}function Us([n,e]){return n==="or"&&Array.isArray(e)}function Ls([n,e]){return n==="and"&&Array.isArray(e)}function Fs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function vn(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Fs(n,o,u);return On(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ns(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function kn(n,e,t,r,s){return Ns(s).map(i=>mt(n,e,t,r,i,{$isNull:!0}))}function On(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Us([i,o]))return vn(n,"or",e,t,r,o);if(Ls([i,o]))return vn(n,"and",e,t,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o!=null&&o.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o!=null&&o.hasOwnProperty("$not")){const c=mt(n,e,t,r,a,o),u=kn(n,e,t,r,a);return[{or:{patterns:[c,...u],joinSym:n(t,r)}}]}return o!=null&&o.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:kn(n,e,t,r,a),joinSym:n(t,r)}}]:mt(n,e,t,r,a,o)})}function qs(n,e,t,r){const s=qe;return r?On(s,n,e,t,r).concat(Tn(s,n,e,t)):Tn(s,n,e,t)}function Ks(n,e,t){return[n(e,t),n("time",t)]}function zs(n,e,t,r,s,i){const[o,a,c,u,l]=Sn(n,e,t,r,s),d=js(c,n(t,r),i);return[o,a,d,u,l]}function Ws(n,e,t,{etype:r,level:s,form:i},o){const a=Object.keys(i).filter(c=>c!=="$");return a.length?Object.entries(o).map(function([u,l]){return a.map(function(p){var g,m,w;const y=!!(e.cardinalityInference&&((w=(m=(g=t.linkIndex)==null?void 0:g[r])==null?void 0:m[p])!=null&&w.isSingular));try{const[b,_,k]=zs(n,t,r,s,p,u),T=En(e,t,{etype:b,level:_,form:i[p],join:k}),S=y?T[0]:T;return{[p]:S}}catch(b){if(b instanceof me)return{[p]:y?void 0:[]};throw b}}).reduce(function(p,y){return{...p,...y}},l)}):Object.values(o)}function Vs(n,e,t){return t==="string"?Is(n,e):n>e?1:-1}function Ce(n,e,t,r,s){return e===r||e==null&&r==null?vs(n,t):r==null?1:e==null?-1:Vs(e,r,s)}function Ke([n,e],[t,r],s){return Ce(n,e,t,r,s)}function _t(n){return n==null?n:new Date(n).getTime()}function Qs(n,e,t,r){var y;const[s,i,o,a]=n,c=t==="desc"?1:-1;if(((y=e["forward-identity"])==null?void 0:y[2])==="id")return Ke(r,[s,a],null)===c;const[u,l]=r,d=e["checked-data-type"],f=d==="date"?_t(l):l,p=d==="date"?_t(o):o;return Ke([u,f],[s,p],d)===c}function Bs(n,e){const t=e[1];return n.getAttr(t)}function Gs(n,e,t){const r=Object.keys(t)[0];return R(n,e,r)}function Hs(n,e,t,r){if(t)return Bs(n,t);if(r)return Gs(n,e,r)}function Js(n,e,t){var s,i;if(!Array.isArray(t.fields))return is(n,e);const r=new Map;for(const o of t.fields){const a=R(n,e,o),c=(s=a==null?void 0:a["forward-identity"])==null?void 0:s[2];c&&ht(a)&&r.set(c,a)}if(!r.has("id")){const o=R(n,e,"id"),a=(i=o==null?void 0:o["forward-identity"])==null?void 0:i[2];a&&r.set(a,o)}return r}function Ys(n,e,{etype:t,pageInfo:r,dq:s,form:i}){var y,g;const o=(y=i==null?void 0:i.$)==null?void 0:y.order,a=In(i),c=Zs(i);let u=bs(n,s);const l=r==null?void 0:r["start-cursor"],d=Hs(e,t,l,o);if(d&&((g=d==null?void 0:d["forward-identity"])==null?void 0:g[2])!=="id"){const m=d["checked-data-type"]==="date",w=d.id;u=u.map(([b])=>{var k,T,S,v,D;let _=(D=(v=(S=(T=(k=n.eav.get(b))==null?void 0:k.get(w))==null?void 0:T.values())==null?void 0:S.next())==null?void 0:v.value)==null?void 0:D[2];return m&&(_=_t(_)),[b,_]})}u.sort(c==="asc"?function(w,b){return Ke(w,b,d==null?void 0:d["checked-data-type"])}:function(w,b){return Ke(b,w,d==null?void 0:d["checked-data-type"])});let f={};const p=Js(e,t,s);for(const m of u){const[w]=m;if(f[w]||!a&&l&&d&&Qs(l,d,c,m))continue;const b=ss(n,p,w);b&&(f[w]=b)}return f}function Zs(n){var t;const e=(t=n.$)==null?void 0:t.order;return e&&e[Object.keys(e)[0]]||"asc"}function In(n){var s,i,o;const e=(s=n.$)==null?void 0:s.offset,t=(i=n.$)==null?void 0:i.before,r=(o=n.$)==null?void 0:o.after;return!e&&!t&&!r}function Xs(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){var f,p,y,g,m;if(!In(s)&&(!o||!o["start-cursor"]))return[];const a=xs(qs(e,t,r,(f=s.$)==null?void 0:f.where),i),c=Ks(qe,t,r),u=(p=s.$)==null?void 0:p.fields,l=Ys(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((y=s.$)==null?void 0:y.limit)||((g=s.$)==null?void 0:g.first)||((m=s.$)==null?void 0:m.last);if(d!=null){r>0&&wn&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const w=Object.entries(l);return w.length<=d?l:Object.fromEntries(w.slice(0,d))}return l}function ei(n,e,t){try{return Xs(n,e,t)}catch(r){if(r instanceof me)return{};throw r}}function En(n,e,t){const r=ei(n,e,t);return Ws(qe,n,e,t,r)}function ti(n){const e={};for(const[t,r]of Object.entries(n))e[t]={startCursor:r["start-cursor"],endCursor:r["end-cursor"],hasNextPage:r["has-next-page?"],hasPreviousPage:r["has-previous-page?"]};return e}function wt({store:n,attrsStore:e,pageInfo:t,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r!=null&&r[u]||u==="$$ruleParams"||(c[u]=En(n,e,{etype:u,form:s[u],level:0,pageInfo:t==null?void 0:t[u]})),c},{})};return t&&(o.pageInfo=ti(t)),r&&(o.aggregate=r),o}function ni(){const e={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(e))}const ri=ni();function ze(n,e,t){const r={__etype:n,__ops:t};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return t;if(i==="__etype")return n;if(ri.has(i))return(o,a)=>ze(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Cn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function We(n){return n.startsWith("lookup__")}function Tt(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function si(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>ze(n,Tt(Cn(s,i)),[]);if(t==="__etype")return n;const r=t;return We(r)?ze(n,Tt(r),[]):ze(n,r,[])}})}function St(){return new Proxy({},{get(n,e){return si(e)}})}const ii=St();function Mn(n){return n.__ops}function oi(n,e){const{attrIdMap:t,refSwapAttrIds:r}=n,s=[];for(const o of e){const a=t[o];if(a)s.push(a);else if(Array.isArray(o)&&o.length==2&&t[o[0]]){const[c,u]=o;s.push([t[c],u])}else s.push(o)}const[i]=e;if((i==="add-triple"||i==="retract-triple")&&r.has(e[2])){const o=s[1];s[1]=s[3],s[3]=o}return s}function ai(n){if(Array.isArray(n))return n;const e=Object.entries(n);if(e.length!==1)throw new Error("lookup must be an object with a single unique attr and value.");return e[0]}function ci(n,e,t){return t.indexOf(".")!==-1&&!R(n,e,t)}function At(n){const[e,t,...r]=n.split(".");if(r.length>0||t!=="id")throw new Error(`${n} is not a valid lookup attribute.`);return e}function ui(n,e,t){if(!ci(n,e,t))return R(n,e,t);const r=At(t),s=R(n,e,r)||fe(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function vt(n){return typeof n=="string"&&!We(n)?null:typeof n=="string"&&We(n)?Tt(n):ai(n)}function V(n,e,t){const r=vt(t);if(r===null)return t;const[s,i]=r,o=ui(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Pn(n,e,t,r){var o;const s=V(n,e,t);return Array.isArray(s)?[["add-triple",s,(o=R(n,e,"id"))==null?void 0:o.id,s]].concat(r):r}function li({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=R(n,e,i),u=fe(n,e,i);return a.map(l=>c?["add-triple",V(n,e,t),c.id,V(n,c["reverse-identity"][1],l)]:["add-triple",V(n,u["forward-identity"][1],l),u==null?void 0:u.id,V(n,e,t)])});return Pn(n,e,t,s)}function di({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=R(n,e,i),u=fe(n,e,i);return a.map(l=>c?["retract-triple",V(n,e,t),c.id,V(n,c["reverse-identity"][1],l)]:["retract-triple",V(n,u["forward-identity"][1],l),u.id,V(n,e,t)])});return Pn(n,e,t,s)}function fi(n,e,t,r){var s;if(Array.isArray(r)){const[i,o]=r;for(const a of n||[]){const c=a==null?void 0:a.aev.get(i);if(c){for(const[u,l,d]of W(c,2))if(d===o)return!0}}}else for(const i of n||[]){const o=i==null?void 0:i.eav.get(r);if(o){for(const a of o.keys())if(((s=e.getAttr(a))==null?void 0:s["forward-identity"][1])==t)return!0}}return!1}function jn({stores:n,attrsStore:e},[t,r,s,i]){return(i==null?void 0:i.upsert)===!1?{mode:"update"}:(i==null?void 0:i.upsert)===!0?null:fi(n,e,t,r)?{mode:"update"}:null}function hi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,d])=>{const f=R(t,r,l);return f["checked-data-type"]==="date"&&n.useDateObjects&&(d=Oe(d)),["add-triple",c,f.id,d,{mode:"create"}]})}function pi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s),u=jn(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([d,f])=>{const p=R(t,r,d);return p["checked-data-type"]==="date"&&n.useDateObjects&&(f=Oe(f)),["add-triple",c,p.id,f,...u?[u]:[]]})}function yi({attrsStore:n},[e,t]){return[["delete-entity",V(n,e,t),e]]}function bi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s),u=jn(n,[r,c,i,o]),l=Object.entries(a).map(([f,p])=>{const y=R(t,r,f);return["deep-merge-triple",c,y.id,p,...u?[u]:[]]});return[["add-triple",c,R(t,r,"id").id,c,...u?[u]:[]]].concat(l)}function gi({attrsStore:n},[e,t,r]){return[["rule-params",V(n,e,t),e,r]]}function mi(n){const[e,t,r,s,i]=n;if(!s)return n;const o={...s};return delete o.id,[e,t,r,o,...i?[i]:[]]}function _i(n,e){const[t,...r]=mi(e);switch(t){case"merge":return bi(n,r);case"create":return hi(n,r);case"update":return pi(n,r);case"link":return li(n,r);case"unlink":return di(n,r);case"delete":return yi(n,r);case"ruleParams":return gi(n,r);default:throw new Error(`unsupported action ${t}`)}}function wi(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Ti(n,e,t){var a,c;const r=(c=(a=n.entities[e])==null?void 0:a.attrs)==null?void 0:c[t];if(t==="id")return null;if(!r)throw new Error(`${e}.${t} does not exist in your schema`);const{unique:s,indexed:i}=r==null?void 0:r.config,o=wi(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Ve(n,e,t,r){const s=n?Ti(n,e,t):null,i=j(),a=[j(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function Si(n,e,t){return Object.values(n.links).find(i=>i.forward.on===e&&i.forward.label===t||i.reverse.on===e&&i.reverse.label===t)}function Ai(n,e,t){const r=Si(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[j(),s.on,s.label],"reverse-identity":[j(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Dn(n,e,t,r){const s=n?Ai(n,e,t):null,i=j(),o=[j(),e,t],a=[j(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const vi=new Set(["create","update","merge","link","unlink"]),ki=new Set(["link","unlink"]),Oi=new Set(["create","update","merge"]),Ii=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),kt={"unique?":!0,"index?":!0},Ei={...kt,cardinality:"one"};function Ci(n){const e=[],[t,r,s,i]=n;if(!Ii.has(t))return e;const o=vt(s);if(o&&e.push({etype:r,lookupPair:o}),t==="link")for(const[a,c]of Object.entries(i)){const u=Array.isArray(c)?c:[c];for(const l of u){const d=vt(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function Mi({attrsStore:n,schema:e},t){var f,p;const r=new Set,s=[],i=[];function o(y,g){return R(n,y,g)||s.find(m=>m["forward-identity"][1]===y&&m["forward-identity"][2]===g)}function a(y,g){return fe(n,y,g)||s.find(m=>{var w,b;return((w=m["reverse-identity"])==null?void 0:w[1])===y&&((b=m["reverse-identity"])==null?void 0:b[2])===g})}function c(y){s.push(y),i.push(["add-attr",y]),r.add(y.id)}function u(y){y&&"isUnsynced"in y&&y.isUnsynced&&!r.has(y.id)&&(s.push(y),i.push(["add-attr",y]),r.add(y.id))}function l(y,g){return g.indexOf(".")!==-1&&!o(y,g)}function d(y,g){const m=o(y,g),w=a(y,g);u(m),u(w),!m&&!w&&c(Dn(e,y,g,Ei))}for(const y of t)for(const{etype:g,lookupPair:m,linkLabel:w}of Ci(y)){const b=m[0];if(w){d(g,w);const _=o(g,w),k=a(g,w);u(_),u(k);const T=((f=_==null?void 0:_["reverse-identity"])==null?void 0:f[1])||((p=k==null?void 0:k["forward-identity"])==null?void 0:p[1])||w;if(l(T,b))d(T,At(b));else{const S=o(T,b);S||c(Ve(e,T,b,kt)),u(S)}}else if(l(g,b))d(g,At(b));else{const _=o(g,b);_||c(Ve(e,g,b,kt)),u(_)}}for(const y of t){const[g,m,w,b]=y;if(vi.has(g)){const _=o(m,"id");u(_),_||c(Ve(e,m,"id",{"unique?":!0}));for(const k of Object.keys(b)){const T=o(m,k);if(u(T),Oi.has(g)&&(T||c(Ve(e,m,k,k==="id"?{"unique?":!0}:null))),ki.has(g)){const S=a(m,k);!T&&!S&&c(Dn(e,m,k)),u(S)}}}}if(s.length){const y={...n.attrs};for(const g of s)y[g.id]=g;return[new oe(y,n.linkIndex),i]}return[n,i]}function Pi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Mn(c)),[s,i]=Mi(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>_i(o,c));return[...i,...a]}function $n(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Me="__meta";class Ot{constructor(e,t){}}class It{constructor(e){h(this,"currentValue");h(this,"_subs",[]);h(this,"_persister");h(this,"_merge");h(this,"serialize");h(this,"parse");h(this,"_saveThrottleMs");h(this,"_idleCallbackMaxWaitMs");h(this,"_nextSave",null);h(this,"_nextGc",null);h(this,"_pendingSaveKeys",new Set);h(this,"_loadedKeys",new Set);h(this,"_loadingKeys");h(this,"_objectSize");h(this,"_log");h(this,"onKeyLoaded");h(this,"_version",0);h(this,"_meta",{isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0});h(this,"_gcOpts");this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){var e;this._meta.loadingPromise&&await this._meta.loadingPromise;try{const t=this._persister.getItem(Me);this._meta.loadingPromise=t;const r=await t;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const s=((e=this._meta.value)==null?void 0:e.objects)??{},i=r??{},o=i.objects??{};this._meta.value={...i,objects:{...s,...o}}}catch(t){this._meta.error=t,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const t=await this.waitForMetaToLoad();if(!t)return;const r=Object.entries(t.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const t=await this._persister.getItem(e);return t&&this.parse(e,t)}catch(t){return console.error(`Unable to read from storage for key=${e}`,t),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const t=this._getFromStorage(e);this._loadingKeys[e]=t;const r=await t;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const t=[],r=e==null?void 0:e.skipGc;if(this._meta.isLoading){const d=new Promise((f,p)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(f).catch(p),10+((e==null?void 0:e.attempts)??0)*1e3)});return t.push(d),Promise.all(t).then(f=>f.reduce((p,y)=>p+y,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const d of this._pendingSaveKeys)d in this.currentValue?o.push(d):(i.push(d),delete s.objects[d]);for(const d of i){const f=this._persister.removeItem(d);t.push(f.then(()=>1)),this._loadedKeys.delete(d),this._pendingSaveKeys.delete(d)}const a=[],c=[[Me,s]],u=s.objects??{};s.objects=u;for(const d of o)if(this._loadedKeys.has(d)){const f=this.serialize(d,this.currentValue[d]);c.push([d,f]);const p=this._objectSize(f),y=u[d]??{createdAt:Date.now(),updatedAt:Date.now(),size:p};y.updatedAt=Date.now(),y.size=p,u[d]=y,this._pendingSaveKeys.delete(d)}else a.push(d);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const d of a){const f=this._loadKey(d).then(()=>this._enqueuePersist(e));t.push(f)}return r||this.gc(),Promise.all(t).then(d=>d.reduce((f,p)=>f+p,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Me);const t=new Set(Object.keys(this.currentValue));for(const f of Object.keys(this._loadingKeys))t.add(f);for(const f of this._loadedKeys)t.add(f);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:t,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const f of e)t.has(f)||f in r.objects||(this._log.info("Lost track of key in meta",f),s.push(this._persister.removeItem(f)),i.removed.push(f),i.removedMissingCount++);const o=Date.now();for(const[f,p]of Object.entries(r.objects))!t.has(f)&&p.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([f,p],[y,g])=>p.updatedAt-g.updatedAt);const c=a.filter(([f])=>!t.has(f));if(a.length>this._gcOpts.maxEntries)for(const[f]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([f,p],[y,g])=>p.updatedAt-g.updatedAt);const l=u.filter(([f])=>!t.has(f));let d=u.reduce((f,[p,y])=>f+y.size,0);for(;d>0&&d>this._gcOpts.maxSize&&l.length;){const[[f,p]]=l.splice(0,1);d-=p.size,s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedSizeCount++}for(const f of Object.keys(r.objects))!e.has(f)&&!t.has(f)&&delete r.objects[f];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{$n(()=>{this._nextGc=null,this._gc()},30*1e3)},1e3*60+Math.random()*500))}_enqueuePersist(e){return new Promise((t,r)=>{if(this._nextSave){t(0);return}this._nextSave=setTimeout(()=>{$n(()=>{this._nextSave=null,this._writeToStorage(e).then(t).catch(r)},this._idleCallbackMaxWaitMs)},this._saveThrottleMs)})}version(){return this._version}updateInPlace(e){this._version++;const[t,r]=Le(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=t,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return t}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(t=>t!==e)}}}const ji=6,Di=["kv","querySubs","syncSubs"];function $i(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Ri(n){return new Promise(e=>{const t=indexedDB.open(n);t.onerror=r=>{e(null)},t.onsuccess=r=>{const i=r.target.result;e(i)},t.onupgradeneeded=r=>{var i;(i=r.target.transaction)==null||i.abort(),e(null)}})}async function xi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{var l,d,f;const a={};for(const[p,y]of Object.entries(r)){const g=typeof y=="string"?JSON.parse(y):y;if(g.lastAccessed){const w={createdAt:g.lastAccessed,updatedAt:g.lastAccessed,size:((f=(d=(l=g.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:f.length)??0};a[p]=w}const m=t.put(g,p);s.add(m)}const c={objects:a},u=t.put(c,Me);s.add(u);for(const p of s)p.onsuccess=()=>{s.delete(p),s.size===0&&i()},p.onerror=y=>{o(y)}})}async function Rn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Ui(n,e){const t=await Ri(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,d)=>{const y=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();y.onerror=m=>{d(m)};const g=[];y.onsuccess=()=>{const m=y.result;if(m){const w=m.key,b=m.value;g.push([w,b]),m.continue()}else l(g)},y.onerror=m=>{d(m)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,d]of r)switch(l){case"querySubs":{const f=xi(l,d,o);a.push(f);break}default:{const f=Rn(l,d,i);a.push(f);const p={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=p;break}}const u=Rn(Me,c,i);a.push(u),await Promise.all(a),await new Promise((l,d)=>{s.oncomplete=f=>l(f),s.onerror=f=>d(f),s.onabort=f=>d(f)})}const xn=new Map;class Et extends Ot{constructor(t,r){super(t,r);h(this,"dbName");h(this,"_storeName");h(this,"_appId");h(this,"_prefix");h(this,"_dbPromise");this.dbName=`instant_${t}_${ji}`,this._storeName=r,this._appId=t,this._dbPromise=this._init()}_init(){return new Promise((t,r)=>{let s=!1;const i=indexedDB.open(this.dbName,1);i.onerror=o=>{r(o)},i.onsuccess=o=>{const c=o.target.result;if(s){const u=Ui(this._appId,c).catch(l=>{$i("Error upgrading store from version 5 to 6.")(l)});xn.set(this.dbName,u),u.then(()=>t(c)).catch(()=>t(c))}else{const u=xn.get(this.dbName);u?u.then(()=>t(c)).catch(()=>t(c)):t(c)}},i.onupgradeneeded=o=>{s=!0,this._upgradeStore(o)}})}_upgradeStore(t){const s=t.target.result;for(const i of Di)s.objectStoreNames.contains(i)||s.createObjectStore(i)}async getItem(t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readonly").objectStore(this._storeName).get(t);c.onerror=u=>{i(u)},c.onsuccess=u=>{c.result?s(c.result):s(null)}})}async setItem(t,r){const s=await this._dbPromise;return new Promise((i,o)=>{const u=s.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(r,t);u.onerror=l=>{o(l)},u.onsuccess=l=>{i()}})}async multiSet(t){const r=await this._dbPromise;return new Promise((s,i)=>{const o=r.transaction([this._storeName],"readwrite"),a=o.objectStore(this._storeName),c=new Set;for(const[u,l]of t){const d=a.put(l,u);c.add(d)}for(const u of c)u.onerror=l=>{o.abort(),i(l)},u.onsuccess=l=>{c.delete(u),c.size===0&&s()}})}async removeItem(t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(t);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async getAllKeys(){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();a.onerror=c=>{s(c)},a.onsuccess=c=>{r(a.result.filter(u=>typeof u=="string"))}})}}class Ct{static async getIsOnline(){return navigator.onLine}static listen(e){const t=()=>{e(!0)},r=()=>{e(!1)};return addEventListener("online",t),addEventListener("offline",r),()=>{removeEventListener("online",t),removeEventListener("offline",r)}}}class N extends Error{constructor(t,r){super(t);h(this,"hint");this.hint=r;const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,N),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class Pe extends N{constructor(t){var i;const r=((i=t.body)==null?void 0:i.message)||`API Error (${t.status})`;super(r,t.body.hint);h(this,"body");h(this,"status");const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,Pe),this.name="InstantAPIError",this.status=t.status,this.body=t.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function Z(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new Pe({status:t.status,body:r}))}function Li({apiURI:n,appId:e,email:t}){return Z(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Fi({apiURI:n,appId:e,email:t,code:r,refreshToken:s}){return await Z(`${n}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t,code:r,...s?{"refresh-token":s}:{}})})}async function Ni({apiURI:n,appId:e,refreshToken:t}){return await Z(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function qi({apiURI:n,appId:e}){return await Z(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function Un({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s}){return await Z(`${n}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:t,code_verifier:r,refresh_token:s})})}async function Ki({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i}){return await Z(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i})})}async function zi({apiURI:n,appId:e,refreshToken:t}){return await Z(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function Wi({apiURI:n,appId:e,path:t,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:t,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await Z(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function Vi({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await Z(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function Qi({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await Z(`${n}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:t})});return i}async function Bi(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function Gi({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await Z(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let Mt=!1,Ln=!1,Fn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(Mt=!!window.localStorage.getItem("devBackend"),Ln=!!window.localStorage.getItem("__instantLogging"),Fn=!!window.localStorage.getItem("__devtoolLocalDash"));function Nn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function Hi(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Nn(n.user??{},e==null?void 0:e.keys);r.user={...i,peerId:t}}for(const i of Object.keys(n.peers??{})){const o=(e==null?void 0:e.peers)===void 0,a=Array.isArray(e==null?void 0:e.peers)&&(e==null?void 0:e.peers.includes(i));if(o||a){const c=Nn(n.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Ji(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!en(n.user,e.user))||!Xt(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!en(n.peers[r],e.peers[r]))return!0;return!1}class qn{constructor(){h(this,"promise");h(this,"_resolve");h(this,"_reject");this.promise=new Promise((e,t)=>{this._resolve=e,this._reject=t})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function Kn(n,e=[]){n.forEach(t=>{const{data:r}=t,{"datalog-result":s}=r,{"join-rows":i}=s;for(const o of i)for(const a of o)e.push(a);Kn(t["child-nodes"],e)})}function zn(n){const e=[];return Kn(n,e),e}function Pt(n){return Object.values(n.links).reduce((e,t)=>{var r,s;return e[r=t.forward.on]??(e[r]={}),e[t.forward.on][t.forward.label]={isForward:!0,isSingular:t.forward.has==="one",link:t},e[s=t.reverse.on]??(e[s]={}),e[t.reverse.on][t.reverse.label]={isForward:!1,isSingular:t.reverse.has==="one",link:t},e},{})}const jt="v0.22.140";function Yi(n,e){return{info:n?(...t)=>console.info(...t,e()):()=>{},debug:n?(...t)=>console.debug(...t,e()):()=>{},error:n?(...t)=>console.error(...t,e()):()=>{}}}class q{constructor(e,t,r,s={indexed:!1,unique:!1}){h(this,"metadata",{});this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}clientRequired(){return new q(this.valueType,!1,this.isIndexed,this.config)}optional(){return new q(this.valueType,!1,this.isIndexed,this.config)}unique(){return new q(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new q(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Qe{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Qe(this.attrs,this.links)}}class Be{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Be(this.entities,this.links,{})}}class P extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Wn=["where","order","limit","last","first","offset","after","before","fields","aggregate"],Zi=n=>n.valueType||"unknown",Vn=(n,e,t=!1)=>{if(t||n==null)return!0;switch(e){case"string":return typeof n=="string";case"number":return typeof n=="number"&&!isNaN(n);case"boolean":return typeof n=="boolean";case"date":return n instanceof Date||typeof n=="string"||typeof n=="number";default:return!0}},Xi=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!Vn(d,l,a))throw new P(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof d}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new P(`Operator '${n}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(n,t,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(n,t,e);break;case"$like":case"$ilike":if(c(n,"string",e),n==="$ilike"&&!i.isIndexed)throw new P(`Operator '${n}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(n,"boolean",e);break;default:throw new P(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},_e=(n,e,t,r,s)=>{const i=Zi(t),o=t.valueType==="json";if(typeof n=="object"&&n!==null&&!Array.isArray(n)){if(o)return;const c=n;for(const[u,l]of Object.entries(c))Xi(u,l,i,e,r,t,`${s}.${u}`)}else if(!Vn(n,i,o))throw new P(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},eo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new P(`Invalid dot notation path '${n}'. Must contain at least one dot.`,s);let o=t;for(let l=0;l<i.length-1;l++){const d=i[l],f=r.entities[o];if(!f)throw new P(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const p=f.links[d];if(!p){const y=Object.keys(f.links);throw new P(`Link '${d}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${y.length>0?y.join(", "):"none"}`,s)}o=p.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new P(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!ge(e))throw new P(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);_e(e,n,new q("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!ge(e))throw new P(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);_e(e,n,new q("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new P(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}_e(e,n,u,t,s)},Qn=(n,e,t,r)=>{for(const[s,i]of Object.entries(n)){if(s==="or"||s==="and"){if(Array.isArray(i))for(const u of i)typeof u=="object"&&u!==null&&Qn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){_e(i,"id",new q("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){eo(s,i,e,t,`${r}.${s}`);continue}const o=t.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new P(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)_e(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!ge(i))throw new P(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new q("string",!1,!0);_e(i,s,u,e,`${r}.${s}`)}}},to=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Wn.includes(o))throw new P(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Wn.join(", ")}. Found: ${o}`,r);const i=["offset","before","after","first","last"];for(const o of i)if(n[o]!==void 0&&s>0)throw new P(`'${o}' can only be used on top-level namespaces. It cannot be used in nested queries.`,r);if(n.where&&t){if(typeof n.where!="object"||n.where===null)throw new P(`'where' clause must be an object in entity '${e}', but received: ${typeof n.where}`,r?`${r}.where`:void 0);Qn(n.where,e,t,r?`${r}.where`:"where")}},Bn=(n,e,t,r,s=0)=>{var i;if(!n||typeof n!="object")throw new P(`Query part for entity '${e}' must be an object, but received: ${typeof n}`,r);for(const o of Object.keys(n))if(o!=="$"){if(t&&!(o in t.entities[e].links)){const c=Object.keys(t.entities[e].links);throw new P(`Link '${o}' does not exist on entity '${e}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${r}.${o}`)}const a=n[o];if(typeof a=="object"&&a!==null){const c=(i=t==null?void 0:t.entities[e].links[o])==null?void 0:i.entityName;c&&Bn(a,c,t,`${r}.${o}`,s+1)}}else{const a=n[o];if(typeof a!="object"||a===null)throw new P(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof a}`,`${r}.$`);to(a,e,t,`${r}.$`,s)}},Dt=(n,e)=>{if(typeof n!="object"||n===null)throw new P(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new P(`Query must be an object, but received: ${typeof n}`);const t=n;for(const r of Object.keys(t)){if(Array.isArray(n[r]))throw new P(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new P(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new P(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Bn(t[r],r,e,r,0)}}},Gn=n=>typeof n!="string"?!1:We(n)?!0:ge(n);class H extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Hn=n=>n.length>0?n.join(", "):"none",no=(n,e)=>new H(`Entity '${n}' does not exist in schema. Available entities: ${Hn(e)}`),$t={string:n=>typeof n=="string",number:n=>typeof n=="number"&&!isNaN(n),boolean:n=>typeof n=="boolean",date:n=>n instanceof Date||typeof n=="string"||typeof n=="number",json:()=>!0},ro=(n,e)=>{var t;return n==null?!0:((t=$t[e.valueType])==null?void 0:t.call($t,n))??!1},Jn=(n,e)=>{const t=e.entities[n];if(!t)throw no(n,Object.keys(e.entities));return t},Rt=(n,e,t)=>{const r=Jn(n,t);if(typeof e!="object"||e===null)throw new H(`Arguments for data operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!ro(i,o))throw new H(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},Yn=(n,e,t)=>{const r=Jn(n,t);if(typeof e!="object"||e===null)throw new H(`Arguments for link operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new H(`Link '${s}' does not exist on entity '${n}'. Available links: ${Hn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Gn(a))throw new H(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Gn(i))throw new H(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},so={create:Rt,update:Rt,merge:Rt,link:Yn,unlink:Yn,delete:()=>{}},io=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!ge(s))throw new H(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new H(`Entity name must be a string, but received: ${typeof r}`);const o=so[t];o&&i!==void 0&&o(r,i,e)},Zn=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new H(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new H(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new H(`Transaction operation must be an array, but received: ${typeof s}`);io(s,e)}}};let Xn=0;class er{constructor(e){h(this,"type","ws");h(this,"conn");h(this,"id");h(this,"onopen");h(this,"onmessage");h(this,"onclose");h(this,"onerror");this.id=`${this.type}_${Xn++}`,this.conn=new WebSocket(e),this.conn.onopen=t=>{this.onopen&&this.onopen({target:this})},this.conn.onmessage=t=>{this.onmessage&&this.onmessage({target:this,message:JSON.parse(t.data.toString())})},this.conn.onclose=t=>{this.onclose&&this.onclose({target:this})},this.conn.onerror=t=>{this.onerror&&this.onerror({target:this})}}close(){this.conn.close()}isOpen(){return this.conn.readyState===(WebSocket.OPEN??1)}isConnecting(){return this.conn.readyState===(WebSocket.CONNECTING??0)}send(e){return this.conn.send(JSON.stringify(e))}}class tr{constructor(e,t,r){h(this,"type","sse");h(this,"initParams",null);h(this,"sendQueue",[]);h(this,"sendPromise");h(this,"closeFired",!1);h(this,"sseInitTimeout");h(this,"ES");h(this,"messageUrl");h(this,"conn");h(this,"url");h(this,"id");h(this,"onopen");h(this,"onmessage");h(this,"onclose");h(this,"onerror");this.id=`${this.type}_${Xn++}`,this.url=t,this.messageUrl=r||this.url,this.ES=e,this.conn=new e(t),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=s=>{const i=JSON.parse(s.data);if(Array.isArray(i))for(const o of i)this.handleMessage(o);else this.handleMessage(i)},this.conn.onerror=s=>{this.handleError()}}handleMessage(e){if(e.op==="sse-init"){this.initParams={machineId:e["machine-id"],sessionId:e["session-id"],sseToken:e["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:e})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(e){var t,r,s;try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(t=this.initParams)==null?void 0:t.machineId,session_id:(r=this.initParams)==null?void 0:r.sessionId,sse_token:(s=this.initParams)==null?void 0:s.sseToken,messages:e})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const e=this.sendQueue;this.sendQueue=[];const t=this.postMessages(e);this.sendPromise=t,t.then(()=>{this.sendPromise=null,this.flushQueue()})}send(e){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(e),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}function oo(n,e){const t=n.values;if(t){const r=un(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=cn(r,s.store);t.attrsStore=r}}return n}function ao(n,e){var t;if(e.values){const r=[];for(const s of(t=e.values)==null?void 0:t.entities){const i=an(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function co(n,e,t){var i,o;const r=(i=e==null?void 0:e.state)==null?void 0:i.txId,s=(o=t==null?void 0:t.state)==null?void 0:o.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?t:e||t}function xt(n,e,t){return wt({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function nr(n,e,t,r){var o;const s=(o=R(t,n.table,"id"))==null?void 0:o.id;if(!s)return-1;const i=ye(e.eav,[r,s,r]);return i?i[3]:-1}function rr(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":fn(n,e,s);break;case"removed":ln(n,e,s);break}}function uo(n,e,t){var s,i;const r={};for(const{action:o,triple:a}of t){const[c,u,l]=a,d=(i=(s=e.getAttr(u))==null?void 0:s["forward-identity"])==null?void 0:i[2];if(!d)continue;const f=r[c]??{};r[c]=f;const p=f[d]??{};switch(o){case"added":p.newValue=l;break;case"removed":p.oldValue===void 0&&(p.oldValue=l);break}f[d]=p}for(const[o,a]of Object.entries(r))for(const[c,{oldValue:u,newValue:l}]of Object.entries(a))u===l&&delete a[c];return r}function Ge(n,e){return{[n.table]:e.map(t=>t.entity)}}function lo(n,e){var r;if(n.orderFieldType)return n.orderFieldType;const t=n.orderField==="serverCreatedAt"?"number":(r=R(e(),n.table,n.orderField))==null?void 0:r["checked-data-type"];return n.orderFieldType=t,t}function fo(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return Ce(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Ce(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=n.orderField;t.sort(n.orderDirection==="asc"?function(o,a){return Ce(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Ce(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var sr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(sr||{});class ho{constructor(e,t,r,s,i,o){h(this,"trySend");h(this,"subs");h(this,"callbacks",{});h(this,"config");h(this,"idToHash",{});h(this,"log");h(this,"createStore");h(this,"getAttrs");this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new It({persister:t,merge:co,serialize:ao,parse:(a,c)=>oo(c,this.config.useDateObjects),objectSize:a=>{var c;return((c=a.values)==null?void 0:c.entities.length)||0},logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,t){const r=C(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,s==null?void 0:s.keepSubscription)}}unsubscribe(e,t,r){const s=(this.callbacks[e]||[]).filter(i=>i!==t);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i!=null&&i.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend(j(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend(j(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){var u,l,d,f;await this.subs.waitForKeyToLoad(t);const s=this.subs.currentValue[t];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),(u=s.values)!=null&&u.entities&&r&&r({type:"LoadFromStorage",data:Ge(s,(l=s.values)==null?void 0:l.entities)});return}const i=Object.keys(e)[0],o=((f=(d=e[i])==null?void 0:d.$)==null?void 0:f.order)||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(p=>{p[t]={query:e,hash:t,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const t=this.subs.currentValue[e];t?await this.initSubscription(t.query,t.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const t=e["subscription-id"],r=e.q,s=C(r);this.idToHash[t]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",t,"query",r),i;o.state={subscriptionId:t,token:e.token}})}notifyCbs(e,t){for(const r of this.callbacks[e]||[])r(t)}onSyncLoadBatch(e){const t=e["subscription-id"],r=e["join-rows"],s=this.idToHash[t];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),d=xt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:nr(o,l,a.attrsStore,d.id)}),i.push(d)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ge(o,o.values.entities),batch:i})}onSyncInitFinish(e){var i;const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(o=>{const a=o[r];if(!a){this.log.error("Missing sub for hash",r,e);return}const c=a.state;if(!c)return this.log.error("Sub never set init, missing result",a,e),o;c.txId=e["tx-id"],a.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ge(s,((i=s.values)==null?void 0:i.entities)||[])})}onSyncUpdateTriples(e){var o;const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const a of e.txes){if(i.txId&&i.txId>=a["tx-id"])continue;i.txId=a["tx-id"];const c=[],u={};for(const m of a.changes){const w=u[m.triple[0]]??[];u[m.triple[0]]=w,w.push(m)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const f=[];e:for(const[m,w]of Object.entries(u))for(let b=0;b<d.length;b++){const _=d[b];if(Hr(_.store,m)){rr(_.store,l.attrsStore,w);const k=xt(s,_.store,l.attrsStore),T=uo(_.store,l.attrsStore,w)[m];k?(f.push({oldEntity:_.entity,newEntity:k,changedFields:T||{}}),_.entity=k):c.push(b),delete u[m];continue e}}const p=[];for(const[m,w]of Object.entries(u)){const b=this.createStore([]);rr(b,l.attrsStore,w);const _=xt(s,b,l.attrsStore);if(!_){this.log.error("No entity found after applying change",{sub:s,changes:w,store:b});continue}d.push({store:b,entity:_,serverCreatedAt:nr(s,b,l.attrsStore,_.id)}),p.push(_)}const y=[];for(const m of c.sort().reverse())y.push(d[m].entity),d.splice(m,1);const g=lo(s,this.getAttrs);fo(s,g,d),this.notifyCbs(r,{type:"SyncTransaction",data:Ge(s,(o=s.values)==null?void 0:o.entities),added:p,removed:y,updated:f})}this.subs.updateInPlace(a=>{a[r]=s,a[r].updatedAt=Date.now()})}clearSubscriptionData(e,t){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,t),t?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const t=C(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(t,{type:"Error",data:{[s]:[]},error:r})}onResyncError(e){const t=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(t,!1);r&&this.initSubscription(r.query,r.hash)}}function po({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null;const c=j();let u=!1,l=!1;const d=[],f=[];let p=!1,y=0,g=0;const m=[],w=new TextEncoder;function b(){l=!0;for(const O of d)O()}function _(O){return d.push(O),()=>{const E=d.indexOf(O);E!==-1&&d.splice(E,1)}}function k(O){return f.push(O),()=>{const E=f.indexOf(O);E!==-1&&f.splice(E,1)}}function T(O){o=O;for(const E of f)E(o)}function S(){p=!0}function v(O){let E=y,K=0,Q=0;for(const{byteLen:ee}of m){const ie=E+ee;if(ie>O)break;E=ie,K++,Q+=ee}K>0&&(y+=Q,g-=Q,m.splice(0,K))}async function D(){const O=await t({clientId:i,reconnectToken:c});switch(O.type){case"ok":{const{streamId:E,offset:K}=O;o=E,v(K),m.length&&r({streamId:E,chunks:m.map(Q=>Q.chunk),offset:y}),p=!1;break}case"disconnect":{S();break}case"error":{a&&(a.error(O.error),b());break}}}function U(){S(),D()}function we({offset:O,done:E}){v(O),E&&(u=!0)}function ae(O,E){b(),O.error(E)}function ce(O){return u&&ae(O,new N("Stream has been closed.")),o||ae(O,new N("Stream has not been initialized.")),o}async function X(O){a=O;let E=!0,K=0;for(;E;){let Q=Date.now()+Math.min(15e3,500*(K-1));E=!1;const ee=await t({clientId:e.clientId,reconnectToken:c});switch(ee.type){case"ok":{const{streamId:ie,offset:qt}=ee;if(qt!==0){const De=new N("Write stream is corrupted");ae(O,De);return}T(ie),s(ie,{onDisconnect:S,onFlush:we,onConnectionReconnect:D,onAppendFailed:U}),p=!1;return}case"disconnect":{E=!0,S(),K++,await new Promise(ie=>{setTimeout(ie,Q-Date.now())});break}case"error":{ae(O,ee.error);return}}}}class L extends n{constructor(E,K){super(E,K)}async streamId(){return o||new Promise((E,K)=>{const Q=[],ee=()=>{for(const De of Q)De()},ie=De=>{E(De),ee()},qt=()=>{K(new N("Stream is closed.")),ee()};Q.push(k(ie)),Q.push(_(qt))})}}return{stream:new L({async start(O){try{await X(O)}catch(E){ae(O,E)}},write(O,E){const K=ce(E);if(K){const Q=w.encode(O).length;m.push({chunk:O,byteLen:Q});const ee=y+g;g+=Q,p||r({streamId:K,chunks:[O],offset:ee})}},close(){o&&r({streamId:o,chunks:[],offset:y+g,isDone:!0}),b()},abort(O){o&&r({streamId:o,chunks:[],offset:y+g,isDone:!0,abortReason:O}),b()}}),addCloseCb:_,closed(){return l}}}class yo{constructor(){h(this,"items",[]);h(this,"resolvers",[]);h(this,"isClosed",!1)}push(e){if(this.isClosed)return;const t=this.resolvers.shift();t?t({value:e,done:!1}):this.items.push(e)}close(){for(this.isClosed=!0;this.resolvers.length>0;)this.resolvers.shift()({value:void 0,done:!0})}async*[Symbol.asyncIterator](){for(;;)if(this.items.length>0)yield this.items.shift();else{if(this.isClosed)return;{const{value:e,done:t}=await new Promise(r=>{this.resolvers.push(r)});if(t||!e)return;yield e}}}}function bo({RStream:n,opts:e,startStream:t,cancelStream:r}){let s=e.byteOffset||0,i=!1;const o=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[];function d(){u=!0;for(const b of l)b()}function f(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function p(b,_){b.error(_),d()}let y=0;async function g(b,_){c=j();const k={...b||{},eventId:c};for await(const T of t(k)){if(i)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){p(_,T.error);return}if(T.offset>s){p(_,new N("Stream is corrupted.")),i=!0;return}let S=s-T.offset;if(T.files&&T.files.length){const v=new AbortController;let D=fetch(T.files[0].url,{signal:v.signal});for(let U=0;U<T.files.length;U++){const we=T.files[U+1],ce=await D;if(we&&(D=fetch(we.url,{signal:v.signal})),!ce.ok){if(y++,y>10){p(_,new N("Unable to process stream."));return}return{retry:!0}}if(ce.body)for await(const X of ce.body){if(i){v.abort();return}let L=X;if(S>0&&(L=X.subarray(S),S-=X.length-L.length),!L.length)continue;s+=L.length;const he=o.decode(L);_.enqueue(he)}else{const X=await ce.arrayBuffer();let L=X;if(i){v.abort();return}if(S>0&&(L=new Uint8Array(X).subarray(S),S-=X.byteLength-L.length),!L.byteLength)continue;s+=L.byteLength;const he=o.decode(L);_.enqueue(he)}}}if(y=0,T.content){let v=T.content,D=a.encode(T.content);if(S>0){const U=D.subarray(S);if(S-=D.length-U.length,!U.length)continue;D=U,v=o.decode(U)}s+=D.length,_.enqueue(v)}}}async function m(b){let _=!0,k=0;for(;_;){_=!1;let T=Date.now()+Math.min(15e3,500*(k-1));const S=await g({...e,offset:s},b);S!=null&&S.retry&&(_=!0,k++,T<Date.now()-3e5&&(k=0),await new Promise(v=>{setTimeout(v,T-Date.now())}))}!i&&!u&&(b.close(),d())}return{stream:new n({start(b){m(b)},cancel(b){i=!0,c&&r({eventId:c}),d()}}),addCloseCb:f,closed(){return u}}}class ir{constructor({WStream:e,RStream:t,trySend:r,log:s}){h(this,"trySend");h(this,"WStream");h(this,"RStream");h(this,"writeStreams",{});h(this,"startWriteStreamCbs",{});h(this,"readStreamIterators",{});h(this,"log");h(this,"activeStreams",new Set);this.WStream=e,this.RStream=t,this.trySend=r,this.log=s}createWriteStream(e){const{stream:t,addCloseCb:r}=po({WStream:this.WStream,startStream:this.startWriteStream.bind(this),appendStream:this.appendStream.bind(this),registerStream:this.registerWriteStream.bind(this),opts:e});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}createReadStream(e){const{stream:t,addCloseCb:r}=bo({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=j();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend(j(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s}){const i={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(i["stream-id"]=r),t&&(i["client-id"]=t),s&&(i.offset=s);const o=new yo;return this.readStreamIterators[e]=o,this.trySend(e,i),o}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend(j(),t),delete this.readStreamIterators[e]}onStreamAppend(e){var s;const t=e["client-event-id"],r=this.readStreamIterators[t];if(!r){this.log.info("No iterator for read stream",e);return}if(e.error){e.retry?r.push({type:"reconnect"}):r.push({type:"error",error:new N(e.error)}),r.close(),delete this.readStreamIterators[t];return}((s=e.files)!=null&&s.length||e.content)&&r.push({type:"append",offset:e.offset,files:e.files,content:e.content}),e.done&&(r.close(),delete this.readStreamIterators[t])}onConnectionStatusChange(e){for(const t of Object.values(this.startWriteStreamCbs))t({type:"disconnect"});if(this.startWriteStreamCbs={},e!==ne.AUTHENTICATED)for(const{onDisconnect:t}of Object.values(this.writeStreams))t();else{for(const{onConnectionReconnect:t}of Object.values(this.writeStreams))t();for(const t of Object.values(this.readStreamIterators))t.push({type:"reconnect"}),t.close();this.readStreamIterators={}}}onRecieveError(e){const t=e["original-event"];switch(t.op){case"append-stream":{const r=t["stream-id"],s=this.writeStreams[r];s==null||s.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new N(e.message||"Unknown error",e.hint)}),delete this.startWriteStreamCbs[r]);break}case"subscribe-stream":{const r=e["client-event-id"],s=this.readStreamIterators[r];s&&(s.push({type:"error",error:new N(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const ne={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},go=3e4,mo=3e4,_o=200,wo=1e3*60,To={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ut="_instant_oauth_redirect",je="currentUser";function So({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new er(`${r}?app_id=${e}`);switch(n){case"ws":return new er(`${r}?app_id=${e}`);case"sse":return new tr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Ao(){return typeof window<"u"||typeof chrome<"u"}const or={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function vo(n,e){var r;const t=typeof n=="string"?JSON.parse(n):n;if((r=t==null?void 0:t.result)!=null&&r.store){const s=un(t.result.attrsStore,t.result.store);if(s){const i=t.result.store;t.result.store=cn(s,{...i,useDateObjects:e}),t.result.attrsStore=s}}return t}function ko(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:an(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Oo(n,e){switch(n){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function Io(n,e){switch(n){case"pendingMutations":return[...e.entries()];default:return e}}function Eo(n,e,t){const r=e==null?void 0:e.result,s=t==null?void 0:t.result;return r&&!s&&t&&(t.result=r),t||e}function Lt(n){return[...n].sort((e,t)=>{const[r,s]=e,[i,o]=t,a=s.order||0,c=o.order||0;return a==c?r<i?-1:r>i?1:0:a-c})}class ar{constructor(e,t=Et,r=Ct,s,i){h(this,"attrs");h(this,"_isOnline",!0);h(this,"_isShutdown",!1);h(this,"status",ne.CONNECTING);h(this,"querySubs");h(this,"kv");h(this,"_syncTable");h(this,"_instantStream");h(this,"queryCbs",{});h(this,"queryOnceDfds",{});h(this,"authCbs",[]);h(this,"attrsCbs",[]);h(this,"mutationErrorCbs",[]);h(this,"connectionStatusCbs",[]);h(this,"config");h(this,"mutationDeferredStore",new Map);h(this,"_reconnectTimeoutId",null);h(this,"_reconnectTimeoutMs",0);h(this,"_transport");h(this,"_transportType","ws");h(this,"_EventSource");h(this,"_wsOk",null);h(this,"_localIdPromises",{});h(this,"_errorMessage",null);h(this,"_oauthCallbackResponse",null);h(this,"_linkIndex",null);h(this,"_broadcastChannel");h(this,"_rooms",{});h(this,"_roomsPendingLeave",{});h(this,"_presence",{});h(this,"_broadcastQueue",[]);h(this,"_broadcastSubs",{});h(this,"_currentUserCached",{isLoading:!0,error:void 0,user:void 0});h(this,"_beforeUnloadCbs",[]);h(this,"_dataForQueryCache",{});h(this,"_log");h(this,"_pendingTxCleanupTimeout");h(this,"_pendingMutationCleanupThreshold");h(this,"_inFlightMutationEventIds",new Set);h(this,"_onMergeKv",(e,t,r)=>{switch(e){case"pendingMutations":{const s=(t==null?void 0:t.entries())??[],i=(r==null?void 0:r.entries())??[],o=new Map([...s,...i]);return(t?this._rewriteMutationsSorted(this.attrs,t):[]).forEach(([c,u])=>{var l;!((l=r==null?void 0:r.pendingMutations)!=null&&l.has(c))&&!u["tx-id"]&&this._sendMutation(c,u)}),o}default:return r||t}});h(this,"getPreviousResult",e=>{var r;const t=C(e);return(r=this.dataForQuery(t))==null?void 0:r.data});h(this,"notifyOne",e=>{var i;const t=this.queryCbs[e]??[],r=(i=this._dataForQueryCache[e])==null?void 0:i.data,s=this.dataForQuery(e);s!=null&&s.data&&(this._dataForQueryCache[e]=s,!Fe(s.data,r)&&t.forEach(o=>o.cb(s.data)))});h(this,"notifyOneQueryOnce",e=>{var s;const t=this.queryOnceDfds[e]??[],r=(s=this.dataForQuery(e))==null?void 0:s.data;t.forEach(i=>{this._completeQueryOnce(i.q,e,i.dfd),i.dfd.resolve(r)})});h(this,"notifyQueryError",(e,t)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:t}))});h(this,"pushTx",e=>{this.config.disableValidation||Zn(e,this.config.schema);try{const t=Pi({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>{var s;return(s=r==null?void 0:r.result)==null?void 0:s.store}),useDateObjects:this.config.useDateObjects},e);return this.pushOps(t)}catch(t){return this.pushOps([],t)}});h(this,"pushOps",(e,t)=>{const r=j(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:t,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new qn;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise});h(this,"_transportOnOpen",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][open]",t.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(ne.OPENED),this.getCurrentUser().then(r=>{var s;this._trySend(j(),{op:"init","app-id":this.config.appId,"refresh-token":(s=r.user)==null?void 0:s.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",t.id,r)})});h(this,"_transportOnMessage",e=>{const t=e.target,r=e.message;if(this._transport!==t){this._log.info("[socket][message]",t.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&t.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(t.id,s);else this._handleReceive(t.id,e.message)});h(this,"_transportOnError",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][error]",t.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",t.id,e)});h(this,"_scheduleReconnect",()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)});h(this,"_transportOnClose",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][close]",t.id,"skip; this is no longer the current transport");return}this._setStatus(ne.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",t.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",t.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()});if(this._EventSource=i,this.config={...To,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??mo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??_o,this._log=Yi(e.verbose||Mt||Ln,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":jt},this.config.schema&&(this._linkIndex=Pt(this.config.schema)),!!Ao()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!ge(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{var a;try{if(((a=o.data)==null?void 0:a.type)==="auth"){const c=await this.getCurrentUser();await this.updateUser(c.user).catch(u=>{this._log.error("[error] update user",u)})}}catch(c){this._log.error("[error] handle broadcast channel",c)}})),this._initStorage(t),this._syncTable=new ho(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>be(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ir({WStream:this.config.WritableStream||WritableStream,RStream:this.config.ReadableStream||ReadableStream,trySend:this._trySendAuthed.bind(this),log:this._log}),this._oauthCallbackResponse=this._oauthLoginInit(),this.getCurrentUser().then(o=>{this.syncUserToEndpoint(o.user)}),setInterval(async()=>{const o=await this.getCurrentUser();this.syncUserToEndpoint(o.user)},wo),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",ne.CLOSED),this._setStatus(ne.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?Pt(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new It({persister:new e(this.config.appId,"querySubs"),merge:Eo,serialize:ko,parse:(t,r)=>vo(r,this.config.useDateObjects),objectSize:t=>{var r,s,i;return((i=(s=(r=t==null?void 0:t.result)==null?void 0:r.store)==null?void 0:s.triples)==null?void 0:i.length)??0},logger:this._log,preloadEntryCount:10,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}}),this.querySubs.onKeyLoaded=t=>this._onQuerySubLoaded(t),this.kv=new It({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:Io,parse:Oo,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=t=>{t==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(je),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,t,r){const s=this.mutationDeferredStore.get(t);this.mutationDeferredStore.delete(t);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:t,...r}),!!s)if(i)s.resolve({status:e,eventId:t});else if(r!=null&&r.type){const{status:o,...a}=r;s.reject(new Pe({body:a,status:o??0}))}else s.reject(new N((r==null?void 0:r.message)||"Unknown error",r==null?void 0:r.hint))}_setStatus(e,t){this.status=e,this._errorMessage=t,this.notifyConnectionStatusSubs(e),this._instantStream.onConnectionStatusChange(e)}_flushEnqueuedRoomData(e){var s,i;const t=(i=(s=this._presence[e])==null?void 0:s.result)==null?void 0:i.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],t&&this._trySetPresence(e,t),r)for(const o of r){const{topic:a,roomType:c,data:u}=o;this._tryBroadcast(e,c,a,u)}}_addQueryData(e,t,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=C(e),i=this.ensureAttrs(),o=be(this.attrs,t.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:t.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,t){var s,i,o,a,c,u,l;const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(or[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ne.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const p of Object.keys(this._rooms)){const y=(i=(s=this._presence[p])==null?void 0:s.result)==null?void 0:i.user,g=(o=this._rooms[p])==null?void 0:o.roomType;this._tryJoinRoom(g,p,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(C(t.q));break}case"add-query-ok":{const{q:p,result:y}=t,g=C(p);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[g])break;const m=(c=(a=y==null?void 0:y[0])==null?void 0:a.data)==null?void 0:c["page-info"],w=(l=(u=y==null?void 0:y[0])==null?void 0:u.data)==null?void 0:l.aggregate,b=zn(y),_=this.ensureAttrs(),k=be(_,b,r,this.config.useDateObjects);this.querySubs.updateInPlace(T=>{if(!T[g]){this._log.info("Missing value in querySubs",{hash:g,q:p});return}T[g].result={store:k,attrsStore:_,pageInfo:m,aggregate:w,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(g),this.notifyOneQueryOnce(g),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(t);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(t);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(t);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(t);break}case"start-stream-ok":{this._instantStream.onStartStreamOk(t);break}case"stream-flushed":{this._instantStream.onStreamFlushed(t);break}case"append-failed":{this._instantStream.onAppendFailed(t);break}case"stream-append":{this._instantStream.onStreamAppend(t);break}case"refresh-ok":{const{computations:p,attrs:y}=t,g=t["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const m=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),g);m!==this._pendingMutations()&&this.kv.updateInPlace(_=>{_.pendingMutations=m});const w=Lt(m.entries()),b=p.map(_=>{var L,he,O,E;const k=_["instaql-query"],T=_["instaql-result"],S=C(k),v=zn(T),D=this.ensureAttrs(),U=be(D,v,r,this.config.useDateObjects),{store:we,attrsStore:ae}=this._applyOptimisticUpdates(U,D,w,g),ce=(he=(L=T==null?void 0:T[0])==null?void 0:L.data)==null?void 0:he["page-info"],X=(E=(O=T==null?void 0:T[0])==null?void 0:O.data)==null?void 0:E.aggregate;return{q:k,hash:S,store:we,attrsStore:ae,pageInfo:ce,aggregate:X}});b.forEach(({hash:_,q:k,store:T,attrsStore:S,pageInfo:v,aggregate:D})=>{this.querySubs.updateInPlace(U=>{if(!U[_]){this._log.error("Missing value in querySubs",{hash:_,q:k});return}U[_].result={store:T,attrsStore:S,pageInfo:v,aggregate:D,processedTxId:g}})}),this._cleanupPendingMutationsQueries(),b.forEach(({hash:_})=>{this.notifyOne(_)});break}case"transact-ok":{const{"client-event-id":p,"tx-id":y}=t;this._inFlightMutationEventIds.delete(p);const m=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(p);if(!m)break;this._updatePendingMutations(b=>{b.set(p,{...b.get(p),"tx-id":y,confirmed:Date.now()})});const w=[];for(const b of m["tx-steps"])if(b[0]==="add-attr"){const _=b[1];w.push(_)}if(w.length){const b=Object.values(this.ensureAttrs().attrs);this._setAttrs([...b,...w])}this._finishTransaction("synced",p),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const p=t["room-id"];this._trySetRoomConnected(p,!0),this._patchPresencePeers(p,t.edits),this._notifyPresenceSubs(p);break}case"refresh-presence":{const p=t["room-id"];this._trySetRoomConnected(p,!0),this._setPresencePeers(p,t.data),this._notifyPresenceSubs(p);break}case"server-broadcast":{const p=t["room-id"],y=t.topic;this._trySetRoomConnected(p,!0),this._notifyBroadcastSubs(p,y,t);break}case"join-room-ok":{const p=t["room-id"];if(!this._rooms[p]){this._roomsPendingLeave[p]&&(this._tryLeaveRoom(p),delete this._roomsPendingLeave[p]);break}this._trySetRoomConnected(p,!0),this._flushEnqueuedRoomData(p);break}case"leave-room-ok":{const p=t["room-id"];this._trySetRoomConnected(p,!1);break}case"join-room-error":const d=t["room-id"],f=this._rooms[d];f&&(f.error=t.error),this._notifyPresenceSubs(d);break;case"error":this._handleReceiveError(t);break;default:this._log.info("Uknown op",t.op,t);break}}createWriteStream(e){return this._instantStream.createWriteStream(e)}createReadStream(e){return this._instantStream.createReadStream(e)}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(t=>{const r=t.pendingMutations??new Map;t.pendingMutations=r,e(r)})}_handleMutationError(e,t,r){const s=this._pendingMutations().get(t);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(t),o)),this._inFlightMutationEventIds.delete(t);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,t,r)}}_handleReceiveError(e){var a,c,u,l,d,f;console.log("error",e);const t=e["client-event-id"];this._inFlightMutationEventIds.delete(t);const r=this._pendingMutations().get(t),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",t,e);return}if((a=e["original-event"])!=null&&a.hasOwnProperty("q")&&((c=e["original-event"])==null?void 0:c.op)==="add-query"){const p=(u=e["original-event"])==null?void 0:u.q,y=C(p);this.notifyQueryError(C(p),s),this.notifyQueryOnceError(p,y,t,s);return}if(((l=e["original-event"])==null?void 0:l.op)==="init"){if(e.type==="record-not-found"&&((d=e.hint)==null?void 0:d["record-type"])==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ne.ERRORED,s),this.notifyAll();return}switch((f=e["original-event"])==null?void 0:f.op){case"resync-table":{this._syncTable.onResyncError(e);return}case"start-sync":{this._syncTable.onStartSyncError(e);return}case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{this._instantStream.onRecieveError(e);return}}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
|
|
1
|
+
(function(A,C){typeof exports=="object"&&typeof module<"u"?C(exports):typeof define=="function"&&define.amd?define(["exports"],C):(A=typeof globalThis<"u"?globalThis:A||self,C(A.instant={}))})(this,function(A){"use strict";var ra=Object.defineProperty;var sa=(A,C,M)=>C in A?ra(A,C,{enumerable:!0,configurable:!0,writable:!0,value:M}):A[C]=M;var h=(A,C,M)=>sa(A,typeof C!="symbol"?C+"":C,M);function C(n){if(typeof n=="number")return(Math.abs(n*2654435761)>>>0).toString(16);if(typeof n=="boolean")return n?"1":"0";if(n===null)return"null";if(n===void 0)return"undefined";if(typeof n=="string"){let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(n)){let e=2166136261;for(let t=0;t<n.length;t++){e^=(t+1)*2654435761;const r=C(n[t]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof n=="object"){let e=2166136261;const t=Object.keys(n).sort();for(let r=0;r<t.length;r++){const s=t[r],i=C(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=C(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return C(String(n))}const M={Remove:"remove",Replace:"replace",Add:"add"},Kt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),gr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),$e=Symbol.iterator,B={mutable:"mutable",immutable:"immutable"},Ye={};function Te(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function zt(n,e){if(e in n){let t=Reflect.getPrototypeOf(n);for(;t;){const r=Reflect.getOwnPropertyDescriptor(t,e);if(r)return r;t=Reflect.getPrototypeOf(t)}}}function Ze(n){return Object.getPrototypeOf(n)===Set.prototype}function Xe(n){return Object.getPrototypeOf(n)===Map.prototype}function G(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function ue(n){return!!I(n)}function I(n){return typeof n!="object"?null:n==null?void 0:n[Kt]}function et(n){var e;const t=I(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function J(n,e){if(!n||typeof n!="object")return!1;let t;return Object.getPrototypeOf(n)===Object.prototype||Array.isArray(n)||n instanceof Map||n instanceof Set||!!(e!=null&&e.mark)&&((t=e.mark(n,B))===B.immutable||typeof t=="function")}function Wt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=I(re(t,n.key));if(r!==null&&(r==null?void 0:r.original)!==n.original)return null;const s=n.parent.type===3,i=s?Array.from(n.parent.setMap.keys()).indexOf(n.key):n.key;if(!(s&&t.size>i||Te(t,i)))return null;e.push(i)}if(n.parent)return Wt(n.parent,e);e.reverse();try{mr(n.copy,e)}catch{return null}return e}function le(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function re(n,e){return le(n)===2?n.get(e):n[e]}function Se(n,e,t){le(n)===2?n.set(e,t):n[e]=t}function tt(n,e){const t=I(n);return(t?G(t):n)[e]}function se(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function nt(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function de(n,e){return e?n:[""].concat(n).map(t=>{const r=`${t}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function mr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=re(le(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function _r(n){const e=Object.create(Object.getPrototypeOf(n));return Reflect.ownKeys(n).forEach(t=>{let r=Reflect.getOwnPropertyDescriptor(n,t);if(r.enumerable&&r.configurable&&r.writable){e[t]=n[t];return}r.writable||(r.writable=!0,r.configurable=!0),(r.get||r.set)&&(r={configurable:!0,writable:!0,enumerable:r.enumerable,value:n[t]}),Reflect.defineProperty(e,t,r)}),e}const wr=Object.prototype.propertyIsEnumerable;function Vt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!Ze(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n.values())}return Set.prototype.difference?Set.prototype.difference.call(n,new Set):new Set(n.values())}else if(n instanceof Map){if(!Xe(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e!=null&&e.mark&&(t=e.mark(n,B),t!==void 0)&&t!==B.mutable){if(t===B.immutable)return _r(n);if(typeof t=="function"){if(e.enablePatches||e.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return t()}throw new Error(`Unsupported mark result: ${t}`)}else if(typeof n=="object"&&Object.getPrototypeOf(n)===Object.prototype){const r={};return Object.keys(n).forEach(s=>{r[s]=n[s]}),Object.getOwnPropertySymbols(n).forEach(s=>{wr.call(n,s)&&(r[s]=n[s])}),r}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function F(n){n.copy||(n.copy=Vt(n.original,n.options))}function Ae(n){if(!J(n))return et(n);if(Array.isArray(n))return n.map(Ae);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ae(s)]);if(!Xe(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Map(t)}if(n instanceof Set){const t=Array.from(n).map(Ae);if(!Ze(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Set(t)}const e=Object.create(Object.getPrototypeOf(n));for(const t in n)e[t]=Ae(n[t]);return e}function Re(n){return ue(n)?Ae(n):n}function te(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&te(n.parent))}function Qt(){throw new Error("Cannot modify frozen object")}function pe(n,e,t,r,s){{t=t??new WeakMap,r=r??[],s=s??[];const o=t.has(n)?t.get(n):n;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(n)||ue(n)){r.pop(),s.pop();return}switch(le(n)){case 2:for(const[a,c]of n)pe(a,a,t,r,s),pe(c,a,t,r,s);n.set=n.clear=n.delete=Qt;break;case 3:for(const a of n)pe(a,a,t,r,s);n.add=n.clear=n.delete=Qt;break;case 1:Object.freeze(n);let o=0;for(const a of n)pe(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];pe(c,a,t,r,s)})}r.pop(),s.pop()}function rt(n,e){const t=le(n);if(t===0)Reflect.ownKeys(n).forEach(r=>{e(r,n[r],n)});else if(t===1){let r=0;for(const s of n)e(r,s,n),r+=1}else n.forEach((r,s)=>e(s,r,n))}function Bt(n,e,t){if(ue(n)||!J(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),rt(n,(i,o)=>{var a;if(ue(o)){const c=I(o);F(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Se(r?s:n,i,u)}else Bt(o,e,t)}),s){const i=n,o=Array.from(i);i.clear(),o.forEach(a=>{i.add(s.has(a)?s.get(a):a)})}}function Tr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Bt(re(t,e),n.finalities.handledSet,n.options)}function st(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(et(e))}))}function it(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Wt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ot(n,e,t,r){const s=I(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(se(re(c,e),t)){let u=s.original;s.copy&&(u=s.copy),st(n),it(n,r,i,o),n.options.enableAutoFreeze&&(n.options.updatedValues=(a=n.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,n.options.updatedValues.set(u,s.original)),Se(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),J(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;se(re(i,e),t)&&Tr(n,e)})}function Sr(n,e,t,r,s){let{original:i,assignedMap:o,options:a}=n,c=n.copy;c.length<i.length&&([i,c]=[c,i],[t,r]=[r,t]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),d=de(l,s);t.push({op:M.Replace,path:d,value:Re(c[u])}),r.push({op:M.Replace,path:d,value:Re(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),d=de(l,s);t.push({op:M.Add,path:d,value:Re(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),d=de(l,s);r.push({op:M.Replace,path:d,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const d=e.concat([l-1]),f=de(d,s);r.push({op:M.Remove,path:f})}}}function Ar({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=re(n,c),l=Re(re(e,c)),d=a?Te(n,c)?M.Replace:M.Add:M.Remove;if(se(u,l)&&d===M.Replace)return;const f=r.concat(c),p=de(f,o);s.push(d===M.Remove?{op:d,path:p}:{op:d,path:p,value:l}),i.push(d===M.Add?{op:M.Remove,path:p}:d===M.Remove?{op:M.Add,path:p,value:u}:{op:M.Replace,path:p,value:u})})}function vr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=de(c,i);r.push({op:M.Remove,path:u,value:a}),s.unshift({op:M.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=de(c,i);r.push({op:M.Add,path:u,value:a}),s.unshift({op:M.Remove,path:u,value:a})}o+=1})}function ve(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return Ar(n,e,t,r,s);case 1:return Sr(n,e,t,r,s);case 3:return vr(n,e,t,r,s)}}const xe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!J(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},at={get size(){return G(I(this)).size},has(n){return G(I(this)).has(n)},set(n,e){const t=I(this),r=G(t);return(!r.has(n)||!se(r.get(n),e))&&(F(t),te(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ot(t,n,e,ve)),this},delete(n){if(!this.has(n))return!1;const e=I(this);return F(e),te(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=I(this);if(this.size){F(n),te(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=I(this);G(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=I(this),s=G(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,B))===B.mutable;if(r.options.strict&&xe(s,r.options,i),i||r.finalized||!J(s,r.options)||s!==r.original.get(n))return s;const o=Ye.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return F(r),r.copy.set(n,o),o},keys(){return G(I(this)).keys()},values(){const n=this.keys();return{[$e]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[$e]:()=>this.entries(),next:()=>{const e=n.next();if(e.done)return e;const t=this.get(e.value);return{done:!1,value:[e.value,t]}}}},[$e](){return this.entries()}},kr=Reflect.ownKeys(at),Gt=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=I(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,B))===B.mutable;if(n.options.strict&&xe(o,n.options,u),!u&&!c&&J(o,n.options)&&!n.finalized&&n.original.has(o)){const l=Ye.createDraft({original:o,parentDraft:n,key:o,finalities:n.finalities,options:n.options});n.setMap.set(o,l),a=l}else c&&(a=c.proxy);return{done:!1,value:t?a:[a,a]}},Ue={get size(){return I(this).setMap.size},has(n){const e=I(this);if(e.setMap.has(n))return!0;F(e);const t=I(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=I(this);return this.has(n)||(F(e),te(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ot(e,n,n,ve)),this},delete(n){if(!this.has(n))return!1;const e=I(this);F(e),te(e);const t=I(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=I(this);F(n),te(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Gt(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Gt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[$e](){return this.values()},forEach(n,e){const t=this.values();let r=t.next();for(;!r.done;)n.call(e,r.value,r.value,this),r=t.next()}};Set.prototype.difference&&Object.assign(Ue,{intersection(n){return Set.prototype.intersection.call(new Set(this.values()),n)},union(n){return Set.prototype.union.call(new Set(this.values()),n)},difference(n){return Set.prototype.difference.call(new Set(this.values()),n)},symmetricDifference(n){return Set.prototype.symmetricDifference.call(new Set(this.values()),n)},isSubsetOf(n){return Set.prototype.isSubsetOf.call(new Set(this.values()),n)},isSupersetOf(n){return Set.prototype.isSupersetOf.call(new Set(this.values()),n)},isDisjointFrom(n){return Set.prototype.isDisjointFrom.call(new Set(this.values()),n)}});const Or=Reflect.ownKeys(Ue),Ht=new WeakSet,Jt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Ht.has(i))return i;if(e===Kt)return n;let o;if(n.options.mark){const u=e==="size"&&(n.original instanceof Map||n.original instanceof Set)?Reflect.get(n.original,e):Reflect.get(n.original,e,t);if(o=n.options.mark(u,B),o===B.mutable)return n.options.strict&&xe(u,n.options,!0),u}const a=G(n);if(a instanceof Map&&kr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(at,"size").get.call(n.proxy);const u=at[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Or.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(Ue,"size").get.call(n.proxy);const u=Ue[e];if(u)return u.bind(n.proxy)}if(!Te(a,e)){const u=zt(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(n.proxy):void 0}const c=a[e];if(n.options.strict&&xe(c,n.options),n.finalized||!J(c,n.options))return c;if(c===tt(n.original,e)){if(F(n),n.copy[e]=ct({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=I(n.copy[e]);return F(u),te(u),u.copy}return n.copy[e]}return c},set(n,e,t){var r;if(n.type===3||n.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(n.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=zt(G(n),e);if(i!=null&&i.set)return i.set.call(n.proxy,t),!0;const o=tt(G(n),e),a=I(o);return a&&se(a.original,t)?(n.copy[e]=t,n.assignedMap=(r=n.assignedMap)!==null&&r!==void 0?r:new Map,n.assignedMap.set(e,!1),!0):(se(t,o)&&(t!==void 0||Te(n.original,e))||(F(n),te(n),Te(n.original,e)&&se(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ot(n,e,t,ve)),!0)},has(n,e){return e in G(n)},ownKeys(n){return Reflect.ownKeys(G(n))},getOwnPropertyDescriptor(n,e){const t=G(n),r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:n.type!==1||e!=="length",enumerable:r.enumerable,value:t[e]}},getPrototypeOf(n){return Reflect.getPrototypeOf(n.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(n,e){var t;return n.type===1?Jt.set.call(this,n,e,void 0,n.proxy):(tt(n.original,e)!==void 0||e in n.original?(F(n),te(n),n.assignedMap.set(e,!1)):(n.assignedMap=(t=n.assignedMap)!==null&&t!==void 0?t:new Map,n.assignedMap.delete(e)),n.copy&&delete n.copy[e],!0)}};function ct(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=le(e),a={type:o,finalized:!1,parent:t,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in n)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,Jt);if(s.revoke.push(u),Ht.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((d,f)=>{var p,y;const g=I(c);let m=l.type===3?l.setMap:l.copy;const w=re(m,r),b=I(w);if(b){let _=b.original;b.operated&&(_=et(w)),st(b),it(b,ve,d,f),l.options.enableAutoFreeze&&(l.options.updatedValues=(p=l.options.updatedValues)!==null&&p!==void 0?p:new WeakMap,l.options.updatedValues.set(_,b.original)),Se(m,r,_)}(y=g.callbacks)===null||y===void 0||y.forEach(_=>{_(d,f)})})}else{const l=I(c);l.finalities.draft.push((d,f)=>{st(l),it(l,ve,d,f)})}return c}Ye.createDraft=ct;function Ir(n,e,t,r,s){var i;const o=I(n),a=(i=o==null?void 0:o.original)!==null&&i!==void 0?i:n,c=!!e.length;if(o!=null&&o.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(t,r);const u=c?e[0]:o?o.operated?o.copy:o.original:n;return o&&nt(o),s&&pe(u,u,o==null?void 0:o.options.updatedValues),[u,t&&c?[{op:M.Replace,path:[],value:e[0]}]:t,r&&c?[{op:M.Replace,path:[],value:a}]:r]}function Er(n,e){var t;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((t=e.mark)===null||t===void 0?void 0:t.call(e,n,B))===B.mutable||!J(n,e)?n:ct({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=Ir(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function ut(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;rt(t,(i,o,a)=>{const c=I(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(d=>a.add(i===d?u:d))}else Se(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ut(n))}),s&&(n.isContainDraft||console.warn("The return value does not contain any draft, please use 'rawReturn()' to wrap the return value to improve performance."),r&&console.warn("The return value contains drafts, please don't use 'rawReturn()' to wrap the return value."))}function Yt(n){var e;const t=I(n);if(!J(n,t==null?void 0:t.options))return n;const r=le(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?Xe(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Vt(n,t==null?void 0:t.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(rt(s,(o,a)=>{if(t&&se(re(t.original,o),a))return;const c=Yt(a);c!==a&&(s===n&&i(),Se(s,o,c))}),r===3){const o=(e=t==null?void 0:t.original)!==null&&e!==void 0?e:s;return Ze(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function Zt(n){if(!ue(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return Yt(n)}const Le=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(T,...S){return e(T,v=>t.call(this,v,...S),r)};const c=t,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},n),l);const d=ue(c)?Zt(c):c,f=Array.isArray(l.mark)?(T,S)=>{for(const v of l.mark){if(typeof v!="function")throw new Error(`Invalid mark: ${v}, 'mark' should be a function.`);const D=v(T,S);if(D)return D}}:l.mark,p=(i=l.enablePatches)!==null&&i!==void 0?i:!1,y=(o=l.strict)!==null&&o!==void 0?o:!1,m={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:f,strict:y,enablePatches:p};if(!J(d,m)&&typeof d=="object"&&d!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[w,b]=Er(d,m);if(typeof r!="function"){if(!J(d,m))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[w,b]}let _;try{_=u(w)}catch(T){throw nt(I(w)),T}const k=T=>{const S=I(w);if(!ue(T)){if(T!==void 0&&!se(T,w)&&(S!=null&&S.operated))throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const D=T==null?void 0:T[gr];if(D){const U=D[0];return m.strict&&typeof T=="object"&&T!==null&&ut({rootDraft:S,value:T,useRawReturn:!0}),b([U])}if(T!==void 0)return typeof T=="object"&&T!==null&&ut({rootDraft:S,value:T}),b([T])}if(T===w||T===void 0)return b([]);const v=I(T);if(m===v.options){if(v.operated)throw new Error("Cannot return a modified child draft.");return b([Zt(T)])}return b([T])};return _ instanceof Promise?_.then(k,T=>{throw nt(I(w)),T}):k(_)})();Object.prototype.constructor.toString();function Xt(n,e){const t=Object.keys(n),r=Object.keys(e);return t.length===r.length&&Object.keys(n).every(s=>e.hasOwnProperty(s))}function en(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function Fe(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:Xt(n,e)?Object.keys(n).every(t=>Fe(n[t],e[t])):!1}function lt(n){if(!ke(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function tn(n,e){if(!ke(n)||!ke(e))return e;const t={...n};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete t[r];continue}const s=ke(n[r])&&ke(e[r]);t[r]=s?tn(n[r],e[r]):e[r]}return t}function ke(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Cr(n,e,t){if(!n||e.length===0)return;let r=n||{};for(let i=0;i<e.length-1;i++){const o=e[i];(!(o in r)||typeof r[o]!="object")&&(r[o]=typeof e[i+1]=="number"?[]:{}),r=r[o]}const s=e[e.length-1];Array.isArray(r)&&typeof s=="number"?r.splice(s,0,t):r[s]=t}function nn(n,e,t){if(!n||e.length===0)return;let r=n||{};for(let s=0;s<e.length-1;s++){const i=e[s];(!(i in r)||typeof r[i]!="object")&&(r[i]=typeof e[s+1]=="number"?[]:{}),r=r[i]}r[e[e.length-1]]=t}function rn(n,e){if(!n||e.length===0)return;const[t,...r]=e;if(t in n){if(r.length===0){Array.isArray(n)?n.splice(t,1):delete n[t];return}rn(n[t],r),Mr(n[t])&&delete n[t]}}function Mr(n){return n&&Object.keys(n).length===0}const sn=/ZULU|YEKT|YEKST|YAPT|YAKT|YAKST|XJT|WGT|WGST|WFT|WETDST|WET|WDT|WAT|WAST|WAKT|WADT|VUT|VOLT|VLAT|VLAST|VET|UZT|UZST|UYT|UYST|UTC|UT|ULAT|ULAST|UCT|TVT|TRUT|TOT|TMT|TKT|TJT|TFT|TAHT|SGT|SCT|SAST|SADT|RET|PYT|PYST|PWT|PST|PONT|PMST|PMDT|PKT|PKST|PHT|PGT|PETT|PETST|PET|PDT|OMST|OMSST|NZT|NZST|NZDT|NUT|NST|NPT|NOVT|NOVST|NFT|NDT|MYT|MVT|MUT|MUST|MST|MSK|MSD|MPT|MMT|MHT|MEZ|METDST|MET|MESZ|MEST|MDT|MAWT|MART|MAGT|MAGST|LKT|LINT|LIGT|LHST|LHDT|KST|KRAT|KRAST|KOST|KGT|KGST|KDT|JST|JAYT|IST|IRT|IRKT|IRKST|IOT|IDT|ICT|HST|HKT|GYT|GMT|GILT|GFT|GET|GEST|GAMT|GALT|FNT|FNST|FKT|FKST|FJT|FJST|FET|EST|EGT|EGST|EETDST|EET|EEST|EDT|EAT|EAST|EASST|DDUT|DAVT|CXT|CST|COT|CLT|CLST|CKT|CHUT|CHAST|CHADT|CETDST|CET|CEST|CDT|CCT|CAST|CADT|BTT|BST|BRT|BRST|BRA|BOT|BORT|BNT|BDT|BDST|AZT|AZST|AZOT|AZOST|AWST|AWSST|AST|ART|ARST|ANAT|ANAST|AMT|AMST|ALMT|ALMST|AKST|AKDT|AFT|AEST|AESST|AEDT|ADT|ACWST|ACT|ACST|ACSST|ACDT$/,Pr={ZULU:0,YEKT:18e3,YEKST:21600,YAPT:36e3,YAKT:32400,YAKST:32400,XJT:21600,WGT:-10800,WGST:-7200,WFT:43200,WETDST:3600,WET:0,WDT:32400,WAT:3600,WAST:25200,WAKT:43200,WADT:28800,VUT:39600,VOLT:10800,VLAT:36e3,VLAST:36e3,VET:-14400,UZT:18e3,UZST:21600,UYT:-10800,UYST:-7200,UTC:0,UT:0,ULAT:28800,ULAST:32400,UCT:0,TVT:43200,TRUT:36e3,TOT:46800,TMT:18e3,TKT:46800,TJT:18e3,TFT:18e3,TAHT:-36e3,SGT:28800,SCT:14400,SAST:7200,SADT:37800,RET:14400,PYT:-14400,PYST:-10800,PWT:32400,PST:-28800,PONT:39600,PMST:-10800,PMDT:-7200,PKT:18e3,PKST:21600,PHT:28800,PGT:36e3,PETT:43200,PETST:43200,PET:-18e3,PDT:-25200,OMST:21600,OMSST:21600,NZT:43200,NZST:43200,NZDT:46800,NUT:-39600,NST:-12600,NPT:20700,NOVT:25200,NOVST:25200,NFT:-12600,NDT:-9e3,MYT:28800,MVT:18e3,MUT:14400,MUST:18e3,MST:-25200,MSK:10800,MSD:14400,MPT:36e3,MMT:23400,MHT:43200,MEZ:3600,METDST:7200,MET:3600,MESZ:7200,MEST:7200,MDT:-21600,MAWT:18e3,MART:-34200,MAGT:39600,MAGST:39600,LKT:19800,LINT:50400,LIGT:36e3,LHST:37800,LHDT:37800,KST:32400,KRAT:25200,KRAST:25200,KOST:39600,KGT:21600,KGST:21600,KDT:36e3,JST:32400,JAYT:32400,IST:7200,IRT:12600,IRKT:28800,IRKST:28800,IOT:21600,IDT:10800,ICT:25200,HST:-36e3,HKT:28800,GYT:-14400,GMT:0,GILT:43200,GFT:-10800,GET:14400,GEST:14400,GAMT:-32400,GALT:-21600,FNT:-7200,FNST:-3600,FKT:-10800,FKST:-10800,FJT:43200,FJST:46800,FET:10800,EST:-18e3,EGT:-3600,EGST:0,EETDST:10800,EET:7200,EEST:10800,EDT:-14400,EAT:10800,EAST:-21600,EASST:-21600,DDUT:36e3,DAVT:25200,CXT:25200,CST:-21600,COT:-18e3,CLT:-14400,CLST:-10800,CKT:-36e3,CHUT:36e3,CHAST:45900,CHADT:49500,CETDST:7200,CET:3600,CEST:7200,CDT:-18e3,CCT:28800,CAST:34200,CADT:37800,BTT:21600,BST:3600,BRT:-10800,BRST:-7200,BRA:-10800,BOT:-14400,BORT:28800,BNT:28800,BDT:21600,BDST:7200,AZT:14400,AZST:14400,AZOT:-3600,AZOST:0,AWST:28800,AWSST:32400,AST:-14400,ART:-10800,ARST:-10800,ANAT:43200,ANAST:43200,AMT:-14400,AMST:14400,ALMT:21600,ALMST:25200,AKST:-32400,AKDT:-28800,AFT:16200,AEST:36e3,AESST:39600,AEDT:39600,ADT:-10800,ACWST:31500,ACT:-18e3,ACST:34200,ACSST:37800,ACDT:37800};function jr(n){return new Date(n)}function Dr(n){return new Date(n+"Z")}const $r=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Rr(n){const e=n.match($r);if(!e)return null;const[t,r,s,i]=e;return r<=0||s<=0||i<=0?null:r>999?new Date(Date.UTC(r,s-1,i,0,0,0,0)):new Date(Date.UTC(i,r-1,s,0,0,0,0))}function xr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Ur(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Lr(n){return new Date(n)}function Fr(n){const e=/^(\w{3}) (\w{3}) (\d{2}) (\d{4})$/;if(!n.match(e))throw new Error(`Unable to parse \`${n}\` as a date.`);const r=new Date(n+" UTC");return new Date(Date.UTC(r.getUTCFullYear(),r.getUTCMonth(),r.getUTCDate(),0,0,0,0))}function Nr(n){const e=/^(.+T.+)([+-])(\d{2})$/,t=n.match(e);if(t){const[,r,s,i]=t,o=`${r}${s}${i}:00`;return new Date(o)}return null}function qr(n){const e=/^(\d+)-(\d{1,2})-(\d{1,2})([ T])(.+)$/,t=n.match(e);if(t){const[,r,s,i,o,a]=t,c=s.padStart(2,"0"),u=i.padStart(2,"0"),l=`${r}-${c}-${u}T${a}`;return new Date(l)}return null}function Kr(n){const[e,t]=n.split(", "),[r,s,i]=e.split("/").map(Number),o=t.match(/(\d{1,2}):(\d{2}):(\d{2}) (AM|PM)/);if(!o)throw new Error(`Unable to parse time from: ${n}`);let[,a,c,u,l]=o;return a=Number(a),c=Number(c),u=Number(u),l==="PM"&&a!==12?a+=12:l==="AM"&&a===12&&(a=0),new Date(Date.UTC(i,r-1,s,a,c,u))}function zr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Wr(n){const e=n.match(sn);if(!e)return null;const[t]=e,r=Pr[t],s=new Date(n.replace(sn,"Z"));return new Date(s.getTime()-r*1e3)}const Vr=[Rr,Ur,Fr,Kr,Lr,Dr,Nr,xr,jr,zr,Wr,qr];function Qr(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function dt(n){for(const e of Vr){const t=Qr(e,n);if(t)return t}return null}function Br(n){try{const e=JSON.parse(n);return typeof e=="string"?dt(e):null}catch{return null}}function Oe(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=dt(n)||Br(n)||dt(n.trim());if(!e)throw new Error(`Unable to parse \`${n}\` as a date.`);return e}else if(typeof n=="number")return new Date(n);throw new Error(`Invalid date value \`${n}\`. Expected a date, number, or string, got type ${typeof n}.`)}}class oe{constructor(e,t){h(this,"attrs");h(this,"linkIndex");h(this,"_blobAttrs",null);h(this,"_primaryKeys",null);h(this,"_forwardIdents",null);h(this,"_revIdents",null);this.attrs=e,this.linkIndex=t}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const t=this.attrs[e.id];t&&(this.attrs[e.id]={...t,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(ht(e)){const[t,r,s]=e["forward-identity"];z(this.blobAttrs,[r,s],e)}return this._blobAttrs}get primaryKeys(){if(this._primaryKeys)return this._primaryKeys;this._primaryKeys=new Map;for(const e of Object.values(this.attrs))if(e["primary?"]){const[t,r]=e["forward-identity"];z(this._primaryKeys,[r],e)}return this._primaryKeys}get forwardIdents(){if(this._forwardIdents)return this._forwardIdents;this._forwardIdents=new Map;for(const e of Object.values(this.attrs)){const t=e["forward-identity"],[r,s,i]=t;z(this._forwardIdents,[s,i],e)}return this._forwardIdents}get revIdents(){if(this._revIdents)return this._revIdents;this._revIdents=new Map;for(const e of Object.values(this.attrs)){const t=e["reverse-identity"];if(t){const[r,s,i]=t;z(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function Gr(n){return n.cardinality==="one"}function ft(n){return n["value-type"]==="ref"}function ht(n){return n["value-type"]==="blob"}function ye(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function Y(n,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){n.delete(e[0]);return}const[t,...r]=e;n.has(t)&&Y(n.get(t),r)}function z(n,e,t){let r=n;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],t)}function on(n,e,t){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=n.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&t&&(u=Oe(u),o[2]=u),ft(l)&&z(i,[u,c,a],o),z(r,[a,c,u],o),z(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function an(n){return{triples:W(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function cn(n,e){return be(n,e.triples,e.cardinalityInference,e.useDateObjects)}function un(n,e){if(n)return new oe(n.attrs,n.linkIndex);if(e&&"__type"in e)return new oe(e.attrs,e.linkIndex)}function Hr(n,e){return ye(n.eav,[e])!==void 0}function be(n,e,t,r){const s=on(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Ie(n,e){var s,i;let t;if(Array.isArray(e[0])){const[o,a]=e[0],c=n.aev.get(o);if(!c)return null;t=(s=W(c,2).find(l=>l[2]===a))==null?void 0:s[0]}else t=e[0];if(!t)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&n.aev.get(r[0])){const[o,a]=r,c=n.aev.get(o);if(!c)return null;const l=(i=W(c,2).find(g=>g[2]===a))==null?void 0:i[0];if(!l)return null;const[d,f,p,...y]=e;return[t,f,l,...y]}else{const[o,...a]=e;return[t,...a]}}function ln(n,e,t){const r=Ie(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(Y(n.eav,[s,i,o]),Y(n.aev,[i,s,o]),ft(a)&&Y(n.vae,[o,i,s]))}let Jr=0;function dn(n,e,t){const[r,s,i]=t;let o;const a=ye(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+Jr++}function fn(n,e,t){const r=Ie(n,t);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&n.useDateObjects&&(o=Oe(o));const c=ye(n.eav,[s,i,o]),u=(c==null?void 0:c[3])??dn(n,a,r),l=[s,i,o,u];Gr(a)?(z(n.eav,[s,i],new Map([[o,l]])),z(n.aev,[i,s],new Map([[o,l]]))):(z(n.eav,[s,i,o],l),z(n.aev,[i,s,o],l)),ft(a)&&z(n.vae,[o,i,s],l)}function Yr(n,e,t){var p;const r=Ie(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!ht(a))throw new Error("merge operation is not supported for links");const c=ye(n.eav,[s,i]);if(!c)return;const u=(p=c.values().next())==null?void 0:p.value;if(!u)return;const l=u[2],d=tn(l,o),f=[s,i,d,dn(n,a,u)];z(n.eav,[s,i],new Map([[d,f]])),z(n.aev,[i,s],new Map([[d,f]]))}function pt(n,e,t){var u,l;const[r,s]=t,i=Ie(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const d of a.keys()){const f=e.getAttr(d);f&&f["on-delete-reverse"]==="cascade"&&W(a.get(d),1).forEach(([p,y,g])=>{var m;return pt(n,e,[g,(m=f["reverse-identity"])==null?void 0:m[1]])}),(!s||!f||((u=f["forward-identity"])==null?void 0:u[1])===s)&&(Y(n.aev,[d,o]),Y(n.eav,[o,d]))}a.size===0&&Y(n.eav,[o])}const c=n.vae.get(o)&&W(n.vae.get(o),2);c&&c.forEach(d=>{var m,w,b;const[f,p,y]=d,g=e.getAttr(p);(!s||!g||((m=g["reverse-identity"])==null?void 0:m[1])===s)&&(Y(n.eav,[f,p,y]),Y(n.aev,[p,f,y]),Y(n.vae,[y,p,f])),g&&g["on-delete"]==="cascade"&&((w=g["reverse-identity"])==null?void 0:w[1])===s&&pt(n,e,[f,(b=g["forward-identity"])==null?void 0:b[1]])}),((l=n.vae.get(o))==null?void 0:l.size)===0&&Y(n.vae,[o])}function hn(n,e,t){const r=on(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function Zr(n,[e]){n.addAttr(e)}function pn(n){return W(n.eav,3)}function Xr(n,e,[t]){if(!e.getAttr(t))return;const r=pn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),hn(n,e,r)}function es(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),hn(n,e,pn(n)))}function ts(n,e,t){const[r,...s]=t;switch(r){case"add-triple":fn(n,e,s);break;case"deep-merge-triple":Yr(n,e,s);break;case"retract-triple":ln(n,e,s);break;case"delete-entity":pt(n,e,s);break;case"add-attr":Zr(e,s);break;case"delete-attr":Xr(n,e,s);break;case"update-attr":es(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function W(n,e,t=[]){if(!n||e===0)return t;if(e===1){for(const r of n.values())t.push(r);return t}for(const r of n.values())W(r,e-1,t);return t}function Ne(n,e,t){var i;const r=[];if(t!=null&&t.hasOwnProperty("$not")){for(const o of e.keys())t.$not!==o&&r.push(e.get(o));return r}if(t!=null&&t.hasOwnProperty("$isNull")){const{attrId:o,isNull:a,reverse:c}=t.$isNull;if(c)for(const u of e.keys()){const l=n.vae.get(u),d=!l||!l.get(o);(a?d:!d)&&r.push(e.get(u))}else{const u=n.aev.get(o);for(const l of e.keys()){const d=!u||((i=u.get(l))==null?void 0:i.get(null))||!u.get(l);(a?d:!d)&&r.push(e.get(l))}}return r}if(t!=null&&t.$comparator)return W(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const o of s){const a=e.get(o);a&&r.push(a)}return r}function ns(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function rs(n,[e,t,r]){var i,o;switch(ns(e,t,r)){case"e":{const a=n.eav.get(e);return W(a,2)}case"ea":{const a=(i=n.eav.get(e))==null?void 0:i.get(t);return W(a,1)}case"eav":{const a=(o=n.eav.get(e))==null?void 0:o.get(t);return a?Ne(n,a,r):[]}case"ev":{const a=n.eav.get(e);if(!a)return[];const c=[];for(const u of a.values())c.push(...Ne(n,u,r));return c}case"a":{const a=n.aev.get(t);return W(a,2)}case"av":{const a=n.aev.get(t);if(!a)return[];const c=[];for(const u of a.values())c.push(...Ne(n,u,r));return c}case"v":{const a=[];for(const c of n.eav.values())for(const u of c.values())a.push(...Ne(n,u,r));return a}default:return W(n.eav,3)}}function ss(n,e,t){var s;const r={};if(!e)return r;for(const[i,o]of e.entries()){const a=(s=n.eav.get(t))==null?void 0:s.get(o.id),c=W(a,1);for(const u of c)r[i]=u[2]}return r}function R(n,e,t){var r;return(r=n.forwardIdents.get(e))==null?void 0:r.get(t)}function fe(n,e,t){var r;return(r=n.revIdents.get(e))==null?void 0:r.get(t)}function is(n,e){return n.blobAttrs.get(e)}function yn(n,e){var r;const t=n.primaryKeys.get(e);return t||((r=n.forwardIdents.get(e))==null?void 0:r.get("id"))}function os(n,e,t){const r=Ie(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return ye(n.eav,[s,i])}function as(n,e,t){const r=t.filter(([s,i,o,a,c])=>{if(s!=="add-triple"&&s!=="deep-merge-triple")return!0;const u=c==null?void 0:c.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const d=e.getAttr(o);if(d){const f=yn(e,d["forward-identity"][1]);l=!!os(n,e,[i,f==null?void 0:f.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Le({store:n,attrsStore:e},s=>{r.forEach(i=>{ts(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof oe)return"immutable"}})}function cs(n){return typeof n=="string"&&n.startsWith("?")}function us(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return gn(r,e,t)}return{...t,[n]:e}}function bn(n,e,t){return n===e?t:null}function ls(n){switch(typeof n){case"string":return n.startsWith("?")?us:bn;default:return bn}}const ds=["in","$in","$not","$isNull","$comparator"];function fs(n){for(const e of ds)if(n.hasOwnProperty(e))return!0;return!1}function gn(n,e,t){return t?typeof n=="object"?fs(n)?t:null:ls(n)(n,e,t):null}function hs(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return gn(s,o,r)},t)}function ps(n,e,t){return gs(n,e,t).map(r=>hs(e,r,t)).filter(r=>r)}function ys(n,e,t){return e.or?e.or.patterns.flatMap(r=>yt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>yt(n,s,r),t):t.flatMap(r=>ps(n,e,r))}function yt(n,e,t=[{}]){return e.reduce((r,s)=>ys(n,s,r),t)}function bt(n,e){return Array.isArray(e)?e.map(t=>bt(n,t)):cs(e)?n[e]:e}function bs(n,{find:e,where:t}){return yt(n,t).map(s=>bt(s,e))}function gs(n,e,t){return rs(n,bt(t,e))}const ms=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function ge(n){return typeof n=="string"&&ms.test(n)}const x=[];for(let n=0;n<256;++n)x.push((n+256).toString(16).slice(1));function _s(n,e=0){return(x[n[e+0]]+x[n[e+1]]+x[n[e+2]]+x[n[e+3]]+"-"+x[n[e+4]]+x[n[e+5]]+"-"+x[n[e+6]]+x[n[e+7]]+"-"+x[n[e+8]]+x[n[e+9]]+"-"+x[n[e+10]]+x[n[e+11]]+x[n[e+12]]+x[n[e+13]]+x[n[e+14]]+x[n[e+15]]).toLowerCase()}let gt;const ws=new Uint8Array(16);function Ts(){if(!gt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");gt=crypto.getRandomValues.bind(crypto)}return gt(ws)}const mn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ss(n,e,t){var s;if(mn.randomUUID&&!n)return mn.randomUUID();n=n||{};const r=n.random??((s=n.rng)==null?void 0:s.call(n))??Ts();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,_s(r)}function _n(n){const e=n.replace(/-/g,""),t=[];for(let r=0;r<e.length;r+=2)t.push(parseInt(e.substring(r,r+2),16));return t}function As(n,e){for(let t=0;t<n.length;t++){if(n[t]<e[t])return-1;if(n[t]>e[t])return 1}return 0}function vs(n,e){return As(_n(n),_n(e))}function j(){return Ss()}function ks(n,e){return n.localeCompare(e)}function Os(){let n=ks;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Is=Os();let wn=!0;const Es=n=>{wn=n};let Cs=0;function Ee(n){return qe(`_${n}`,Cs++)}function qe(n,e){return`?${n}-${e}`}class me extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Ms(n,e){const t=yn(n,e);if(!t)throw new me(`Could not find id attr for ${e}`);return t}function Tn(n,e,t,r){return[Ps(n,e,t,r)]}function Ps(n,e,t,r){return[n(t,r),Ms(e,t).id,n(t,r),n("time",r)]}function js(n,e,t){return n.map(r=>r===e?t:r)}function Sn(n,e,t,r,s){const i=R(e,t,s),o=fe(e,t,s),a=i||o;if(!a)throw new me(`Could not find attr for ${[t,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,d]=a["reverse-identity"],f=r+1,p=i?[n(u,r),a.id,n(d,f),Ee("time")]:[n(u,f),a.id,n(d,r),Ee("time")];return[i?d:u,f,p,a,!!i]}function An(n,e){if(typeof e!="string")return function(o){return!1};const r=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/%/g,".*").replace(/_/g,"."),s=new RegExp(`^${r}$`,n?void 0:"i");return function(o){return typeof o!="string"?!1:s.test(o)}}function Ds(n,e){if(typeof e!="object"||e.hasOwnProperty("$in")||e.hasOwnProperty("in"))return e;const t=n["checked-data-type"]==="date";if(e.hasOwnProperty("$gt"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])>new Date(e.$gt)}:function(s){return s[2]>e.$gt}};if(e.hasOwnProperty("$gte"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])>=new Date(e.$gte)}:function(s){return s[2]>=e.$gte}};if(e.hasOwnProperty("$lt"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])<new Date(e.$lt)}:function(s){return s[2]<e.$lt}};if(e.hasOwnProperty("$lte"))return{$comparator:!0,$op:t?function(s){return new Date(s[2])<=new Date(e.$lte)}:function(s){return s[2]<=e.$lte}};if(e.hasOwnProperty("$like")){const r=An(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=An(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function $s(n,e,t,r,s,i){const o=R(e,t,s),a=fe(e,t,s),c=o||a;if(!c)throw new me(`No attr for etype = ${t} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=R(e,t,"id");if(!u)throw new me(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Ee("time")]}return o?[n(t,r),c.id,Ds(c,i),Ee("time")]:[i,c.id,n(t,r),Ee("time")]}function Rs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,f]=c,[p,y,g]=Sn(n,e,l,d,u);return[p,y,[...f,g]]},[t,r,[]]);return[i,o,a]}function mt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Rs(n,e,t,r,o),d=$s(n,e,c,u,a,i);return l.concat([d])}function xs(n,e){return e?[e].concat(n):n}function Us([n,e]){return n==="or"&&Array.isArray(e)}function Ls([n,e]){return n==="and"&&Array.isArray(e)}function Fs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function vn(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Fs(n,o,u);return On(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ns(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function kn(n,e,t,r,s){return Ns(s).map(i=>mt(n,e,t,r,i,{$isNull:!0}))}function On(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Us([i,o]))return vn(n,"or",e,t,r,o);if(Ls([i,o]))return vn(n,"and",e,t,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o!=null&&o.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o!=null&&o.hasOwnProperty("$not")){const c=mt(n,e,t,r,a,o),u=kn(n,e,t,r,a);return[{or:{patterns:[c,...u],joinSym:n(t,r)}}]}return o!=null&&o.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:kn(n,e,t,r,a),joinSym:n(t,r)}}]:mt(n,e,t,r,a,o)})}function qs(n,e,t,r){const s=qe;return r?On(s,n,e,t,r).concat(Tn(s,n,e,t)):Tn(s,n,e,t)}function Ks(n,e,t){return[n(e,t),n("time",t)]}function zs(n,e,t,r,s,i){const[o,a,c,u,l]=Sn(n,e,t,r,s),d=js(c,n(t,r),i);return[o,a,d,u,l]}function Ws(n,e,t,{etype:r,level:s,form:i},o){const a=Object.keys(i).filter(c=>c!=="$");return a.length?Object.entries(o).map(function([u,l]){return a.map(function(p){var g,m,w;const y=!!(e.cardinalityInference&&((w=(m=(g=t.linkIndex)==null?void 0:g[r])==null?void 0:m[p])!=null&&w.isSingular));try{const[b,_,k]=zs(n,t,r,s,p,u),T=En(e,t,{etype:b,level:_,form:i[p],join:k}),S=y?T[0]:T;return{[p]:S}}catch(b){if(b instanceof me)return{[p]:y?void 0:[]};throw b}}).reduce(function(p,y){return{...p,...y}},l)}):Object.values(o)}function Vs(n,e,t){return t==="string"?Is(n,e):n>e?1:-1}function Ce(n,e,t,r,s){return e===r||e==null&&r==null?vs(n,t):r==null?1:e==null?-1:Vs(e,r,s)}function Ke([n,e],[t,r],s){return Ce(n,e,t,r,s)}function _t(n){return n==null?n:new Date(n).getTime()}function Qs(n,e,t,r){var y;const[s,i,o,a]=n,c=t==="desc"?1:-1;if(((y=e["forward-identity"])==null?void 0:y[2])==="id")return Ke(r,[s,a],null)===c;const[u,l]=r,d=e["checked-data-type"],f=d==="date"?_t(l):l,p=d==="date"?_t(o):o;return Ke([u,f],[s,p],d)===c}function Bs(n,e){const t=e[1];return n.getAttr(t)}function Gs(n,e,t){const r=Object.keys(t)[0];return R(n,e,r)}function Hs(n,e,t,r){if(t)return Bs(n,t);if(r)return Gs(n,e,r)}function Js(n,e,t){var s,i;if(!Array.isArray(t.fields))return is(n,e);const r=new Map;for(const o of t.fields){const a=R(n,e,o),c=(s=a==null?void 0:a["forward-identity"])==null?void 0:s[2];c&&ht(a)&&r.set(c,a)}if(!r.has("id")){const o=R(n,e,"id"),a=(i=o==null?void 0:o["forward-identity"])==null?void 0:i[2];a&&r.set(a,o)}return r}function Ys(n,e,{etype:t,pageInfo:r,dq:s,form:i}){var y,g;const o=(y=i==null?void 0:i.$)==null?void 0:y.order,a=In(i),c=Zs(i);let u=bs(n,s);const l=r==null?void 0:r["start-cursor"],d=Hs(e,t,l,o);if(d&&((g=d==null?void 0:d["forward-identity"])==null?void 0:g[2])!=="id"){const m=d["checked-data-type"]==="date",w=d.id;u=u.map(([b])=>{var k,T,S,v,D;let _=(D=(v=(S=(T=(k=n.eav.get(b))==null?void 0:k.get(w))==null?void 0:T.values())==null?void 0:S.next())==null?void 0:v.value)==null?void 0:D[2];return m&&(_=_t(_)),[b,_]})}u.sort(c==="asc"?function(w,b){return Ke(w,b,d==null?void 0:d["checked-data-type"])}:function(w,b){return Ke(b,w,d==null?void 0:d["checked-data-type"])});let f={};const p=Js(e,t,s);for(const m of u){const[w]=m;if(f[w]||!a&&l&&d&&Qs(l,d,c,m))continue;const b=ss(n,p,w);b&&(f[w]=b)}return f}function Zs(n){var t;const e=(t=n.$)==null?void 0:t.order;return e&&e[Object.keys(e)[0]]||"asc"}function In(n){var s,i,o;const e=(s=n.$)==null?void 0:s.offset,t=(i=n.$)==null?void 0:i.before,r=(o=n.$)==null?void 0:o.after;return!e&&!t&&!r}function Xs(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){var f,p,y,g,m;if(!In(s)&&(!o||!o["start-cursor"]))return[];const a=xs(qs(e,t,r,(f=s.$)==null?void 0:f.where),i),c=Ks(qe,t,r),u=(p=s.$)==null?void 0:p.fields,l=Ys(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((y=s.$)==null?void 0:y.limit)||((g=s.$)==null?void 0:g.first)||((m=s.$)==null?void 0:m.last);if(d!=null){r>0&&wn&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const w=Object.entries(l);return w.length<=d?l:Object.fromEntries(w.slice(0,d))}return l}function ei(n,e,t){try{return Xs(n,e,t)}catch(r){if(r instanceof me)return{};throw r}}function En(n,e,t){const r=ei(n,e,t);return Ws(qe,n,e,t,r)}function ti(n){const e={};for(const[t,r]of Object.entries(n))e[t]={startCursor:r["start-cursor"],endCursor:r["end-cursor"],hasNextPage:r["has-next-page?"],hasPreviousPage:r["has-previous-page?"]};return e}function wt({store:n,attrsStore:e,pageInfo:t,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r!=null&&r[u]||u==="$$ruleParams"||(c[u]=En(n,e,{etype:u,form:s[u],level:0,pageInfo:t==null?void 0:t[u]})),c},{})};return t&&(o.pageInfo=ti(t)),r&&(o.aggregate=r),o}function ni(){const e={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(e))}const ri=ni();function ze(n,e,t){const r={__etype:n,__ops:t};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return t;if(i==="__etype")return n;if(ri.has(i))return(o,a)=>ze(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Cn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function We(n){return n.startsWith("lookup__")}function Tt(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function si(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>ze(n,Tt(Cn(s,i)),[]);if(t==="__etype")return n;const r=t;return We(r)?ze(n,Tt(r),[]):ze(n,r,[])}})}function St(){return new Proxy({},{get(n,e){return si(e)}})}const ii=St();function Mn(n){return n.__ops}function oi(n,e){const{attrIdMap:t,refSwapAttrIds:r}=n,s=[];for(const o of e){const a=t[o];if(a)s.push(a);else if(Array.isArray(o)&&o.length==2&&t[o[0]]){const[c,u]=o;s.push([t[c],u])}else s.push(o)}const[i]=e;if((i==="add-triple"||i==="retract-triple")&&r.has(e[2])){const o=s[1];s[1]=s[3],s[3]=o}return s}function ai(n){if(Array.isArray(n))return n;const e=Object.entries(n);if(e.length!==1)throw new Error("lookup must be an object with a single unique attr and value.");return e[0]}function ci(n,e,t){return t.indexOf(".")!==-1&&!R(n,e,t)}function At(n){const[e,t,...r]=n.split(".");if(r.length>0||t!=="id")throw new Error(`${n} is not a valid lookup attribute.`);return e}function ui(n,e,t){if(!ci(n,e,t))return R(n,e,t);const r=At(t),s=R(n,e,r)||fe(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function vt(n){return typeof n=="string"&&!We(n)?null:typeof n=="string"&&We(n)?Tt(n):ai(n)}function V(n,e,t){const r=vt(t);if(r===null)return t;const[s,i]=r,o=ui(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Pn(n,e,t,r){var o;const s=V(n,e,t);return Array.isArray(s)?[["add-triple",s,(o=R(n,e,"id"))==null?void 0:o.id,s]].concat(r):r}function li({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=R(n,e,i),u=fe(n,e,i);return a.map(l=>c?["add-triple",V(n,e,t),c.id,V(n,c["reverse-identity"][1],l)]:["add-triple",V(n,u["forward-identity"][1],l),u==null?void 0:u.id,V(n,e,t)])});return Pn(n,e,t,s)}function di({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=R(n,e,i),u=fe(n,e,i);return a.map(l=>c?["retract-triple",V(n,e,t),c.id,V(n,c["reverse-identity"][1],l)]:["retract-triple",V(n,u["forward-identity"][1],l),u.id,V(n,e,t)])});return Pn(n,e,t,s)}function fi(n,e,t,r){var s;if(Array.isArray(r)){const[i,o]=r;for(const a of n||[]){const c=a==null?void 0:a.aev.get(i);if(c){for(const[u,l,d]of W(c,2))if(d===o)return!0}}}else for(const i of n||[]){const o=i==null?void 0:i.eav.get(r);if(o){for(const a of o.keys())if(((s=e.getAttr(a))==null?void 0:s["forward-identity"][1])==t)return!0}}return!1}function jn({stores:n,attrsStore:e},[t,r,s,i]){return(i==null?void 0:i.upsert)===!1?{mode:"update"}:(i==null?void 0:i.upsert)===!0?null:fi(n,e,t,r)?{mode:"update"}:null}function hi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,d])=>{const f=R(t,r,l);return f["checked-data-type"]==="date"&&n.useDateObjects&&(d=Oe(d)),["add-triple",c,f.id,d,{mode:"create"}]})}function pi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s),u=jn(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([d,f])=>{const p=R(t,r,d);return p["checked-data-type"]==="date"&&n.useDateObjects&&(f=Oe(f)),["add-triple",c,p.id,f,...u?[u]:[]]})}function yi({attrsStore:n},[e,t]){return[["delete-entity",V(n,e,t),e]]}function bi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=lt(i),c=V(t,r,s),u=jn(n,[r,c,i,o]),l=Object.entries(a).map(([f,p])=>{const y=R(t,r,f);return["deep-merge-triple",c,y.id,p,...u?[u]:[]]});return[["add-triple",c,R(t,r,"id").id,c,...u?[u]:[]]].concat(l)}function gi({attrsStore:n},[e,t,r]){return[["rule-params",V(n,e,t),e,r]]}function mi(n){const[e,t,r,s,i]=n;if(!s)return n;const o={...s};return delete o.id,[e,t,r,o,...i?[i]:[]]}function _i(n,e){const[t,...r]=mi(e);switch(t){case"merge":return bi(n,r);case"create":return hi(n,r);case"update":return pi(n,r);case"link":return li(n,r);case"unlink":return di(n,r);case"delete":return yi(n,r);case"ruleParams":return gi(n,r);default:throw new Error(`unsupported action ${t}`)}}function wi(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Ti(n,e,t){var a,c;const r=(c=(a=n.entities[e])==null?void 0:a.attrs)==null?void 0:c[t];if(t==="id")return null;if(!r)throw new Error(`${e}.${t} does not exist in your schema`);const{unique:s,indexed:i}=r==null?void 0:r.config,o=wi(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Ve(n,e,t,r){const s=n?Ti(n,e,t):null,i=j(),a=[j(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function Si(n,e,t){return Object.values(n.links).find(i=>i.forward.on===e&&i.forward.label===t||i.reverse.on===e&&i.reverse.label===t)}function Ai(n,e,t){const r=Si(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[j(),s.on,s.label],"reverse-identity":[j(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Dn(n,e,t,r){const s=n?Ai(n,e,t):null,i=j(),o=[j(),e,t],a=[j(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const vi=new Set(["create","update","merge","link","unlink"]),ki=new Set(["link","unlink"]),Oi=new Set(["create","update","merge"]),Ii=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),kt={"unique?":!0,"index?":!0},Ei={...kt,cardinality:"one"};function Ci(n){const e=[],[t,r,s,i]=n;if(!Ii.has(t))return e;const o=vt(s);if(o&&e.push({etype:r,lookupPair:o}),t==="link")for(const[a,c]of Object.entries(i)){const u=Array.isArray(c)?c:[c];for(const l of u){const d=vt(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function Mi({attrsStore:n,schema:e},t){var f,p;const r=new Set,s=[],i=[];function o(y,g){return R(n,y,g)||s.find(m=>m["forward-identity"][1]===y&&m["forward-identity"][2]===g)}function a(y,g){return fe(n,y,g)||s.find(m=>{var w,b;return((w=m["reverse-identity"])==null?void 0:w[1])===y&&((b=m["reverse-identity"])==null?void 0:b[2])===g})}function c(y){s.push(y),i.push(["add-attr",y]),r.add(y.id)}function u(y){y&&"isUnsynced"in y&&y.isUnsynced&&!r.has(y.id)&&(s.push(y),i.push(["add-attr",y]),r.add(y.id))}function l(y,g){return g.indexOf(".")!==-1&&!o(y,g)}function d(y,g){const m=o(y,g),w=a(y,g);u(m),u(w),!m&&!w&&c(Dn(e,y,g,Ei))}for(const y of t)for(const{etype:g,lookupPair:m,linkLabel:w}of Ci(y)){const b=m[0];if(w){d(g,w);const _=o(g,w),k=a(g,w);u(_),u(k);const T=((f=_==null?void 0:_["reverse-identity"])==null?void 0:f[1])||((p=k==null?void 0:k["forward-identity"])==null?void 0:p[1])||w;if(l(T,b))d(T,At(b));else{const S=o(T,b);S||c(Ve(e,T,b,kt)),u(S)}}else if(l(g,b))d(g,At(b));else{const _=o(g,b);_||c(Ve(e,g,b,kt)),u(_)}}for(const y of t){const[g,m,w,b]=y;if(vi.has(g)){const _=o(m,"id");u(_),_||c(Ve(e,m,"id",{"unique?":!0}));for(const k of Object.keys(b)){const T=o(m,k);if(u(T),Oi.has(g)&&(T||c(Ve(e,m,k,k==="id"?{"unique?":!0}:null))),ki.has(g)){const S=a(m,k);!T&&!S&&c(Dn(e,m,k)),u(S)}}}}if(s.length){const y={...n.attrs};for(const g of s)y[g.id]=g;return[new oe(y,n.linkIndex),i]}return[n,i]}function Pi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Mn(c)),[s,i]=Mi(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>_i(o,c));return[...i,...a]}function $n(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Me="__meta";class Ot{constructor(e,t){}}class It{constructor(e){h(this,"currentValue");h(this,"_subs",[]);h(this,"_persister");h(this,"_merge");h(this,"serialize");h(this,"parse");h(this,"_saveThrottleMs");h(this,"_idleCallbackMaxWaitMs");h(this,"_nextSave",null);h(this,"_nextGc",null);h(this,"_pendingSaveKeys",new Set);h(this,"_loadedKeys",new Set);h(this,"_loadingKeys");h(this,"_objectSize");h(this,"_log");h(this,"onKeyLoaded");h(this,"_version",0);h(this,"_meta",{isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0});h(this,"_gcOpts");this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){var e;this._meta.loadingPromise&&await this._meta.loadingPromise;try{const t=this._persister.getItem(Me);this._meta.loadingPromise=t;const r=await t;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const s=((e=this._meta.value)==null?void 0:e.objects)??{},i=r??{},o=i.objects??{};this._meta.value={...i,objects:{...s,...o}}}catch(t){this._meta.error=t,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const t=await this.waitForMetaToLoad();if(!t)return;const r=Object.entries(t.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const t=await this._persister.getItem(e);return t&&this.parse(e,t)}catch(t){return console.error(`Unable to read from storage for key=${e}`,t),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const t=this._getFromStorage(e);this._loadingKeys[e]=t;const r=await t;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const t=[],r=e==null?void 0:e.skipGc;if(this._meta.isLoading){const d=new Promise((f,p)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(f).catch(p),10+((e==null?void 0:e.attempts)??0)*1e3)});return t.push(d),Promise.all(t).then(f=>f.reduce((p,y)=>p+y,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const d of this._pendingSaveKeys)d in this.currentValue?o.push(d):(i.push(d),delete s.objects[d]);for(const d of i){const f=this._persister.removeItem(d);t.push(f.then(()=>1)),this._loadedKeys.delete(d),this._pendingSaveKeys.delete(d)}const a=[],c=[[Me,s]],u=s.objects??{};s.objects=u;for(const d of o)if(this._loadedKeys.has(d)){const f=this.serialize(d,this.currentValue[d]);c.push([d,f]);const p=this._objectSize(f),y=u[d]??{createdAt:Date.now(),updatedAt:Date.now(),size:p};y.updatedAt=Date.now(),y.size=p,u[d]=y,this._pendingSaveKeys.delete(d)}else a.push(d);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const d of a){const f=this._loadKey(d).then(()=>this._enqueuePersist(e));t.push(f)}return r||this.gc(),Promise.all(t).then(d=>d.reduce((f,p)=>f+p,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Me);const t=new Set(Object.keys(this.currentValue));for(const f of Object.keys(this._loadingKeys))t.add(f);for(const f of this._loadedKeys)t.add(f);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:t,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const f of e)t.has(f)||f in r.objects||(this._log.info("Lost track of key in meta",f),s.push(this._persister.removeItem(f)),i.removed.push(f),i.removedMissingCount++);const o=Date.now();for(const[f,p]of Object.entries(r.objects))!t.has(f)&&p.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([f,p],[y,g])=>p.updatedAt-g.updatedAt);const c=a.filter(([f])=>!t.has(f));if(a.length>this._gcOpts.maxEntries)for(const[f]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([f,p],[y,g])=>p.updatedAt-g.updatedAt);const l=u.filter(([f])=>!t.has(f));let d=u.reduce((f,[p,y])=>f+y.size,0);for(;d>0&&d>this._gcOpts.maxSize&&l.length;){const[[f,p]]=l.splice(0,1);d-=p.size,s.push(this._persister.removeItem(f)),delete r.objects[f],i.removed.push(f),i.removedSizeCount++}for(const f of Object.keys(r.objects))!e.has(f)&&!t.has(f)&&delete r.objects[f];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{$n(()=>{this._nextGc=null,this._gc()},30*1e3)},1e3*60+Math.random()*500))}_enqueuePersist(e){return new Promise((t,r)=>{if(this._nextSave){t(0);return}this._nextSave=setTimeout(()=>{$n(()=>{this._nextSave=null,this._writeToStorage(e).then(t).catch(r)},this._idleCallbackMaxWaitMs)},this._saveThrottleMs)})}version(){return this._version}updateInPlace(e){this._version++;const[t,r]=Le(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=t,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return t}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(t=>t!==e)}}}const ji=6,Di=["kv","querySubs","syncSubs"];function $i(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Ri(n){return new Promise(e=>{const t=indexedDB.open(n);t.onerror=r=>{e(null)},t.onsuccess=r=>{const i=r.target.result;e(i)},t.onupgradeneeded=r=>{var i;(i=r.target.transaction)==null||i.abort(),e(null)}})}async function xi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{var l,d,f;const a={};for(const[p,y]of Object.entries(r)){const g=typeof y=="string"?JSON.parse(y):y;if(g.lastAccessed){const w={createdAt:g.lastAccessed,updatedAt:g.lastAccessed,size:((f=(d=(l=g.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:f.length)??0};a[p]=w}const m=t.put(g,p);s.add(m)}const c={objects:a},u=t.put(c,Me);s.add(u);for(const p of s)p.onsuccess=()=>{s.delete(p),s.size===0&&i()},p.onerror=y=>{o(y)}})}async function Rn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Ui(n,e){const t=await Ri(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,d)=>{const y=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();y.onerror=m=>{d(m)};const g=[];y.onsuccess=()=>{const m=y.result;if(m){const w=m.key,b=m.value;g.push([w,b]),m.continue()}else l(g)},y.onerror=m=>{d(m)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,d]of r)switch(l){case"querySubs":{const f=xi(l,d,o);a.push(f);break}default:{const f=Rn(l,d,i);a.push(f);const p={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=p;break}}const u=Rn(Me,c,i);a.push(u),await Promise.all(a),await new Promise((l,d)=>{s.oncomplete=f=>l(f),s.onerror=f=>d(f),s.onabort=f=>d(f)})}const xn=new Map;class Et extends Ot{constructor(t,r){super(t,r);h(this,"dbName");h(this,"_storeName");h(this,"_appId");h(this,"_prefix");h(this,"_dbPromise");this.dbName=`instant_${t}_${ji}`,this._storeName=r,this._appId=t,this._dbPromise=this._init()}_init(){return new Promise((t,r)=>{let s=!1;const i=indexedDB.open(this.dbName,1);i.onerror=o=>{r(o)},i.onsuccess=o=>{const c=o.target.result;if(s){const u=Ui(this._appId,c).catch(l=>{$i("Error upgrading store from version 5 to 6.")(l)});xn.set(this.dbName,u),u.then(()=>t(c)).catch(()=>t(c))}else{const u=xn.get(this.dbName);u?u.then(()=>t(c)).catch(()=>t(c)):t(c)}},i.onupgradeneeded=o=>{s=!0,this._upgradeStore(o)}})}_upgradeStore(t){const s=t.target.result;for(const i of Di)s.objectStoreNames.contains(i)||s.createObjectStore(i)}async getItem(t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readonly").objectStore(this._storeName).get(t);c.onerror=u=>{i(u)},c.onsuccess=u=>{c.result?s(c.result):s(null)}})}async setItem(t,r){const s=await this._dbPromise;return new Promise((i,o)=>{const u=s.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(r,t);u.onerror=l=>{o(l)},u.onsuccess=l=>{i()}})}async multiSet(t){const r=await this._dbPromise;return new Promise((s,i)=>{const o=r.transaction([this._storeName],"readwrite"),a=o.objectStore(this._storeName),c=new Set;for(const[u,l]of t){const d=a.put(l,u);c.add(d)}for(const u of c)u.onerror=l=>{o.abort(),i(l)},u.onsuccess=l=>{c.delete(u),c.size===0&&s()}})}async removeItem(t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(t);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async getAllKeys(){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();a.onerror=c=>{s(c)},a.onsuccess=c=>{r(a.result.filter(u=>typeof u=="string"))}})}}class Ct{static async getIsOnline(){return navigator.onLine}static listen(e){const t=()=>{e(!0)},r=()=>{e(!1)};return addEventListener("online",t),addEventListener("offline",r),()=>{removeEventListener("online",t),removeEventListener("offline",r)}}}class N extends Error{constructor(t,r){super(t);h(this,"hint");this.hint=r;const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,N),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class Pe extends N{constructor(t){var i;const r=((i=t.body)==null?void 0:i.message)||`API Error (${t.status})`;super(r,t.body.hint);h(this,"body");h(this,"status");const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,Pe),this.name="InstantAPIError",this.status=t.status,this.body=t.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function Z(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new Pe({status:t.status,body:r}))}function Li({apiURI:n,appId:e,email:t}){return Z(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Fi({apiURI:n,appId:e,email:t,code:r,refreshToken:s}){return await Z(`${n}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t,code:r,...s?{"refresh-token":s}:{}})})}async function Ni({apiURI:n,appId:e,refreshToken:t}){return await Z(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function qi({apiURI:n,appId:e}){return await Z(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function Un({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s}){return await Z(`${n}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:t,code_verifier:r,refresh_token:s})})}async function Ki({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i}){return await Z(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i})})}async function zi({apiURI:n,appId:e,refreshToken:t}){return await Z(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function Wi({apiURI:n,appId:e,path:t,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:t,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await Z(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function Vi({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await Z(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function Qi({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await Z(`${n}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:t})});return i}async function Bi(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function Gi({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await Z(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let Mt=!1,Ln=!1,Fn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(Mt=!!window.localStorage.getItem("devBackend"),Ln=!!window.localStorage.getItem("__instantLogging"),Fn=!!window.localStorage.getItem("__devtoolLocalDash"));function Nn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function Hi(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Nn(n.user??{},e==null?void 0:e.keys);r.user={...i,peerId:t}}for(const i of Object.keys(n.peers??{})){const o=(e==null?void 0:e.peers)===void 0,a=Array.isArray(e==null?void 0:e.peers)&&(e==null?void 0:e.peers.includes(i));if(o||a){const c=Nn(n.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Ji(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!en(n.user,e.user))||!Xt(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!en(n.peers[r],e.peers[r]))return!0;return!1}class qn{constructor(){h(this,"promise");h(this,"_resolve");h(this,"_reject");this.promise=new Promise((e,t)=>{this._resolve=e,this._reject=t})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function Kn(n,e=[]){n.forEach(t=>{const{data:r}=t,{"datalog-result":s}=r,{"join-rows":i}=s;for(const o of i)for(const a of o)e.push(a);Kn(t["child-nodes"],e)})}function zn(n){const e=[];return Kn(n,e),e}function Pt(n){return Object.values(n.links).reduce((e,t)=>{var r,s;return e[r=t.forward.on]??(e[r]={}),e[t.forward.on][t.forward.label]={isForward:!0,isSingular:t.forward.has==="one",link:t},e[s=t.reverse.on]??(e[s]={}),e[t.reverse.on][t.reverse.label]={isForward:!1,isSingular:t.reverse.has==="one",link:t},e},{})}const jt="v0.22.141";function Yi(n,e){return{info:n?(...t)=>console.info(...t,e()):()=>{},debug:n?(...t)=>console.debug(...t,e()):()=>{},error:n?(...t)=>console.error(...t,e()):()=>{}}}class q{constructor(e,t,r,s={indexed:!1,unique:!1}){h(this,"metadata",{});this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}clientRequired(){return new q(this.valueType,!1,this.isIndexed,this.config)}optional(){return new q(this.valueType,!1,this.isIndexed,this.config)}unique(){return new q(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new q(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Qe{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Qe(this.attrs,this.links)}}class Be{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Be(this.entities,this.links,{})}}class P extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Wn=["where","order","limit","last","first","offset","after","before","fields","aggregate"],Zi=n=>n.valueType||"unknown",Vn=(n,e,t=!1)=>{if(t||n==null)return!0;switch(e){case"string":return typeof n=="string";case"number":return typeof n=="number"&&!isNaN(n);case"boolean":return typeof n=="boolean";case"date":return n instanceof Date||typeof n=="string"||typeof n=="number";default:return!0}},Xi=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!Vn(d,l,a))throw new P(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof d}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new P(`Operator '${n}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(n,t,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(n,t,e);break;case"$like":case"$ilike":if(c(n,"string",e),n==="$ilike"&&!i.isIndexed)throw new P(`Operator '${n}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(n,"boolean",e);break;default:throw new P(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},_e=(n,e,t,r,s)=>{const i=Zi(t),o=t.valueType==="json";if(typeof n=="object"&&n!==null&&!Array.isArray(n)){if(o)return;const c=n;for(const[u,l]of Object.entries(c))Xi(u,l,i,e,r,t,`${s}.${u}`)}else if(!Vn(n,i,o))throw new P(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},eo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new P(`Invalid dot notation path '${n}'. Must contain at least one dot.`,s);let o=t;for(let l=0;l<i.length-1;l++){const d=i[l],f=r.entities[o];if(!f)throw new P(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const p=f.links[d];if(!p){const y=Object.keys(f.links);throw new P(`Link '${d}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${y.length>0?y.join(", "):"none"}`,s)}o=p.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new P(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!ge(e))throw new P(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);_e(e,n,new q("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!ge(e))throw new P(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);_e(e,n,new q("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new P(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}_e(e,n,u,t,s)},Qn=(n,e,t,r)=>{for(const[s,i]of Object.entries(n)){if(s==="or"||s==="and"){if(Array.isArray(i))for(const u of i)typeof u=="object"&&u!==null&&Qn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){_e(i,"id",new q("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){eo(s,i,e,t,`${r}.${s}`);continue}const o=t.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new P(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)_e(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!ge(i))throw new P(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new q("string",!1,!0);_e(i,s,u,e,`${r}.${s}`)}}},to=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Wn.includes(o))throw new P(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Wn.join(", ")}. Found: ${o}`,r);const i=["offset","before","after","first","last"];for(const o of i)if(n[o]!==void 0&&s>0)throw new P(`'${o}' can only be used on top-level namespaces. It cannot be used in nested queries.`,r);if(n.where&&t){if(typeof n.where!="object"||n.where===null)throw new P(`'where' clause must be an object in entity '${e}', but received: ${typeof n.where}`,r?`${r}.where`:void 0);Qn(n.where,e,t,r?`${r}.where`:"where")}},Bn=(n,e,t,r,s=0)=>{var i;if(!n||typeof n!="object")throw new P(`Query part for entity '${e}' must be an object, but received: ${typeof n}`,r);for(const o of Object.keys(n))if(o!=="$"){if(t&&!(o in t.entities[e].links)){const c=Object.keys(t.entities[e].links);throw new P(`Link '${o}' does not exist on entity '${e}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${r}.${o}`)}const a=n[o];if(typeof a=="object"&&a!==null){const c=(i=t==null?void 0:t.entities[e].links[o])==null?void 0:i.entityName;c&&Bn(a,c,t,`${r}.${o}`,s+1)}}else{const a=n[o];if(typeof a!="object"||a===null)throw new P(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof a}`,`${r}.$`);to(a,e,t,`${r}.$`,s)}},Dt=(n,e)=>{if(typeof n!="object"||n===null)throw new P(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new P(`Query must be an object, but received: ${typeof n}`);const t=n;for(const r of Object.keys(t)){if(Array.isArray(n[r]))throw new P(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new P(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new P(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Bn(t[r],r,e,r,0)}}},Gn=n=>typeof n!="string"?!1:We(n)?!0:ge(n);class H extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Hn=n=>n.length>0?n.join(", "):"none",no=(n,e)=>new H(`Entity '${n}' does not exist in schema. Available entities: ${Hn(e)}`),$t={string:n=>typeof n=="string",number:n=>typeof n=="number"&&!isNaN(n),boolean:n=>typeof n=="boolean",date:n=>n instanceof Date||typeof n=="string"||typeof n=="number",json:()=>!0},ro=(n,e)=>{var t;return n==null?!0:((t=$t[e.valueType])==null?void 0:t.call($t,n))??!1},Jn=(n,e)=>{const t=e.entities[n];if(!t)throw no(n,Object.keys(e.entities));return t},Rt=(n,e,t)=>{const r=Jn(n,t);if(typeof e!="object"||e===null)throw new H(`Arguments for data operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!ro(i,o))throw new H(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},Yn=(n,e,t)=>{const r=Jn(n,t);if(typeof e!="object"||e===null)throw new H(`Arguments for link operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new H(`Link '${s}' does not exist on entity '${n}'. Available links: ${Hn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Gn(a))throw new H(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Gn(i))throw new H(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},so={create:Rt,update:Rt,merge:Rt,link:Yn,unlink:Yn,delete:()=>{}},io=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!ge(s))throw new H(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new H(`Entity name must be a string, but received: ${typeof r}`);const o=so[t];o&&i!==void 0&&o(r,i,e)},Zn=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new H(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new H(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new H(`Transaction operation must be an array, but received: ${typeof s}`);io(s,e)}}};let Xn=0;class er{constructor(e){h(this,"type","ws");h(this,"conn");h(this,"id");h(this,"onopen");h(this,"onmessage");h(this,"onclose");h(this,"onerror");this.id=`${this.type}_${Xn++}`,this.conn=new WebSocket(e),this.conn.onopen=t=>{this.onopen&&this.onopen({target:this})},this.conn.onmessage=t=>{this.onmessage&&this.onmessage({target:this,message:JSON.parse(t.data.toString())})},this.conn.onclose=t=>{this.onclose&&this.onclose({target:this})},this.conn.onerror=t=>{this.onerror&&this.onerror({target:this})}}close(){this.conn.close()}isOpen(){return this.conn.readyState===(WebSocket.OPEN??1)}isConnecting(){return this.conn.readyState===(WebSocket.CONNECTING??0)}send(e){return this.conn.send(JSON.stringify(e))}}class tr{constructor(e,t,r){h(this,"type","sse");h(this,"initParams",null);h(this,"sendQueue",[]);h(this,"sendPromise");h(this,"closeFired",!1);h(this,"sseInitTimeout");h(this,"ES");h(this,"messageUrl");h(this,"conn");h(this,"url");h(this,"id");h(this,"onopen");h(this,"onmessage");h(this,"onclose");h(this,"onerror");this.id=`${this.type}_${Xn++}`,this.url=t,this.messageUrl=r||this.url,this.ES=e,this.conn=new e(t),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=s=>{const i=JSON.parse(s.data);if(Array.isArray(i))for(const o of i)this.handleMessage(o);else this.handleMessage(i)},this.conn.onerror=s=>{this.handleError()}}handleMessage(e){if(e.op==="sse-init"){this.initParams={machineId:e["machine-id"],sessionId:e["session-id"],sseToken:e["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:e})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(e){var t,r,s;try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(t=this.initParams)==null?void 0:t.machineId,session_id:(r=this.initParams)==null?void 0:r.sessionId,sse_token:(s=this.initParams)==null?void 0:s.sseToken,messages:e})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const e=this.sendQueue;this.sendQueue=[];const t=this.postMessages(e);this.sendPromise=t,t.then(()=>{this.sendPromise=null,this.flushQueue()})}send(e){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(e),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}function oo(n,e){const t=n.values;if(t){const r=un(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=cn(r,s.store);t.attrsStore=r}}return n}function ao(n,e){var t;if(e.values){const r=[];for(const s of(t=e.values)==null?void 0:t.entities){const i=an(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function co(n,e,t){var i,o;const r=(i=e==null?void 0:e.state)==null?void 0:i.txId,s=(o=t==null?void 0:t.state)==null?void 0:o.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?t:e||t}function xt(n,e,t){return wt({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function nr(n,e,t,r){var o;const s=(o=R(t,n.table,"id"))==null?void 0:o.id;if(!s)return-1;const i=ye(e.eav,[r,s,r]);return i?i[3]:-1}function rr(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":fn(n,e,s);break;case"removed":ln(n,e,s);break}}function uo(n,e,t){var s,i;const r={};for(const{action:o,triple:a}of t){const[c,u,l]=a,d=(i=(s=e.getAttr(u))==null?void 0:s["forward-identity"])==null?void 0:i[2];if(!d)continue;const f=r[c]??{};r[c]=f;const p=f[d]??{};switch(o){case"added":p.newValue=l;break;case"removed":p.oldValue===void 0&&(p.oldValue=l);break}f[d]=p}for(const[o,a]of Object.entries(r))for(const[c,{oldValue:u,newValue:l}]of Object.entries(a))u===l&&delete a[c];return r}function Ge(n,e){return{[n.table]:e.map(t=>t.entity)}}function lo(n,e){var r;if(n.orderFieldType)return n.orderFieldType;const t=n.orderField==="serverCreatedAt"?"number":(r=R(e(),n.table,n.orderField))==null?void 0:r["checked-data-type"];return n.orderFieldType=t,t}function fo(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return Ce(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Ce(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=n.orderField;t.sort(n.orderDirection==="asc"?function(o,a){return Ce(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Ce(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var sr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(sr||{});class ho{constructor(e,t,r,s,i,o){h(this,"trySend");h(this,"subs");h(this,"callbacks",{});h(this,"config");h(this,"idToHash",{});h(this,"log");h(this,"createStore");h(this,"getAttrs");this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new It({persister:t,merge:co,serialize:ao,parse:(a,c)=>oo(c,this.config.useDateObjects),objectSize:a=>{var c;return((c=a.values)==null?void 0:c.entities.length)||0},logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,t){const r=C(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,s==null?void 0:s.keepSubscription)}}unsubscribe(e,t,r){const s=(this.callbacks[e]||[]).filter(i=>i!==t);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i!=null&&i.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend(j(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend(j(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){var u,l,d,f;await this.subs.waitForKeyToLoad(t);const s=this.subs.currentValue[t];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),(u=s.values)!=null&&u.entities&&r&&r({type:"LoadFromStorage",data:Ge(s,(l=s.values)==null?void 0:l.entities)});return}const i=Object.keys(e)[0],o=((f=(d=e[i])==null?void 0:d.$)==null?void 0:f.order)||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(p=>{p[t]={query:e,hash:t,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const t=this.subs.currentValue[e];t?await this.initSubscription(t.query,t.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const t=e["subscription-id"],r=e.q,s=C(r);this.idToHash[t]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",t,"query",r),i;o.state={subscriptionId:t,token:e.token}})}notifyCbs(e,t){for(const r of this.callbacks[e]||[])r(t)}onSyncLoadBatch(e){const t=e["subscription-id"],r=e["join-rows"],s=this.idToHash[t];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),d=xt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:nr(o,l,a.attrsStore,d.id)}),i.push(d)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ge(o,o.values.entities),batch:i})}onSyncInitFinish(e){var i;const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(o=>{const a=o[r];if(!a){this.log.error("Missing sub for hash",r,e);return}const c=a.state;if(!c)return this.log.error("Sub never set init, missing result",a,e),o;c.txId=e["tx-id"],a.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ge(s,((i=s.values)==null?void 0:i.entities)||[])})}onSyncUpdateTriples(e){var o;const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const a of e.txes){if(i.txId&&i.txId>=a["tx-id"])continue;i.txId=a["tx-id"];const c=[],u={};for(const m of a.changes){const w=u[m.triple[0]]??[];u[m.triple[0]]=w,w.push(m)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const f=[];e:for(const[m,w]of Object.entries(u))for(let b=0;b<d.length;b++){const _=d[b];if(Hr(_.store,m)){rr(_.store,l.attrsStore,w);const k=xt(s,_.store,l.attrsStore),T=uo(_.store,l.attrsStore,w)[m];k?(f.push({oldEntity:_.entity,newEntity:k,changedFields:T||{}}),_.entity=k):c.push(b),delete u[m];continue e}}const p=[];for(const[m,w]of Object.entries(u)){const b=this.createStore([]);rr(b,l.attrsStore,w);const _=xt(s,b,l.attrsStore);if(!_){this.log.error("No entity found after applying change",{sub:s,changes:w,store:b});continue}d.push({store:b,entity:_,serverCreatedAt:nr(s,b,l.attrsStore,_.id)}),p.push(_)}const y=[];for(const m of c.sort().reverse())y.push(d[m].entity),d.splice(m,1);const g=lo(s,this.getAttrs);fo(s,g,d),this.notifyCbs(r,{type:"SyncTransaction",data:Ge(s,(o=s.values)==null?void 0:o.entities),added:p,removed:y,updated:f})}this.subs.updateInPlace(a=>{a[r]=s,a[r].updatedAt=Date.now()})}clearSubscriptionData(e,t){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,t),t?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const t=C(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(t,{type:"Error",data:{[s]:[]},error:r})}onResyncError(e){const t=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(t,!1);r&&this.initSubscription(r.query,r.hash)}}function po({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null;const c=j();let u=!1,l=!1;const d=[],f=[];let p=!1,y=0,g=0;const m=[],w=new TextEncoder;function b(){l=!0;for(const O of d)O()}function _(O){return d.push(O),()=>{const E=d.indexOf(O);E!==-1&&d.splice(E,1)}}function k(O){return f.push(O),()=>{const E=f.indexOf(O);E!==-1&&f.splice(E,1)}}function T(O){o=O;for(const E of f)E(o)}function S(){p=!0}function v(O){let E=y,K=0,Q=0;for(const{byteLen:ee}of m){const ie=E+ee;if(ie>O)break;E=ie,K++,Q+=ee}K>0&&(y+=Q,g-=Q,m.splice(0,K))}async function D(){const O=await t({clientId:i,reconnectToken:c});switch(O.type){case"ok":{const{streamId:E,offset:K}=O;o=E,v(K),m.length&&r({streamId:E,chunks:m.map(Q=>Q.chunk),offset:y}),p=!1;break}case"disconnect":{S();break}case"error":{a&&(a.error(O.error),b());break}}}function U(){S(),D()}function we({offset:O,done:E}){v(O),E&&(u=!0)}function ae(O,E){b(),O.error(E)}function ce(O){return u&&ae(O,new N("Stream has been closed.")),o||ae(O,new N("Stream has not been initialized.")),o}async function X(O){a=O;let E=!0,K=0;for(;E;){let Q=Date.now()+Math.min(15e3,500*(K-1));E=!1;const ee=await t({clientId:e.clientId,reconnectToken:c});switch(ee.type){case"ok":{const{streamId:ie,offset:qt}=ee;if(qt!==0){const De=new N("Write stream is corrupted");ae(O,De);return}T(ie),s(ie,{onDisconnect:S,onFlush:we,onConnectionReconnect:D,onAppendFailed:U}),p=!1;return}case"disconnect":{E=!0,S(),K++,await new Promise(ie=>{setTimeout(ie,Q-Date.now())});break}case"error":{ae(O,ee.error);return}}}}class L extends n{constructor(E,K){super(E,K)}async streamId(){return o||new Promise((E,K)=>{const Q=[],ee=()=>{for(const De of Q)De()},ie=De=>{E(De),ee()},qt=()=>{K(new N("Stream is closed.")),ee()};Q.push(k(ie)),Q.push(_(qt))})}}return{stream:new L({async start(O){try{await X(O)}catch(E){ae(O,E)}},write(O,E){const K=ce(E);if(K){const Q=w.encode(O).length;m.push({chunk:O,byteLen:Q});const ee=y+g;g+=Q,p||r({streamId:K,chunks:[O],offset:ee})}},close(){o&&r({streamId:o,chunks:[],offset:y+g,isDone:!0}),b()},abort(O){o&&r({streamId:o,chunks:[],offset:y+g,isDone:!0,abortReason:O}),b()}}),addCloseCb:_,closed(){return l}}}class yo{constructor(){h(this,"items",[]);h(this,"resolvers",[]);h(this,"isClosed",!1)}push(e){if(this.isClosed)return;const t=this.resolvers.shift();t?t({value:e,done:!1}):this.items.push(e)}close(){for(this.isClosed=!0;this.resolvers.length>0;)this.resolvers.shift()({value:void 0,done:!0})}async*[Symbol.asyncIterator](){for(;;)if(this.items.length>0)yield this.items.shift();else{if(this.isClosed)return;{const{value:e,done:t}=await new Promise(r=>{this.resolvers.push(r)});if(t||!e)return;yield e}}}}function bo({RStream:n,opts:e,startStream:t,cancelStream:r}){let s=e.byteOffset||0,i=!1;const o=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[];function d(){u=!0;for(const b of l)b()}function f(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function p(b,_){b.error(_),d()}let y=0;async function g(b,_){c=j();const k={...b||{},eventId:c};for await(const T of t(k)){if(i)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){p(_,T.error);return}if(T.offset>s){p(_,new N("Stream is corrupted.")),i=!0;return}let S=s-T.offset;if(T.files&&T.files.length){const v=new AbortController;let D=fetch(T.files[0].url,{signal:v.signal});for(let U=0;U<T.files.length;U++){const we=T.files[U+1],ce=await D;if(we&&(D=fetch(we.url,{signal:v.signal})),!ce.ok){if(y++,y>10){p(_,new N("Unable to process stream."));return}return{retry:!0}}if(ce.body)for await(const X of ce.body){if(i){v.abort();return}let L=X;if(S>0&&(L=X.subarray(S),S-=X.length-L.length),!L.length)continue;s+=L.length;const he=o.decode(L);_.enqueue(he)}else{const X=await ce.arrayBuffer();let L=X;if(i){v.abort();return}if(S>0&&(L=new Uint8Array(X).subarray(S),S-=X.byteLength-L.length),!L.byteLength)continue;s+=L.byteLength;const he=o.decode(L);_.enqueue(he)}}}if(y=0,T.content){let v=T.content,D=a.encode(T.content);if(S>0){const U=D.subarray(S);if(S-=D.length-U.length,!U.length)continue;D=U,v=o.decode(U)}s+=D.length,_.enqueue(v)}}}async function m(b){let _=!0,k=0;for(;_;){_=!1;let T=Date.now()+Math.min(15e3,500*(k-1));const S=await g({...e,offset:s},b);S!=null&&S.retry&&(_=!0,k++,T<Date.now()-3e5&&(k=0),await new Promise(v=>{setTimeout(v,T-Date.now())}))}!i&&!u&&(b.close(),d())}return{stream:new n({start(b){m(b)},cancel(b){i=!0,c&&r({eventId:c}),d()}}),addCloseCb:f,closed(){return u}}}class ir{constructor({WStream:e,RStream:t,trySend:r,log:s}){h(this,"trySend");h(this,"WStream");h(this,"RStream");h(this,"writeStreams",{});h(this,"startWriteStreamCbs",{});h(this,"readStreamIterators",{});h(this,"log");h(this,"activeStreams",new Set);this.WStream=e,this.RStream=t,this.trySend=r,this.log=s}createWriteStream(e){const{stream:t,addCloseCb:r}=po({WStream:this.WStream,startStream:this.startWriteStream.bind(this),appendStream:this.appendStream.bind(this),registerStream:this.registerWriteStream.bind(this),opts:e});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}createReadStream(e){const{stream:t,addCloseCb:r}=bo({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=j();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend(j(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s}){const i={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(i["stream-id"]=r),t&&(i["client-id"]=t),s&&(i.offset=s);const o=new yo;return this.readStreamIterators[e]=o,this.trySend(e,i),o}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend(j(),t),delete this.readStreamIterators[e]}onStreamAppend(e){var s;const t=e["client-event-id"],r=this.readStreamIterators[t];if(!r){this.log.info("No iterator for read stream",e);return}if(e.error){e.retry?r.push({type:"reconnect"}):r.push({type:"error",error:new N(e.error)}),r.close(),delete this.readStreamIterators[t];return}((s=e.files)!=null&&s.length||e.content)&&r.push({type:"append",offset:e.offset,files:e.files,content:e.content}),e.done&&(r.close(),delete this.readStreamIterators[t])}onConnectionStatusChange(e){for(const t of Object.values(this.startWriteStreamCbs))t({type:"disconnect"});if(this.startWriteStreamCbs={},e!==ne.AUTHENTICATED)for(const{onDisconnect:t}of Object.values(this.writeStreams))t();else{for(const{onConnectionReconnect:t}of Object.values(this.writeStreams))t();for(const t of Object.values(this.readStreamIterators))t.push({type:"reconnect"}),t.close();this.readStreamIterators={}}}onRecieveError(e){const t=e["original-event"];switch(t.op){case"append-stream":{const r=t["stream-id"],s=this.writeStreams[r];s==null||s.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new N(e.message||"Unknown error",e.hint)}),delete this.startWriteStreamCbs[r]);break}case"subscribe-stream":{const r=e["client-event-id"],s=this.readStreamIterators[r];s&&(s.push({type:"error",error:new N(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const ne={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},go=3e4,mo=3e4,_o=200,wo=1e3*60,To={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ut="_instant_oauth_redirect",je="currentUser";function So({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new er(`${r}?app_id=${e}`);switch(n){case"ws":return new er(`${r}?app_id=${e}`);case"sse":return new tr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Ao(){return typeof window<"u"||typeof chrome<"u"}const or={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function vo(n,e){var r;const t=typeof n=="string"?JSON.parse(n):n;if((r=t==null?void 0:t.result)!=null&&r.store){const s=un(t.result.attrsStore,t.result.store);if(s){const i=t.result.store;t.result.store=cn(s,{...i,useDateObjects:e}),t.result.attrsStore=s}}return t}function ko(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:an(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Oo(n,e){switch(n){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function Io(n,e){switch(n){case"pendingMutations":return[...e.entries()];default:return e}}function Eo(n,e,t){const r=e==null?void 0:e.result,s=t==null?void 0:t.result;return r&&!s&&t&&(t.result=r),t||e}function Lt(n){return[...n].sort((e,t)=>{const[r,s]=e,[i,o]=t,a=s.order||0,c=o.order||0;return a==c?r<i?-1:r>i?1:0:a-c})}class ar{constructor(e,t=Et,r=Ct,s,i){h(this,"attrs");h(this,"_isOnline",!0);h(this,"_isShutdown",!1);h(this,"status",ne.CONNECTING);h(this,"querySubs");h(this,"kv");h(this,"_syncTable");h(this,"_instantStream");h(this,"queryCbs",{});h(this,"queryOnceDfds",{});h(this,"authCbs",[]);h(this,"attrsCbs",[]);h(this,"mutationErrorCbs",[]);h(this,"connectionStatusCbs",[]);h(this,"config");h(this,"mutationDeferredStore",new Map);h(this,"_reconnectTimeoutId",null);h(this,"_reconnectTimeoutMs",0);h(this,"_transport");h(this,"_transportType","ws");h(this,"_EventSource");h(this,"_wsOk",null);h(this,"_localIdPromises",{});h(this,"_errorMessage",null);h(this,"_oauthCallbackResponse",null);h(this,"_linkIndex",null);h(this,"_broadcastChannel");h(this,"_rooms",{});h(this,"_roomsPendingLeave",{});h(this,"_presence",{});h(this,"_broadcastQueue",[]);h(this,"_broadcastSubs",{});h(this,"_currentUserCached",{isLoading:!0,error:void 0,user:void 0});h(this,"_beforeUnloadCbs",[]);h(this,"_dataForQueryCache",{});h(this,"_log");h(this,"_pendingTxCleanupTimeout");h(this,"_pendingMutationCleanupThreshold");h(this,"_inFlightMutationEventIds",new Set);h(this,"_onMergeKv",(e,t,r)=>{switch(e){case"pendingMutations":{const s=(t==null?void 0:t.entries())??[],i=(r==null?void 0:r.entries())??[],o=new Map([...s,...i]);return(t?this._rewriteMutationsSorted(this.attrs,t):[]).forEach(([c,u])=>{var l;!((l=r==null?void 0:r.pendingMutations)!=null&&l.has(c))&&!u["tx-id"]&&this._sendMutation(c,u)}),o}default:return r||t}});h(this,"getPreviousResult",e=>{var r;const t=C(e);return(r=this.dataForQuery(t))==null?void 0:r.data});h(this,"notifyOne",e=>{var i;const t=this.queryCbs[e]??[],r=(i=this._dataForQueryCache[e])==null?void 0:i.data,s=this.dataForQuery(e);s!=null&&s.data&&(this._dataForQueryCache[e]=s,!Fe(s.data,r)&&t.forEach(o=>o.cb(s.data)))});h(this,"notifyOneQueryOnce",e=>{var s;const t=this.queryOnceDfds[e]??[],r=(s=this.dataForQuery(e))==null?void 0:s.data;t.forEach(i=>{this._completeQueryOnce(i.q,e,i.dfd),i.dfd.resolve(r)})});h(this,"notifyQueryError",(e,t)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:t}))});h(this,"pushTx",e=>{this.config.disableValidation||Zn(e,this.config.schema);try{const t=Pi({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>{var s;return(s=r==null?void 0:r.result)==null?void 0:s.store}),useDateObjects:this.config.useDateObjects},e);return this.pushOps(t)}catch(t){return this.pushOps([],t)}});h(this,"pushOps",(e,t)=>{const r=j(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:t,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new qn;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise});h(this,"_transportOnOpen",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][open]",t.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(ne.OPENED),this.getCurrentUser().then(r=>{var s;this._trySend(j(),{op:"init","app-id":this.config.appId,"refresh-token":(s=r.user)==null?void 0:s.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",t.id,r)})});h(this,"_transportOnMessage",e=>{const t=e.target,r=e.message;if(this._transport!==t){this._log.info("[socket][message]",t.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&t.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(t.id,s);else this._handleReceive(t.id,e.message)});h(this,"_transportOnError",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][error]",t.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",t.id,e)});h(this,"_scheduleReconnect",()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)});h(this,"_transportOnClose",e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][close]",t.id,"skip; this is no longer the current transport");return}this._setStatus(ne.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",t.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",t.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()});if(this._EventSource=i,this.config={...To,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??mo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??_o,this._log=Yi(e.verbose||Mt||Ln,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":jt},this.config.schema&&(this._linkIndex=Pt(this.config.schema)),!!Ao()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!ge(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{var a;try{if(((a=o.data)==null?void 0:a.type)==="auth"){const c=await this.getCurrentUser();await this.updateUser(c.user).catch(u=>{this._log.error("[error] update user",u)})}}catch(c){this._log.error("[error] handle broadcast channel",c)}})),this._initStorage(t),this._syncTable=new ho(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>be(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ir({WStream:this.config.WritableStream||WritableStream,RStream:this.config.ReadableStream||ReadableStream,trySend:this._trySendAuthed.bind(this),log:this._log}),this._oauthCallbackResponse=this._oauthLoginInit(),this.getCurrentUser().then(o=>{this.syncUserToEndpoint(o.user)}),setInterval(async()=>{const o=await this.getCurrentUser();this.syncUserToEndpoint(o.user)},wo),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",ne.CLOSED),this._setStatus(ne.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?Pt(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new It({persister:new e(this.config.appId,"querySubs"),merge:Eo,serialize:ko,parse:(t,r)=>vo(r,this.config.useDateObjects),objectSize:t=>{var r,s,i;return((i=(s=(r=t==null?void 0:t.result)==null?void 0:r.store)==null?void 0:s.triples)==null?void 0:i.length)??0},logger:this._log,preloadEntryCount:10,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}}),this.querySubs.onKeyLoaded=t=>this._onQuerySubLoaded(t),this.kv=new It({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:Io,parse:Oo,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=t=>{t==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(je),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,t,r){const s=this.mutationDeferredStore.get(t);this.mutationDeferredStore.delete(t);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:t,...r}),!!s)if(i)s.resolve({status:e,eventId:t});else if(r!=null&&r.type){const{status:o,...a}=r;s.reject(new Pe({body:a,status:o??0}))}else s.reject(new N((r==null?void 0:r.message)||"Unknown error",r==null?void 0:r.hint))}_setStatus(e,t){this.status=e,this._errorMessage=t,this.notifyConnectionStatusSubs(e),this._instantStream.onConnectionStatusChange(e)}_flushEnqueuedRoomData(e){var s,i;const t=(i=(s=this._presence[e])==null?void 0:s.result)==null?void 0:i.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],t&&this._trySetPresence(e,t),r)for(const o of r){const{topic:a,roomType:c,data:u}=o;this._tryBroadcast(e,c,a,u)}}_addQueryData(e,t,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=C(e),i=this.ensureAttrs(),o=be(this.attrs,t.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:t.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,t){var s,i,o,a,c,u,l;const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(or[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ne.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const p of Object.keys(this._rooms)){const y=(i=(s=this._presence[p])==null?void 0:s.result)==null?void 0:i.user,g=(o=this._rooms[p])==null?void 0:o.roomType;this._tryJoinRoom(g,p,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(C(t.q));break}case"add-query-ok":{const{q:p,result:y}=t,g=C(p);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[g])break;const m=(c=(a=y==null?void 0:y[0])==null?void 0:a.data)==null?void 0:c["page-info"],w=(l=(u=y==null?void 0:y[0])==null?void 0:u.data)==null?void 0:l.aggregate,b=zn(y),_=this.ensureAttrs(),k=be(_,b,r,this.config.useDateObjects);this.querySubs.updateInPlace(T=>{if(!T[g]){this._log.info("Missing value in querySubs",{hash:g,q:p});return}T[g].result={store:k,attrsStore:_,pageInfo:m,aggregate:w,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(g),this.notifyOneQueryOnce(g),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(t);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(t);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(t);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(t);break}case"start-stream-ok":{this._instantStream.onStartStreamOk(t);break}case"stream-flushed":{this._instantStream.onStreamFlushed(t);break}case"append-failed":{this._instantStream.onAppendFailed(t);break}case"stream-append":{this._instantStream.onStreamAppend(t);break}case"refresh-ok":{const{computations:p,attrs:y}=t,g=t["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const m=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),g);m!==this._pendingMutations()&&this.kv.updateInPlace(_=>{_.pendingMutations=m});const w=Lt(m.entries()),b=p.map(_=>{var L,he,O,E;const k=_["instaql-query"],T=_["instaql-result"],S=C(k),v=zn(T),D=this.ensureAttrs(),U=be(D,v,r,this.config.useDateObjects),{store:we,attrsStore:ae}=this._applyOptimisticUpdates(U,D,w,g),ce=(he=(L=T==null?void 0:T[0])==null?void 0:L.data)==null?void 0:he["page-info"],X=(E=(O=T==null?void 0:T[0])==null?void 0:O.data)==null?void 0:E.aggregate;return{q:k,hash:S,store:we,attrsStore:ae,pageInfo:ce,aggregate:X}});b.forEach(({hash:_,q:k,store:T,attrsStore:S,pageInfo:v,aggregate:D})=>{this.querySubs.updateInPlace(U=>{if(!U[_]){this._log.error("Missing value in querySubs",{hash:_,q:k});return}U[_].result={store:T,attrsStore:S,pageInfo:v,aggregate:D,processedTxId:g}})}),this._cleanupPendingMutationsQueries(),b.forEach(({hash:_})=>{this.notifyOne(_)});break}case"transact-ok":{const{"client-event-id":p,"tx-id":y}=t;this._inFlightMutationEventIds.delete(p);const m=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(p);if(!m)break;this._updatePendingMutations(b=>{b.set(p,{...b.get(p),"tx-id":y,confirmed:Date.now()})});const w=[];for(const b of m["tx-steps"])if(b[0]==="add-attr"){const _=b[1];w.push(_)}if(w.length){const b=Object.values(this.ensureAttrs().attrs);this._setAttrs([...b,...w])}this._finishTransaction("synced",p),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const p=t["room-id"];this._trySetRoomConnected(p,!0),this._patchPresencePeers(p,t.edits),this._notifyPresenceSubs(p);break}case"refresh-presence":{const p=t["room-id"];this._trySetRoomConnected(p,!0),this._setPresencePeers(p,t.data),this._notifyPresenceSubs(p);break}case"server-broadcast":{const p=t["room-id"],y=t.topic;this._trySetRoomConnected(p,!0),this._notifyBroadcastSubs(p,y,t);break}case"join-room-ok":{const p=t["room-id"];if(!this._rooms[p]){this._roomsPendingLeave[p]&&(this._tryLeaveRoom(p),delete this._roomsPendingLeave[p]);break}this._trySetRoomConnected(p,!0),this._flushEnqueuedRoomData(p);break}case"leave-room-ok":{const p=t["room-id"];this._trySetRoomConnected(p,!1);break}case"join-room-error":const d=t["room-id"],f=this._rooms[d];f&&(f.error=t.error),this._notifyPresenceSubs(d);break;case"error":this._handleReceiveError(t);break;default:this._log.info("Uknown op",t.op,t);break}}createWriteStream(e){return this._instantStream.createWriteStream(e)}createReadStream(e){return this._instantStream.createReadStream(e)}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(t=>{const r=t.pendingMutations??new Map;t.pendingMutations=r,e(r)})}_handleMutationError(e,t,r){const s=this._pendingMutations().get(t);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(t),o)),this._inFlightMutationEventIds.delete(t);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,t,r)}}_handleReceiveError(e){var a,c,u,l,d,f;console.log("error",e);const t=e["client-event-id"];this._inFlightMutationEventIds.delete(t);const r=this._pendingMutations().get(t),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",t,e);return}if((a=e["original-event"])!=null&&a.hasOwnProperty("q")&&((c=e["original-event"])==null?void 0:c.op)==="add-query"){const p=(u=e["original-event"])==null?void 0:u.q,y=C(p);this.notifyQueryError(C(p),s),this.notifyQueryOnceError(p,y,t,s);return}if(((l=e["original-event"])==null?void 0:l.op)==="init"){if(e.type==="record-not-found"&&((d=e.hint)==null?void 0:d["record-type"])==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ne.ERRORED,s),this.notifyAll();return}switch((f=e["original-event"])==null?void 0:f.op){case"resync-table":{this._syncTable.onResyncError(e);return}case"start-sync":{this._syncTable.onStartSyncError(e);return}case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{this._instantStream.onRecieveError(e);return}}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
|
|
2
2
|
`,e.hint)}notifyQueryOnceError(e,t,r,s){var o;const i=(o=this.queryOnceDfds[t])==null?void 0:o.find(a=>a.eventId===r);i&&(i.dfd.reject(s),this._completeQueryOnce(e,t,i.dfd))}_setAttrs(e){this.attrs=new oe(e.reduce((t,r)=>(t[r.id]=r,t),{}),this._linkIndex),this.notifyAttrsSubs()}_startQuerySub(e,t){const r=j();return this.querySubs.updateInPlace(s=>{s[t]=s[t]||{q:e,result:null,eventId:r},s[t].lastAccessed=Date.now()}),this._trySendAuthed(r,{op:"add-query",q:e}),r}subscribeTable(e,t){return this._syncTable.subscribe(e,t)}subscribeQuery(e,t,r){this.config.disableValidation||Dt(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=C(e),i=this.getPreviousResult(e);return i&&t(i),this.queryCbs[s]=this.queryCbs[s]??[],this.queryCbs[s].push({q:e,cb:t}),this._startQuerySub(e,s),()=>{this._unsubQuery(e,s,t)}}queryOnce(e,t){this.config.disableValidation||Dt(e,this.config.schema),t&&"ruleParams"in t&&(e={$$ruleParams:t.ruleParams,...e});const r=new qn;if(!this._isOnline)return r.reject(new Error("We can't run `queryOnce`, because the device is offline.")),r.promise;if(!this.querySubs)return r.reject(new Error("We can't run `queryOnce` on the backend. Use adminAPI.query instead: https://www.instantdb.com/docs/backend#query")),r.promise;const s=C(e),i=this._startQuerySub(e,s);return this.queryOnceDfds[s]=this.queryOnceDfds[s]??[],this.queryOnceDfds[s].push({q:e,dfd:r,eventId:i}),setTimeout(()=>r.reject(new Error("Query timed out")),go),r.promise}_completeQueryOnce(e,t,r){this.queryOnceDfds[t]&&(this.queryOnceDfds[t]=this.queryOnceDfds[t].filter(s=>s.dfd!==r),this._cleanupQuery(e,t))}_unsubQuery(e,t,r){this.queryCbs[t]&&(this.queryCbs[t]=this.queryCbs[t].filter(s=>s.cb!==r),this._cleanupQuery(e,t))}_hasQueryListeners(e){var t,r;return!!((t=this.queryCbs[e])!=null&&t.length||(r=this.queryOnceDfds[e])!=null&&r.length)}_cleanupQuery(e,t){this._hasQueryListeners(t)||(delete this.queryCbs[t],delete this.queryOnceDfds[t],delete this._dataForQueryCache[t],this.querySubs.unloadKey(t),this._trySendAuthed(j(),{op:"remove-query",q:e}))}_rewriteMutations(e,t,r){if(!e)return t;if(!t)return new Map;const s=l=>{const[d,f,p]=l["forward-identity"];return R(e,f,p)},i=l=>{const[d,f,p]=l["forward-identity"];return fe(e,f,p)},o={attrIdMap:{},refSwapAttrIds:new Set};let a=!1;const c=(l,d)=>{const f=[];for(const p of l){const[y]=p;if(y==="add-attr"){const[m,w]=p,b=s(w);if(b&&w.id!==b.id){o.attrIdMap[w.id]=b.id,a=!0;continue}if(w["value-type"]==="ref"){const _=i(w);if(_){o.attrIdMap[w.id]=_.id,o.refSwapAttrIds.add(w.id),a=!0;continue}}}if(r&&d&&r>=d&&y==="add-attr"||y==="update-attr"||y==="delete-attr"){a=!0;continue}const g=a?oi(o,p):p;f.push(g)}return a?f:l},u=new Map;for(const[l,d]of t.entries())u.set(l,{...d,"tx-steps":c(d["tx-steps"],d["tx-id"])});return a?u:t}_rewriteMutationsSorted(e,t){return Lt(this._rewriteMutations(e,t).entries())}optimisticAttrs(){var i,o;const e=[...this._pendingMutations().values()].flatMap(a=>a["tx-steps"]),t=new Set(e.filter(([a,c])=>a==="delete-attr").map(([a,c])=>c)),r=[];for(const[a,c]of e)if(a==="add-attr")r.push(c);else if(a==="update-attr"&&c.id&&((i=this.attrs)!=null&&i.getAttr(c.id))){const u={...this.attrs.getAttr(c.id),...c};r.push(u)}if(!t.size&&!r.length)return this.attrs||new oe({},this._linkIndex);const s={...((o=this.attrs)==null?void 0:o.attrs)||{}};for(const a of r)s[a.id]=a;for(const a of t)delete s[a];return new oe(s,this._linkIndex)}dataForQuery(e,t=!0){const r=this._errorMessage;if(r)return{error:r};if(!this.querySubs||!this.kv.currentValue.pendingMutations)return;const s=this.querySubs.version(),i=this.querySubs.currentValue,o=this.kv.version(),a=this._pendingMutations(),{q:c,result:u}=i[e]||{};if(!u)return;const l=this._dataForQueryCache[e];if(l&&s===l.querySubVersion&&o===l.pendingMutationsVersion)return l;let d=u.store,f=u.attrsStore;const{pageInfo:p,aggregate:y,processedTxId:g}=u,m=this._rewriteMutationsSorted(f,a);if(t){const b=this._applyOptimisticUpdates(d,f,m,g);d=b.store,f=b.attrsStore}return{data:wt({store:d,attrsStore:f,pageInfo:p,aggregate:y},c),querySubVersion:s,pendingMutationsVersion:o}}_applyOptimisticUpdates(e,t,r,s){for(const[i,o]of r)if(!o["tx-id"]||s&&o["tx-id"]>s){const a=as(e,t,o["tx-steps"]);e=a.store,t=a.attrsStore}return{store:e,attrsStore:t}}notifyAll(){Object.keys(this.queryCbs).forEach(e=>{this.querySubs.waitForKeyToLoad(e).then(()=>this.notifyOne(e)).catch(()=>this.notifyOne(e))})}loadedNotifyAll(){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyAll()).catch(()=>this.notifyAll())}shutdown(){var e;this._log.info("[shutdown]",this.config.appId),this._isShutdown=!0,(e=this._transport)==null||e.close()}_sendMutation(e,t){if(t.error){this._handleMutationError("error",e,{message:t.error.message});return}if(this.status!==ne.AUTHENTICATED){this._finishTransaction("enqueued",e);return}const r=Math.max(6e3,Math.min(this._inFlightMutationEventIds.size+1,this._pendingMutations().size+1)*6e3);this._isOnline?(this._trySend(e,t),setTimeout(()=>{this._isOnline&&this._handleMutationError("timeout",e,{message:"transaction timed out"})},r)):this._finishTransaction("enqueued",e)}_flushPendingMessages(){Object.keys(this.queryCbs).map(i=>this.querySubs.currentValue[i]).filter(i=>i).forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})}),Object.values(this.queryOnceDfds).flat().forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})});const r=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations());r!==this._pendingMutations()&&this.kv.updateInPlace(i=>{i.pendingMutations=r}),Lt(r.entries()).forEach(([i,o])=>{o["tx-id"]||this._sendMutation(i,o)}),this._syncTable.flushPending()}_cleanupPendingMutationsQueries(){let e=Number.MAX_SAFE_INTEGER;for(const{result:t}of Object.values(this.querySubs.currentValue))t!=null&&t.processedTxId&&(e=Math.min(e,t==null?void 0:t.processedTxId));this._updatePendingMutations(t=>{for(const[r,s]of Array.from(t.entries()))s["tx-id"]&&s["tx-id"]<=e&&t.delete(r)})}_cleanupPendingMutationsTimeout(){if(this._pendingMutations().size<this._pendingMutationCleanupThreshold)return;const e=Date.now();this._updatePendingMutations(t=>{for(const[r,s]of Array.from(t.entries()))s.confirmed&&s.confirmed+this._pendingTxCleanupTimeout<e&&t.delete(r)})}_trySendAuthed(...e){this.status===ne.AUTHENTICATED&&this._trySend(...e)}_trySend(e,t,r){if(this._transport.isOpen()){switch(or[t.op]||this._log.info("[send]",this._transport.id,t.op,{"client-event-id":e,...t}),t.op){case"transact":{this._inFlightMutationEventIds.add(e);break}case"init":this._inFlightMutationEventIds.clear()}this._transport.send({"client-event-id":e,...t})}}_startSocket(){if(this._wsOk=null,this._isShutdown){this._log.info("[socket][start]",this.config.appId,"Reactor has been shut down and will not start a new socket");return}if(this._transport&&this._transport.isConnecting()){this._log.info("[socket][start]",this._transport.id,"maintained as current transport, we were still in a connecting state");return}const e=this._transport;this._transport=So({transportType:this._transportType,appId:this.config.appId,apiURI:this.config.apiURI,wsURI:this.config.websocketURI,EventSourceImpl:this._EventSource}),this._transport.onopen=this._transportOnOpen,this._transport.onmessage=this._transportOnMessage,this._transport.onclose=this._transportOnClose,this._transport.onerror=this._transportOnError,this._log.info("[socket][start]",this._transport.id),e!=null&&e.isOpen()&&(this._log.info("[socket][start]",this._transport.id,"close previous transport id = ",e.id),e.close())}async getLocalId(e){const t=`localToken_${e}`;if(this.kv.currentValue[t])return this.kv.currentValue[t];const r=await this.kv.waitForKeyToLoad(t);if(r)return r;const s=j();return this.kv.updateInPlace(i=>{i[t]||(i[t]=s)}),await this.kv.waitForKeyToLoad(t)}_replaceUrlAfterOAuth(){if(typeof URL>"u")return;const e=new URL(window.location.href);if(e.searchParams.get(Ut)){const t=e.toString();e.searchParams.delete(Ut),e.searchParams.delete("code"),e.searchParams.delete("error");const r=e.pathname+(e.searchParams.size?"?"+e.searchParams:"")+e.hash;if(history.replaceState(history.state,"",r),typeof navigation=="object"&&typeof navigation.addEventListener=="function"&&typeof navigation.removeEventListener=="function"){let s=!1;const i=o=>{var a;s||(s=!0,navigation.removeEventListener("navigate",i),!o.userInitiated&&o.navigationType==="replace"&&((a=o.destination)==null?void 0:a.url)===t&&history.replaceState(history.state,"",r))};navigation.addEventListener("navigate",i)}}}async _oauthLoginInit(){var s,i,o,a;if(typeof window>"u"||typeof window.location>"u"||typeof URLSearchParams>"u")return null;const e=new URLSearchParams(window.location.search);if(!e.get(Ut))return null;const t=e.get("error");if(t)return this._replaceUrlAfterOAuth(),{error:{message:t}};const r=e.get("code");if(!r)return null;this._replaceUrlAfterOAuth();try{const c=await this._getCurrentUser(),u=(c==null?void 0:c.type)==="guest",{user:l}=await Un({apiURI:this.config.apiURI,appId:this.config.appId,code:r,refreshToken:u?c.refresh_token:void 0});return this.setCurrentUser(l),null}catch(c){return((s=c==null?void 0:c.body)==null?void 0:s.type)==="record-not-found"&&((o=(i=c==null?void 0:c.body)==null?void 0:i.hint)==null?void 0:o["record-type"])==="app-oauth-code"&&await this._hasCurrentUser()?null:{error:{message:((a=c==null?void 0:c.body)==null?void 0:a.message)||"Error logging in."}}}}async _waitForOAuthCallbackResponse(){return await this._oauthCallbackResponse}__subscribeMutationErrors(e){return this.mutationErrorCbs.push(e),()=>{this.mutationErrorCbs=this.mutationErrorCbs.filter(t=>t!==e)}}subscribeAuth(e){this.authCbs.push(e);const t=this._currentUserCached;t.isLoading||e(this._currentUserCached);let r=!1;return this.getCurrentUser().then(s=>{r||Fe(s,t)||e(s)}),()=>{r=!0,this.authCbs=this.authCbs.filter(s=>s!==e)}}async getAuth(){const{user:e,error:t}=await this.getCurrentUser();if(t)throw new N("Could not get current user: "+t.message);return e}subscribeConnectionStatus(e){return this.connectionStatusCbs.push(e),()=>{this.connectionStatusCbs=this.connectionStatusCbs.filter(t=>t!==e)}}subscribeAttrs(e){return this.attrsCbs.push(e),this.attrs&&e(this.attrs.attrs),()=>{this.attrsCbs=this.attrsCbs.filter(t=>t!==e)}}notifyAuthSubs(e){this.authCbs.forEach(t=>t(e))}notifyMutationErrorSubs(e){this.mutationErrorCbs.forEach(t=>t(e))}notifyAttrsSubs(){if(!this.attrs)return;const e=this.optimisticAttrs();this.attrsCbs.forEach(t=>t(e.attrs))}notifyConnectionStatusSubs(e){this.connectionStatusCbs.forEach(t=>t(e))}async setCurrentUser(e){this.kv.updateInPlace(t=>{t[je]=e}),await this.kv.waitForKeyToLoad(je)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(){const e=await this.kv.waitForKeyToLoad(je);return typeof e=="string"?JSON.parse(e):e}async getCurrentUser(){const e=await this._waitForOAuthCallbackResponse();if(e!=null&&e.error){const t={error:e.error,user:void 0};return this._currentUserCached={isLoading:!1,...t},t}try{const r={user:await this._getCurrentUser(),error:void 0};return this._currentUserCached={isLoading:!1,...r},r}catch(t){return{user:void 0,isLoading:!1,error:{message:(t==null?void 0:t.message)||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(je);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){var r;const{user:t}=await this.getCurrentUser();if(!Fe(t,e)){await this.setCurrentUser(e),await this.updateUser(e);try{(r=this._broadcastChannel)==null||r.postMessage({type:"auth"})}catch(s){console.error("Error posting message to broadcast channel",s)}}}async syncUserToEndpoint(e){if(this.config.firstPartyPath)try{await fetch(this.config.firstPartyPath+"/",{method:"POST",body:JSON.stringify({type:"sync-user",appId:this.config.appId,user:e}),headers:{"Content-Type":"application/json"}})}catch(t){this._log.error("Error syncing user with external endpoint",t)}}async updateUser(e){try{await this.syncUserToEndpoint(e)}catch(r){this._log.error("Error syncing user with external endpoint",r)}const t={error:void 0,user:e};this._currentUserCached={isLoading:!1,...t},this._dataForQueryCache={},this.querySubs.updateInPlace(r=>{Object.keys(r).forEach(s=>{delete r[s].result})}),this._reconnectTimeoutMs=0,this._transport.close(),this._oauthCallbackResponse=null,this.notifyAuthSubs(t)}sendMagicCode({email:e}){return Li({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode({email:e,code:t}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await Fi({apiURI:this.config.apiURI,appId:this.config.appId,email:e,code:t,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}async signInWithCustomToken(e){const t=await Ni({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(t.user),t}async signInAsGuest(){const e=await qi({apiURI:this.config.apiURI,appId:this.config.appId});return await this.changeCurrentUser(e.user),e}potentiallyInvalidateToken(e,t){var i;const r=(i=e==null?void 0:e.user)==null?void 0:i.refresh_token;if(!r)return;if(t.invalidateToken===!1){this._log.info("[auth-invalidate] skipped invalidateToken");return}zi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:r}).then(()=>{this._log.info("[auth-invalidate] completed invalidateToken")}).catch(o=>{})}async signOut(e){const t=await this.getCurrentUser();this.potentiallyInvalidateToken(t,e),await this.changeCurrentUser(null)}createAuthorizationURL({clientName:e,redirectURL:t}){const{apiURI:r,appId:s}=this.config;return`${r}/runtime/oauth/start?app_id=${s}&client_name=${e}&redirect_uri=${t}`}async exchangeCodeForToken({code:e,codeVerifier:t}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await Un({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:t,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}issuerURI(){const{apiURI:e,appId:t}=this.config;return`${e}/runtime/${t}`}async signInWithIdToken({idToken:e,clientName:t,nonce:r}){var a;const s=await this.getCurrentUser(),i=(a=s==null?void 0:s.user)==null?void 0:a.refresh_token,o=await Ki({apiURI:this.config.apiURI,appId:this.config.appId,idToken:e,clientName:t,nonce:r,refreshToken:i});return await this.changeCurrentUser(o.user),o}joinRoom(e,t,r){let s=!1;this._rooms[t]||(s=!0,this._rooms[t]={roomType:e,isConnected:!1,error:void 0}),this._presence[t]=this._presence[t]||{};const i=this._presence[t].result;return r&&!i&&(this._presence[t].result=this._presence[t].result||{},this._presence[t].result.user=r,this._notifyPresenceSubs(t)),s&&this._tryJoinRoom(e,t,r),()=>{this._cleanupRoom(t)}}_cleanupRoom(e){var t,r,s;if(!((r=(t=this._presence[e])==null?void 0:t.handlers)!=null&&r.length)&&!Object.keys(this._broadcastSubs[e]??{}).length){const i=(s=this._rooms[e])==null?void 0:s.isConnected;delete this._rooms[e],delete this._presence[e],delete this._broadcastSubs[e],i?this._tryLeaveRoom(e):this._roomsPendingLeave[e]=!0}}getPresence(e,t,r={}){const s=this._rooms[t],i=this._presence[t];return!s||!i||!i.result?null:{...Hi(i.result,r,this._sessionId),isLoading:!s.isConnected,error:s.error}}publishPresence(e,t,r){const s=this._rooms[t],i=this._presence[t];if(!s||!i)return;i.result=i.result||{};const o={...i.result.user,...r};i.result.user=o,s.isConnected&&(this._trySetPresence(t,o),this._notifyPresenceSubs(t))}_trySetPresence(e,t){this._trySendAuthed(j(),{op:"set-presence","room-id":e,data:t})}_tryJoinRoom(e,t,r){this._trySendAuthed(j(),{op:"join-room","room-type":e,"room-id":t,data:r}),delete this._roomsPendingLeave[t]}_tryLeaveRoom(e){this._trySendAuthed(j(),{op:"leave-room","room-id":e})}_trySetRoomConnected(e,t){const r=this._rooms[e];r&&(r.isConnected=t)}subscribePresence(e,t,r,s){const i=this.joinRoom(e,t,r.initialPresence||r.initialData),o={...r,roomId:t,cb:s,prev:null};return this._presence[t]=this._presence[t]||{},this._presence[t].handlers=this._presence[t].handlers||[],this._presence[t].handlers.push(o),this._notifyPresenceSub(t,o),()=>{var a,c;this._presence[t].handlers=((c=(a=this._presence[t])==null?void 0:a.handlers)==null?void 0:c.filter(u=>u!==o))??[],i()}}_notifyPresenceSubs(e){var t,r;(r=(t=this._presence[e])==null?void 0:t.handlers)==null||r.forEach(s=>{this._notifyPresenceSub(e,s)})}_notifyPresenceSub(e,t){const r=this.getPresence("",e,t);r&&(t.prev&&!Ji(r,t.prev)||(t.prev=r,t.cb(r)))}_patchPresencePeers(e,t){var o,a,c;const r=((a=(o=this._presence[e])==null?void 0:o.result)==null?void 0:a.peers)||{};let s=Object.fromEntries(Object.entries(r).map(([u,l])=>[u,{data:l}]));(c=this._presence[e])==null||c.result;const i=Le(s,u=>{for(let[l,d,f]of t)switch(d){case"+":Cr(u,l,f);break;case"r":nn(u,l,f);break;case"-":rn(u,l);break}delete u[this._sessionId]});this._setPresencePeers(e,i)}_setPresencePeers(e,t){const r={...t};delete r[this._sessionId];const s=Object.fromEntries(Object.entries(r).map(([i,o])=>[i,o.data]));this._presence=Le(this._presence,i=>{nn(i,[e,"result","peers"],s)})}publishTopic({roomType:e,roomId:t,topic:r,data:s}){const i=this._rooms[t];if(i){if(!i.isConnected){this._broadcastQueue[t]=this._broadcastQueue[t]??[],this._broadcastQueue[t].push({topic:r,roomType:e,data:s});return}this._tryBroadcast(t,e,r,s)}}_tryBroadcast(e,t,r,s){this._trySendAuthed(j(),{op:"client-broadcast","room-id":e,roomType:t,topic:r,data:s})}subscribeTopic(e,t,r,s){const i=this.joinRoom(e,t);return this._broadcastSubs[t]=this._broadcastSubs[t]||{},this._broadcastSubs[t][r]=this._broadcastSubs[t][r]||[],this._broadcastSubs[t][r].push(s),this._presence[t]=this._presence[t]||{},()=>{this._broadcastSubs[t][r]=this._broadcastSubs[t][r].filter(o=>o!==s),this._broadcastSubs[t][r].length||delete this._broadcastSubs[t][r],i()}}_notifyBroadcastSubs(e,t,r){var s,i,o;(o=(i=(s=this._broadcastSubs)==null?void 0:s[e])==null?void 0:i[t])==null||o.forEach(a=>{var l,d,f,p,y,g;const c=(l=r.data)==null?void 0:l.data,u=r.data["peer-id"]===this._sessionId?(f=(d=this._presence[e])==null?void 0:d.result)==null?void 0:f.user:(g=(y=(p=this._presence[e])==null?void 0:p.result)==null?void 0:y.peers)==null?void 0:g[r.data["peer-id"]];return a(c,u)})}async uploadFile(e,t,r){var o;const s=await this.getCurrentUser(),i=(o=s==null?void 0:s.user)==null?void 0:o.refresh_token;return Wi({...r,apiURI:this.config.apiURI,appId:this.config.appId,path:e,file:t,refreshToken:i})}async deleteFile(e){var i;const t=await this.getCurrentUser(),r=(i=t==null?void 0:t.user)==null?void 0:i.refresh_token;return await Vi({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}async upload(e,t){var c;const r=await this.getCurrentUser(),s=(c=r==null?void 0:r.user)==null?void 0:c.refresh_token,i=e||t.name,o=await Qi({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await Bi(o,t)}async getDownloadUrl(e){var i;const t=await this.getCurrentUser(),r=(i=t==null?void 0:t.user)==null?void 0:i.refresh_token;return await Gi({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function Co(n,e){return new Be(cr(n,e),e,void 0)}function Mo(n){return new Qe(n,{})}function Po(){return new q("string",!0,!1)}function jo(){return new q("number",!0,!1)}function Do(){return new q("boolean",!0,!1)}function $o(){return new q("date",!0,!1)}function Ro(){return new q("json",!0,!1)}function xo(){return new q("json",!0,!1)}function cr(n,e){var s,i,o,a;const t={fwd:{},rev:{}};for(const c of Object.values(e))(s=t.fwd)[i=c.forward.on]||(s[i]={}),(o=t.rev)[a=c.reverse.on]||(o[a]={}),t.fwd[c.forward.on][c.forward.label]={entityName:c.reverse.on,cardinality:c.forward.has},t.rev[c.reverse.on][c.reverse.label]={entityName:c.forward.on,cardinality:c.reverse.has};return Object.fromEntries(Object.entries(n).map(([c,u])=>[c,new Qe(u.attrs,{...t.fwd[c],...t.rev[c]})]))}function Uo({entities:n,links:e,rooms:t}){const r=e??{},s=t??{};return new Be(cr(n,r),r,s)}const $={graph:Co,schema:Uo,entity:Mo,string:Po,number:jo,boolean:Do,date:$o,json:Ro,any:xo};let He;function Lo(n,e){He==null||He.dispose();const t=Wo(e),r=qo(e,a),s=No(Fo(n));function i(l){var d;l.source===s.element.contentWindow&&((d=l.data)==null?void 0:d.type)==="close"&&t.isVisible()&&a()}function o(l){const d=l.shiftKey&&l.ctrlKey&&l.key==="0",f=l.key==="Escape"||l.key==="Esc";(d||f&&t.isVisible())&&a()}function a(){t.isVisible()?t.element.style.display="none":(t.element.style.display="block",t.element.contains(s.element)||t.element.appendChild(s.element))}function c(){t.element.remove(),r.element.remove(),removeEventListener("keydown",o),removeEventListener("message",i)}function u(){document.body.appendChild(t.element),document.body.appendChild(r.element),addEventListener("keydown",o),addEventListener("message",i),He={dispose:c}}return u()}function Fo(n){return`${Mt||Fn?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${n}`}function No(n){const e=document.createElement("iframe");return e.src=n,e.className="instant-devtool-iframe",Object.assign(e.style,{width:"100%",height:"100%",backgroundColor:"white",border:"none"}),{element:e}}function qo(n,e){const t=`
|
|
3
3
|
<svg width="32" height="32" viewBox="0 0 512 512" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
4
4
|
<rect width="512" height="512" fill="black"/>
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@instantdb/core",
|
|
3
|
-
"version": "0.22.
|
|
3
|
+
"version": "0.22.141",
|
|
4
4
|
"description": "Instant's core local abstraction",
|
|
5
5
|
"homepage": "https://github.com/instantdb/instant/tree/main/client/packages/core",
|
|
6
6
|
"repository": {
|
|
@@ -53,7 +53,7 @@
|
|
|
53
53
|
"dependencies": {
|
|
54
54
|
"mutative": "^1.0.10",
|
|
55
55
|
"uuid": "^11.1.0",
|
|
56
|
-
"@instantdb/version": "0.22.
|
|
56
|
+
"@instantdb/version": "0.22.141"
|
|
57
57
|
},
|
|
58
58
|
"scripts": {
|
|
59
59
|
"test": "vitest",
|