@instantdb/core 0.22.146 → 0.22.147
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,E){typeof exports=="object"&&typeof module<"u"?E(exports):typeof define=="function"&&define.amd?define(["exports"],E):(A=typeof globalThis<"u"?globalThis:A||self,E(A.instant={}))})(this,function(A){"use strict";var ia=Object.defineProperty;var oa=(A,E,M)=>E in A?ia(A,E,{enumerable:!0,configurable:!0,writable:!0,value:M}):A[E]=M;var h=(A,E,M)=>oa(A,typeof E!="symbol"?E+"":E,M);function E(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=E(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=E(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=E(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return E(String(n))}const M={Remove:"remove",Replace:"replace",Add:"add"},Wt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),_r=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),$e=Symbol.iterator,B={mutable:"mutable",immutable:"immutable"},Xe={};function Se(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Vt(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 et(n){return Object.getPrototypeOf(n)===Set.prototype}function tt(n){return Object.getPrototypeOf(n)===Map.prototype}function G(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function le(n){return!!I(n)}function I(n){return typeof n!="object"?null:n==null?void 0:n[Wt]}function nt(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 Qt(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||Se(t,i)))return null;e.push(i)}if(n.parent)return Qt(n.parent,e);e.reverse();try{wr(n.copy,e)}catch{return null}return e}function de(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function re(n,e){return de(n)===2?n.get(e):n[e]}function Ae(n,e,t){de(n)===2?n.set(e,t):n[e]=t}function rt(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 st(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function fe(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 wr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=re(de(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Tr(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 Sr=Object.prototype.propertyIsEnumerable;function Bt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!et(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(!tt(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 Tr(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=>{Sr.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=Bt(n.original,n.options))}function ve(n){if(!J(n))return nt(n);if(Array.isArray(n))return n.map(ve);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,ve(s)]);if(!tt(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(ve);if(!et(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]=ve(n[t]);return e}function Re(n){return le(n)?ve(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 Gt(){throw new Error("Cannot modify frozen object")}function ye(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)||le(n)){r.pop(),s.pop();return}switch(de(n)){case 2:for(const[a,c]of n)ye(a,a,t,r,s),ye(c,a,t,r,s);n.set=n.clear=n.delete=Gt;break;case 3:for(const a of n)ye(a,a,t,r,s);n.add=n.clear=n.delete=Gt;break;case 1:Object.freeze(n);let o=0;for(const a of n)ye(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ye(c,a,t,r,s)})}r.pop(),s.pop()}function it(n,e){const t=de(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 Ht(n,e,t){if(le(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),it(n,(i,o)=>{var a;if(le(o)){const c=I(o);F(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ae(r?s:n,i,u)}else Ht(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 Ar(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Ht(re(t,e),n.finalities.handledSet,n.options)}function ot(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(nt(e))}))}function at(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Qt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ct(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),ot(n),at(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)),Ae(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)&&Ar(n,e)})}function vr(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=fe(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=fe(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=fe(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=fe(d,s);r.push({op:M.Remove,path:f})}}}function kr({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?Se(n,c)?M.Replace:M.Add:M.Remove;if(se(u,l)&&d===M.Replace)return;const f=r.concat(c),p=fe(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 Or({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=fe(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=fe(c,i);r.push({op:M.Add,path:u,value:a}),s.unshift({op:M.Remove,path:u,value:a})}o+=1})}function ke(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return kr(n,e,t,r,s);case 1:return vr(n,e,t,r,s);case 3:return Or(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.")},ut={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),ct(t,n,e,ke)),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=Xe.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()}},Ir=Reflect.ownKeys(ut),Jt=(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=Xe.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),ct(e,n,n,ke)),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:Jt(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Jt(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 Cr=Reflect.ownKeys(Ue),Yt=new WeakSet,Zt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Yt.has(i))return i;if(e===Wt)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&&Ir.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(ut,"size").get.call(n.proxy);const u=ut[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Cr.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(!Se(a,e)){const u=Vt(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===rt(n.original,e)){if(F(n),n.copy[e]=lt({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=Vt(G(n),e);if(i!=null&&i.set)return i.set.call(n.proxy,t),!0;const o=rt(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||Se(n.original,e))||(F(n),te(n),Se(n.original,e)&&se(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ct(n,e,t,ke)),!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?Zt.set.call(this,n,e,void 0,n.proxy):(rt(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 lt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=de(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,Zt);if(s.revoke.push(u),Yt.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((d,f)=>{var p,y;const m=I(c);let _=l.type===3?l.setMap:l.copy;const w=re(_,r),b=I(w);if(b){let g=b.original;b.operated&&(g=nt(w)),ot(b),at(b,ke,d,f),l.options.enableAutoFreeze&&(l.options.updatedValues=(p=l.options.updatedValues)!==null&&p!==void 0?p:new WeakMap,l.options.updatedValues.set(g,b.original)),Ae(_,r,g)}(y=m.callbacks)===null||y===void 0||y.forEach(g=>{g(d,f)})})}else{const l=I(c);l.finalities.draft.push((d,f)=>{ot(l),at(l,ke,d,f)})}return c}Xe.createDraft=lt;function Er(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&&st(o),s&&ye(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 Mr(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:lt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=Er(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function dt(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;it(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 Ae(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,dt(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 Xt(n){var e;const t=I(n);if(!J(n,t==null?void 0:t.options))return n;const r=de(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?tt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Bt(n,t==null?void 0:t.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(it(s,(o,a)=>{if(t&&se(re(t.original,o),a))return;const c=Xt(a);c!==a&&(s===n&&i(),Ae(s,o,c))}),r===3){const o=(e=t==null?void 0:t.original)!==null&&e!==void 0?e:s;return et(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function en(n){if(!le(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return Xt(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,k=>t.call(this,k,...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=le(c)?en(c):c,f=Array.isArray(l.mark)?(T,S)=>{for(const k of l.mark){if(typeof k!="function")throw new Error(`Invalid mark: ${k}, 'mark' should be a function.`);const $=k(T,S);if($)return $}}:l.mark,p=(i=l.enablePatches)!==null&&i!==void 0?i:!1,y=(o=l.strict)!==null&&o!==void 0?o:!1,_={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:f,strict:y,enablePatches:p};if(!J(d,_)&&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]=Mr(d,_);if(typeof r!="function"){if(!J(d,_))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 g;try{g=u(w)}catch(T){throw st(I(w)),T}const O=T=>{const S=I(w);if(!le(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 $=T==null?void 0:T[_r];if($){const x=$[0];return _.strict&&typeof T=="object"&&T!==null&&dt({rootDraft:S,value:T,useRawReturn:!0}),b([x])}if(T!==void 0)return typeof T=="object"&&T!==null&&dt({rootDraft:S,value:T}),b([T])}if(T===w||T===void 0)return b([]);const k=I(T);if(_===k.options){if(k.operated)throw new Error("Cannot return a modified child draft.");return b([en(T)])}return b([T])};return g instanceof Promise?g.then(O,T=>{throw st(I(w)),T}):O(g)})();Object.prototype.constructor.toString();function tn(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 nn(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:tn(n,e)?Object.keys(n).every(t=>Fe(n[t],e[t])):!1}function ft(n){if(!Oe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function rn(n,e){if(!Oe(n)||!Oe(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=Oe(n[r])&&Oe(e[r]);t[r]=s?rn(n[r],e[r]):e[r]}return t}function Oe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Pr(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 sn(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 on(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}on(n[t],r),jr(n[t])&&delete n[t]}}function jr(n){return n&&Object.keys(n).length===0}const an=/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$/,Dr={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 $r(n){return new Date(n)}function Rr(n){return new Date(n+"Z")}const xr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Ur(n){const e=n.match(xr);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 Lr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Fr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Nr(n){return new Date(n)}function qr(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 Kr(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 zr(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 Wr(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 Vr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Qr(n){const e=n.match(an);if(!e)return null;const[t]=e,r=Dr[t],s=new Date(n.replace(an,"Z"));return new Date(s.getTime()-r*1e3)}const Br=[Ur,Fr,qr,Wr,Nr,Rr,Kr,Lr,$r,Vr,Qr,zr];function Gr(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function ht(n){for(const e of Br){const t=Gr(e,n);if(t)return t}return null}function Hr(n){try{const e=JSON.parse(n);return typeof e=="string"?ht(e):null}catch{return null}}function Ie(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=ht(n)||Hr(n)||ht(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 ce{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(yt(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 Jr(n){return n.cardinality==="one"}function pt(n){return n["value-type"]==="ref"}function yt(n){return n["value-type"]==="blob"}function be(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 cn(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=Ie(u),o[2]=u),pt(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 un(n){return{triples:W(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function ln(n,e){return me(n,e.triples,e.cardinalityInference,e.useDateObjects)}function dn(n,e){if(n)return new ce(n.attrs,n.linkIndex);if(e&&"__type"in e)return new ce(e.attrs,e.linkIndex)}function Yr(n,e){return be(n.eav,[e])!==void 0}function me(n,e,t,r){const s=cn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Ce(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(m=>m[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 fn(n,e,t){const r=Ce(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]),pt(a)&&Y(n.vae,[o,i,s]))}let Zr=0;function hn(n,e,t){const[r,s,i]=t;let o;const a=be(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+Zr++}function pn(n,e,t){const r=Ce(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=Ie(o));const c=be(n.eav,[s,i,o]),u=(c==null?void 0:c[3])??hn(n,a,r),l=[s,i,o,u];Jr(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)),pt(a)&&z(n.vae,[o,i,s],l)}function Xr(n,e,t){var p;const r=Ce(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!yt(a))throw new Error("merge operation is not supported for links");const c=be(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=rn(l,o),f=[s,i,d,hn(n,a,u)];z(n.eav,[s,i],new Map([[d,f]])),z(n.aev,[i,s],new Map([[d,f]]))}function bt(n,e,t){var u,l;const[r,s]=t,i=Ce(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,m])=>{var _;return bt(n,e,[m,(_=f["reverse-identity"])==null?void 0:_[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 _,w,b;const[f,p,y]=d,m=e.getAttr(p);(!s||!m||((_=m["reverse-identity"])==null?void 0:_[1])===s)&&(Y(n.eav,[f,p,y]),Y(n.aev,[p,f,y]),Y(n.vae,[y,p,f])),m&&m["on-delete"]==="cascade"&&((w=m["reverse-identity"])==null?void 0:w[1])===s&&bt(n,e,[f,(b=m["forward-identity"])==null?void 0:b[1]])}),((l=n.vae.get(o))==null?void 0:l.size)===0&&Y(n.vae,[o])}function yn(n,e,t){const r=cn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function es(n,[e]){n.addAttr(e)}function bn(n){return W(n.eav,3)}function ts(n,e,[t]){if(!e.getAttr(t))return;const r=bn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),yn(n,e,r)}function ns(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),yn(n,e,bn(n)))}function rs(n,e,t){const[r,...s]=t;switch(r){case"add-triple":pn(n,e,s);break;case"deep-merge-triple":Xr(n,e,s);break;case"retract-triple":fn(n,e,s);break;case"delete-entity":bt(n,e,s);break;case"add-attr":es(e,s);break;case"delete-attr":ts(n,e,s);break;case"update-attr":ns(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 ss(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function is(n,[e,t,r]){var i,o;switch(ss(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 os(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 he(n,e,t){var r;return(r=n.revIdents.get(e))==null?void 0:r.get(t)}function as(n,e){return n.blobAttrs.get(e)}function mn(n,e){var r;const t=n.primaryKeys.get(e);return t||((r=n.forwardIdents.get(e))==null?void 0:r.get("id"))}function cs(n,e,t){const r=Ce(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return be(n.eav,[s,i])}function us(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=mn(e,d["forward-identity"][1]);l=!!cs(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=>{rs(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof ce)return"immutable"}})}function ls(n){return typeof n=="string"&&n.startsWith("?")}function ds(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return _n(r,e,t)}return{...t,[n]:e}}function gn(n,e,t){return n===e?t:null}function fs(n){switch(typeof n){case"string":return n.startsWith("?")?ds:gn;default:return gn}}const hs=["in","$in","$not","$isNull","$comparator"];function ps(n){for(const e of hs)if(n.hasOwnProperty(e))return!0;return!1}function _n(n,e,t){return t?typeof n=="object"?ps(n)?t:null:fs(n)(n,e,t):null}function ys(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return _n(s,o,r)},t)}function bs(n,e,t){return _s(n,e,t).map(r=>ys(e,r,t)).filter(r=>r)}function ms(n,e,t){return e.or?e.or.patterns.flatMap(r=>mt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>mt(n,s,r),t):t.flatMap(r=>bs(n,e,r))}function mt(n,e,t=[{}]){return e.reduce((r,s)=>ms(n,s,r),t)}function gt(n,e){return Array.isArray(e)?e.map(t=>gt(n,t)):ls(e)?n[e]:e}function gs(n,{find:e,where:t}){return mt(n,t).map(s=>gt(s,e))}function _s(n,e,t){return is(n,gt(t,e))}const ws=/^(?:[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"&&ws.test(n)}const U=[];for(let n=0;n<256;++n)U.push((n+256).toString(16).slice(1));function Ts(n,e=0){return(U[n[e+0]]+U[n[e+1]]+U[n[e+2]]+U[n[e+3]]+"-"+U[n[e+4]]+U[n[e+5]]+"-"+U[n[e+6]]+U[n[e+7]]+"-"+U[n[e+8]]+U[n[e+9]]+"-"+U[n[e+10]]+U[n[e+11]]+U[n[e+12]]+U[n[e+13]]+U[n[e+14]]+U[n[e+15]]).toLowerCase()}let _t;const Ss=new Uint8Array(16);function As(){if(!_t){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");_t=crypto.getRandomValues.bind(crypto)}return _t(Ss)}const wn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function vs(n,e,t){var s;if(wn.randomUUID&&!n)return wn.randomUUID();n=n||{};const r=n.random??((s=n.rng)==null?void 0:s.call(n))??As();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,Ts(r)}function Tn(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 ks(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 Os(n,e){return ks(Tn(n),Tn(e))}function j(){return vs()}function Is(n,e){return n.localeCompare(e)}function Cs(){let n=Is;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Es=Cs();let Sn=!0;const Ms=n=>{Sn=n};let Ps=0;function Ee(n){return qe(`_${n}`,Ps++)}function qe(n,e){return`?${n}-${e}`}class _e extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function js(n,e){const t=mn(n,e);if(!t)throw new _e(`Could not find id attr for ${e}`);return t}function An(n,e,t,r){return[Ds(n,e,t,r)]}function Ds(n,e,t,r){return[n(t,r),js(e,t).id,n(t,r),n("time",r)]}function $s(n,e,t){return n.map(r=>r===e?t:r)}function vn(n,e,t,r,s){const i=R(e,t,s),o=he(e,t,s),a=i||o;if(!a)throw new _e(`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 kn(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 Rs(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=kn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=kn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function xs(n,e,t,r,s,i){const o=R(e,t,s),a=he(e,t,s),c=o||a;if(!c)throw new _e(`No attr for etype = ${t} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=R(e,t,"id");if(!u)throw new _e(`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,Rs(c,i),Ee("time")]:[i,c.id,n(t,r),Ee("time")]}function Us(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,f]=c,[p,y,m]=vn(n,e,l,d,u);return[p,y,[...f,m]]},[t,r,[]]);return[i,o,a]}function wt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Us(n,e,t,r,o),d=xs(n,e,c,u,a,i);return l.concat([d])}function Ls(n,e){return e?[e].concat(n):n}function Fs([n,e]){return n==="or"&&Array.isArray(e)}function Ns([n,e]){return n==="and"&&Array.isArray(e)}function qs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function On(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=qs(n,o,u);return Cn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ks(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function In(n,e,t,r,s){return Ks(s).map(i=>wt(n,e,t,r,i,{$isNull:!0}))}function Cn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Fs([i,o]))return On(n,"or",e,t,r,o);if(Ns([i,o]))return On(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=wt(n,e,t,r,a,o),u=In(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:In(n,e,t,r,a),joinSym:n(t,r)}}]:wt(n,e,t,r,a,o)})}function zs(n,e,t,r){const s=qe;return r?Cn(s,n,e,t,r).concat(An(s,n,e,t)):An(s,n,e,t)}function Ws(n,e,t){return[n(e,t),n("time",t)]}function Vs(n,e,t,r,s,i){const[o,a,c,u,l]=vn(n,e,t,r,s),d=$s(c,n(t,r),i);return[o,a,d,u,l]}function Qs(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 m,_,w;const y=!!(e.cardinalityInference&&((w=(_=(m=t.linkIndex)==null?void 0:m[r])==null?void 0:_[p])!=null&&w.isSingular));try{const[b,g,O]=Vs(n,t,r,s,p,u),T=Mn(e,t,{etype:b,level:g,form:i[p],join:O}),S=y?T[0]:T;return{[p]:S}}catch(b){if(b instanceof _e)return{[p]:y?void 0:[]};throw b}}).reduce(function(p,y){return{...p,...y}},l)}):Object.values(o)}function Bs(n,e,t){return t==="string"?Es(n,e):n>e?1:-1}function Me(n,e,t,r,s){return e===r||e==null&&r==null?Os(n,t):r==null?1:e==null?-1:Bs(e,r,s)}function Ke([n,e],[t,r],s){return Me(n,e,t,r,s)}function Tt(n){return n==null?n:new Date(n).getTime()}function Gs(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"?Tt(l):l,p=d==="date"?Tt(o):o;return Ke([u,f],[s,p],d)===c}function Hs(n,e){const t=e[1];return n.getAttr(t)}function Js(n,e,t){const r=Object.keys(t)[0];return R(n,e,r)}function Ys(n,e,t,r){if(t)return Hs(n,t);if(r)return Js(n,e,r)}function Zs(n,e,t){var s,i;if(!Array.isArray(t.fields))return as(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&&yt(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 Xs(n,e,{etype:t,pageInfo:r,dq:s,form:i}){var y,m;const o=(y=i==null?void 0:i.$)==null?void 0:y.order,a=En(i),c=ei(i);let u=gs(n,s);const l=r==null?void 0:r["start-cursor"],d=Ys(e,t,l,o);if(d&&((m=d==null?void 0:d["forward-identity"])==null?void 0:m[2])!=="id"){const _=d["checked-data-type"]==="date",w=d.id;u=u.map(([b])=>{var O,T,S,k,$;let g=($=(k=(S=(T=(O=n.eav.get(b))==null?void 0:O.get(w))==null?void 0:T.values())==null?void 0:S.next())==null?void 0:k.value)==null?void 0:$[2];return _&&(g=Tt(g)),[b,g]})}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=Zs(e,t,s);for(const _ of u){const[w]=_;if(f[w]||!a&&l&&d&&Gs(l,d,c,_))continue;const b=os(n,p,w);b&&(f[w]=b)}return f}function ei(n){var t;const e=(t=n.$)==null?void 0:t.order;return e&&e[Object.keys(e)[0]]||"asc"}function En(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 ti(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){var f,p,y,m,_;if(!En(s)&&(!o||!o["start-cursor"]))return[];const a=Ls(zs(e,t,r,(f=s.$)==null?void 0:f.where),i),c=Ws(qe,t,r),u=(p=s.$)==null?void 0:p.fields,l=Xs(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((y=s.$)==null?void 0:y.limit)||((m=s.$)==null?void 0:m.first)||((_=s.$)==null?void 0:_.last);if(d!=null){r>0&&Sn&&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 ni(n,e,t){try{return ti(n,e,t)}catch(r){if(r instanceof _e)return{};throw r}}function Mn(n,e,t){const r=ni(n,e,t);return Qs(qe,n,e,t,r)}function ri(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 St({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]=Mn(n,e,{etype:u,form:s[u],level:0,pageInfo:t==null?void 0:t[u]})),c},{})};return t&&(o.pageInfo=ri(t)),r&&(o.aggregate=r),o}function si(){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 ii=si();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(ii.has(i))return(o,a)=>ze(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Pn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function We(n){return n.startsWith("lookup__")}function At(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function oi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>ze(n,At(Pn(s,i)),[]);if(t==="__etype")return n;const r=t;return We(r)?ze(n,At(r),[]):ze(n,r,[])}})}function vt(){return new Proxy({},{get(n,e){return oi(e)}})}const ai=vt();function jn(n){return n.__ops}function ci(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 ui(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 li(n,e,t){return t.indexOf(".")!==-1&&!R(n,e,t)}function kt(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 di(n,e,t){if(!li(n,e,t))return R(n,e,t);const r=kt(t),s=R(n,e,r)||he(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Ot(n){return typeof n=="string"&&!We(n)?null:typeof n=="string"&&We(n)?At(n):ui(n)}function V(n,e,t){const r=Ot(t);if(r===null)return t;const[s,i]=r,o=di(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Dn(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 fi({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=he(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 Dn(n,e,t,s)}function hi({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=he(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 Dn(n,e,t,s)}function pi(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 $n({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:pi(n,e,t,r)?{mode:"update"}:null}function yi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(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=Ie(d)),["add-triple",c,f.id,d,{mode:"create"}]})}function bi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(i),c=V(t,r,s),u=$n(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=Ie(f)),["add-triple",c,p.id,f,...u?[u]:[]]})}function mi({attrsStore:n},[e,t]){return[["delete-entity",V(n,e,t),e]]}function gi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(i),c=V(t,r,s),u=$n(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 _i({attrsStore:n},[e,t,r]){return[["rule-params",V(n,e,t),e,r]]}function wi(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 Ti(n,e){const[t,...r]=wi(e);switch(t){case"merge":return gi(n,r);case"create":return yi(n,r);case"update":return bi(n,r);case"link":return fi(n,r);case"unlink":return hi(n,r);case"delete":return mi(n,r);case"ruleParams":return _i(n,r);default:throw new Error(`unsupported action ${t}`)}}function Si(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Ai(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=Si(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Ve(n,e,t,r){const s=n?Ai(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 vi(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 ki(n,e,t){const r=vi(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 Rn(n,e,t,r){const s=n?ki(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 Oi=new Set(["create","update","merge","link","unlink"]),Ii=new Set(["link","unlink"]),Ci=new Set(["create","update","merge"]),Ei=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),It={"unique?":!0,"index?":!0},Mi={...It,cardinality:"one"};function Pi(n){const e=[],[t,r,s,i]=n;if(!Ei.has(t))return e;const o=Ot(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=Ot(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function ji({attrsStore:n,schema:e},t){var f,p;const r=new Set,s=[],i=[];function o(y,m){return R(n,y,m)||s.find(_=>_["forward-identity"][1]===y&&_["forward-identity"][2]===m)}function a(y,m){return he(n,y,m)||s.find(_=>{var w,b;return((w=_["reverse-identity"])==null?void 0:w[1])===y&&((b=_["reverse-identity"])==null?void 0:b[2])===m})}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,m){return m.indexOf(".")!==-1&&!o(y,m)}function d(y,m){const _=o(y,m),w=a(y,m);u(_),u(w),!_&&!w&&c(Rn(e,y,m,Mi))}for(const y of t)for(const{etype:m,lookupPair:_,linkLabel:w}of Pi(y)){const b=_[0];if(w){d(m,w);const g=o(m,w),O=a(m,w);u(g),u(O);const T=((f=g==null?void 0:g["reverse-identity"])==null?void 0:f[1])||((p=O==null?void 0:O["forward-identity"])==null?void 0:p[1])||w;if(l(T,b))d(T,kt(b));else{const S=o(T,b);S||c(Ve(e,T,b,It)),u(S)}}else if(l(m,b))d(m,kt(b));else{const g=o(m,b);g||c(Ve(e,m,b,It)),u(g)}}for(const y of t){const[m,_,w,b]=y;if(Oi.has(m)){const g=o(_,"id");u(g),g||c(Ve(e,_,"id",{"unique?":!0}));for(const O of Object.keys(b)){const T=o(_,O);if(u(T),Ci.has(m)&&(T||c(Ve(e,_,O,O==="id"?{"unique?":!0}:null))),Ii.has(m)){const S=a(_,O);!T&&!S&&c(Rn(e,_,O)),u(S)}}}}if(s.length){const y={...n.attrs};for(const m of s)y[m.id]=m;return[new ce(y,n.linkIndex),i]}return[n,i]}function Di(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>jn(c)),[s,i]=ji(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Ti(o,c));return[...i,...a]}function xn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Pe="__meta";class Ct{constructor(e,t){}}class Et{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(Pe);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=[[Pe,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(Pe);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,m])=>p.updatedAt-m.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,m])=>p.updatedAt-m.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(()=>{xn(()=>{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(()=>{xn(()=>{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 $i=6,Ri=["kv","querySubs","syncSubs"];function xi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Ui(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 Li(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 m=typeof y=="string"?JSON.parse(y):y;if(m.lastAccessed){const w={createdAt:m.lastAccessed,updatedAt:m.lastAccessed,size:((f=(d=(l=m.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:f.length)??0};a[p]=w}const _=t.put(m,p);s.add(_)}const c={objects:a},u=t.put(c,Pe);s.add(u);for(const p of s)p.onsuccess=()=>{s.delete(p),s.size===0&&i()},p.onerror=y=>{o(y)}})}async function Un(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Fi(n,e){const t=await Ui(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,d)=>{const y=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();y.onerror=_=>{d(_)};const m=[];y.onsuccess=()=>{const _=y.result;if(_){const w=_.key,b=_.value;m.push([w,b]),_.continue()}else l(m)},y.onerror=_=>{d(_)}}),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=Li(l,d,o);a.push(f);break}default:{const f=Un(l,d,i);a.push(f);const p={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=p;break}}const u=Un(Pe,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 Ln=new Map;class Mt extends Ct{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}_${$i}`,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=Fi(this._appId,c).catch(l=>{xi("Error upgrading store from version 5 to 6.")(l)});Ln.set(this.dbName,u),u.then(()=>t(c)).catch(()=>t(c))}else{const u=Ln.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 Ri)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 Pt{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 je 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,je),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 je({status:t.status,body:r}))}function Ni({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 qi({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 Ki({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 zi({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 Fn({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 Wi({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 Vi({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 Qi({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 Bi({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 Gi({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 Hi(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function Ji({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 jt=!1,Nn=!1,qn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(jt=!!window.localStorage.getItem("devBackend"),Nn=!!window.localStorage.getItem("__instantLogging"),qn=!!window.localStorage.getItem("__devtoolLocalDash"));function Kn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function Yi(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Kn(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=Kn(n.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Zi(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!nn(n.user,e.user))||!tn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!nn(n.peers[r],e.peers[r]))return!0;return!1}class zn{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 Wn(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);Wn(t["child-nodes"],e)})}function Vn(n){const e=[];return Wn(n,e),e}function Dt(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 $t="v0.22.146";function Xi(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 Qn=["where","order","limit","last","first","offset","after","before","fields","aggregate"],eo=n=>n.valueType||"unknown",Bn=(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}},to=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!Bn(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)}},we=(n,e,t,r,s)=>{const i=eo(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))to(u,l,i,e,r,t,`${s}.${u}`)}else if(!Bn(n,i,o))throw new P(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},no=(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);we(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);we(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)}we(e,n,u,t,s)},Gn=(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&&Gn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){we(i,"id",new q("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){no(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)we(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);we(i,s,u,e,`${r}.${s}`)}}},ro=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Qn.includes(o))throw new P(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Qn.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);Gn(n.where,e,t,r?`${r}.where`:"where")}},Hn=(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&&Hn(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}.$`);ro(a,e,t,`${r}.$`,s)}},Rt=(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)}Hn(t[r],r,e,r,0)}}},Jn=n=>typeof n!="string"?!1:We(n)?!0:ge(n);class H extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Yn=n=>n.length>0?n.join(", "):"none",so=(n,e)=>new H(`Entity '${n}' does not exist in schema. Available entities: ${Yn(e)}`),xt={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},io=(n,e)=>{var t;return n==null?!0:((t=xt[e.valueType])==null?void 0:t.call(xt,n))??!1},Zn=(n,e)=>{const t=e.entities[n];if(!t)throw so(n,Object.keys(e.entities));return t},Ut=(n,e,t)=>{const r=Zn(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&&!io(i,o))throw new H(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},Xn=(n,e,t)=>{const r=Zn(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: ${Yn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Jn(a))throw new H(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Jn(i))throw new H(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},oo={create:Ut,update:Ut,merge:Ut,link:Xn,unlink:Xn,delete:()=>{}},ao=(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=oo[t];o&&i!==void 0&&o(r,i,e)},er=(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}`);ao(s,e)}}};let tr=0;class nr{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}_${tr++}`,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 rr{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}_${tr++}`,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 co(n,e){const t=n.values;if(t){const r=dn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=ln(r,s.store);t.attrsStore=r}}return n}function uo(n,e){var t;if(e.values){const r=[];for(const s of(t=e.values)==null?void 0:t.entities){const i=un(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function lo(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 Lt(n,e,t){return St({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function sr(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=be(e.eav,[r,s,r]);return i?i[3]:-1}function ir(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":pn(n,e,s);break;case"removed":fn(n,e,s);break}}function fo(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 ho(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 po(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return Me(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Me(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 Me(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Me(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var or=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(or||{});class yo{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 Et({persister:t,merge:lo,serialize:uo,parse:(a,c)=>co(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=E(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=E(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=Lt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:sr(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 _ of a.changes){const w=u[_.triple[0]]??[];u[_.triple[0]]=w,w.push(_)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const f=[];e:for(const[_,w]of Object.entries(u))for(let b=0;b<d.length;b++){const g=d[b];if(Yr(g.store,_)){ir(g.store,l.attrsStore,w);const O=Lt(s,g.store,l.attrsStore),T=fo(g.store,l.attrsStore,w)[_];O?(f.push({oldEntity:g.entity,newEntity:O,changedFields:T||{}}),g.entity=O):c.push(b),delete u[_];continue e}}const p=[];for(const[_,w]of Object.entries(u)){const b=this.createStore([]);ir(b,l.attrsStore,w);const g=Lt(s,b,l.attrsStore);if(!g){this.log.error("No entity found after applying change",{sub:s,changes:w,store:b});continue}d.push({store:b,entity:g,serverCreatedAt:sr(s,b,l.attrsStore,g.id)}),p.push(g)}const y=[];for(const _ of c.sort().reverse())y.push(d[_].entity),d.splice(_,1);const m=ho(s,this.getAttrs);po(s,m,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=E(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 bo({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=[],p=[];let y=!1,m=0,_=0;const w=[],b=new TextEncoder;function g(){l=!0;for(const v of d)v()}function O(v){return d.push(v),()=>{const C=d.indexOf(v);C!==-1&&d.splice(C,1)}}function T(v){return p.push(v),()=>{const C=p.indexOf(v);C!==-1&&p.splice(C,1)}}e.waitUntil&&e.waitUntil(new Promise(v=>{p.push(v)}));function S(){for(const v of p)try{v()}catch{}}function k(v){return f.push(v),()=>{const C=f.indexOf(v);C!==-1&&f.splice(C,1)}}function $(v){o=v;for(const C of f)C(o)}function x(){y=!0}function pe(v){let C=m,K=0,Q=0;for(const{byteLen:ee}of w){const ae=C+ee;if(ae>v)break;C=ae,K++,Q+=ee}K>0&&(m+=Q,_-=Q,w.splice(0,K))}function ie(v,C){g(),v.error(C),S()}async function oe(){const v=await t({clientId:i,reconnectToken:c,ruleParams:e.ruleParams});switch(v.type){case"ok":{const{streamId:C,offset:K}=v;o=C,pe(K),w.length&&r({streamId:C,chunks:w.map(Q=>Q.chunk),offset:m}),y=!1;break}case"disconnect":{x();break}case"error":{a&&ie(a,v.error);break}}}function X(){x(),oe()}function L({offset:v,done:C}){pe(v),C&&(u=!0,S())}function ue(v){return u?(ie(v,new N("Stream has been closed.")),null):o||(ie(v,new N("Stream has not been initialized.")),null)}async function Ye(v){a=v;let C=!0,K=0;for(;C;){let Q=Date.now()+Math.min(15e3,500*(K-1));C=!1;const ee=await t({clientId:e.clientId,reconnectToken:c,ruleParams:e.ruleParams});switch(ee.type){case"ok":{const{streamId:ae,offset:zt}=ee;if(zt!==0){const De=new N("Write stream is corrupted");ie(v,De);return}$(ae),s(ae,{onDisconnect:x,onFlush:L,onConnectionReconnect:oe,onAppendFailed:X}),y=!1;return}case"disconnect":{C=!0,x(),K++,await new Promise(ae=>{setTimeout(ae,Math.max(0,Q-Date.now()))});break}case"error":{ie(v,ee.error);return}}}}class Ze extends n{constructor(C,K){super(C,K)}async streamId(){return o||new Promise((C,K)=>{const Q=[],ee=()=>{for(const De of Q)De()},ae=De=>{C(De),ee()},zt=()=>{K(new N("Stream is closed.")),ee()};Q.push(k(ae)),Q.push(O(zt))})}}return{stream:new Ze({async start(v){try{await Ye(v)}catch(C){ie(v,C)}},write(v,C){const K=ue(C);if(K){const Q=b.encode(v).length;w.push({chunk:v,byteLen:Q});const ee=m+_;_+=Q,y||r({streamId:K,chunks:[v],offset:ee})}},close(){o?r({streamId:o,chunks:[],offset:m+_,isDone:!0}):S(),g()},abort(v){o?r({streamId:o,chunks:[],offset:m+_,isDone:!0,abortReason:v}):S(),g()}}),addCompleteCb:T,closed(){return l}}}class mo{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 go({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 g=l.indexOf(b);g!==-1&&l.splice(g,1)}}function p(b,g){b.error(g),d()}let y=0;async function m(b,g){c=j();const O={...b||{},eventId:c};for await(const T of t(O)){if(i)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){p(g,T.error);return}if(T.offset>s){p(g,new N("Stream is corrupted.")),i=!0;return}let S=s-T.offset;if(T.files&&T.files.length){const k=new AbortController;let $=fetch(T.files[0].url,{signal:k.signal});for(let x=0;x<T.files.length;x++){const pe=T.files[x+1],oe=await $;if(pe&&($=fetch(pe.url,{signal:k.signal})),!oe.ok){if(y++,y>10){p(g,new N("Unable to process stream."));return}return{retry:!0}}if(oe.body)for await(const X of oe.body){if(i){k.abort();return}let L=X;if(S>0&&(L=X.subarray(S),S-=X.length-L.length),!L.length)continue;s+=L.length;const ue=o.decode(L);g.enqueue(ue)}else{const X=await oe.arrayBuffer();let L=X;if(i){k.abort();return}if(S>0&&(L=new Uint8Array(X).subarray(S),S-=X.byteLength-L.length),!L.byteLength)continue;s+=L.byteLength;const ue=o.decode(L);g.enqueue(ue)}}}if(y=0,T.content){let k=T.content,$=a.encode(T.content);if(S>0){const x=$.subarray(S);if(S-=$.length-x.length,!x.length)continue;$=x,k=o.decode(x)}s+=$.length,g.enqueue(k)}}}async function _(b){let g=!0,O=0;for(;g;){g=!1;let T=Date.now()+Math.min(15e3,500*(O-1));const S=await m({...e,offset:s},b);S!=null&&S.retry&&(g=!0,O++,T<Date.now()-3e5&&(O=0),await new Promise(k=>{setTimeout(k,Math.max(0,T-Date.now()))}))}!i&&!u&&(b.close(),d())}return{stream:new n({start(b){_(b)},cancel(b){i=!0,c&&r({eventId:c}),d()}}),addCloseCb:f,closed(){return u}}}class ar{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,addCompleteCb:r}=bo({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}=go({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 e.ruleParams&&(i["rule-params"]=e.ruleParams),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,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new mo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}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"},_o=3e4,wo=3e4,To=200,So=1e3*60,Ao={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ft="_instant_oauth_redirect",Te="currentUser";function vo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new nr(`${r}?app_id=${e}`);switch(n){case"ws":return new nr(`${r}?app_id=${e}`);case"sse":return new rr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function ko(){return typeof window<"u"||typeof chrome<"u"}const cr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function Oo(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=dn(t.result.attrsStore,t.result.store);if(s){const i=t.result.store;t.result.store=ln(s,{...i,useDateObjects:e}),t.result.attrsStore=s}}return t}function Io(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:un(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Co(n,e){switch(n){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function Eo(n,e){switch(n){case"pendingMutations":return[...e.entries()];default:return e}}function Mo(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 Nt(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 ur{constructor(e,t=Mt,r=Pt,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=E(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||er(e,this.config.schema);try{const t=Di({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 zn;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={...Ao,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??wo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??To,this._log=Xi(e.verbose||jt||Nn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":$t},this.config.schema&&(this._linkIndex=Dt(this.config.schema)),!!ko()){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({forceReadFromStorage:!0});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 yo(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>me(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ar({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)},So),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?Dt(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 Et({persister:new e(this.config.appId,"querySubs"),merge:Mo,serialize:Io,parse:(t,r)=>Oo(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 Et({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:Eo,parse:Co,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(Te),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 je({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=E(e),i=this.ensureAttrs(),o=me(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(cr[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,m=(o=this._rooms[p])==null?void 0:o.roomType;this._tryJoinRoom(m,p,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(E(t.q));break}case"add-query-ok":{const{q:p,result:y}=t,m=E(p);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[m])break;const _=(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=Vn(y),g=this.ensureAttrs(),O=me(g,b,r,this.config.useDateObjects);this.querySubs.updateInPlace(T=>{if(!T[m]){this._log.info("Missing value in querySubs",{hash:m,q:p});return}T[m].result={store:O,attrsStore:g,pageInfo:_,aggregate:w,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(m),this.notifyOneQueryOnce(m),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,m=t["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const _=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),m);_!==this._pendingMutations()&&this.kv.updateInPlace(g=>{g.pendingMutations=_});const w=Nt(_.entries()),b=p.map(g=>{var L,ue,Ye,Ze;const O=g["instaql-query"],T=g["instaql-result"],S=E(O),k=Vn(T),$=this.ensureAttrs(),x=me($,k,r,this.config.useDateObjects),{store:pe,attrsStore:ie}=this._applyOptimisticUpdates(x,$,w,m),oe=(ue=(L=T==null?void 0:T[0])==null?void 0:L.data)==null?void 0:ue["page-info"],X=(Ze=(Ye=T==null?void 0:T[0])==null?void 0:Ye.data)==null?void 0:Ze.aggregate;return{q:O,hash:S,store:pe,attrsStore:ie,pageInfo:oe,aggregate:X}});b.forEach(({hash:g,q:O,store:T,attrsStore:S,pageInfo:k,aggregate:$})=>{this.querySubs.updateInPlace(x=>{if(!x[g]){this._log.error("Missing value in querySubs",{hash:g,q:O});return}x[g].result={store:T,attrsStore:S,pageInfo:k,aggregate:$,processedTxId:m}})}),this._cleanupPendingMutationsQueries(),b.forEach(({hash:g})=>{this.notifyOne(g)});break}case"transact-ok":{const{"client-event-id":p,"tx-id":y}=t;this._inFlightMutationEventIds.delete(p);const _=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(p);if(!_)break;this._updatePendingMutations(b=>{b.set(p,{...b.get(p),"tx-id":y,confirmed:Date.now()})});const w=[];for(const b of _["tx-steps"])if(b[0]==="add-attr"){const g=b[1];w.push(g)}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("Unknown 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=E(p);this.notifyQueryError(E(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,E){typeof exports=="object"&&typeof module<"u"?E(exports):typeof define=="function"&&define.amd?define(["exports"],E):(A=typeof globalThis<"u"?globalThis:A||self,E(A.instant={}))})(this,function(A){"use strict";var ia=Object.defineProperty;var oa=(A,E,M)=>E in A?ia(A,E,{enumerable:!0,configurable:!0,writable:!0,value:M}):A[E]=M;var h=(A,E,M)=>oa(A,typeof E!="symbol"?E+"":E,M);function E(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=E(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=E(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=E(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return E(String(n))}const M={Remove:"remove",Replace:"replace",Add:"add"},Wt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),_r=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),$e=Symbol.iterator,B={mutable:"mutable",immutable:"immutable"},Xe={};function Se(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Vt(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 et(n){return Object.getPrototypeOf(n)===Set.prototype}function tt(n){return Object.getPrototypeOf(n)===Map.prototype}function G(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function le(n){return!!I(n)}function I(n){return typeof n!="object"?null:n==null?void 0:n[Wt]}function nt(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 Qt(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||Se(t,i)))return null;e.push(i)}if(n.parent)return Qt(n.parent,e);e.reverse();try{wr(n.copy,e)}catch{return null}return e}function de(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function re(n,e){return de(n)===2?n.get(e):n[e]}function Ae(n,e,t){de(n)===2?n.set(e,t):n[e]=t}function rt(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 st(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function fe(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 wr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=re(de(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Tr(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 Sr=Object.prototype.propertyIsEnumerable;function Bt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!et(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(!tt(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 Tr(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=>{Sr.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=Bt(n.original,n.options))}function ve(n){if(!J(n))return nt(n);if(Array.isArray(n))return n.map(ve);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,ve(s)]);if(!tt(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(ve);if(!et(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]=ve(n[t]);return e}function Re(n){return le(n)?ve(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 Gt(){throw new Error("Cannot modify frozen object")}function ye(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)||le(n)){r.pop(),s.pop();return}switch(de(n)){case 2:for(const[a,c]of n)ye(a,a,t,r,s),ye(c,a,t,r,s);n.set=n.clear=n.delete=Gt;break;case 3:for(const a of n)ye(a,a,t,r,s);n.add=n.clear=n.delete=Gt;break;case 1:Object.freeze(n);let o=0;for(const a of n)ye(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ye(c,a,t,r,s)})}r.pop(),s.pop()}function it(n,e){const t=de(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 Ht(n,e,t){if(le(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),it(n,(i,o)=>{var a;if(le(o)){const c=I(o);F(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ae(r?s:n,i,u)}else Ht(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 Ar(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Ht(re(t,e),n.finalities.handledSet,n.options)}function ot(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(nt(e))}))}function at(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Qt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ct(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),ot(n),at(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)),Ae(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)&&Ar(n,e)})}function vr(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=fe(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=fe(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=fe(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=fe(d,s);r.push({op:M.Remove,path:f})}}}function kr({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?Se(n,c)?M.Replace:M.Add:M.Remove;if(se(u,l)&&d===M.Replace)return;const f=r.concat(c),p=fe(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 Or({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=fe(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=fe(c,i);r.push({op:M.Add,path:u,value:a}),s.unshift({op:M.Remove,path:u,value:a})}o+=1})}function ke(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return kr(n,e,t,r,s);case 1:return vr(n,e,t,r,s);case 3:return Or(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.")},ut={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),ct(t,n,e,ke)),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=Xe.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()}},Ir=Reflect.ownKeys(ut),Jt=(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=Xe.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),ct(e,n,n,ke)),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:Jt(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);F(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Jt(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 Cr=Reflect.ownKeys(Ue),Yt=new WeakSet,Zt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Yt.has(i))return i;if(e===Wt)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&&Ir.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(ut,"size").get.call(n.proxy);const u=ut[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Cr.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(!Se(a,e)){const u=Vt(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===rt(n.original,e)){if(F(n),n.copy[e]=lt({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=Vt(G(n),e);if(i!=null&&i.set)return i.set.call(n.proxy,t),!0;const o=rt(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||Se(n.original,e))||(F(n),te(n),Se(n.original,e)&&se(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ct(n,e,t,ke)),!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?Zt.set.call(this,n,e,void 0,n.proxy):(rt(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 lt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=de(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,Zt);if(s.revoke.push(u),Yt.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((d,f)=>{var p,y;const m=I(c);let _=l.type===3?l.setMap:l.copy;const w=re(_,r),b=I(w);if(b){let g=b.original;b.operated&&(g=nt(w)),ot(b),at(b,ke,d,f),l.options.enableAutoFreeze&&(l.options.updatedValues=(p=l.options.updatedValues)!==null&&p!==void 0?p:new WeakMap,l.options.updatedValues.set(g,b.original)),Ae(_,r,g)}(y=m.callbacks)===null||y===void 0||y.forEach(g=>{g(d,f)})})}else{const l=I(c);l.finalities.draft.push((d,f)=>{ot(l),at(l,ke,d,f)})}return c}Xe.createDraft=lt;function Er(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&&st(o),s&&ye(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 Mr(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:lt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=Er(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function dt(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;it(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 Ae(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,dt(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 Xt(n){var e;const t=I(n);if(!J(n,t==null?void 0:t.options))return n;const r=de(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?tt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Bt(n,t==null?void 0:t.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(it(s,(o,a)=>{if(t&&se(re(t.original,o),a))return;const c=Xt(a);c!==a&&(s===n&&i(),Ae(s,o,c))}),r===3){const o=(e=t==null?void 0:t.original)!==null&&e!==void 0?e:s;return et(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function en(n){if(!le(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return Xt(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,k=>t.call(this,k,...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=le(c)?en(c):c,f=Array.isArray(l.mark)?(T,S)=>{for(const k of l.mark){if(typeof k!="function")throw new Error(`Invalid mark: ${k}, 'mark' should be a function.`);const $=k(T,S);if($)return $}}:l.mark,p=(i=l.enablePatches)!==null&&i!==void 0?i:!1,y=(o=l.strict)!==null&&o!==void 0?o:!1,_={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:f,strict:y,enablePatches:p};if(!J(d,_)&&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]=Mr(d,_);if(typeof r!="function"){if(!J(d,_))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 g;try{g=u(w)}catch(T){throw st(I(w)),T}const O=T=>{const S=I(w);if(!le(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 $=T==null?void 0:T[_r];if($){const x=$[0];return _.strict&&typeof T=="object"&&T!==null&&dt({rootDraft:S,value:T,useRawReturn:!0}),b([x])}if(T!==void 0)return typeof T=="object"&&T!==null&&dt({rootDraft:S,value:T}),b([T])}if(T===w||T===void 0)return b([]);const k=I(T);if(_===k.options){if(k.operated)throw new Error("Cannot return a modified child draft.");return b([en(T)])}return b([T])};return g instanceof Promise?g.then(O,T=>{throw st(I(w)),T}):O(g)})();Object.prototype.constructor.toString();function tn(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 nn(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:tn(n,e)?Object.keys(n).every(t=>Fe(n[t],e[t])):!1}function ft(n){if(!Oe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function rn(n,e){if(!Oe(n)||!Oe(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=Oe(n[r])&&Oe(e[r]);t[r]=s?rn(n[r],e[r]):e[r]}return t}function Oe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Pr(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 sn(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 on(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}on(n[t],r),jr(n[t])&&delete n[t]}}function jr(n){return n&&Object.keys(n).length===0}const an=/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$/,Dr={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 $r(n){return new Date(n)}function Rr(n){return new Date(n+"Z")}const xr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Ur(n){const e=n.match(xr);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 Lr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Fr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Nr(n){return new Date(n)}function qr(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 Kr(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 zr(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 Wr(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 Vr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Qr(n){const e=n.match(an);if(!e)return null;const[t]=e,r=Dr[t],s=new Date(n.replace(an,"Z"));return new Date(s.getTime()-r*1e3)}const Br=[Ur,Fr,qr,Wr,Nr,Rr,Kr,Lr,$r,Vr,Qr,zr];function Gr(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function ht(n){for(const e of Br){const t=Gr(e,n);if(t)return t}return null}function Hr(n){try{const e=JSON.parse(n);return typeof e=="string"?ht(e):null}catch{return null}}function Ie(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=ht(n)||Hr(n)||ht(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 ce{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(yt(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 Jr(n){return n.cardinality==="one"}function pt(n){return n["value-type"]==="ref"}function yt(n){return n["value-type"]==="blob"}function be(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 cn(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=Ie(u),o[2]=u),pt(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 un(n){return{triples:W(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function ln(n,e){return me(n,e.triples,e.cardinalityInference,e.useDateObjects)}function dn(n,e){if(n)return new ce(n.attrs,n.linkIndex);if(e&&"__type"in e)return new ce(e.attrs,e.linkIndex)}function Yr(n,e){return be(n.eav,[e])!==void 0}function me(n,e,t,r){const s=cn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Ce(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(m=>m[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 fn(n,e,t){const r=Ce(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]),pt(a)&&Y(n.vae,[o,i,s]))}let Zr=0;function hn(n,e,t){const[r,s,i]=t;let o;const a=be(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+Zr++}function pn(n,e,t){const r=Ce(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=Ie(o));const c=be(n.eav,[s,i,o]),u=(c==null?void 0:c[3])??hn(n,a,r),l=[s,i,o,u];Jr(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)),pt(a)&&z(n.vae,[o,i,s],l)}function Xr(n,e,t){var p;const r=Ce(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!yt(a))throw new Error("merge operation is not supported for links");const c=be(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=rn(l,o),f=[s,i,d,hn(n,a,u)];z(n.eav,[s,i],new Map([[d,f]])),z(n.aev,[i,s],new Map([[d,f]]))}function bt(n,e,t){var u,l;const[r,s]=t,i=Ce(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,m])=>{var _;return bt(n,e,[m,(_=f["reverse-identity"])==null?void 0:_[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 _,w,b;const[f,p,y]=d,m=e.getAttr(p);(!s||!m||((_=m["reverse-identity"])==null?void 0:_[1])===s)&&(Y(n.eav,[f,p,y]),Y(n.aev,[p,f,y]),Y(n.vae,[y,p,f])),m&&m["on-delete"]==="cascade"&&((w=m["reverse-identity"])==null?void 0:w[1])===s&&bt(n,e,[f,(b=m["forward-identity"])==null?void 0:b[1]])}),((l=n.vae.get(o))==null?void 0:l.size)===0&&Y(n.vae,[o])}function yn(n,e,t){const r=cn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function es(n,[e]){n.addAttr(e)}function bn(n){return W(n.eav,3)}function ts(n,e,[t]){if(!e.getAttr(t))return;const r=bn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),yn(n,e,r)}function ns(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),yn(n,e,bn(n)))}function rs(n,e,t){const[r,...s]=t;switch(r){case"add-triple":pn(n,e,s);break;case"deep-merge-triple":Xr(n,e,s);break;case"retract-triple":fn(n,e,s);break;case"delete-entity":bt(n,e,s);break;case"add-attr":es(e,s);break;case"delete-attr":ts(n,e,s);break;case"update-attr":ns(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 ss(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function is(n,[e,t,r]){var i,o;switch(ss(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 os(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 he(n,e,t){var r;return(r=n.revIdents.get(e))==null?void 0:r.get(t)}function as(n,e){return n.blobAttrs.get(e)}function mn(n,e){var r;const t=n.primaryKeys.get(e);return t||((r=n.forwardIdents.get(e))==null?void 0:r.get("id"))}function cs(n,e,t){const r=Ce(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return be(n.eav,[s,i])}function us(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=mn(e,d["forward-identity"][1]);l=!!cs(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=>{rs(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof ce)return"immutable"}})}function ls(n){return typeof n=="string"&&n.startsWith("?")}function ds(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return _n(r,e,t)}return{...t,[n]:e}}function gn(n,e,t){return n===e?t:null}function fs(n){switch(typeof n){case"string":return n.startsWith("?")?ds:gn;default:return gn}}const hs=["in","$in","$not","$isNull","$comparator"];function ps(n){for(const e of hs)if(n.hasOwnProperty(e))return!0;return!1}function _n(n,e,t){return t?typeof n=="object"?ps(n)?t:null:fs(n)(n,e,t):null}function ys(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return _n(s,o,r)},t)}function bs(n,e,t){return _s(n,e,t).map(r=>ys(e,r,t)).filter(r=>r)}function ms(n,e,t){return e.or?e.or.patterns.flatMap(r=>mt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>mt(n,s,r),t):t.flatMap(r=>bs(n,e,r))}function mt(n,e,t=[{}]){return e.reduce((r,s)=>ms(n,s,r),t)}function gt(n,e){return Array.isArray(e)?e.map(t=>gt(n,t)):ls(e)?n[e]:e}function gs(n,{find:e,where:t}){return mt(n,t).map(s=>gt(s,e))}function _s(n,e,t){return is(n,gt(t,e))}const ws=/^(?:[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"&&ws.test(n)}const U=[];for(let n=0;n<256;++n)U.push((n+256).toString(16).slice(1));function Ts(n,e=0){return(U[n[e+0]]+U[n[e+1]]+U[n[e+2]]+U[n[e+3]]+"-"+U[n[e+4]]+U[n[e+5]]+"-"+U[n[e+6]]+U[n[e+7]]+"-"+U[n[e+8]]+U[n[e+9]]+"-"+U[n[e+10]]+U[n[e+11]]+U[n[e+12]]+U[n[e+13]]+U[n[e+14]]+U[n[e+15]]).toLowerCase()}let _t;const Ss=new Uint8Array(16);function As(){if(!_t){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");_t=crypto.getRandomValues.bind(crypto)}return _t(Ss)}const wn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function vs(n,e,t){var s;if(wn.randomUUID&&!n)return wn.randomUUID();n=n||{};const r=n.random??((s=n.rng)==null?void 0:s.call(n))??As();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,Ts(r)}function Tn(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 ks(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 Os(n,e){return ks(Tn(n),Tn(e))}function j(){return vs()}function Is(n,e){return n.localeCompare(e)}function Cs(){let n=Is;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Es=Cs();let Sn=!0;const Ms=n=>{Sn=n};let Ps=0;function Ee(n){return qe(`_${n}`,Ps++)}function qe(n,e){return`?${n}-${e}`}class _e extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function js(n,e){const t=mn(n,e);if(!t)throw new _e(`Could not find id attr for ${e}`);return t}function An(n,e,t,r){return[Ds(n,e,t,r)]}function Ds(n,e,t,r){return[n(t,r),js(e,t).id,n(t,r),n("time",r)]}function $s(n,e,t){return n.map(r=>r===e?t:r)}function vn(n,e,t,r,s){const i=R(e,t,s),o=he(e,t,s),a=i||o;if(!a)throw new _e(`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 kn(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 Rs(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=kn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=kn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function xs(n,e,t,r,s,i){const o=R(e,t,s),a=he(e,t,s),c=o||a;if(!c)throw new _e(`No attr for etype = ${t} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=R(e,t,"id");if(!u)throw new _e(`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,Rs(c,i),Ee("time")]:[i,c.id,n(t,r),Ee("time")]}function Us(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,f]=c,[p,y,m]=vn(n,e,l,d,u);return[p,y,[...f,m]]},[t,r,[]]);return[i,o,a]}function wt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Us(n,e,t,r,o),d=xs(n,e,c,u,a,i);return l.concat([d])}function Ls(n,e){return e?[e].concat(n):n}function Fs([n,e]){return n==="or"&&Array.isArray(e)}function Ns([n,e]){return n==="and"&&Array.isArray(e)}function qs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function On(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=qs(n,o,u);return Cn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ks(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function In(n,e,t,r,s){return Ks(s).map(i=>wt(n,e,t,r,i,{$isNull:!0}))}function Cn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Fs([i,o]))return On(n,"or",e,t,r,o);if(Ns([i,o]))return On(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=wt(n,e,t,r,a,o),u=In(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:In(n,e,t,r,a),joinSym:n(t,r)}}]:wt(n,e,t,r,a,o)})}function zs(n,e,t,r){const s=qe;return r?Cn(s,n,e,t,r).concat(An(s,n,e,t)):An(s,n,e,t)}function Ws(n,e,t){return[n(e,t),n("time",t)]}function Vs(n,e,t,r,s,i){const[o,a,c,u,l]=vn(n,e,t,r,s),d=$s(c,n(t,r),i);return[o,a,d,u,l]}function Qs(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 m,_,w;const y=!!(e.cardinalityInference&&((w=(_=(m=t.linkIndex)==null?void 0:m[r])==null?void 0:_[p])!=null&&w.isSingular));try{const[b,g,O]=Vs(n,t,r,s,p,u),T=Mn(e,t,{etype:b,level:g,form:i[p],join:O}),S=y?T[0]:T;return{[p]:S}}catch(b){if(b instanceof _e)return{[p]:y?void 0:[]};throw b}}).reduce(function(p,y){return{...p,...y}},l)}):Object.values(o)}function Bs(n,e,t){return t==="string"?Es(n,e):n>e?1:-1}function Me(n,e,t,r,s){return e===r||e==null&&r==null?Os(n,t):r==null?1:e==null?-1:Bs(e,r,s)}function Ke([n,e],[t,r],s){return Me(n,e,t,r,s)}function Tt(n){return n==null?n:new Date(n).getTime()}function Gs(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"?Tt(l):l,p=d==="date"?Tt(o):o;return Ke([u,f],[s,p],d)===c}function Hs(n,e){const t=e[1];return n.getAttr(t)}function Js(n,e,t){const r=Object.keys(t)[0];return R(n,e,r)}function Ys(n,e,t,r){if(t)return Hs(n,t);if(r)return Js(n,e,r)}function Zs(n,e,t){var s,i;if(!Array.isArray(t.fields))return as(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&&yt(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 Xs(n,e,{etype:t,pageInfo:r,dq:s,form:i}){var y,m;const o=(y=i==null?void 0:i.$)==null?void 0:y.order,a=En(i),c=ei(i);let u=gs(n,s);const l=r==null?void 0:r["start-cursor"],d=Ys(e,t,l,o);if(d&&((m=d==null?void 0:d["forward-identity"])==null?void 0:m[2])!=="id"){const _=d["checked-data-type"]==="date",w=d.id;u=u.map(([b])=>{var O,T,S,k,$;let g=($=(k=(S=(T=(O=n.eav.get(b))==null?void 0:O.get(w))==null?void 0:T.values())==null?void 0:S.next())==null?void 0:k.value)==null?void 0:$[2];return _&&(g=Tt(g)),[b,g]})}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=Zs(e,t,s);for(const _ of u){const[w]=_;if(f[w]||!a&&l&&d&&Gs(l,d,c,_))continue;const b=os(n,p,w);b&&(f[w]=b)}return f}function ei(n){var t;const e=(t=n.$)==null?void 0:t.order;return e&&e[Object.keys(e)[0]]||"asc"}function En(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 ti(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){var f,p,y,m,_;if(!En(s)&&(!o||!o["start-cursor"]))return[];const a=Ls(zs(e,t,r,(f=s.$)==null?void 0:f.where),i),c=Ws(qe,t,r),u=(p=s.$)==null?void 0:p.fields,l=Xs(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((y=s.$)==null?void 0:y.limit)||((m=s.$)==null?void 0:m.first)||((_=s.$)==null?void 0:_.last);if(d!=null){r>0&&Sn&&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 ni(n,e,t){try{return ti(n,e,t)}catch(r){if(r instanceof _e)return{};throw r}}function Mn(n,e,t){const r=ni(n,e,t);return Qs(qe,n,e,t,r)}function ri(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 St({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]=Mn(n,e,{etype:u,form:s[u],level:0,pageInfo:t==null?void 0:t[u]})),c},{})};return t&&(o.pageInfo=ri(t)),r&&(o.aggregate=r),o}function si(){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 ii=si();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(ii.has(i))return(o,a)=>ze(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Pn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function We(n){return n.startsWith("lookup__")}function At(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function oi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>ze(n,At(Pn(s,i)),[]);if(t==="__etype")return n;const r=t;return We(r)?ze(n,At(r),[]):ze(n,r,[])}})}function vt(){return new Proxy({},{get(n,e){return oi(e)}})}const ai=vt();function jn(n){return n.__ops}function ci(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 ui(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 li(n,e,t){return t.indexOf(".")!==-1&&!R(n,e,t)}function kt(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 di(n,e,t){if(!li(n,e,t))return R(n,e,t);const r=kt(t),s=R(n,e,r)||he(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Ot(n){return typeof n=="string"&&!We(n)?null:typeof n=="string"&&We(n)?At(n):ui(n)}function V(n,e,t){const r=Ot(t);if(r===null)return t;const[s,i]=r,o=di(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Dn(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 fi({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=he(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 Dn(n,e,t,s)}function hi({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=he(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 Dn(n,e,t,s)}function pi(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 $n({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:pi(n,e,t,r)?{mode:"update"}:null}function yi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(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=Ie(d)),["add-triple",c,f.id,d,{mode:"create"}]})}function bi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(i),c=V(t,r,s),u=$n(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=Ie(f)),["add-triple",c,p.id,f,...u?[u]:[]]})}function mi({attrsStore:n},[e,t]){return[["delete-entity",V(n,e,t),e]]}function gi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ft(i),c=V(t,r,s),u=$n(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 _i({attrsStore:n},[e,t,r]){return[["rule-params",V(n,e,t),e,r]]}function wi(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 Ti(n,e){const[t,...r]=wi(e);switch(t){case"merge":return gi(n,r);case"create":return yi(n,r);case"update":return bi(n,r);case"link":return fi(n,r);case"unlink":return hi(n,r);case"delete":return mi(n,r);case"ruleParams":return _i(n,r);default:throw new Error(`unsupported action ${t}`)}}function Si(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Ai(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=Si(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Ve(n,e,t,r){const s=n?Ai(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 vi(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 ki(n,e,t){const r=vi(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 Rn(n,e,t,r){const s=n?ki(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 Oi=new Set(["create","update","merge","link","unlink"]),Ii=new Set(["link","unlink"]),Ci=new Set(["create","update","merge"]),Ei=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),It={"unique?":!0,"index?":!0},Mi={...It,cardinality:"one"};function Pi(n){const e=[],[t,r,s,i]=n;if(!Ei.has(t))return e;const o=Ot(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=Ot(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function ji({attrsStore:n,schema:e},t){var f,p;const r=new Set,s=[],i=[];function o(y,m){return R(n,y,m)||s.find(_=>_["forward-identity"][1]===y&&_["forward-identity"][2]===m)}function a(y,m){return he(n,y,m)||s.find(_=>{var w,b;return((w=_["reverse-identity"])==null?void 0:w[1])===y&&((b=_["reverse-identity"])==null?void 0:b[2])===m})}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,m){return m.indexOf(".")!==-1&&!o(y,m)}function d(y,m){const _=o(y,m),w=a(y,m);u(_),u(w),!_&&!w&&c(Rn(e,y,m,Mi))}for(const y of t)for(const{etype:m,lookupPair:_,linkLabel:w}of Pi(y)){const b=_[0];if(w){d(m,w);const g=o(m,w),O=a(m,w);u(g),u(O);const T=((f=g==null?void 0:g["reverse-identity"])==null?void 0:f[1])||((p=O==null?void 0:O["forward-identity"])==null?void 0:p[1])||w;if(l(T,b))d(T,kt(b));else{const S=o(T,b);S||c(Ve(e,T,b,It)),u(S)}}else if(l(m,b))d(m,kt(b));else{const g=o(m,b);g||c(Ve(e,m,b,It)),u(g)}}for(const y of t){const[m,_,w,b]=y;if(Oi.has(m)){const g=o(_,"id");u(g),g||c(Ve(e,_,"id",{"unique?":!0}));for(const O of Object.keys(b)){const T=o(_,O);if(u(T),Ci.has(m)&&(T||c(Ve(e,_,O,O==="id"?{"unique?":!0}:null))),Ii.has(m)){const S=a(_,O);!T&&!S&&c(Rn(e,_,O)),u(S)}}}}if(s.length){const y={...n.attrs};for(const m of s)y[m.id]=m;return[new ce(y,n.linkIndex),i]}return[n,i]}function Di(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>jn(c)),[s,i]=ji(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Ti(o,c));return[...i,...a]}function xn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Pe="__meta";class Ct{constructor(e,t){}}class Et{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(Pe);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=[[Pe,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(Pe);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,m])=>p.updatedAt-m.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,m])=>p.updatedAt-m.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(()=>{xn(()=>{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(()=>{xn(()=>{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 $i=6,Ri=["kv","querySubs","syncSubs"];function xi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Ui(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 Li(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 m=typeof y=="string"?JSON.parse(y):y;if(m.lastAccessed){const w={createdAt:m.lastAccessed,updatedAt:m.lastAccessed,size:((f=(d=(l=m.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:f.length)??0};a[p]=w}const _=t.put(m,p);s.add(_)}const c={objects:a},u=t.put(c,Pe);s.add(u);for(const p of s)p.onsuccess=()=>{s.delete(p),s.size===0&&i()},p.onerror=y=>{o(y)}})}async function Un(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Fi(n,e){const t=await Ui(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,d)=>{const y=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();y.onerror=_=>{d(_)};const m=[];y.onsuccess=()=>{const _=y.result;if(_){const w=_.key,b=_.value;m.push([w,b]),_.continue()}else l(m)},y.onerror=_=>{d(_)}}),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=Li(l,d,o);a.push(f);break}default:{const f=Un(l,d,i);a.push(f);const p={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=p;break}}const u=Un(Pe,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 Ln=new Map;class Mt extends Ct{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}_${$i}`,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=Fi(this._appId,c).catch(l=>{xi("Error upgrading store from version 5 to 6.")(l)});Ln.set(this.dbName,u),u.then(()=>t(c)).catch(()=>t(c))}else{const u=Ln.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 Ri)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 Pt{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 je 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,je),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 je({status:t.status,body:r}))}function Ni({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 qi({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 Ki({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 zi({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 Fn({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 Wi({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 Vi({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 Qi({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 Bi({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 Gi({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 Hi(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function Ji({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 jt=!1,Nn=!1,qn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(jt=!!window.localStorage.getItem("devBackend"),Nn=!!window.localStorage.getItem("__instantLogging"),qn=!!window.localStorage.getItem("__devtoolLocalDash"));function Kn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function Yi(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Kn(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=Kn(n.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Zi(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!nn(n.user,e.user))||!tn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!nn(n.peers[r],e.peers[r]))return!0;return!1}class zn{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 Wn(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);Wn(t["child-nodes"],e)})}function Vn(n){const e=[];return Wn(n,e),e}function Dt(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 $t="v0.22.147";function Xi(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 Qn=["where","order","limit","last","first","offset","after","before","fields","aggregate"],eo=n=>n.valueType||"unknown",Bn=(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}},to=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!Bn(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)}},we=(n,e,t,r,s)=>{const i=eo(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))to(u,l,i,e,r,t,`${s}.${u}`)}else if(!Bn(n,i,o))throw new P(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},no=(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);we(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);we(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)}we(e,n,u,t,s)},Gn=(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&&Gn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){we(i,"id",new q("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){no(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)we(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);we(i,s,u,e,`${r}.${s}`)}}},ro=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Qn.includes(o))throw new P(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Qn.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);Gn(n.where,e,t,r?`${r}.where`:"where")}},Hn=(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&&Hn(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}.$`);ro(a,e,t,`${r}.$`,s)}},Rt=(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)}Hn(t[r],r,e,r,0)}}},Jn=n=>typeof n!="string"?!1:We(n)?!0:ge(n);class H extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Yn=n=>n.length>0?n.join(", "):"none",so=(n,e)=>new H(`Entity '${n}' does not exist in schema. Available entities: ${Yn(e)}`),xt={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},io=(n,e)=>{var t;return n==null?!0:((t=xt[e.valueType])==null?void 0:t.call(xt,n))??!1},Zn=(n,e)=>{const t=e.entities[n];if(!t)throw so(n,Object.keys(e.entities));return t},Ut=(n,e,t)=>{const r=Zn(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&&!io(i,o))throw new H(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},Xn=(n,e,t)=>{const r=Zn(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: ${Yn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Jn(a))throw new H(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Jn(i))throw new H(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},oo={create:Ut,update:Ut,merge:Ut,link:Xn,unlink:Xn,delete:()=>{}},ao=(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=oo[t];o&&i!==void 0&&o(r,i,e)},er=(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}`);ao(s,e)}}};let tr=0;class nr{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}_${tr++}`,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 rr{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}_${tr++}`,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 co(n,e){const t=n.values;if(t){const r=dn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=ln(r,s.store);t.attrsStore=r}}return n}function uo(n,e){var t;if(e.values){const r=[];for(const s of(t=e.values)==null?void 0:t.entities){const i=un(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function lo(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 Lt(n,e,t){return St({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function sr(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=be(e.eav,[r,s,r]);return i?i[3]:-1}function ir(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":pn(n,e,s);break;case"removed":fn(n,e,s);break}}function fo(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 ho(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 po(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return Me(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Me(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 Me(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Me(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var or=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(or||{});class yo{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 Et({persister:t,merge:lo,serialize:uo,parse:(a,c)=>co(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=E(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=E(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=Lt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:sr(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 _ of a.changes){const w=u[_.triple[0]]??[];u[_.triple[0]]=w,w.push(_)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const f=[];e:for(const[_,w]of Object.entries(u))for(let b=0;b<d.length;b++){const g=d[b];if(Yr(g.store,_)){ir(g.store,l.attrsStore,w);const O=Lt(s,g.store,l.attrsStore),T=fo(g.store,l.attrsStore,w)[_];O?(f.push({oldEntity:g.entity,newEntity:O,changedFields:T||{}}),g.entity=O):c.push(b),delete u[_];continue e}}const p=[];for(const[_,w]of Object.entries(u)){const b=this.createStore([]);ir(b,l.attrsStore,w);const g=Lt(s,b,l.attrsStore);if(!g){this.log.error("No entity found after applying change",{sub:s,changes:w,store:b});continue}d.push({store:b,entity:g,serverCreatedAt:sr(s,b,l.attrsStore,g.id)}),p.push(g)}const y=[];for(const _ of c.sort().reverse())y.push(d[_].entity),d.splice(_,1);const m=ho(s,this.getAttrs);po(s,m,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=E(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 bo({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=[],p=[];let y=!1,m=0,_=0;const w=[],b=new TextEncoder;function g(){l=!0;for(const v of d)v()}function O(v){return d.push(v),()=>{const C=d.indexOf(v);C!==-1&&d.splice(C,1)}}function T(v){return p.push(v),()=>{const C=p.indexOf(v);C!==-1&&p.splice(C,1)}}e.waitUntil&&e.waitUntil(new Promise(v=>{p.push(v)}));function S(){for(const v of p)try{v()}catch{}}function k(v){return f.push(v),()=>{const C=f.indexOf(v);C!==-1&&f.splice(C,1)}}function $(v){o=v;for(const C of f)C(o)}function x(){y=!0}function pe(v){let C=m,K=0,Q=0;for(const{byteLen:ee}of w){const ae=C+ee;if(ae>v)break;C=ae,K++,Q+=ee}K>0&&(m+=Q,_-=Q,w.splice(0,K))}function ie(v,C){g(),v.error(C),S()}async function oe(){const v=await t({clientId:i,reconnectToken:c,ruleParams:e.ruleParams});switch(v.type){case"ok":{const{streamId:C,offset:K}=v;o=C,pe(K),w.length&&r({streamId:C,chunks:w.map(Q=>Q.chunk),offset:m}),y=!1;break}case"disconnect":{x();break}case"error":{a&&ie(a,v.error);break}}}function X(){x(),oe()}function L({offset:v,done:C}){pe(v),C&&(u=!0,S())}function ue(v){return u?(ie(v,new N("Stream has been closed.")),null):o||(ie(v,new N("Stream has not been initialized.")),null)}async function Ye(v){a=v;let C=!0,K=0;for(;C;){let Q=Date.now()+Math.min(15e3,500*(K-1));C=!1;const ee=await t({clientId:e.clientId,reconnectToken:c,ruleParams:e.ruleParams});switch(ee.type){case"ok":{const{streamId:ae,offset:zt}=ee;if(zt!==0){const De=new N("Write stream is corrupted");ie(v,De);return}$(ae),s(ae,{onDisconnect:x,onFlush:L,onConnectionReconnect:oe,onAppendFailed:X}),y=!1;return}case"disconnect":{C=!0,x(),K++,await new Promise(ae=>{setTimeout(ae,Math.max(0,Q-Date.now()))});break}case"error":{ie(v,ee.error);return}}}}class Ze extends n{constructor(C,K){super(C,K)}async streamId(){return o||new Promise((C,K)=>{const Q=[],ee=()=>{for(const De of Q)De()},ae=De=>{C(De),ee()},zt=()=>{K(new N("Stream is closed.")),ee()};Q.push(k(ae)),Q.push(O(zt))})}}return{stream:new Ze({async start(v){try{await Ye(v)}catch(C){ie(v,C)}},write(v,C){const K=ue(C);if(K){const Q=b.encode(v).length;w.push({chunk:v,byteLen:Q});const ee=m+_;_+=Q,y||r({streamId:K,chunks:[v],offset:ee})}},close(){o?r({streamId:o,chunks:[],offset:m+_,isDone:!0}):S(),g()},abort(v){o?r({streamId:o,chunks:[],offset:m+_,isDone:!0,abortReason:v}):S(),g()}}),addCompleteCb:T,closed(){return l}}}class mo{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 go({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 g=l.indexOf(b);g!==-1&&l.splice(g,1)}}function p(b,g){b.error(g),d()}let y=0;async function m(b,g){c=j();const O={...b||{},eventId:c};for await(const T of t(O)){if(i)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){p(g,T.error);return}if(T.offset>s){p(g,new N("Stream is corrupted.")),i=!0;return}let S=s-T.offset;if(T.files&&T.files.length){const k=new AbortController;let $=fetch(T.files[0].url,{signal:k.signal});for(let x=0;x<T.files.length;x++){const pe=T.files[x+1],oe=await $;if(pe&&($=fetch(pe.url,{signal:k.signal})),!oe.ok){if(y++,y>10){p(g,new N("Unable to process stream."));return}return{retry:!0}}if(oe.body)for await(const X of oe.body){if(i){k.abort();return}let L=X;if(S>0&&(L=X.subarray(S),S-=X.length-L.length),!L.length)continue;s+=L.length;const ue=o.decode(L);g.enqueue(ue)}else{const X=await oe.arrayBuffer();let L=X;if(i){k.abort();return}if(S>0&&(L=new Uint8Array(X).subarray(S),S-=X.byteLength-L.length),!L.byteLength)continue;s+=L.byteLength;const ue=o.decode(L);g.enqueue(ue)}}}if(y=0,T.content){let k=T.content,$=a.encode(T.content);if(S>0){const x=$.subarray(S);if(S-=$.length-x.length,!x.length)continue;$=x,k=o.decode(x)}s+=$.length,g.enqueue(k)}}}async function _(b){let g=!0,O=0;for(;g;){g=!1;let T=Date.now()+Math.min(15e3,500*(O-1));const S=await m({...e,offset:s},b);S!=null&&S.retry&&(g=!0,O++,T<Date.now()-3e5&&(O=0),await new Promise(k=>{setTimeout(k,Math.max(0,T-Date.now()))}))}!i&&!u&&(b.close(),d())}return{stream:new n({start(b){_(b)},cancel(b){i=!0,c&&r({eventId:c}),d()}}),addCloseCb:f,closed(){return u}}}class ar{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,addCompleteCb:r}=bo({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}=go({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 e.ruleParams&&(i["rule-params"]=e.ruleParams),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,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new mo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}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"},_o=3e4,wo=3e4,To=200,So=1e3*60,Ao={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ft="_instant_oauth_redirect",Te="currentUser";function vo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new nr(`${r}?app_id=${e}`);switch(n){case"ws":return new nr(`${r}?app_id=${e}`);case"sse":return new rr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function ko(){return typeof window<"u"||typeof chrome<"u"}const cr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function Oo(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=dn(t.result.attrsStore,t.result.store);if(s){const i=t.result.store;t.result.store=ln(s,{...i,useDateObjects:e}),t.result.attrsStore=s}}return t}function Io(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:un(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Co(n,e){switch(n){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function Eo(n,e){switch(n){case"pendingMutations":return[...e.entries()];default:return e}}function Mo(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 Nt(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 ur{constructor(e,t=Mt,r=Pt,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=E(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||er(e,this.config.schema);try{const t=Di({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 zn;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={...Ao,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??wo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??To,this._log=Xi(e.verbose||jt||Nn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":$t},this.config.schema&&(this._linkIndex=Dt(this.config.schema)),!!ko()){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({forceReadFromStorage:!0});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 yo(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>me(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ar({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)},So),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?Dt(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 Et({persister:new e(this.config.appId,"querySubs"),merge:Mo,serialize:Io,parse:(t,r)=>Oo(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 Et({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:Eo,parse:Co,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(Te),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 je({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=E(e),i=this.ensureAttrs(),o=me(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(cr[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,m=(o=this._rooms[p])==null?void 0:o.roomType;this._tryJoinRoom(m,p,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(E(t.q));break}case"add-query-ok":{const{q:p,result:y}=t,m=E(p);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[m])break;const _=(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=Vn(y),g=this.ensureAttrs(),O=me(g,b,r,this.config.useDateObjects);this.querySubs.updateInPlace(T=>{if(!T[m]){this._log.info("Missing value in querySubs",{hash:m,q:p});return}T[m].result={store:O,attrsStore:g,pageInfo:_,aggregate:w,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(m),this.notifyOneQueryOnce(m),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,m=t["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const _=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),m);_!==this._pendingMutations()&&this.kv.updateInPlace(g=>{g.pendingMutations=_});const w=Nt(_.entries()),b=p.map(g=>{var L,ue,Ye,Ze;const O=g["instaql-query"],T=g["instaql-result"],S=E(O),k=Vn(T),$=this.ensureAttrs(),x=me($,k,r,this.config.useDateObjects),{store:pe,attrsStore:ie}=this._applyOptimisticUpdates(x,$,w,m),oe=(ue=(L=T==null?void 0:T[0])==null?void 0:L.data)==null?void 0:ue["page-info"],X=(Ze=(Ye=T==null?void 0:T[0])==null?void 0:Ye.data)==null?void 0:Ze.aggregate;return{q:O,hash:S,store:pe,attrsStore:ie,pageInfo:oe,aggregate:X}});b.forEach(({hash:g,q:O,store:T,attrsStore:S,pageInfo:k,aggregate:$})=>{this.querySubs.updateInPlace(x=>{if(!x[g]){this._log.error("Missing value in querySubs",{hash:g,q:O});return}x[g].result={store:T,attrsStore:S,pageInfo:k,aggregate:$,processedTxId:m}})}),this._cleanupPendingMutationsQueries(),b.forEach(({hash:g})=>{this.notifyOne(g)});break}case"transact-ok":{const{"client-event-id":p,"tx-id":y}=t;this._inFlightMutationEventIds.delete(p);const _=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(p);if(!_)break;this._updatePendingMutations(b=>{b.set(p,{...b.get(p),"tx-id":y,confirmed:Date.now()})});const w=[];for(const b of _["tx-steps"])if(b[0]==="add-attr"){const g=b[1];w.push(g)}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("Unknown 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=E(p);this.notifyQueryError(E(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 ce(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||Rt(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=E(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||Rt(e,this.config.schema),t&&"ruleParams"in t&&(e={$$ruleParams:t.ruleParams,...e});const r=new zn;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=E(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")),_o),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 he(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[_,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 g=i(w);if(g){o.attrIdMap[w.id]=g.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 m=a?ci(o,p):p;f.push(m)}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 Nt(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 ce({},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 ce(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:m}=u,_=this._rewriteMutationsSorted(f,a);if(t){const b=this._applyOptimisticUpdates(d,f,_,m);d=b.store,f=b.attrsStore}return{data:St({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=us(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}),Nt(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(cr[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=vo({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(Ft)){const t=e.toString();e.searchParams.delete(Ft),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(Ft))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 Fn({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??null}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[Te]=e}),await this.kv.waitForKeyToLoad(Te)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(e){e!=null&&e.forceReadFromStorage&&await this.kv.unloadKey(Te);const t=await this.kv.waitForKeyToLoad(Te);return typeof t=="string"?JSON.parse(t):t}async getCurrentUser(e){const t=await this._waitForOAuthCallbackResponse();if(t!=null&&t.error){const r={error:t.error,user:void 0};return this._currentUserCached={isLoading:!1,...r},this._currentUserCached}try{const s={user:await this._getCurrentUser(e),error:void 0};return this._currentUserCached={isLoading:!1,...s},this._currentUserCached}catch(r){return{user:void 0,isLoading:!1,error:{message:(r==null?void 0:r.message)||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(Te);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{await this.kv.flush(),(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 Ni({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode({email:e,code:t}){var o,a;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await qi({apiURI:this.config.apiURI,appId:this.config.appId,email:e,code:t,refreshToken:s?(a=r==null?void 0:r.user)==null?void 0:a.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}async signInWithCustomToken(e){const t=await Ki({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(t.user),t}async signInAsGuest(){const e=await zi({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}Vi({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,a;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await Fn({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:t,refreshToken:s?(a=r==null?void 0:r.user)==null?void 0:a.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 Wi({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:{...Yi(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&&!Zi(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"+":Pr(u,l,f);break;case"r":sn(u,l,f);break;case"-":on(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=>{sn(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,m;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:(m=(y=(p=this._presence[e])==null?void 0:p.result)==null?void 0:y.peers)==null?void 0:m[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 Qi({...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 Bi({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 Gi({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await Hi(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 Ji({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function Po(n,e){return new Be(lr(n,e),e,void 0)}function jo(n){return new Qe(n,{})}function Do(){return new q("string",!0,!1)}function $o(){return new q("number",!0,!1)}function Ro(){return new q("boolean",!0,!1)}function xo(){return new q("date",!0,!1)}function Uo(){return new q("json",!0,!1)}function Lo(){return new q("json",!0,!1)}function lr(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 Fo({entities:n,links:e,rooms:t}){const r=e??{},s=t??{};return new Be(lr(n,r),r,s)}const D={graph:Po,schema:Fo,entity:jo,string:Do,number:$o,boolean:Ro,date:xo,json:Uo,any:Lo};let He;function No(n,e){He==null||He.dispose();const t=Qo(e),r=zo(e,a),s=Ko(qo(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 qo(n){return`${jt||qn?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${n}`}function Ko(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 zo(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.147",
|
|
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.147"
|
|
57
57
|
},
|
|
58
58
|
"scripts": {
|
|
59
59
|
"test": "vitest",
|