@instantdb/core 0.22.166 → 0.22.167
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(v,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(v=typeof globalThis<"u"?globalThis:v||self,R(v.instant={}))})(this,(function(v){"use strict";function R(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=R(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];if(n[s]===void 0)continue;const i=R(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=R(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return R(String(n))}const U={Remove:"remove",Replace:"replace",Add:"add"},Vt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),kr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Le=Symbol.iterator,J={mutable:"mutable",immutable:"immutable"},et={};function Ie(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Qt(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 tt(n){return Object.getPrototypeOf(n)===Set.prototype}function nt(n){return Object.getPrototypeOf(n)===Map.prototype}function Y(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function fe(n){return!!k(n)}function k(n){return typeof n!="object"?null:n?.[Vt]}function rt(n){var e;const t=k(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function te(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?.mark&&((t=e.mark(n,J))===J.immutable||typeof t=="function")}function Bt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=k(ce(t,n.key));if(r!==null&&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||Ie(t,i)))return null;e.push(i)}if(n.parent)return Bt(n.parent,e);e.reverse();try{Or(n.copy,e)}catch{return null}return e}function he(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ce(n,e){return he(n)===2?n.get(e):n[e]}function Ce(n,e,t){he(n)===2?n.set(e,t):n[e]=t}function st(n,e){const t=k(n);return(t?Y(t):n)[e]}function ue(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function it(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function pe(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 Or(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ce(he(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Ir(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 Cr=Object.prototype.propertyIsEnumerable;function Gt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!tt(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(!nt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,J),t!==void 0)&&t!==J.mutable){if(t===J.immutable)return Ir(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=>{Cr.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 z(n){n.copy||(n.copy=Gt(n.original,n.options))}function Ee(n){if(!te(n))return rt(n);if(Array.isArray(n))return n.map(Ee);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ee(s)]);if(!nt(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(Ee);if(!tt(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]=Ee(n[t]);return e}function Ne(n){return fe(n)?Ee(n):n}function oe(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&oe(n.parent))}function Ht(){throw new Error("Cannot modify frozen object")}function ge(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)||fe(n)){r.pop(),s.pop();return}switch(he(n)){case 2:for(const[a,c]of n)ge(a,a,t,r,s),ge(c,a,t,r,s);n.set=n.clear=n.delete=Ht;break;case 3:for(const a of n)ge(a,a,t,r,s);n.add=n.clear=n.delete=Ht;break;case 1:Object.freeze(n);let o=0;for(const a of n)ge(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ge(c,a,t,r,s)})}r.pop(),s.pop()}function ot(n,e){const t=he(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 Jt(n,e,t){if(fe(n)||!te(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),ot(n,(i,o)=>{var a;if(fe(o)){const c=k(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ce(r?s:n,i,u)}else Jt(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 Er(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Jt(ce(t,e),n.finalities.handledSet,n.options)}function at(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(rt(e))}))}function ct(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Bt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ut(n,e,t,r){const s=k(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ue(ce(c,e),t)){let u=s.original;s.copy&&(u=s.copy),at(n),ct(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)),Ce(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),te(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ue(ce(i,e),t)&&Er(n,e)})}function Mr(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]),f=pe(l,s);t.push({op:U.Replace,path:f,value:Ne(c[u])}),r.push({op:U.Replace,path:f,value:Ne(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=pe(l,s);t.push({op:U.Add,path:f,value:Ne(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=pe(l,s);r.push({op:U.Replace,path:f,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const f=e.concat([l-1]),d=pe(f,s);r.push({op:U.Remove,path:d})}}}function Pr({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ce(n,c),l=Ne(ce(e,c)),f=a?Ie(n,c)?U.Replace:U.Add:U.Remove;if(ue(u,l)&&f===U.Replace)return;const d=r.concat(c),h=pe(d,o);s.push(f===U.Remove?{op:f,path:h}:{op:f,path:h,value:l}),i.push(f===U.Add?{op:U.Remove,path:h}:f===U.Remove?{op:U.Add,path:h,value:u}:{op:U.Replace,path:h,value:u})})}function jr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:U.Remove,path:u,value:a}),s.unshift({op:U.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:U.Add,path:u,value:a}),s.unshift({op:U.Remove,path:u,value:a})}o+=1})}function Me(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return Pr(n,e,t,r,s);case 1:return Mr(n,e,t,r,s);case 3:return jr(n,e,t,r,s)}}const Fe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!te(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},lt={get size(){return Y(k(this)).size},has(n){return Y(k(this)).has(n)},set(n,e){const t=k(this),r=Y(t);return(!r.has(n)||!ue(r.get(n),e))&&(z(t),oe(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ut(t,n,e,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);return z(e),oe(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=k(this);if(this.size){z(n),oe(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=k(this);Y(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=k(this),s=Y(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,J))===J.mutable;if(r.options.strict&&Fe(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(n))return s;const o=et.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Y(k(this)).keys()},values(){const n=this.keys();return{[Le]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Le]:()=>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]}}}},[Le](){return this.entries()}},$r=Reflect.ownKeys(lt),Yt=(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=k(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,J))===J.mutable;if(n.options.strict&&Fe(o,n.options,u),!u&&!c&&te(o,n.options)&&!n.finalized&&n.original.has(o)){const l=et.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]}},qe={get size(){return k(this).setMap.size},has(n){const e=k(this);if(e.setMap.has(n))return!0;z(e);const t=k(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=k(this);return this.has(n)||(z(e),oe(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ut(e,n,n,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);z(e),oe(e);const t=k(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=k(this);z(n),oe(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Yt(n,e,{isValuesIterator:!0})}},entries(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Yt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Le](){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(qe,{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 Rr=Reflect.ownKeys(qe),Zt=new WeakSet,Xt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Zt.has(i))return i;if(e===Vt)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,J),o===J.mutable)return n.options.strict&&Fe(u,n.options,!0),u}const a=Y(n);if(a instanceof Map&&$r.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(lt,"size").get.call(n.proxy);const u=lt[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Rr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(qe,"size").get.call(n.proxy);const u=qe[e];if(u)return u.bind(n.proxy)}if(!Ie(a,e)){const u=Qt(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&&Fe(c,n.options),n.finalized||!te(c,n.options))return c;if(c===st(n.original,e)){if(z(n),n.copy[e]=dt({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=k(n.copy[e]);return z(u),oe(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=Qt(Y(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=st(Y(n),e),a=k(o);return a&&ue(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):(ue(t,o)&&(t!==void 0||Ie(n.original,e))||(z(n),oe(n),Ie(n.original,e)&&ue(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ut(n,e,t,Me)),!0)},has(n,e){return e in Y(n)},ownKeys(n){return Reflect.ownKeys(Y(n))},getOwnPropertyDescriptor(n,e){const t=Y(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?Xt.set.call(this,n,e,void 0,n.proxy):(st(n.original,e)!==void 0||e in n.original?(z(n),oe(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 dt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=he(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,Xt);if(s.revoke.push(u),Zt.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=k(c);let g=l.type===3?l.setMap:l.copy;const y=ce(g,r),b=k(y);if(b){let _=b.original;b.operated&&(_=rt(y)),at(b),ct(b,Me,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(_,b.original)),Ce(g,r,_)}(p=m.callbacks)===null||p===void 0||p.forEach(_=>{_(f,d)})})}else{const l=k(c);l.finalities.draft.push((f,d)=>{at(l),ct(l,Me,f,d)})}return c}et.createDraft=dt;function Dr(n,e,t,r,s){var i;const o=k(n),a=(i=o?.original)!==null&&i!==void 0?i:n,c=!!e.length;if(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&&it(o),s&&ge(u,u,o?.options.updatedValues),[u,t&&c?[{op:U.Replace,path:[],value:e[0]}]:t,r&&c?[{op:U.Replace,path:[],value:a}]:r]}function Ur(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,J))===J.mutable||!te(n,e)?n:dt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Dr(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function ft(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;ot(t,(i,o,a)=>{const c=k(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(f=>a.add(i===f?u:f))}else Ce(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ft(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 en(n){var e;const t=k(n);if(!te(n,t?.options))return n;const r=he(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?nt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Gt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(ot(s,(o,a)=>{if(t&&ue(ce(t.original,o),a))return;const c=en(a);c!==a&&(s===n&&i(),Ce(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return tt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function tn(n){if(!fe(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return en(n)}const Ke=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(w,...M){return e(w,j=>t.call(this,j,...M),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 f=fe(c)?tn(c):c,d=Array.isArray(l.mark)?((w,M)=>{for(const j of l.mark){if(typeof j!="function")throw new Error(`Invalid mark: ${j}, 'mark' should be a function.`);const K=j(w,M);if(K)return K}}):l.mark,h=(i=l.enablePatches)!==null&&i!==void 0?i:!1,p=(o=l.strict)!==null&&o!==void 0?o:!1,g={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:d,strict:p,enablePatches:h};if(!te(f,g)&&typeof f=="object"&&f!==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[y,b]=Ur(f,g);if(typeof r!="function"){if(!te(f,g))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[y,b]}let _;try{_=u(y)}catch(w){throw it(k(y)),w}const P=w=>{const M=k(y);if(!fe(w)){if(w!==void 0&&!ue(w,y)&&M?.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 K=w?.[kr];if(K){const X=K[0];return g.strict&&typeof w=="object"&&w!==null&&ft({rootDraft:M,value:w,useRawReturn:!0}),b([X])}if(w!==void 0)return typeof w=="object"&&w!==null&&ft({rootDraft:M,value:w}),b([w])}if(w===y||w===void 0)return b([]);const j=k(w);if(g===j.options){if(j.operated)throw new Error("Cannot return a modified child draft.");return b([tn(w)])}return b([w])};return _ instanceof Promise?_.then(P,w=>{throw it(k(y)),w}):P(_)})();Object.prototype.constructor.toString();function nn(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 rn(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function ze(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:nn(n,e)?Object.keys(n).every(t=>ze(n[t],e[t])):!1}function ht(n){if(!Pe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function sn(n,e){if(!Pe(n)||!Pe(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=Pe(n[r])&&Pe(e[r]);t[r]=s?sn(n[r],e[r]):e[r]}return t}function Pe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function xr(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 on(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 an(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}an(n[t],r),Lr(n[t])&&delete n[t]}}function Lr(n){return n&&Object.keys(n).length===0}const cn=/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$/,Nr={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 Fr(n){return new Date(n)}function qr(n){return new Date(n+"Z")}const Kr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function zr(n){const e=n.match(Kr);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 Wr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Vr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Qr(n){return new Date(n)}function Br(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 Gr(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 Hr(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 Jr(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 Yr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Zr(n){const e=n.match(cn);if(!e)return null;const[t]=e,r=Nr[t],s=new Date(n.replace(cn,"Z"));return new Date(s.getTime()-r*1e3)}const Xr=[zr,Vr,Br,Jr,Qr,qr,Gr,Wr,Fr,Yr,Zr,Hr];function es(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function pt(n){for(const e of Xr){const t=es(e,n);if(t)return t}return null}function ts(n){try{const e=JSON.parse(n);return typeof e=="string"?pt(e):null}catch{return null}}function je(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=pt(n)||ts(n)||pt(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 de{attrs;linkIndex;_blobAttrs=null;_primaryKeys=null;_forwardIdents=null;_revIdents=null;constructor(e,t){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(bt(e)){const[t,r,s]=e["forward-identity"];Q(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"];Q(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;Q(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;Q(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function ns(n){return n.cardinality==="one"}function yt(n){return n["value-type"]==="ref"}function bt(n){return n["value-type"]==="blob"}function me(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function ne(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)&&ne(n.get(t),r)}function Q(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 un(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=je(u),o[2]=u),yt(l)&&Q(i,[u,c,a],o),Q(r,[a,c,u],o),Q(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function ln(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function dn(n,e){return we(n,e.triples,e.cardinalityInference,e.useDateObjects)}function fn(n,e){if(n)return new de(n.attrs,n.linkIndex);if(e&&"__type"in e)return new de(e.attrs,e.linkIndex)}function rs(n,e){return me(n.eav,[e])!==void 0}function we(n,e,t,r){const s=un(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function $e(n,e){let t;if(Array.isArray(e[0])){const[s,i]=e[0],o=n.aev.get(s);if(!o)return null;t=B(o,2).find(c=>c[2]===i)?.[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[s,i]=r,o=n.aev.get(s);if(!o)return null;const c=B(o,2).find(h=>h[2]===i)?.[0];if(!c)return null;const[u,l,f,...d]=e;return[t,l,c,...d]}else{const[s,...i]=e;return[t,...i]}}function hn(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(n.eav,[s,i,o]),ne(n.aev,[i,s,o]),yt(a)&&ne(n.vae,[o,i,s]))}let ss=0;function pn(n,e,t){const[r,s,i]=t;let o;const a=me(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+ss++}function yn(n,e,t){const r=$e(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=je(o));const u=me(n.eav,[s,i,o])?.[3]??pn(n,a,r),l=[s,i,o,u];ns(a)?(Q(n.eav,[s,i],new Map([[o,l]])),Q(n.aev,[i,s],new Map([[o,l]]))):(Q(n.eav,[s,i,o],l),Q(n.aev,[i,s,o],l)),yt(a)&&Q(n.vae,[o,i,s],l)}function is(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!bt(a))throw new Error("merge operation is not supported for links");const c=me(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=sn(l,o),d=[s,i,f,pn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function gt(n,e,t){const[r,s]=t,i=$e(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const u of a.keys()){const l=e.getAttr(u);l&&l["on-delete-reverse"]==="cascade"&&B(a.get(u),1).forEach(([f,d,h])=>gt(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(ne(n.aev,[u,o]),ne(n.eav,[o,u]))}a.size===0&&ne(n.eav,[o])}const c=n.vae.get(o)&&B(n.vae.get(o),2);c&&c.forEach(u=>{const[l,f,d]=u,h=e.getAttr(f);(!s||!h||h["reverse-identity"]?.[1]===s)&&(ne(n.eav,[l,f,d]),ne(n.aev,[f,l,d]),ne(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&>(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&ne(n.vae,[o])}function bn(n,e,t){const r=un(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function os(n,[e]){n.addAttr(e)}function gn(n){return B(n.eav,3)}function as(n,e,[t]){if(!e.getAttr(t))return;const r=gn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),bn(n,e,r)}function cs(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),bn(n,e,gn(n)))}function us(n,e,t){const[r,...s]=t;switch(r){case"add-triple":yn(n,e,s);break;case"deep-merge-triple":is(n,e,s);break;case"retract-triple":hn(n,e,s);break;case"delete-entity":gt(n,e,s);break;case"add-attr":os(e,s);break;case"delete-attr":as(n,e,s);break;case"update-attr":cs(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(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())B(r,e-1,t);return t}function We(n,e,t){const r=[];if(t?.hasOwnProperty("$not")){for(const i of e.keys())t.$not!==i&&r.push(e.get(i));return r}if(t?.hasOwnProperty("$isNull")){const{attrId:i,isNull:o,reverse:a}=t.$isNull;if(a)for(const c of e.keys()){const u=n.vae.get(c),l=!u||!u.get(i);(o?l:!l)&&r.push(e.get(c))}else{const c=n.aev.get(i);for(const u of e.keys()){const l=!c||c.get(u)?.get(null)||!c.get(u);(o?l:!l)&&r.push(e.get(u))}}return r}if(t?.$comparator)return B(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const i of s){const o=e.get(i);o&&r.push(o)}return r}function ls(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function ds(n,[e,t,r]){switch(ls(e,t,r)){case"e":{const i=n.eav.get(e);return B(i,2)}case"ea":{const i=n.eav.get(e)?.get(t);return B(i,1)}case"eav":{const i=n.eav.get(e)?.get(t);return i?We(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"a":{const i=n.aev.get(t);return B(i,2)}case"av":{const i=n.aev.get(t);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...We(n,a,r));return i}default:return B(n.eav,3)}}function fs(n,e,t){const r={};if(!e)return r;for(const[s,i]of e.entries()){const o=n.eav.get(t)?.get(i.id),a=B(o,1);for(const c of a)r[s]=c[2]}return r}function L(n,e,t){return n.forwardIdents.get(e)?.get(t)}function ye(n,e,t){return n.revIdents.get(e)?.get(t)}function hs(n,e){return n.blobAttrs.get(e)}function mn(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function ps(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return me(n.eav,[s,i])}function ys(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?.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const f=e.getAttr(o);if(f){const d=mn(e,f["forward-identity"][1]);l=!!ps(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Ke({store:n,attrsStore:e},s=>{r.forEach(i=>{us(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof de)return"immutable"}})}function bs(n){return typeof n=="string"&&n.startsWith("?")}function gs(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return _n(r,e,t)}return{...t,[n]:e}}function wn(n,e,t){return n===e?t:null}function ms(n){return typeof n==="string"&&n.startsWith("?")?gs:wn}const ws=["in","$in","$not","$isNull","$comparator"];function _s(n){for(const e of ws)if(n.hasOwnProperty(e))return!0;return!1}function _n(n,e,t){return t?typeof n=="object"?_s(n)?t:null:ms(n)(n,e,t):null}function Ss(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return _n(s,o,r)},t)}function Ts(n,e,t){return ks(n,e,t).map(r=>Ss(e,r,t)).filter(r=>r)}function vs(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=>Ts(n,e,r))}function mt(n,e,t=[{}]){return e.reduce((r,s)=>vs(n,s,r),t)}function wt(n,e){return Array.isArray(e)?e.map(t=>wt(n,t)):bs(e)?n[e]:e}function As(n,{find:e,where:t}){return mt(n,t).map(s=>wt(s,e))}function ks(n,e,t){return ds(n,wt(t,e))}const Os=/^(?:[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 _e(n){return typeof n=="string"&&Os.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function Is(n,e=0){return(F[n[e+0]]+F[n[e+1]]+F[n[e+2]]+F[n[e+3]]+"-"+F[n[e+4]]+F[n[e+5]]+"-"+F[n[e+6]]+F[n[e+7]]+"-"+F[n[e+8]]+F[n[e+9]]+"-"+F[n[e+10]]+F[n[e+11]]+F[n[e+12]]+F[n[e+13]]+F[n[e+14]]+F[n[e+15]]).toLowerCase()}let _t;const Cs=new Uint8Array(16);function Es(){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(Cs)}const Sn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ms(n,e,t){if(Sn.randomUUID&&!n)return Sn.randomUUID();n=n||{};const r=n.random??n.rng?.()??Es();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,Is(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 Ps(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 js(n,e){return Ps(Tn(n),Tn(e))}function $(){return Ms()}function $s(n,e){return n.localeCompare(e)}function Rs(){let n=$s;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Ds=Rs();let vn=!0;const Us=n=>{vn=n};let xs=0;function Re(n){return Ve(`_${n}`,xs++)}function Ve(n,e){return`?${n}-${e}`}class Se extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Ls(n,e){const t=mn(n,e);if(!t)throw new Se(`Could not find id attr for ${e}`);return t}function An(n,e,t,r){return[Ns(n,e,t,r)]}function Ns(n,e,t,r){return[n(t,r),Ls(e,t).id,n(t,r),n("time",r)]}function Fs(n,e,t){return n.map(r=>r===e?t:r)}function kn(n,e,t,r,s){const i=L(e,t,s),o=ye(e,t,s),a=i||o;if(!a)throw new Se(`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,f]=a["reverse-identity"],d=r+1,h=i?[n(u,r),a.id,n(f,d),Re("time")]:[n(u,d),a.id,n(f,r),Re("time")];return[i?f:u,d,h,a,!!i]}function On(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 qs(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=On(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=On(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Ks(n,e,t,r,s,i){const o=L(e,t,s),a=ye(e,t,s),c=o||a;if(!c)throw new Se(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Se(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Re("time")]}return o?[n(t,r),c.id,qs(c,i),Re("time")]:[i,c.id,n(t,r),Re("time")]}function zs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=kn(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function St(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=zs(n,e,t,r,o),f=Ks(n,e,c,u,a,i);return l.concat([f])}function Ws(n,e){return e?[e].concat(n):n}function Vs([n,e]){return n==="or"&&Array.isArray(e)}function Qs([n,e]){return n==="and"&&Array.isArray(e)}function Bs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function In(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Bs(n,o,u);return En(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Gs(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function Cn(n,e,t,r,s){return Gs(s).map(i=>St(n,e,t,r,i,{$isNull:!0}))}function En(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Vs([i,o]))return In(n,"or",e,t,r,o);if(Qs([i,o]))return In(n,"and",e,t,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o?.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o?.hasOwnProperty("$not")){const c=St(n,e,t,r,a,o),u=Cn(n,e,t,r,a);return[{or:{patterns:[c,...u],joinSym:n(t,r)}}]}return o?.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:Cn(n,e,t,r,a),joinSym:n(t,r)}}]:St(n,e,t,r,a,o)})}function Hs(n,e,t,r){const s=Ve;return r?En(s,n,e,t,r).concat(An(s,n,e,t)):An(s,n,e,t)}function Js(n,e,t){return[n(e,t),n("time",t)]}function Ys(n,e,t,r,s,i){const[o,a,c,u,l]=kn(n,e,t,r,s),f=Fs(c,n(t,r),i);return[o,a,f,u,l]}function Zs(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(h){const p=!!(e.cardinalityInference&&t.linkIndex?.[r]?.[h]?.isSingular);try{const[m,g,y]=Ys(n,t,r,s,h,u),b=jn(e,t,{etype:m,level:g,form:i[h],join:y}),_=p?b[0]:b;return{[h]:_}}catch(m){if(m instanceof Se)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function Xs(n,e,t){return t==="string"?Ds(n,e):n>e?1:-1}function De(n,e,t,r,s){return e===r||e==null&&r==null?js(n,t):r==null?1:e==null?-1:Xs(e,r,s)}function Qe([n,e],[t,r],s){return De(n,e,t,r,s)}function Tt(n){return n==null?n:new Date(n).getTime()}function Mn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Qe(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?Tt(c):c,f=u==="date"?Tt(i):i;return Qe([a,l],[r,f],u)}function ei(n,e,t,r){const s=Mn(n,e,r);return t==="desc"?s>0:s<0}function ti(n,e,t,r){const s=Mn(n,e,r);return t==="desc"?s<0:s>0}function ni(n,e){const t=e[1];return n.getAttr(t)}function ri(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function si(n,e,t,r){if(t)return ni(n,t);if(r)return ri(n,e,r)}function ii(n,e,t){if(!Array.isArray(t.fields))return hs(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&&bt(i)&&r.set(o,i)}if(!r.has("id")){const s=L(n,e,"id"),i=s?.["forward-identity"]?.[2];i&&r.set(i,s)}return r}function oi(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=Pn(i),c=ai(i);let u=As(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=si(e,t,l,o);if(d&&d?.["forward-identity"]?.[2]!=="id"){const m=d["checked-data-type"]==="date",g=d.id;u=u.map(([y])=>{let b=n.eav.get(y)?.get(g)?.values()?.next()?.value?.[2];return m&&(b=Tt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Qe(g,y,d?.["checked-data-type"])}:function(g,y){return Qe(y,g,d?.["checked-data-type"])});let h={};const p=ii(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ei(l,d,c,m)||f&&d&&ti(f,d,c,m))continue;const y=fs(n,p,g);y&&(h[g]=y)}return h}function ai(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function Pn(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function ci(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!Pn(s)&&(!o||!o["start-cursor"]))return[];const a=Ws(Hs(e,t,r,s.$?.where),i),c=Js(Ve,t,r),u=s.$?.fields,l=oi(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),f=s.$?.limit||s.$?.first||s.$?.last;if(f!=null){r>0&&vn&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const d=Object.entries(l);return d.length<=f?l:Object.fromEntries(d.slice(0,f))}return l}function ui(n,e,t){try{return ci(n,e,t)}catch(r){if(r instanceof Se)return{};throw r}}function jn(n,e,t){const r=ui(n,e,t);return Zs(Ve,n,e,t,r)}function li(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 vt({store:n,attrsStore:e,pageInfo:t,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r?.[u]||u==="$$ruleParams"||(c[u]=jn(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=li(t)),r&&(o.aggregate=r),o}function di(){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 fi=di();function Be(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(fi.has(i))return(o,a)=>Be(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function $n(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function Ge(n){return n.startsWith("lookup__")}function At(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function hi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Be(n,At($n(s,i)),[]);if(t==="__etype")return n;const r=t;return Ge(r)?Be(n,At(r),[]):Be(n,r,[])}})}function kt(){return new Proxy({},{get(n,e){return hi(e)}})}const pi=kt();function Rn(n){return n.__ops}function yi(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 bi(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 gi(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Ot(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 mi(n,e,t){if(!gi(n,e,t))return L(n,e,t);const r=Ot(t),s=L(n,e,r)||ye(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function It(n){return typeof n=="string"&&!Ge(n)?null:typeof n=="string"&&Ge(n)?At(n):bi(n)}function G(n,e,t){const r=It(t);if(r===null)return t;const[s,i]=r,o=mi(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){const s=G(n,e,t);return Array.isArray(s)?[["add-triple",s,L(n,e,"id")?.id,s]].concat(r):r}function wi({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["add-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["add-triple",G(n,u["forward-identity"][1],l),u?.id,G(n,e,t)])});return Dn(n,e,t,s)}function _i({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["retract-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["retract-triple",G(n,u["forward-identity"][1],l),u.id,G(n,e,t)])});return Dn(n,e,t,s)}function Si(n,e,t,r){if(Array.isArray(r)){const[s,i]=r;for(const o of n||[]){const a=o?.aev.get(s);if(a){for(const[c,u,l]of B(a,2))if(l===i)return!0}}}else for(const s of n||[]){const i=s?.eav.get(r);if(i){for(const o of i.keys())if(e.getAttr(o)?.["forward-identity"][1]==t)return!0}}return!1}function Un({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:Si(n,e,t,r)?{mode:"update"}:null}function Ti(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,f])=>{const d=L(t,r,l);return d["checked-data-type"]==="date"&&n.useDateObjects&&(f=je(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function vi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s),u=Un(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([f,d])=>{const h=L(t,r,f);return h["checked-data-type"]==="date"&&n.useDateObjects&&(d=je(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ai({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function ki(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s),u=Un(n,[r,c,i,o]),l=Object.entries(a).map(([d,h])=>{const p=L(t,r,d);return["deep-merge-triple",c,p.id,h,...u?[u]:[]]});return[["add-triple",c,L(t,r,"id").id,c,...u?[u]:[]]].concat(l)}function Oi({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function Ii(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 Ci(n,e){const[t,...r]=Ii(e);switch(t){case"merge":return ki(n,r);case"create":return Ti(n,r);case"update":return vi(n,r);case"link":return wi(n,r);case"unlink":return _i(n,r);case"delete":return Ai(n,r);case"ruleParams":return Oi(n,r);default:throw new Error(`unsupported action ${t}`)}}function Ei(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Mi(n,e,t){const r=n.entities[e]?.attrs?.[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?.config,o=Ei(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function He(n,e,t,r){const s=n?Mi(n,e,t):null,i=$(),a=[$(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function Pi(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 ji(n,e,t){const r=Pi(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":[$(),s.on,s.label],"reverse-identity":[$(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function xn(n,e,t,r){const s=n?ji(n,e,t):null,i=$(),o=[$(),e,t],a=[$(),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 $i=new Set(["create","update","merge","link","unlink"]),Ri=new Set(["link","unlink"]),Di=new Set(["create","update","merge"]),Ui=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Ct={"unique?":!0,"index?":!0},xi={...Ct,cardinality:"one"};function Li(n){const e=[],[t,r,s,i]=n;if(!Ui.has(t))return e;const o=It(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 f=It(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Ni({attrsStore:n,schema:e},t){const r=new Set,s=[],i=[];function o(d,h){return L(n,d,h)||s.find(p=>p["forward-identity"][1]===d&&p["forward-identity"][2]===h)}function a(d,h){return ye(n,d,h)||s.find(p=>p["reverse-identity"]?.[1]===d&&p["reverse-identity"]?.[2]===h)}function c(d){s.push(d),i.push(["add-attr",d]),r.add(d.id)}function u(d){d&&"isUnsynced"in d&&d.isUnsynced&&!r.has(d.id)&&(s.push(d),i.push(["add-attr",d]),r.add(d.id))}function l(d,h){return h.indexOf(".")!==-1&&!o(d,h)}function f(d,h){const p=o(d,h),m=a(d,h);u(p),u(m),!p&&!m&&c(xn(e,d,h,xi))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of Li(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const _=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(_,g))f(_,Ot(g));else{const P=o(_,g);P||c(He(e,_,g,Ct)),u(P)}}else if(l(h,g))f(h,Ot(g));else{const y=o(h,g);y||c(He(e,h,g,Ct)),u(y)}}for(const d of t){const[h,p,m,g]=d;if($i.has(h)){const y=o(p,"id");u(y),y||c(He(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const _=o(p,b);if(u(_),Di.has(h)&&(_||c(He(e,p,b,b==="id"?{"unique?":!0}:null))),Ri.has(h)){const P=a(p,b);!_&&!P&&c(xn(e,p,b)),u(P)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new de(d,n.linkIndex),i]}return[n,i]}function Fi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Rn(c)),[s,i]=Ni(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Ci(o,c));return[...i,...a]}function Ln(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Te="__meta";class Et{constructor(e,t){}}class Mt{currentValue;_subs=[];_persister;_merge;serialize;parse;_saveThrottleMs;_idleCallbackMaxWaitMs;_nextSave=null;_nextGc=null;_pendingSaveKeys=new Set;_loadedKeys=new Set;_loadingKeys;_objectSize;_log;onKeyLoaded;_version=0;_meta={isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0};_gcOpts;constructor(e){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(){this._meta.loadingPromise&&await this._meta.loadingPromise;try{const e=this._persister.getItem(Te);this._meta.loadingPromise=e;const t=await e;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const r=this._meta.value?.objects??{},s=t??{},i=s.objects??{};this._meta.value={...s,objects:{...r,...i}}}catch(e){this._meta.error=e,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?.skipGc;if(this._meta.isLoading){const f=new Promise((d,h)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(d).catch(h),10+(e?.attempts??0)*1e3)});return t.push(f),Promise.all(t).then(d=>d.reduce((h,p)=>h+p,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const f of this._pendingSaveKeys)f in this.currentValue?o.push(f):(i.push(f),delete s.objects[f]);for(const f of i){const d=this._persister.removeItem(f);t.push(d.then(()=>1)),this._loadedKeys.delete(f),this._pendingSaveKeys.delete(f)}const a=[],c=[[Te,s]],u=s.objects??{};s.objects=u;for(const f of o)if(this._loadedKeys.has(f)){const d=this.serialize(f,this.currentValue[f]);c.push([f,d]);const h=this._objectSize(d),p=u[f]??{createdAt:Date.now(),updatedAt:Date.now(),size:h};p.updatedAt=Date.now(),p.size=h,u[f]=p,this._pendingSaveKeys.delete(f)}else a.push(f);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const f of a){const d=this._loadKey(f).then(()=>this._enqueuePersist(e));t.push(d)}return r||this.gc(),Promise.all(t).then(f=>f.reduce((d,h)=>d+h,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(Te);const t=new Set(Object.keys(this.currentValue));for(const d of Object.keys(this._loadingKeys))t.add(d);for(const d of this._loadedKeys)t.add(d);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 d of e)t.has(d)||d in r.objects||(this._log.info("Lost track of key in meta",d),s.push(this._persister.removeItem(d)),i.removed.push(d),i.removedMissingCount++);const o=Date.now();for(const[d,h]of Object.entries(r.objects))!t.has(d)&&h.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const c=a.filter(([d])=>!t.has(d));if(a.length>this._gcOpts.maxEntries)for(const[d]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const l=u.filter(([d])=>!t.has(d));let f=u.reduce((d,[h,p])=>d+p.size,0);for(;f>0&&f>this._gcOpts.maxSize&&l.length;){const[[d,h]]=l.splice(0,1);f-=h.size,s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedSizeCount++}for(const d of Object.keys(r.objects))!e.has(d)&&!t.has(d)&&delete r.objects[d];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(()=>{Ln(()=>{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(()=>{Ln(()=>{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]=Ke(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)}}async clearUnloadedKeys(){let e=!1;for(const t of await this._persister.getAllKeys())t===Te||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const qi=6,Ki=["kv","querySubs","syncSubs"];function zi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Wi(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=>{r.target.transaction?.abort(),e(null)}})}async function Vi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{const a={};for(const[l,f]of Object.entries(r)){const d=typeof f=="string"?JSON.parse(f):f;if(d.lastAccessed){const p={createdAt:d.lastAccessed,updatedAt:d.lastAccessed,size:d.result?.store?.triples?.length??0};a[l]=p}const h=t.put(d,l);s.add(h)}const c={objects:a},u=t.put(c,Te);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Nn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Qi(n,e){const t=await Wi(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,f)=>{const p=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();p.onerror=g=>{f(g)};const m=[];p.onsuccess=()=>{const g=p.result;if(g){const y=g.key,b=g.value;m.push([y,b]),g.continue()}else l(m)},p.onerror=g=>{f(g)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,f]of r)if(l==="querySubs"){const d=Vi(l,f,o);a.push(d)}else{const d=Nn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Nn(Te,c,i);a.push(u),await Promise.all(a),await new Promise((l,f)=>{s.oncomplete=d=>l(d),s.onerror=d=>f(d),s.onabort=d=>f(d)})}const Fn=new Map;class Pt extends Et{dbName;_storeName;_appId;_prefix;_dbPromise;constructor(e,t){super(e,t),this.dbName=`instant_${e}_${qi}`,this._storeName=t,this._appId=e,this._dbPromise=this._init()}_init(){return new Promise((e,t)=>{let r=!1;const s=indexedDB.open(this.dbName,1);s.onerror=i=>{t(i)},s.onsuccess=i=>{const a=i.target.result;if(r){const c=Qi(this._appId,a).catch(u=>{zi("Error upgrading store from version 5 to 6.")(u)});Fn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=Fn.get(this.dbName);c?c.then(()=>e(a)).catch(()=>e(a)):e(a)}},s.onupgradeneeded=i=>{r=!0,this._upgradeStore(i)}})}_upgradeStore(e){const r=e.target.result;for(const s of Ki)r.objectStoreNames.contains(s)||r.createObjectStore(s)}async getItem(e){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readonly").objectStore(this._storeName).get(e);a.onerror=c=>{s(c)},a.onsuccess=c=>{a.result?r(a.result):r(null)}})}async setItem(e,t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(t,e);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async multiSet(e){const t=await this._dbPromise;return new Promise((r,s)=>{const i=t.transaction([this._storeName],"readwrite"),o=i.objectStore(this._storeName),a=new Set;for(const[c,u]of e){const l=o.put(u,c);a.add(l)}for(const c of a)c.onerror=u=>{i.abort(),s(u)},c.onsuccess=u=>{a.delete(c),a.size===0&&r()}})}async removeItem(e){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(e);a.onerror=c=>{s(c)},a.onsuccess=c=>{r()}})}async getAllKeys(){const e=await this._dbPromise;return new Promise((t,r)=>{const o=e.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();o.onerror=a=>{r(a)},o.onsuccess=a=>{t(o.result.filter(c=>typeof c=="string"))}})}}class jt{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 q extends Error{hint;traceId;constructor(e,t,r){super(e),this.hint=t,r&&(this.traceId=r);const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,q),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class ve extends q{body;status;constructor(e){const t=e.body?.message||`API Error (${e.status})`;super(t,e.body.hint,e.body["trace-id"]);const r=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,r),Error.captureStackTrace&&Error.captureStackTrace(this,ve),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new ve({status:t.status,body:r}))}function Bi({apiURI:n,appId:e,email:t}){return re(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Gi({apiURI:n,appId:e,email:t,code:r,refreshToken:s}){return await re(`${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 Hi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function Ji({apiURI:n,appId:e}){return await re(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function qn({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s}){return await re(`${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 Yi({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i}){return await re(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i})})}async function Zi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function Xi({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 re(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function eo({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function to({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${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 no(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function ro({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let $t=!1,Kn=!1,zn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&($t=!!window.localStorage.getItem("devBackend"),Kn=!!window.localStorage.getItem("__instantLogging"),zn=!!window.localStorage.getItem("__devtoolLocalDash"));function Wn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function so(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Wn(n.user??{},e?.keys);r.user={...i,peerId:t}}for(const i of Object.keys(n.peers??{})){const o=e?.peers===void 0,a=Array.isArray(e?.peers)&&e?.peers.includes(i);if(o||a){const c=Wn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function io(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!rn(n.user,e.user))||!nn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!rn(n.peers[r],e.peers[r]))return!0;return!1}class Vn{promise;_resolve;_reject;constructor(){this.promise=new Promise((e,t)=>{this._resolve=e,this._reject=t})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function Qn(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);Qn(t["child-nodes"],e)})}function Bn(n){const e=[];return Qn(n,e),e}function Rt(n){return Object.values(n.links).reduce((e,t)=>(e[t.forward.on]??={},e[t.forward.on][t.forward.label]={isForward:!0,isSingular:t.forward.has==="one",link:t},e[t.reverse.on]??={},e[t.reverse.on][t.reverse.label]={isForward:!1,isSingular:t.reverse.has==="one",link:t},e),{})}const Dt="v0.22.166";function oo(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 W{constructor(e,t,r,s={indexed:!1,unique:!1}){this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}metadata={};clientRequired(){return new W(this.valueType,!1,this.isIndexed,this.config)}optional(){return new W(this.valueType,!1,this.isIndexed,this.config)}unique(){return new W(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new W(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Je{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Je(this.attrs,this.links)}}class Ye{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ye(this.entities,this.links,{})}}class C extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Gn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ao=n=>n.valueType||"unknown",Hn=(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}},co=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!Hn(f,l,a))throw new C(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof f}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new C(`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 C(`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 C(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},Ae=(n,e,t,r,s)=>{const i=ao(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))co(u,l,i,e,r,t,`${s}.${u}`)}else if(!Hn(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},uo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new C(`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 f=i[l],d=r.entities[o];if(!d)throw new C(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const h=d.links[f];if(!h){const p=Object.keys(d.links);throw new C(`Link '${f}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${p.length>0?p.join(", "):"none"}`,s)}o=h.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new C(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new C(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Ae(e,n,u,t,s)},Jn=(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&&Jn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){Ae(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){uo(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 C(`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)Ae(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!_e(i))throw new C(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new W("string",!1,!0);Ae(i,s,u,e,`${r}.${s}`)}}},lo=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Gn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Gn.join(", ")}. Found: ${o}`,r);const i=["offset","before","beforeInclusive","after","afterInclusive","first","last"];for(const o of i)if(n[o]!==void 0&&s>0)throw new C(`'${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 C(`'where' clause must be an object in entity '${e}', but received: ${typeof n.where}`,r?`${r}.where`:void 0);Jn(n.where,e,t,r?`${r}.where`:"where")}},Yn=(n,e,t,r,s=0)=>{if(!n||typeof n!="object")throw new C(`Query part for entity '${e}' must be an object, but received: ${typeof n}`,r);for(const i of Object.keys(n))if(i!=="$"){if(t&&!(i in t.entities[e].links)){const a=Object.keys(t.entities[e].links);throw new C(`Link '${i}' does not exist on entity '${e}'. Available links: ${a.length>0?a.join(", "):"none"}`,`${r}.${i}`)}const o=n[i];if(typeof o=="object"&&o!==null){const a=t?.entities[e].links[i]?.entityName;a&&Yn(o,a,t,`${r}.${i}`,s+1)}}else{const o=n[i];if(typeof o!="object"||o===null)throw new C(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof o}`,`${r}.$`);lo(o,e,t,`${r}.$`,s)}},Ut=(n,e)=>{if(typeof n!="object"||n===null)throw new C(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new C(`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 C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new C(`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 C(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Yn(t[r],r,e,r,0)}}},Zn=n=>typeof n!="string"?!1:Ge(n)?!0:_e(n);class Z extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Xn=n=>n.length>0?n.join(", "):"none",fo=(n,e)=>new Z(`Entity '${n}' does not exist in schema. Available entities: ${Xn(e)}`),ho={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},po=(n,e)=>n==null?!0:ho[e.valueType]?.(n)??!1,er=(n,e)=>{const t=e.entities[n];if(!t)throw fo(n,Object.keys(e.entities));return t},xt=(n,e,t)=>{const r=er(n,t);if(typeof e!="object"||e===null)throw new Z(`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&&!po(i,o))throw new Z(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},tr=(n,e,t)=>{const r=er(n,t);if(typeof e!="object"||e===null)throw new Z(`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 Z(`Link '${s}' does not exist on entity '${n}'. Available links: ${Xn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Zn(a))throw new Z(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Zn(i))throw new Z(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},yo={create:xt,update:xt,merge:xt,link:tr,unlink:tr,delete:()=>{}},bo=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!_e(s))throw new Z(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new Z(`Entity name must be a string, but received: ${typeof r}`);const o=yo[t];o&&i!==void 0&&o(r,i,e)},nr=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new Z(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new Z(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new Z(`Transaction operation must be an array, but received: ${typeof s}`);bo(s,e)}}};let rr=0;class sr{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${rr++}`,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 ir{type="sse";initParams=null;sendQueue=[];sendPromise;closeFired=!1;sseInitTimeout=void 0;ES;messageUrl;conn;url;id;onopen;onmessage;onclose;onerror;constructor(e,t,r){this.id=`${this.type}_${rr++}`,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){try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:this.initParams?.machineId,session_id:this.initParams?.sessionId,sse_token:this.initParams?.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 go(n,e){const t=n.values;if(t){const r=fn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=dn(r,s.store);t.attrsStore=r}}return n}function mo(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=ln(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function wo(n,e,t){const r=e?.state?.txId,s=t?.state?.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?t:e||t}function Lt(n,e,t){return vt({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function or(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=me(e.eav,[r,s,r]);return i?i[3]:-1}function ar(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":yn(n,e,s);break;case"removed":hn(n,e,s);break}}function _o(n,e,t){const r={};for(const{action:s,triple:i}of t){const[o,a,c]=i,u=e.getAttr(a)?.["forward-identity"]?.[2];if(!u)continue;const l=r[o]??{};r[o]=l;const f=l[u]??{};switch(s){case"added":f.newValue=c;break;case"removed":f.oldValue===void 0&&(f.oldValue=c);break}l[u]=f}for(const[s,i]of Object.entries(r))for(const[o,{oldValue:a,newValue:c}]of Object.entries(i))a===c&&delete i[o];return r}function Ze(n,e){return{[n.table]:e.map(t=>t.entity)}}function So(n,e){if(n.orderFieldType)return n.orderFieldType;const t=n.orderField==="serverCreatedAt"?"number":L(e(),n.table,n.orderField)?.["checked-data-type"];return n.orderFieldType=t,t}function To(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return De(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 De(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return De(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var cr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(cr||{});class vo{trySend;subs;callbacks={};config;idToHash={};log;createStore;getAttrs;constructor(e,t,r,s,i,o){this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new Mt({persister:t,merge:wo,serialize:mo,parse:(a,c)=>go(c,this.config.useDateObjects),objectSize:a=>a.values?.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=R(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,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?.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend($(),{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($(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){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),s.values?.entities&&r&&r({type:"LoadFromStorage",data:Ze(s,s.values?.entities)});return}const i=Object.keys(e)[0],o=e[i]?.$?.order||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(u=>{u[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=R(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),f=Lt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:or(o,l,a.attrsStore,f.id)}),i.push(f)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ze(o,o.values.entities),batch:i})}onSyncInitFinish(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(i=>{const o=i[r];if(!o){this.log.error("Missing sub for hash",r,e);return}const a=o.state;if(!a)return this.log.error("Sub never set init, missing result",o,e),i;a.txId=e["tx-id"],o.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ze(s,s.values?.entities||[])})}onSyncUpdateTriples(e){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 o of e.txes){if(i.txId&&i.txId>=o["tx-id"])continue;i.txId=o["tx-id"];const a=[],c={};for(const m of o.changes){const g=c[m.triple[0]]??[];c[m.triple[0]]=g,g.push(m)}const u=s.values??{entities:[],attrsStore:this.getAttrs()},l=u.entities;s.values=u;const f=[];e:for(const[m,g]of Object.entries(c))for(let y=0;y<l.length;y++){const b=l[y];if(rs(b.store,m)){ar(b.store,u.attrsStore,g);const _=Lt(s,b.store,u.attrsStore),P=_o(b.store,u.attrsStore,g)[m];_?(f.push({oldEntity:b.entity,newEntity:_,changedFields:P||{}}),b.entity=_):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);ar(y,u.attrsStore,g);const b=Lt(s,y,u.attrsStore);if(!b){this.log.error("No entity found after applying change",{sub:s,changes:g,store:y});continue}l.push({store:y,entity:b,serverCreatedAt:or(s,y,u.attrsStore,b.id)}),d.push(b)}const h=[];for(const m of a.sort().reverse())h.push(l[m].entity),l.splice(m,1);const p=So(s,this.getAttrs);To(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Ze(s,s.values?.entities),added:d,removed:h,updated:f})}this.subs.updateInPlace(o=>{o[r]=s,o[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=R(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 Ao({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=$();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],_=new TextEncoder;function P(){f=!0;for(const S of d)S(a??void 0)}function w(S){return d.push(S),f&&S(a??void 0),()=>{const O=d.indexOf(S);O!==-1&&d.splice(O,1)}}function M(S){return p.push(S),()=>{const O=p.indexOf(S);O!==-1&&p.splice(O,1)}}e.waitUntil&&e.waitUntil(new Promise(S=>{p.push(S)}));function j(){for(const S of p)try{S()}catch{}}function K(S){return h.push(S),o&&S(o),()=>{const O=h.indexOf(S);O!==-1&&h.splice(O,1)}}function X(S){o=S;for(const O of h)O(o)}function T(){m=!0}function E(S){let O=g,V=0,H=0;for(const{byteLen:ie}of b){const le=O+ie;if(le>S)break;O=le,V++,H+=ie}V>0&&(g+=H,y-=H,b.splice(0,V))}function A(S,O){a=O,P(),S.error(O),j()}async function I(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:O,offset:V}=S;o=O,E(V),b.length&&r({streamId:O,chunks:b.map(H=>H.chunk),offset:g}),m=!1;break}case"disconnect":{T();break}case"error":{c&&A(c,S.error);break}}}function N(){T(),I()}function x({offset:S,done:O}){E(S),O&&(l=!0,j())}function ee(S){return l?(A(S,new q("Stream has been closed.")),null):o||(A(S,new q("Stream has not been initialized.")),null)}async function se(S){c=S;let O=!0,V=0;for(;O;){let H=Date.now()+Math.min(15e3,500*(V-1));O=!1;const ie=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(ie.type){case"ok":{const{streamId:le,offset:Wt}=ie;if(Wt!==0){const be=new q("Write stream is corrupted");A(S,be);return}X(le),s(le,{onDisconnect:T,onFlush:x,onConnectionReconnect:I,onAppendFailed:N}),m=!1;return}case"disconnect":{O=!0,T(),V++,await new Promise(le=>{setTimeout(le,Math.max(0,H-Date.now()))});break}case"error":{A(S,ie.error);return}}}}class ma extends n{constructor(O,V){super(O,V)}async streamId(){return o||new Promise((O,V)=>{const H=[],ie=()=>{for(const be of H)be()},le=be=>{O(be),ie()},Wt=be=>{V(be||new q("Stream is closed.")),ie()};H.push(K(le)),H.push(w(Wt))})}}return{stream:new ma({async start(S){try{await se(S)}catch(O){A(S,O)}},write(S,O){const V=ee(O);if(V){const H=_.encode(S).length;b.push({chunk:S,byteLen:H});const ie=g+y;y+=H,m||r({streamId:V,chunks:[S],offset:ie})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):j(),P()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):j(),P()}}),addCompleteCb:M,closed(){return f}}}class ko{items=[];resolvers=[];isClosed=!1;constructor(){}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 Oo({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 f(){u=!0;for(const b of l)b()}function d(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function h(b,_){b.error(_),f()}let p=0;async function m(b,_){c=$();const P={...b||{},eventId:c};for await(const w of t(P)){if(i)return;if(w.type==="reconnect")return{retry:!0};if(w.type==="error"){h(_,w.error);return}if(w.offset>s){h(_,new q("Stream is corrupted.")),i=!0;return}let M=s-w.offset;if(w.files&&w.files.length){const j=new AbortController;let K=fetch(w.files[0].url,{signal:j.signal});for(let X=0;X<w.files.length;X++){const T=w.files[X+1],A=await K;if(T&&(K=fetch(T.url,{signal:j.signal})),!A.ok){if(p++,p>10){h(_,new q("Unable to process stream."));return}return{retry:!0}}if(A.body){const I=A.body.getReader();try{for(;;){const{done:N,value:x}=await I.read();if(N)break;if(i){j.abort();return}let ee=x;if(M>0&&(ee=x.subarray(M),M-=x.length-ee.length),!ee.length)continue;s+=ee.length;const se=o.decode(ee);_.enqueue(se)}}finally{I.releaseLock()}}else{const I=await A.arrayBuffer();let N=I;if(i){j.abort();return}if(M>0&&(N=new Uint8Array(I).subarray(M),M-=I.byteLength-N.length),!N.byteLength)continue;s+=N.byteLength;const x=o.decode(N);_.enqueue(x)}}}if(p=0,w.content){let j=w.content,K=a.encode(w.content);if(M>0){const X=K.subarray(M);if(M-=K.length-X.length,!X.length)continue;K=X,j=o.decode(X)}s+=K.length,_.enqueue(j)}}}async function g(b){let _=!0,P=0;for(;_;){_=!1;let w=Date.now()+Math.min(15e3,500*(P-1));(await m({...e,offset:s},b))?.retry&&(_=!0,P++,w<Date.now()-3e5&&(P=0),await new Promise(j=>{setTimeout(j,Math.max(0,w-Date.now()))}))}!i&&!u&&(b.close(),f())}return{stream:new n({start(b){g(b)},cancel(b){i=!0,c&&r({eventId:c}),f()}}),addCloseCb:d,closed(){return u}}}class ur{trySend;WStream;RStream;writeStreams={};startWriteStreamCbs={};readStreamIterators={};log;activeStreams=new Set;constructor({WStream:e,RStream:t,trySend:r,log:s}){this.WStream=e,this.RStream=t,this.trySend=r,this.log=s}createWriteStream(e){const{stream:t,addCompleteCb:r}=Ao({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}=Oo({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=$();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($(),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 ko;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend($(),t),delete this.readStreamIterators[e]}onStreamAppend(e){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 q(e.error)}),r.close(),delete this.readStreamIterators[t];return}(e.files?.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!==ae.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"];this.writeStreams[r]?.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new q(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 q(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const ae={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},Io=3e4,Co=3e4,Eo=200,Mo=1e3*60,Po={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Nt="_instant_oauth_redirect",ke="currentUser";function jo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new sr(`${r}?app_id=${e}`);switch(n){case"ws":return new sr(`${r}?app_id=${e}`);case"sse":return new ir(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function $o(){return typeof window<"u"||typeof chrome<"u"}const lr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function Ro(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=fn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=dn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Do(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:ln(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Uo(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function xo(n,e){return n==="pendingMutations"?[...e.entries()]:e}function Lo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function Ft(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 dr{attrs;_isOnline=!0;_isShutdown=!1;status=ae.CONNECTING;querySubs;kv;_syncTable;_instantStream;queryCbs={};queryOnceDfds={};authCbs=[];attrsCbs=[];mutationErrorCbs=[];connectionStatusCbs=[];config;mutationDeferredStore=new Map;_reconnectTimeoutId=null;_reconnectTimeoutMs=0;_transport;_transportType="ws";_EventSource;_wsOk=null;_localIdPromises={};_errorMessage=null;_oauthCallbackResponse=null;_linkIndex=null;_broadcastChannel;_rooms={};_roomsPendingLeave={};_presence={};_broadcastQueue=[];_broadcastSubs={};_currentUserCached={isLoading:!0,error:void 0,user:void 0};_beforeUnloadCbs=[];_dataForQueryCache={};_log;_pendingTxCleanupTimeout;_pendingMutationCleanupThreshold;_inFlightMutationEventIds=new Set;_frameworkClient=null;constructor(e,t=Pt,r=jt,s,i){if(this._EventSource=i,this.config={...Po,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??Co,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Eo,this._log=oo(e.verbose||$t||Kn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":Dt},this.config.schema&&(this._linkIndex=Rt(this.config.schema)),!!$o()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!_e(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=>{try{if(o.data?.type==="auth"){const a=await this.getCurrentUser({forceReadFromStorage:!0});await this.updateUser(a.user).catch(c=>{this._log.error("[error] update user",c)})}}catch(a){this._log.error("[error] handle broadcast channel",a)}})),this._initStorage(t),this._syncTable=new vo(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>we(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ur({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)},Mo),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",ae.CLOSED),this._setStatus(ae.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}getFrameworkClient(){return this._frameworkClient}setFrameworkClient(e){this._frameworkClient=e}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?Rt(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 Mt({persister:new e(this.config.appId,"querySubs"),merge:Lo,serialize:Do,parse:(t,r)=>Ro(r,this.config.useDateObjects),objectSize:t=>t?.result?.store?.triples?.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 Mt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:xo,parse:Uo,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(ke),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?.type){const{status:o,...a}=r;s.reject(new ve({body:a,status:o??0}))}else s.reject(new q(r?.message||"Unknown error",r?.hint))}_setStatus(e,t){this.status=e,this._errorMessage=t,this.notifyConnectionStatusSubs(e),this._instantStream.onConnectionStatusChange(e)}_onMergeKv=(e,t,r)=>{if(e==="pendingMutations"){const s=t?.entries()??[],i=r?.entries()??[],o=new Map([...s,...i]);return(t?this._rewriteMutationsSorted(this.attrs,t):[]).forEach(([c,u])=>{!r?.pendingMutations?.has(c)&&!u["tx-id"]&&this._sendMutation(c,u)}),o}else return r||t};_flushEnqueuedRoomData(e){const t=this._presence[e]?.result?.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],t&&this._trySetPresence(e,t),r)for(const s of r){const{topic:i,roomType:o,data:a}=s;this._tryBroadcast(e,o,i,a)}}_addQueryData(e,t,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=R(e),i=this.ensureAttrs(),o=we(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){const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(lr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ae.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const o of Object.keys(this._rooms)){const a=this._presence[o]?.result?.user,c=this._rooms[o]?.roomType;this._tryJoinRoom(c,o,a)}break}case"add-query-exists":{this.notifyOneQueryOnce(R(t.q));break}case"add-query-ok":{const{q:o,result:a}=t,c=R(o);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[c])break;const u=a?.[0]?.data?.["page-info"],l=a?.[0]?.data?.aggregate,f=Bn(a),d=this.ensureAttrs(),h=we(d,f,r,this.config.useDateObjects);this.querySubs.updateInPlace(p=>{if(!p[c]){this._log.info("Missing value in querySubs",{hash:c,q:o});return}p[c].result={store:h,attrsStore:d,pageInfo:u,aggregate:l,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(c),this.notifyOneQueryOnce(c),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:o,attrs:a}=t,c=t["processed-tx-id"];a&&this._setAttrs(a),this._cleanupPendingMutationsTimeout();const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),c);u!==this._pendingMutations()&&this.kv.updateInPlace(d=>{d.pendingMutations=u});const l=Ft(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Bn(p),y=this.ensureAttrs(),b=we(y,g,r,this.config.useDateObjects),{store:_,attrsStore:P}=this._applyOptimisticUpdates(b,y,l,c),w=p?.[0]?.data?.["page-info"],M=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:_,attrsStore:P,pageInfo:w,aggregate:M}});f.forEach(({hash:d,q:h,store:p,attrsStore:m,pageInfo:g,aggregate:y})=>{this.querySubs.updateInPlace(b=>{if(!b[d]){this._log.error("Missing value in querySubs",{hash:d,q:h});return}b[d].result={store:p,attrsStore:m,pageInfo:g,aggregate:y,processedTxId:c}})}),this._cleanupPendingMutationsQueries(),f.forEach(({hash:d})=>{this.notifyOne(d)});break}case"transact-ok":{const{"client-event-id":o,"tx-id":a}=t;this._inFlightMutationEventIds.delete(o);const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(o);if(!u)break;this._updatePendingMutations(f=>{f.set(o,{...f.get(o),"tx-id":a,confirmed:Date.now()})});const l=[];for(const f of u["tx-steps"])if(f[0]==="add-attr"){const d=f[1];l.push(d)}if(l.length){const f=Object.values(this.ensureAttrs().attrs);this._setAttrs([...f,...l])}this._finishTransaction("synced",o),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._patchPresencePeers(o,t.edits),this._notifyPresenceSubs(o);break}case"refresh-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._setPresencePeers(o,t.data),this._notifyPresenceSubs(o);break}case"server-broadcast":{const o=t["room-id"],a=t.topic;this._trySetRoomConnected(o,!0),this._notifyBroadcastSubs(o,a,t);break}case"join-room-ok":{const o=t["room-id"];if(!this._rooms[o]){this._roomsPendingLeave[o]&&(this._tryLeaveRoom(o),delete this._roomsPendingLeave[o]);break}this._trySetRoomConnected(o,!0),this._flushEnqueuedRoomData(o);break}case"leave-room-ok":{const o=t["room-id"];this._trySetRoomConnected(o,!1);break}case"join-room-error":const s=t["room-id"],i=this._rooms[s];i&&(i.error=t.error),this._notifyPresenceSubs(s);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){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(e["original-event"]?.hasOwnProperty("q")&&e["original-event"]?.op==="add-query"){const a=e["original-event"]?.q,c=R(a);this.notifyQueryError(R(a),s),this.notifyQueryOnceError(a,c,t,s);return}if(e["original-event"]?.op==="init"){if(e.type==="record-not-found"&&e.hint?.["record-type"]==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ae.ERRORED,s),this.notifyAll();return}switch(e["original-event"]?.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(v,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(v=typeof globalThis<"u"?globalThis:v||self,R(v.instant={}))})(this,(function(v){"use strict";function R(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=R(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];if(n[s]===void 0)continue;const i=R(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=R(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return R(String(n))}const U={Remove:"remove",Replace:"replace",Add:"add"},Vt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),kr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Le=Symbol.iterator,J={mutable:"mutable",immutable:"immutable"},et={};function Ie(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Qt(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 tt(n){return Object.getPrototypeOf(n)===Set.prototype}function nt(n){return Object.getPrototypeOf(n)===Map.prototype}function Y(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function fe(n){return!!k(n)}function k(n){return typeof n!="object"?null:n?.[Vt]}function rt(n){var e;const t=k(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function te(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?.mark&&((t=e.mark(n,J))===J.immutable||typeof t=="function")}function Bt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=k(ce(t,n.key));if(r!==null&&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||Ie(t,i)))return null;e.push(i)}if(n.parent)return Bt(n.parent,e);e.reverse();try{Or(n.copy,e)}catch{return null}return e}function he(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ce(n,e){return he(n)===2?n.get(e):n[e]}function Ce(n,e,t){he(n)===2?n.set(e,t):n[e]=t}function st(n,e){const t=k(n);return(t?Y(t):n)[e]}function ue(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function it(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function pe(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 Or(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ce(he(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Ir(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 Cr=Object.prototype.propertyIsEnumerable;function Gt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!tt(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(!nt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,J),t!==void 0)&&t!==J.mutable){if(t===J.immutable)return Ir(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=>{Cr.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 z(n){n.copy||(n.copy=Gt(n.original,n.options))}function Ee(n){if(!te(n))return rt(n);if(Array.isArray(n))return n.map(Ee);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ee(s)]);if(!nt(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(Ee);if(!tt(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]=Ee(n[t]);return e}function Ne(n){return fe(n)?Ee(n):n}function oe(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&oe(n.parent))}function Ht(){throw new Error("Cannot modify frozen object")}function ge(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)||fe(n)){r.pop(),s.pop();return}switch(he(n)){case 2:for(const[a,c]of n)ge(a,a,t,r,s),ge(c,a,t,r,s);n.set=n.clear=n.delete=Ht;break;case 3:for(const a of n)ge(a,a,t,r,s);n.add=n.clear=n.delete=Ht;break;case 1:Object.freeze(n);let o=0;for(const a of n)ge(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ge(c,a,t,r,s)})}r.pop(),s.pop()}function ot(n,e){const t=he(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 Jt(n,e,t){if(fe(n)||!te(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),ot(n,(i,o)=>{var a;if(fe(o)){const c=k(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ce(r?s:n,i,u)}else Jt(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 Er(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Jt(ce(t,e),n.finalities.handledSet,n.options)}function at(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(rt(e))}))}function ct(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Bt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ut(n,e,t,r){const s=k(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ue(ce(c,e),t)){let u=s.original;s.copy&&(u=s.copy),at(n),ct(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)),Ce(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),te(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ue(ce(i,e),t)&&Er(n,e)})}function Mr(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]),f=pe(l,s);t.push({op:U.Replace,path:f,value:Ne(c[u])}),r.push({op:U.Replace,path:f,value:Ne(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=pe(l,s);t.push({op:U.Add,path:f,value:Ne(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=pe(l,s);r.push({op:U.Replace,path:f,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const f=e.concat([l-1]),d=pe(f,s);r.push({op:U.Remove,path:d})}}}function Pr({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ce(n,c),l=Ne(ce(e,c)),f=a?Ie(n,c)?U.Replace:U.Add:U.Remove;if(ue(u,l)&&f===U.Replace)return;const d=r.concat(c),h=pe(d,o);s.push(f===U.Remove?{op:f,path:h}:{op:f,path:h,value:l}),i.push(f===U.Add?{op:U.Remove,path:h}:f===U.Remove?{op:U.Add,path:h,value:u}:{op:U.Replace,path:h,value:u})})}function jr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:U.Remove,path:u,value:a}),s.unshift({op:U.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:U.Add,path:u,value:a}),s.unshift({op:U.Remove,path:u,value:a})}o+=1})}function Me(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return Pr(n,e,t,r,s);case 1:return Mr(n,e,t,r,s);case 3:return jr(n,e,t,r,s)}}const Fe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!te(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},lt={get size(){return Y(k(this)).size},has(n){return Y(k(this)).has(n)},set(n,e){const t=k(this),r=Y(t);return(!r.has(n)||!ue(r.get(n),e))&&(z(t),oe(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ut(t,n,e,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);return z(e),oe(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=k(this);if(this.size){z(n),oe(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=k(this);Y(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=k(this),s=Y(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,J))===J.mutable;if(r.options.strict&&Fe(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(n))return s;const o=et.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Y(k(this)).keys()},values(){const n=this.keys();return{[Le]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Le]:()=>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]}}}},[Le](){return this.entries()}},$r=Reflect.ownKeys(lt),Yt=(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=k(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,J))===J.mutable;if(n.options.strict&&Fe(o,n.options,u),!u&&!c&&te(o,n.options)&&!n.finalized&&n.original.has(o)){const l=et.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]}},qe={get size(){return k(this).setMap.size},has(n){const e=k(this);if(e.setMap.has(n))return!0;z(e);const t=k(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=k(this);return this.has(n)||(z(e),oe(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ut(e,n,n,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);z(e),oe(e);const t=k(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=k(this);z(n),oe(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Yt(n,e,{isValuesIterator:!0})}},entries(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Yt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Le](){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(qe,{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 Rr=Reflect.ownKeys(qe),Zt=new WeakSet,Xt={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&Zt.has(i))return i;if(e===Vt)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,J),o===J.mutable)return n.options.strict&&Fe(u,n.options,!0),u}const a=Y(n);if(a instanceof Map&&$r.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(lt,"size").get.call(n.proxy);const u=lt[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Rr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(qe,"size").get.call(n.proxy);const u=qe[e];if(u)return u.bind(n.proxy)}if(!Ie(a,e)){const u=Qt(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&&Fe(c,n.options),n.finalized||!te(c,n.options))return c;if(c===st(n.original,e)){if(z(n),n.copy[e]=dt({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=k(n.copy[e]);return z(u),oe(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=Qt(Y(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=st(Y(n),e),a=k(o);return a&&ue(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):(ue(t,o)&&(t!==void 0||Ie(n.original,e))||(z(n),oe(n),Ie(n.original,e)&&ue(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ut(n,e,t,Me)),!0)},has(n,e){return e in Y(n)},ownKeys(n){return Reflect.ownKeys(Y(n))},getOwnPropertyDescriptor(n,e){const t=Y(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?Xt.set.call(this,n,e,void 0,n.proxy):(st(n.original,e)!==void 0||e in n.original?(z(n),oe(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 dt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=he(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,Xt);if(s.revoke.push(u),Zt.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=k(c);let g=l.type===3?l.setMap:l.copy;const y=ce(g,r),b=k(y);if(b){let _=b.original;b.operated&&(_=rt(y)),at(b),ct(b,Me,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(_,b.original)),Ce(g,r,_)}(p=m.callbacks)===null||p===void 0||p.forEach(_=>{_(f,d)})})}else{const l=k(c);l.finalities.draft.push((f,d)=>{at(l),ct(l,Me,f,d)})}return c}et.createDraft=dt;function Dr(n,e,t,r,s){var i;const o=k(n),a=(i=o?.original)!==null&&i!==void 0?i:n,c=!!e.length;if(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&&it(o),s&&ge(u,u,o?.options.updatedValues),[u,t&&c?[{op:U.Replace,path:[],value:e[0]}]:t,r&&c?[{op:U.Replace,path:[],value:a}]:r]}function Ur(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,J))===J.mutable||!te(n,e)?n:dt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Dr(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function ft(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;ot(t,(i,o,a)=>{const c=k(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(f=>a.add(i===f?u:f))}else Ce(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ft(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 en(n){var e;const t=k(n);if(!te(n,t?.options))return n;const r=he(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?nt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Gt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(ot(s,(o,a)=>{if(t&&ue(ce(t.original,o),a))return;const c=en(a);c!==a&&(s===n&&i(),Ce(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return tt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function tn(n){if(!fe(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return en(n)}const Ke=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(w,...M){return e(w,j=>t.call(this,j,...M),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 f=fe(c)?tn(c):c,d=Array.isArray(l.mark)?((w,M)=>{for(const j of l.mark){if(typeof j!="function")throw new Error(`Invalid mark: ${j}, 'mark' should be a function.`);const K=j(w,M);if(K)return K}}):l.mark,h=(i=l.enablePatches)!==null&&i!==void 0?i:!1,p=(o=l.strict)!==null&&o!==void 0?o:!1,g={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:d,strict:p,enablePatches:h};if(!te(f,g)&&typeof f=="object"&&f!==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[y,b]=Ur(f,g);if(typeof r!="function"){if(!te(f,g))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[y,b]}let _;try{_=u(y)}catch(w){throw it(k(y)),w}const P=w=>{const M=k(y);if(!fe(w)){if(w!==void 0&&!ue(w,y)&&M?.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 K=w?.[kr];if(K){const X=K[0];return g.strict&&typeof w=="object"&&w!==null&&ft({rootDraft:M,value:w,useRawReturn:!0}),b([X])}if(w!==void 0)return typeof w=="object"&&w!==null&&ft({rootDraft:M,value:w}),b([w])}if(w===y||w===void 0)return b([]);const j=k(w);if(g===j.options){if(j.operated)throw new Error("Cannot return a modified child draft.");return b([tn(w)])}return b([w])};return _ instanceof Promise?_.then(P,w=>{throw it(k(y)),w}):P(_)})();Object.prototype.constructor.toString();function nn(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 rn(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function ze(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:nn(n,e)?Object.keys(n).every(t=>ze(n[t],e[t])):!1}function ht(n){if(!Pe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function sn(n,e){if(!Pe(n)||!Pe(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=Pe(n[r])&&Pe(e[r]);t[r]=s?sn(n[r],e[r]):e[r]}return t}function Pe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function xr(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 on(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 an(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}an(n[t],r),Lr(n[t])&&delete n[t]}}function Lr(n){return n&&Object.keys(n).length===0}const cn=/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$/,Nr={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 Fr(n){return new Date(n)}function qr(n){return new Date(n+"Z")}const Kr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function zr(n){const e=n.match(Kr);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 Wr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Vr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Qr(n){return new Date(n)}function Br(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 Gr(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 Hr(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 Jr(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 Yr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Zr(n){const e=n.match(cn);if(!e)return null;const[t]=e,r=Nr[t],s=new Date(n.replace(cn,"Z"));return new Date(s.getTime()-r*1e3)}const Xr=[zr,Vr,Br,Jr,Qr,qr,Gr,Wr,Fr,Yr,Zr,Hr];function es(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function pt(n){for(const e of Xr){const t=es(e,n);if(t)return t}return null}function ts(n){try{const e=JSON.parse(n);return typeof e=="string"?pt(e):null}catch{return null}}function je(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=pt(n)||ts(n)||pt(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 de{attrs;linkIndex;_blobAttrs=null;_primaryKeys=null;_forwardIdents=null;_revIdents=null;constructor(e,t){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(bt(e)){const[t,r,s]=e["forward-identity"];Q(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"];Q(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;Q(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;Q(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function ns(n){return n.cardinality==="one"}function yt(n){return n["value-type"]==="ref"}function bt(n){return n["value-type"]==="blob"}function me(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function ne(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)&&ne(n.get(t),r)}function Q(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 un(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=je(u),o[2]=u),yt(l)&&Q(i,[u,c,a],o),Q(r,[a,c,u],o),Q(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function ln(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function dn(n,e){return we(n,e.triples,e.cardinalityInference,e.useDateObjects)}function fn(n,e){if(n)return new de(n.attrs,n.linkIndex);if(e&&"__type"in e)return new de(e.attrs,e.linkIndex)}function rs(n,e){return me(n.eav,[e])!==void 0}function we(n,e,t,r){const s=un(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function $e(n,e){let t;if(Array.isArray(e[0])){const[s,i]=e[0],o=n.aev.get(s);if(!o)return null;t=B(o,2).find(c=>c[2]===i)?.[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[s,i]=r,o=n.aev.get(s);if(!o)return null;const c=B(o,2).find(h=>h[2]===i)?.[0];if(!c)return null;const[u,l,f,...d]=e;return[t,l,c,...d]}else{const[s,...i]=e;return[t,...i]}}function hn(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(n.eav,[s,i,o]),ne(n.aev,[i,s,o]),yt(a)&&ne(n.vae,[o,i,s]))}let ss=0;function pn(n,e,t){const[r,s,i]=t;let o;const a=me(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+ss++}function yn(n,e,t){const r=$e(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=je(o));const u=me(n.eav,[s,i,o])?.[3]??pn(n,a,r),l=[s,i,o,u];ns(a)?(Q(n.eav,[s,i],new Map([[o,l]])),Q(n.aev,[i,s],new Map([[o,l]]))):(Q(n.eav,[s,i,o],l),Q(n.aev,[i,s,o],l)),yt(a)&&Q(n.vae,[o,i,s],l)}function is(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!bt(a))throw new Error("merge operation is not supported for links");const c=me(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=sn(l,o),d=[s,i,f,pn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function gt(n,e,t){const[r,s]=t,i=$e(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const u of a.keys()){const l=e.getAttr(u);l&&l["on-delete-reverse"]==="cascade"&&B(a.get(u),1).forEach(([f,d,h])=>gt(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(ne(n.aev,[u,o]),ne(n.eav,[o,u]))}a.size===0&&ne(n.eav,[o])}const c=n.vae.get(o)&&B(n.vae.get(o),2);c&&c.forEach(u=>{const[l,f,d]=u,h=e.getAttr(f);(!s||!h||h["reverse-identity"]?.[1]===s)&&(ne(n.eav,[l,f,d]),ne(n.aev,[f,l,d]),ne(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&>(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&ne(n.vae,[o])}function bn(n,e,t){const r=un(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function os(n,[e]){n.addAttr(e)}function gn(n){return B(n.eav,3)}function as(n,e,[t]){if(!e.getAttr(t))return;const r=gn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),bn(n,e,r)}function cs(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),bn(n,e,gn(n)))}function us(n,e,t){const[r,...s]=t;switch(r){case"add-triple":yn(n,e,s);break;case"deep-merge-triple":is(n,e,s);break;case"retract-triple":hn(n,e,s);break;case"delete-entity":gt(n,e,s);break;case"add-attr":os(e,s);break;case"delete-attr":as(n,e,s);break;case"update-attr":cs(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(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())B(r,e-1,t);return t}function We(n,e,t){const r=[];if(t?.hasOwnProperty("$not")){for(const i of e.keys())t.$not!==i&&r.push(e.get(i));return r}if(t?.hasOwnProperty("$isNull")){const{attrId:i,isNull:o,reverse:a}=t.$isNull;if(a)for(const c of e.keys()){const u=n.vae.get(c),l=!u||!u.get(i);(o?l:!l)&&r.push(e.get(c))}else{const c=n.aev.get(i);for(const u of e.keys()){const l=!c||c.get(u)?.get(null)||!c.get(u);(o?l:!l)&&r.push(e.get(u))}}return r}if(t?.$comparator)return B(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const i of s){const o=e.get(i);o&&r.push(o)}return r}function ls(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function ds(n,[e,t,r]){switch(ls(e,t,r)){case"e":{const i=n.eav.get(e);return B(i,2)}case"ea":{const i=n.eav.get(e)?.get(t);return B(i,1)}case"eav":{const i=n.eav.get(e)?.get(t);return i?We(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"a":{const i=n.aev.get(t);return B(i,2)}case"av":{const i=n.aev.get(t);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...We(n,a,r));return i}default:return B(n.eav,3)}}function fs(n,e,t){const r={};if(!e)return r;for(const[s,i]of e.entries()){const o=n.eav.get(t)?.get(i.id),a=B(o,1);for(const c of a)r[s]=c[2]}return r}function L(n,e,t){return n.forwardIdents.get(e)?.get(t)}function ye(n,e,t){return n.revIdents.get(e)?.get(t)}function hs(n,e){return n.blobAttrs.get(e)}function mn(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function ps(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return me(n.eav,[s,i])}function ys(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?.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const f=e.getAttr(o);if(f){const d=mn(e,f["forward-identity"][1]);l=!!ps(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Ke({store:n,attrsStore:e},s=>{r.forEach(i=>{us(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof de)return"immutable"}})}function bs(n){return typeof n=="string"&&n.startsWith("?")}function gs(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return _n(r,e,t)}return{...t,[n]:e}}function wn(n,e,t){return n===e?t:null}function ms(n){return typeof n==="string"&&n.startsWith("?")?gs:wn}const ws=["in","$in","$not","$isNull","$comparator"];function _s(n){for(const e of ws)if(n.hasOwnProperty(e))return!0;return!1}function _n(n,e,t){return t?typeof n=="object"?_s(n)?t:null:ms(n)(n,e,t):null}function Ss(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return _n(s,o,r)},t)}function Ts(n,e,t){return ks(n,e,t).map(r=>Ss(e,r,t)).filter(r=>r)}function vs(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=>Ts(n,e,r))}function mt(n,e,t=[{}]){return e.reduce((r,s)=>vs(n,s,r),t)}function wt(n,e){return Array.isArray(e)?e.map(t=>wt(n,t)):bs(e)?n[e]:e}function As(n,{find:e,where:t}){return mt(n,t).map(s=>wt(s,e))}function ks(n,e,t){return ds(n,wt(t,e))}const Os=/^(?:[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 _e(n){return typeof n=="string"&&Os.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function Is(n,e=0){return(F[n[e+0]]+F[n[e+1]]+F[n[e+2]]+F[n[e+3]]+"-"+F[n[e+4]]+F[n[e+5]]+"-"+F[n[e+6]]+F[n[e+7]]+"-"+F[n[e+8]]+F[n[e+9]]+"-"+F[n[e+10]]+F[n[e+11]]+F[n[e+12]]+F[n[e+13]]+F[n[e+14]]+F[n[e+15]]).toLowerCase()}let _t;const Cs=new Uint8Array(16);function Es(){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(Cs)}const Sn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ms(n,e,t){if(Sn.randomUUID&&!n)return Sn.randomUUID();n=n||{};const r=n.random??n.rng?.()??Es();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,Is(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 Ps(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 js(n,e){return Ps(Tn(n),Tn(e))}function $(){return Ms()}function $s(n,e){return n.localeCompare(e)}function Rs(){let n=$s;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Ds=Rs();let vn=!0;const Us=n=>{vn=n};let xs=0;function Re(n){return Ve(`_${n}`,xs++)}function Ve(n,e){return`?${n}-${e}`}class Se extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Ls(n,e){const t=mn(n,e);if(!t)throw new Se(`Could not find id attr for ${e}`);return t}function An(n,e,t,r){return[Ns(n,e,t,r)]}function Ns(n,e,t,r){return[n(t,r),Ls(e,t).id,n(t,r),n("time",r)]}function Fs(n,e,t){return n.map(r=>r===e?t:r)}function kn(n,e,t,r,s){const i=L(e,t,s),o=ye(e,t,s),a=i||o;if(!a)throw new Se(`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,f]=a["reverse-identity"],d=r+1,h=i?[n(u,r),a.id,n(f,d),Re("time")]:[n(u,d),a.id,n(f,r),Re("time")];return[i?f:u,d,h,a,!!i]}function On(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 qs(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=On(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=On(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Ks(n,e,t,r,s,i){const o=L(e,t,s),a=ye(e,t,s),c=o||a;if(!c)throw new Se(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Se(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Re("time")]}return o?[n(t,r),c.id,qs(c,i),Re("time")]:[i,c.id,n(t,r),Re("time")]}function zs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=kn(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function St(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=zs(n,e,t,r,o),f=Ks(n,e,c,u,a,i);return l.concat([f])}function Ws(n,e){return e?[e].concat(n):n}function Vs([n,e]){return n==="or"&&Array.isArray(e)}function Qs([n,e]){return n==="and"&&Array.isArray(e)}function Bs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function In(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Bs(n,o,u);return En(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Gs(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function Cn(n,e,t,r,s){return Gs(s).map(i=>St(n,e,t,r,i,{$isNull:!0}))}function En(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Vs([i,o]))return In(n,"or",e,t,r,o);if(Qs([i,o]))return In(n,"and",e,t,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o?.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o?.hasOwnProperty("$not")){const c=St(n,e,t,r,a,o),u=Cn(n,e,t,r,a);return[{or:{patterns:[c,...u],joinSym:n(t,r)}}]}return o?.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:Cn(n,e,t,r,a),joinSym:n(t,r)}}]:St(n,e,t,r,a,o)})}function Hs(n,e,t,r){const s=Ve;return r?En(s,n,e,t,r).concat(An(s,n,e,t)):An(s,n,e,t)}function Js(n,e,t){return[n(e,t),n("time",t)]}function Ys(n,e,t,r,s,i){const[o,a,c,u,l]=kn(n,e,t,r,s),f=Fs(c,n(t,r),i);return[o,a,f,u,l]}function Zs(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(h){const p=!!(e.cardinalityInference&&t.linkIndex?.[r]?.[h]?.isSingular);try{const[m,g,y]=Ys(n,t,r,s,h,u),b=jn(e,t,{etype:m,level:g,form:i[h],join:y}),_=p?b[0]:b;return{[h]:_}}catch(m){if(m instanceof Se)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function Xs(n,e,t){return t==="string"?Ds(n,e):n>e?1:-1}function De(n,e,t,r,s){return e===r||e==null&&r==null?js(n,t):r==null?1:e==null?-1:Xs(e,r,s)}function Qe([n,e],[t,r],s){return De(n,e,t,r,s)}function Tt(n){return n==null?n:new Date(n).getTime()}function Mn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Qe(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?Tt(c):c,f=u==="date"?Tt(i):i;return Qe([a,l],[r,f],u)}function ei(n,e,t,r){const s=Mn(n,e,r);return t==="desc"?s>0:s<0}function ti(n,e,t,r){const s=Mn(n,e,r);return t==="desc"?s<0:s>0}function ni(n,e){const t=e[1];return n.getAttr(t)}function ri(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function si(n,e,t,r){if(t)return ni(n,t);if(r)return ri(n,e,r)}function ii(n,e,t){if(!Array.isArray(t.fields))return hs(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&&bt(i)&&r.set(o,i)}if(!r.has("id")){const s=L(n,e,"id"),i=s?.["forward-identity"]?.[2];i&&r.set(i,s)}return r}function oi(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=Pn(i),c=ai(i);let u=As(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=si(e,t,l,o);if(d&&d?.["forward-identity"]?.[2]!=="id"){const m=d["checked-data-type"]==="date",g=d.id;u=u.map(([y])=>{let b=n.eav.get(y)?.get(g)?.values()?.next()?.value?.[2];return m&&(b=Tt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Qe(g,y,d?.["checked-data-type"])}:function(g,y){return Qe(y,g,d?.["checked-data-type"])});let h={};const p=ii(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ei(l,d,c,m)||f&&d&&ti(f,d,c,m))continue;const y=fs(n,p,g);y&&(h[g]=y)}return h}function ai(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function Pn(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function ci(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!Pn(s)&&(!o||!o["start-cursor"]))return[];const a=Ws(Hs(e,t,r,s.$?.where),i),c=Js(Ve,t,r),u=s.$?.fields,l=oi(n,e,{etype:t,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),f=s.$?.limit||s.$?.first||s.$?.last;if(f!=null){r>0&&vn&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const d=Object.entries(l);return d.length<=f?l:Object.fromEntries(d.slice(0,f))}return l}function ui(n,e,t){try{return ci(n,e,t)}catch(r){if(r instanceof Se)return{};throw r}}function jn(n,e,t){const r=ui(n,e,t);return Zs(Ve,n,e,t,r)}function li(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 vt({store:n,attrsStore:e,pageInfo:t,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r?.[u]||u==="$$ruleParams"||(c[u]=jn(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=li(t)),r&&(o.aggregate=r),o}function di(){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 fi=di();function Be(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(fi.has(i))return(o,a)=>Be(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function $n(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function Ge(n){return n.startsWith("lookup__")}function At(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function hi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Be(n,At($n(s,i)),[]);if(t==="__etype")return n;const r=t;return Ge(r)?Be(n,At(r),[]):Be(n,r,[])}})}function kt(){return new Proxy({},{get(n,e){return hi(e)}})}const pi=kt();function Rn(n){return n.__ops}function yi(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 bi(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 gi(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Ot(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 mi(n,e,t){if(!gi(n,e,t))return L(n,e,t);const r=Ot(t),s=L(n,e,r)||ye(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function It(n){return typeof n=="string"&&!Ge(n)?null:typeof n=="string"&&Ge(n)?At(n):bi(n)}function G(n,e,t){const r=It(t);if(r===null)return t;const[s,i]=r,o=mi(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){const s=G(n,e,t);return Array.isArray(s)?[["add-triple",s,L(n,e,"id")?.id,s]].concat(r):r}function wi({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["add-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["add-triple",G(n,u["forward-identity"][1],l),u?.id,G(n,e,t)])});return Dn(n,e,t,s)}function _i({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["retract-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["retract-triple",G(n,u["forward-identity"][1],l),u.id,G(n,e,t)])});return Dn(n,e,t,s)}function Si(n,e,t,r){if(Array.isArray(r)){const[s,i]=r;for(const o of n||[]){const a=o?.aev.get(s);if(a){for(const[c,u,l]of B(a,2))if(l===i)return!0}}}else for(const s of n||[]){const i=s?.eav.get(r);if(i){for(const o of i.keys())if(e.getAttr(o)?.["forward-identity"][1]==t)return!0}}return!1}function Un({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:Si(n,e,t,r)?{mode:"update"}:null}function Ti(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,f])=>{const d=L(t,r,l);return d["checked-data-type"]==="date"&&n.useDateObjects&&(f=je(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function vi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s),u=Un(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([f,d])=>{const h=L(t,r,f);return h["checked-data-type"]==="date"&&n.useDateObjects&&(d=je(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ai({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function ki(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=ht(i),c=G(t,r,s),u=Un(n,[r,c,i,o]),l=Object.entries(a).map(([d,h])=>{const p=L(t,r,d);return["deep-merge-triple",c,p.id,h,...u?[u]:[]]});return[["add-triple",c,L(t,r,"id").id,c,...u?[u]:[]]].concat(l)}function Oi({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function Ii(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 Ci(n,e){const[t,...r]=Ii(e);switch(t){case"merge":return ki(n,r);case"create":return Ti(n,r);case"update":return vi(n,r);case"link":return wi(n,r);case"unlink":return _i(n,r);case"delete":return Ai(n,r);case"ruleParams":return Oi(n,r);default:throw new Error(`unsupported action ${t}`)}}function Ei(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Mi(n,e,t){const r=n.entities[e]?.attrs?.[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?.config,o=Ei(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function He(n,e,t,r){const s=n?Mi(n,e,t):null,i=$(),a=[$(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function Pi(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 ji(n,e,t){const r=Pi(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":[$(),s.on,s.label],"reverse-identity":[$(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function xn(n,e,t,r){const s=n?ji(n,e,t):null,i=$(),o=[$(),e,t],a=[$(),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 $i=new Set(["create","update","merge","link","unlink"]),Ri=new Set(["link","unlink"]),Di=new Set(["create","update","merge"]),Ui=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Ct={"unique?":!0,"index?":!0},xi={...Ct,cardinality:"one"};function Li(n){const e=[],[t,r,s,i]=n;if(!Ui.has(t))return e;const o=It(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 f=It(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Ni({attrsStore:n,schema:e},t){const r=new Set,s=[],i=[];function o(d,h){return L(n,d,h)||s.find(p=>p["forward-identity"][1]===d&&p["forward-identity"][2]===h)}function a(d,h){return ye(n,d,h)||s.find(p=>p["reverse-identity"]?.[1]===d&&p["reverse-identity"]?.[2]===h)}function c(d){s.push(d),i.push(["add-attr",d]),r.add(d.id)}function u(d){d&&"isUnsynced"in d&&d.isUnsynced&&!r.has(d.id)&&(s.push(d),i.push(["add-attr",d]),r.add(d.id))}function l(d,h){return h.indexOf(".")!==-1&&!o(d,h)}function f(d,h){const p=o(d,h),m=a(d,h);u(p),u(m),!p&&!m&&c(xn(e,d,h,xi))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of Li(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const _=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(_,g))f(_,Ot(g));else{const P=o(_,g);P||c(He(e,_,g,Ct)),u(P)}}else if(l(h,g))f(h,Ot(g));else{const y=o(h,g);y||c(He(e,h,g,Ct)),u(y)}}for(const d of t){const[h,p,m,g]=d;if($i.has(h)){const y=o(p,"id");u(y),y||c(He(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const _=o(p,b);if(u(_),Di.has(h)&&(_||c(He(e,p,b,b==="id"?{"unique?":!0}:null))),Ri.has(h)){const P=a(p,b);!_&&!P&&c(xn(e,p,b)),u(P)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new de(d,n.linkIndex),i]}return[n,i]}function Fi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Rn(c)),[s,i]=Ni(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Ci(o,c));return[...i,...a]}function Ln(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Te="__meta";class Et{constructor(e,t){}}class Mt{currentValue;_subs=[];_persister;_merge;serialize;parse;_saveThrottleMs;_idleCallbackMaxWaitMs;_nextSave=null;_nextGc=null;_pendingSaveKeys=new Set;_loadedKeys=new Set;_loadingKeys;_objectSize;_log;onKeyLoaded;_version=0;_meta={isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0};_gcOpts;constructor(e){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(){this._meta.loadingPromise&&await this._meta.loadingPromise;try{const e=this._persister.getItem(Te);this._meta.loadingPromise=e;const t=await e;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const r=this._meta.value?.objects??{},s=t??{},i=s.objects??{};this._meta.value={...s,objects:{...r,...i}}}catch(e){this._meta.error=e,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?.skipGc;if(this._meta.isLoading){const f=new Promise((d,h)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(d).catch(h),10+(e?.attempts??0)*1e3)});return t.push(f),Promise.all(t).then(d=>d.reduce((h,p)=>h+p,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const f of this._pendingSaveKeys)f in this.currentValue?o.push(f):(i.push(f),delete s.objects[f]);for(const f of i){const d=this._persister.removeItem(f);t.push(d.then(()=>1)),this._loadedKeys.delete(f),this._pendingSaveKeys.delete(f)}const a=[],c=[[Te,s]],u=s.objects??{};s.objects=u;for(const f of o)if(this._loadedKeys.has(f)){const d=this.serialize(f,this.currentValue[f]);c.push([f,d]);const h=this._objectSize(d),p=u[f]??{createdAt:Date.now(),updatedAt:Date.now(),size:h};p.updatedAt=Date.now(),p.size=h,u[f]=p,this._pendingSaveKeys.delete(f)}else a.push(f);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const f of a){const d=this._loadKey(f).then(()=>this._enqueuePersist(e));t.push(d)}return r||this.gc(),Promise.all(t).then(f=>f.reduce((d,h)=>d+h,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(Te);const t=new Set(Object.keys(this.currentValue));for(const d of Object.keys(this._loadingKeys))t.add(d);for(const d of this._loadedKeys)t.add(d);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 d of e)t.has(d)||d in r.objects||(this._log.info("Lost track of key in meta",d),s.push(this._persister.removeItem(d)),i.removed.push(d),i.removedMissingCount++);const o=Date.now();for(const[d,h]of Object.entries(r.objects))!t.has(d)&&h.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const c=a.filter(([d])=>!t.has(d));if(a.length>this._gcOpts.maxEntries)for(const[d]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const l=u.filter(([d])=>!t.has(d));let f=u.reduce((d,[h,p])=>d+p.size,0);for(;f>0&&f>this._gcOpts.maxSize&&l.length;){const[[d,h]]=l.splice(0,1);f-=h.size,s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedSizeCount++}for(const d of Object.keys(r.objects))!e.has(d)&&!t.has(d)&&delete r.objects[d];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(()=>{Ln(()=>{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(()=>{Ln(()=>{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]=Ke(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)}}async clearUnloadedKeys(){let e=!1;for(const t of await this._persister.getAllKeys())t===Te||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const qi=6,Ki=["kv","querySubs","syncSubs"];function zi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Wi(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=>{r.target.transaction?.abort(),e(null)}})}async function Vi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{const a={};for(const[l,f]of Object.entries(r)){const d=typeof f=="string"?JSON.parse(f):f;if(d.lastAccessed){const p={createdAt:d.lastAccessed,updatedAt:d.lastAccessed,size:d.result?.store?.triples?.length??0};a[l]=p}const h=t.put(d,l);s.add(h)}const c={objects:a},u=t.put(c,Te);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Nn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Qi(n,e){const t=await Wi(`instant_${n}_5`);if(!t)return;const r=await new Promise((l,f)=>{const p=t.transaction(["kv"],"readonly").objectStore("kv").openCursor();p.onerror=g=>{f(g)};const m=[];p.onsuccess=()=>{const g=p.result;if(g){const y=g.key,b=g.value;m.push([y,b]),g.continue()}else l(m)},p.onerror=g=>{f(g)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,f]of r)if(l==="querySubs"){const d=Vi(l,f,o);a.push(d)}else{const d=Nn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Nn(Te,c,i);a.push(u),await Promise.all(a),await new Promise((l,f)=>{s.oncomplete=d=>l(d),s.onerror=d=>f(d),s.onabort=d=>f(d)})}const Fn=new Map;class Pt extends Et{dbName;_storeName;_appId;_prefix;_dbPromise;constructor(e,t){super(e,t),this.dbName=`instant_${e}_${qi}`,this._storeName=t,this._appId=e,this._dbPromise=this._init()}_init(){return new Promise((e,t)=>{let r=!1;const s=indexedDB.open(this.dbName,1);s.onerror=i=>{t(i)},s.onsuccess=i=>{const a=i.target.result;if(r){const c=Qi(this._appId,a).catch(u=>{zi("Error upgrading store from version 5 to 6.")(u)});Fn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=Fn.get(this.dbName);c?c.then(()=>e(a)).catch(()=>e(a)):e(a)}},s.onupgradeneeded=i=>{r=!0,this._upgradeStore(i)}})}_upgradeStore(e){const r=e.target.result;for(const s of Ki)r.objectStoreNames.contains(s)||r.createObjectStore(s)}async getItem(e){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readonly").objectStore(this._storeName).get(e);a.onerror=c=>{s(c)},a.onsuccess=c=>{a.result?r(a.result):r(null)}})}async setItem(e,t){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(t,e);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async multiSet(e){const t=await this._dbPromise;return new Promise((r,s)=>{const i=t.transaction([this._storeName],"readwrite"),o=i.objectStore(this._storeName),a=new Set;for(const[c,u]of e){const l=o.put(u,c);a.add(l)}for(const c of a)c.onerror=u=>{i.abort(),s(u)},c.onsuccess=u=>{a.delete(c),a.size===0&&r()}})}async removeItem(e){const t=await this._dbPromise;return new Promise((r,s)=>{const a=t.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(e);a.onerror=c=>{s(c)},a.onsuccess=c=>{r()}})}async getAllKeys(){const e=await this._dbPromise;return new Promise((t,r)=>{const o=e.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();o.onerror=a=>{r(a)},o.onsuccess=a=>{t(o.result.filter(c=>typeof c=="string"))}})}}class jt{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 q extends Error{hint;traceId;constructor(e,t,r){super(e),this.hint=t,r&&(this.traceId=r);const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,q),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class ve extends q{body;status;constructor(e){const t=e.body?.message||`API Error (${e.status})`;super(t,e.body.hint,e.body["trace-id"]);const r=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,r),Error.captureStackTrace&&Error.captureStackTrace(this,ve),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new ve({status:t.status,body:r}))}function Bi({apiURI:n,appId:e,email:t}){return re(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Gi({apiURI:n,appId:e,email:t,code:r,refreshToken:s}){return await re(`${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 Hi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function Ji({apiURI:n,appId:e}){return await re(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function qn({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s}){return await re(`${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 Yi({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i}){return await re(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i})})}async function Zi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function Xi({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 re(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function eo({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function to({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${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 no(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function ro({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let $t=!1,Kn=!1,zn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&($t=!!window.localStorage.getItem("devBackend"),Kn=!!window.localStorage.getItem("__instantLogging"),zn=!!window.localStorage.getItem("__devtoolLocalDash"));function Wn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function so(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Wn(n.user??{},e?.keys);r.user={...i,peerId:t}}for(const i of Object.keys(n.peers??{})){const o=e?.peers===void 0,a=Array.isArray(e?.peers)&&e?.peers.includes(i);if(o||a){const c=Wn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function io(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!rn(n.user,e.user))||!nn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!rn(n.peers[r],e.peers[r]))return!0;return!1}class Vn{promise;_resolve;_reject;constructor(){this.promise=new Promise((e,t)=>{this._resolve=e,this._reject=t})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function Qn(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);Qn(t["child-nodes"],e)})}function Bn(n){const e=[];return Qn(n,e),e}function Rt(n){return Object.values(n.links).reduce((e,t)=>(e[t.forward.on]??={},e[t.forward.on][t.forward.label]={isForward:!0,isSingular:t.forward.has==="one",link:t},e[t.reverse.on]??={},e[t.reverse.on][t.reverse.label]={isForward:!1,isSingular:t.reverse.has==="one",link:t},e),{})}const Dt="v0.22.167";function oo(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 W{constructor(e,t,r,s={indexed:!1,unique:!1}){this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}metadata={};clientRequired(){return new W(this.valueType,!1,this.isIndexed,this.config)}optional(){return new W(this.valueType,!1,this.isIndexed,this.config)}unique(){return new W(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new W(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Je{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Je(this.attrs,this.links)}}class Ye{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ye(this.entities,this.links,{})}}class C extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Gn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ao=n=>n.valueType||"unknown",Hn=(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}},co=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!Hn(f,l,a))throw new C(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof f}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new C(`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 C(`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 C(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},Ae=(n,e,t,r,s)=>{const i=ao(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))co(u,l,i,e,r,t,`${s}.${u}`)}else if(!Hn(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},uo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new C(`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 f=i[l],d=r.entities[o];if(!d)throw new C(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const h=d.links[f];if(!h){const p=Object.keys(d.links);throw new C(`Link '${f}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${p.length>0?p.join(", "):"none"}`,s)}o=h.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new C(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new C(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Ae(e,n,u,t,s)},Jn=(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&&Jn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){Ae(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){uo(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 C(`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)Ae(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!_e(i))throw new C(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new W("string",!1,!0);Ae(i,s,u,e,`${r}.${s}`)}}},lo=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Gn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Gn.join(", ")}. Found: ${o}`,r);const i=["offset","before","beforeInclusive","after","afterInclusive","first","last"];for(const o of i)if(n[o]!==void 0&&s>0)throw new C(`'${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 C(`'where' clause must be an object in entity '${e}', but received: ${typeof n.where}`,r?`${r}.where`:void 0);Jn(n.where,e,t,r?`${r}.where`:"where")}},Yn=(n,e,t,r,s=0)=>{if(!n||typeof n!="object")throw new C(`Query part for entity '${e}' must be an object, but received: ${typeof n}`,r);for(const i of Object.keys(n))if(i!=="$"){if(t&&!(i in t.entities[e].links)){const a=Object.keys(t.entities[e].links);throw new C(`Link '${i}' does not exist on entity '${e}'. Available links: ${a.length>0?a.join(", "):"none"}`,`${r}.${i}`)}const o=n[i];if(typeof o=="object"&&o!==null){const a=t?.entities[e].links[i]?.entityName;a&&Yn(o,a,t,`${r}.${i}`,s+1)}}else{const o=n[i];if(typeof o!="object"||o===null)throw new C(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof o}`,`${r}.$`);lo(o,e,t,`${r}.$`,s)}},Ut=(n,e)=>{if(typeof n!="object"||n===null)throw new C(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new C(`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 C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new C(`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 C(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Yn(t[r],r,e,r,0)}}},Zn=n=>typeof n!="string"?!1:Ge(n)?!0:_e(n);class Z extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Xn=n=>n.length>0?n.join(", "):"none",fo=(n,e)=>new Z(`Entity '${n}' does not exist in schema. Available entities: ${Xn(e)}`),ho={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},po=(n,e)=>n==null?!0:ho[e.valueType]?.(n)??!1,er=(n,e)=>{const t=e.entities[n];if(!t)throw fo(n,Object.keys(e.entities));return t},xt=(n,e,t)=>{const r=er(n,t);if(typeof e!="object"||e===null)throw new Z(`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&&!po(i,o))throw new Z(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},tr=(n,e,t)=>{const r=er(n,t);if(typeof e!="object"||e===null)throw new Z(`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 Z(`Link '${s}' does not exist on entity '${n}'. Available links: ${Xn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Zn(a))throw new Z(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Zn(i))throw new Z(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},yo={create:xt,update:xt,merge:xt,link:tr,unlink:tr,delete:()=>{}},bo=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!_e(s))throw new Z(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new Z(`Entity name must be a string, but received: ${typeof r}`);const o=yo[t];o&&i!==void 0&&o(r,i,e)},nr=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new Z(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new Z(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new Z(`Transaction operation must be an array, but received: ${typeof s}`);bo(s,e)}}};let rr=0;class sr{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${rr++}`,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 ir{type="sse";initParams=null;sendQueue=[];sendPromise;closeFired=!1;sseInitTimeout=void 0;ES;messageUrl;conn;url;id;onopen;onmessage;onclose;onerror;constructor(e,t,r){this.id=`${this.type}_${rr++}`,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){try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:this.initParams?.machineId,session_id:this.initParams?.sessionId,sse_token:this.initParams?.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 go(n,e){const t=n.values;if(t){const r=fn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=dn(r,s.store);t.attrsStore=r}}return n}function mo(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=ln(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function wo(n,e,t){const r=e?.state?.txId,s=t?.state?.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?t:e||t}function Lt(n,e,t){return vt({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function or(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=me(e.eav,[r,s,r]);return i?i[3]:-1}function ar(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":yn(n,e,s);break;case"removed":hn(n,e,s);break}}function _o(n,e,t){const r={};for(const{action:s,triple:i}of t){const[o,a,c]=i,u=e.getAttr(a)?.["forward-identity"]?.[2];if(!u)continue;const l=r[o]??{};r[o]=l;const f=l[u]??{};switch(s){case"added":f.newValue=c;break;case"removed":f.oldValue===void 0&&(f.oldValue=c);break}l[u]=f}for(const[s,i]of Object.entries(r))for(const[o,{oldValue:a,newValue:c}]of Object.entries(i))a===c&&delete i[o];return r}function Ze(n,e){return{[n.table]:e.map(t=>t.entity)}}function So(n,e){if(n.orderFieldType)return n.orderFieldType;const t=n.orderField==="serverCreatedAt"?"number":L(e(),n.table,n.orderField)?.["checked-data-type"];return n.orderFieldType=t,t}function To(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return De(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 De(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return De(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var cr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(cr||{});class vo{trySend;subs;callbacks={};config;idToHash={};log;createStore;getAttrs;constructor(e,t,r,s,i,o){this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new Mt({persister:t,merge:wo,serialize:mo,parse:(a,c)=>go(c,this.config.useDateObjects),objectSize:a=>a.values?.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=R(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,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?.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend($(),{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($(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){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),s.values?.entities&&r&&r({type:"LoadFromStorage",data:Ze(s,s.values?.entities)});return}const i=Object.keys(e)[0],o=e[i]?.$?.order||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(u=>{u[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=R(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),f=Lt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:or(o,l,a.attrsStore,f.id)}),i.push(f)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ze(o,o.values.entities),batch:i})}onSyncInitFinish(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(i=>{const o=i[r];if(!o){this.log.error("Missing sub for hash",r,e);return}const a=o.state;if(!a)return this.log.error("Sub never set init, missing result",o,e),i;a.txId=e["tx-id"],o.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ze(s,s.values?.entities||[])})}onSyncUpdateTriples(e){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 o of e.txes){if(i.txId&&i.txId>=o["tx-id"])continue;i.txId=o["tx-id"];const a=[],c={};for(const m of o.changes){const g=c[m.triple[0]]??[];c[m.triple[0]]=g,g.push(m)}const u=s.values??{entities:[],attrsStore:this.getAttrs()},l=u.entities;s.values=u;const f=[];e:for(const[m,g]of Object.entries(c))for(let y=0;y<l.length;y++){const b=l[y];if(rs(b.store,m)){ar(b.store,u.attrsStore,g);const _=Lt(s,b.store,u.attrsStore),P=_o(b.store,u.attrsStore,g)[m];_?(f.push({oldEntity:b.entity,newEntity:_,changedFields:P||{}}),b.entity=_):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);ar(y,u.attrsStore,g);const b=Lt(s,y,u.attrsStore);if(!b){this.log.error("No entity found after applying change",{sub:s,changes:g,store:y});continue}l.push({store:y,entity:b,serverCreatedAt:or(s,y,u.attrsStore,b.id)}),d.push(b)}const h=[];for(const m of a.sort().reverse())h.push(l[m].entity),l.splice(m,1);const p=So(s,this.getAttrs);To(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Ze(s,s.values?.entities),added:d,removed:h,updated:f})}this.subs.updateInPlace(o=>{o[r]=s,o[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=R(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 Ao({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=$();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],_=new TextEncoder;function P(){f=!0;for(const S of d)S(a??void 0)}function w(S){return d.push(S),f&&S(a??void 0),()=>{const O=d.indexOf(S);O!==-1&&d.splice(O,1)}}function M(S){return p.push(S),()=>{const O=p.indexOf(S);O!==-1&&p.splice(O,1)}}e.waitUntil&&e.waitUntil(new Promise(S=>{p.push(S)}));function j(){for(const S of p)try{S()}catch{}}function K(S){return h.push(S),o&&S(o),()=>{const O=h.indexOf(S);O!==-1&&h.splice(O,1)}}function X(S){o=S;for(const O of h)O(o)}function T(){m=!0}function E(S){let O=g,V=0,H=0;for(const{byteLen:ie}of b){const le=O+ie;if(le>S)break;O=le,V++,H+=ie}V>0&&(g+=H,y-=H,b.splice(0,V))}function A(S,O){a=O,P(),S.error(O),j()}async function I(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:O,offset:V}=S;o=O,E(V),b.length&&r({streamId:O,chunks:b.map(H=>H.chunk),offset:g}),m=!1;break}case"disconnect":{T();break}case"error":{c&&A(c,S.error);break}}}function N(){T(),I()}function x({offset:S,done:O}){E(S),O&&(l=!0,j())}function ee(S){return l?(A(S,new q("Stream has been closed.")),null):o||(A(S,new q("Stream has not been initialized.")),null)}async function se(S){c=S;let O=!0,V=0;for(;O;){let H=Date.now()+Math.min(15e3,500*(V-1));O=!1;const ie=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(ie.type){case"ok":{const{streamId:le,offset:Wt}=ie;if(Wt!==0){const be=new q("Write stream is corrupted");A(S,be);return}X(le),s(le,{onDisconnect:T,onFlush:x,onConnectionReconnect:I,onAppendFailed:N}),m=!1;return}case"disconnect":{O=!0,T(),V++,await new Promise(le=>{setTimeout(le,Math.max(0,H-Date.now()))});break}case"error":{A(S,ie.error);return}}}}class ma extends n{constructor(O,V){super(O,V)}async streamId(){return o||new Promise((O,V)=>{const H=[],ie=()=>{for(const be of H)be()},le=be=>{O(be),ie()},Wt=be=>{V(be||new q("Stream is closed.")),ie()};H.push(K(le)),H.push(w(Wt))})}}return{stream:new ma({async start(S){try{await se(S)}catch(O){A(S,O)}},write(S,O){const V=ee(O);if(V){const H=_.encode(S).length;b.push({chunk:S,byteLen:H});const ie=g+y;y+=H,m||r({streamId:V,chunks:[S],offset:ie})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):j(),P()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):j(),P()}}),addCompleteCb:M,closed(){return f}}}class ko{items=[];resolvers=[];isClosed=!1;constructor(){}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 Oo({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 f(){u=!0;for(const b of l)b()}function d(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function h(b,_){b.error(_),f()}let p=0;async function m(b,_){c=$();const P={...b||{},eventId:c};for await(const w of t(P)){if(i)return;if(w.type==="reconnect")return{retry:!0};if(w.type==="error"){h(_,w.error);return}if(w.offset>s){h(_,new q("Stream is corrupted.")),i=!0;return}let M=s-w.offset;if(w.files&&w.files.length){const j=new AbortController;let K=fetch(w.files[0].url,{signal:j.signal});for(let X=0;X<w.files.length;X++){const T=w.files[X+1],A=await K;if(T&&(K=fetch(T.url,{signal:j.signal})),!A.ok){if(p++,p>10){h(_,new q("Unable to process stream."));return}return{retry:!0}}if(A.body){const I=A.body.getReader();try{for(;;){const{done:N,value:x}=await I.read();if(N)break;if(i){j.abort();return}let ee=x;if(M>0&&(ee=x.subarray(M),M-=x.length-ee.length),!ee.length)continue;s+=ee.length;const se=o.decode(ee);_.enqueue(se)}}finally{I.releaseLock()}}else{const I=await A.arrayBuffer();let N=I;if(i){j.abort();return}if(M>0&&(N=new Uint8Array(I).subarray(M),M-=I.byteLength-N.length),!N.byteLength)continue;s+=N.byteLength;const x=o.decode(N);_.enqueue(x)}}}if(p=0,w.content){let j=w.content,K=a.encode(w.content);if(M>0){const X=K.subarray(M);if(M-=K.length-X.length,!X.length)continue;K=X,j=o.decode(X)}s+=K.length,_.enqueue(j)}}}async function g(b){let _=!0,P=0;for(;_;){_=!1;let w=Date.now()+Math.min(15e3,500*(P-1));(await m({...e,offset:s},b))?.retry&&(_=!0,P++,w<Date.now()-3e5&&(P=0),await new Promise(j=>{setTimeout(j,Math.max(0,w-Date.now()))}))}!i&&!u&&(b.close(),f())}return{stream:new n({start(b){g(b)},cancel(b){i=!0,c&&r({eventId:c}),f()}}),addCloseCb:d,closed(){return u}}}class ur{trySend;WStream;RStream;writeStreams={};startWriteStreamCbs={};readStreamIterators={};log;activeStreams=new Set;constructor({WStream:e,RStream:t,trySend:r,log:s}){this.WStream=e,this.RStream=t,this.trySend=r,this.log=s}createWriteStream(e){const{stream:t,addCompleteCb:r}=Ao({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}=Oo({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=$();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($(),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 ko;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend($(),t),delete this.readStreamIterators[e]}onStreamAppend(e){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 q(e.error)}),r.close(),delete this.readStreamIterators[t];return}(e.files?.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!==ae.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"];this.writeStreams[r]?.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new q(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 q(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const ae={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},Io=3e4,Co=3e4,Eo=200,Mo=1e3*60,Po={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Nt="_instant_oauth_redirect",ke="currentUser";function jo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new sr(`${r}?app_id=${e}`);switch(n){case"ws":return new sr(`${r}?app_id=${e}`);case"sse":return new ir(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function $o(){return typeof window<"u"||typeof chrome<"u"}const lr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function Ro(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=fn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=dn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Do(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:ln(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Uo(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function xo(n,e){return n==="pendingMutations"?[...e.entries()]:e}function Lo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function Ft(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 dr{attrs;_isOnline=!0;_isShutdown=!1;status=ae.CONNECTING;querySubs;kv;_syncTable;_instantStream;queryCbs={};queryOnceDfds={};authCbs=[];attrsCbs=[];mutationErrorCbs=[];connectionStatusCbs=[];config;mutationDeferredStore=new Map;_reconnectTimeoutId=null;_reconnectTimeoutMs=0;_transport;_transportType="ws";_EventSource;_wsOk=null;_localIdPromises={};_errorMessage=null;_oauthCallbackResponse=null;_linkIndex=null;_broadcastChannel;_rooms={};_roomsPendingLeave={};_presence={};_broadcastQueue=[];_broadcastSubs={};_currentUserCached={isLoading:!0,error:void 0,user:void 0};_beforeUnloadCbs=[];_dataForQueryCache={};_log;_pendingTxCleanupTimeout;_pendingMutationCleanupThreshold;_inFlightMutationEventIds=new Set;_frameworkClient=null;constructor(e,t=Pt,r=jt,s,i){if(this._EventSource=i,this.config={...Po,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??Co,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Eo,this._log=oo(e.verbose||$t||Kn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":Dt},this.config.schema&&(this._linkIndex=Rt(this.config.schema)),!!$o()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!_e(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=>{try{if(o.data?.type==="auth"){const a=await this.getCurrentUser({forceReadFromStorage:!0});await this.updateUser(a.user).catch(c=>{this._log.error("[error] update user",c)})}}catch(a){this._log.error("[error] handle broadcast channel",a)}})),this._initStorage(t),this._syncTable=new vo(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>we(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new ur({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)},Mo),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",ae.CLOSED),this._setStatus(ae.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}getFrameworkClient(){return this._frameworkClient}setFrameworkClient(e){this._frameworkClient=e}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?Rt(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 Mt({persister:new e(this.config.appId,"querySubs"),merge:Lo,serialize:Do,parse:(t,r)=>Ro(r,this.config.useDateObjects),objectSize:t=>t?.result?.store?.triples?.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 Mt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:xo,parse:Uo,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(ke),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?.type){const{status:o,...a}=r;s.reject(new ve({body:a,status:o??0}))}else s.reject(new q(r?.message||"Unknown error",r?.hint))}_setStatus(e,t){this.status=e,this._errorMessage=t,this.notifyConnectionStatusSubs(e),this._instantStream.onConnectionStatusChange(e)}_onMergeKv=(e,t,r)=>{if(e==="pendingMutations"){const s=t?.entries()??[],i=r?.entries()??[],o=new Map([...s,...i]);return(t?this._rewriteMutationsSorted(this.attrs,t):[]).forEach(([c,u])=>{!r?.pendingMutations?.has(c)&&!u["tx-id"]&&this._sendMutation(c,u)}),o}else return r||t};_flushEnqueuedRoomData(e){const t=this._presence[e]?.result?.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],t&&this._trySetPresence(e,t),r)for(const s of r){const{topic:i,roomType:o,data:a}=s;this._tryBroadcast(e,o,i,a)}}_addQueryData(e,t,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=R(e),i=this.ensureAttrs(),o=we(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){const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(lr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ae.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const o of Object.keys(this._rooms)){const a=this._presence[o]?.result?.user,c=this._rooms[o]?.roomType;this._tryJoinRoom(c,o,a)}break}case"add-query-exists":{this.notifyOneQueryOnce(R(t.q));break}case"add-query-ok":{const{q:o,result:a}=t,c=R(o);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[c])break;const u=a?.[0]?.data?.["page-info"],l=a?.[0]?.data?.aggregate,f=Bn(a),d=this.ensureAttrs(),h=we(d,f,r,this.config.useDateObjects);this.querySubs.updateInPlace(p=>{if(!p[c]){this._log.info("Missing value in querySubs",{hash:c,q:o});return}p[c].result={store:h,attrsStore:d,pageInfo:u,aggregate:l,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(c),this.notifyOneQueryOnce(c),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:o,attrs:a}=t,c=t["processed-tx-id"];a&&this._setAttrs(a),this._cleanupPendingMutationsTimeout();const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),c);u!==this._pendingMutations()&&this.kv.updateInPlace(d=>{d.pendingMutations=u});const l=Ft(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Bn(p),y=this.ensureAttrs(),b=we(y,g,r,this.config.useDateObjects),{store:_,attrsStore:P}=this._applyOptimisticUpdates(b,y,l,c),w=p?.[0]?.data?.["page-info"],M=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:_,attrsStore:P,pageInfo:w,aggregate:M}});f.forEach(({hash:d,q:h,store:p,attrsStore:m,pageInfo:g,aggregate:y})=>{this.querySubs.updateInPlace(b=>{if(!b[d]){this._log.error("Missing value in querySubs",{hash:d,q:h});return}b[d].result={store:p,attrsStore:m,pageInfo:g,aggregate:y,processedTxId:c}})}),this._cleanupPendingMutationsQueries(),f.forEach(({hash:d})=>{this.notifyOne(d)});break}case"transact-ok":{const{"client-event-id":o,"tx-id":a}=t;this._inFlightMutationEventIds.delete(o);const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(o);if(!u)break;this._updatePendingMutations(f=>{f.set(o,{...f.get(o),"tx-id":a,confirmed:Date.now()})});const l=[];for(const f of u["tx-steps"])if(f[0]==="add-attr"){const d=f[1];l.push(d)}if(l.length){const f=Object.values(this.ensureAttrs().attrs);this._setAttrs([...f,...l])}this._finishTransaction("synced",o),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._patchPresencePeers(o,t.edits),this._notifyPresenceSubs(o);break}case"refresh-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._setPresencePeers(o,t.data),this._notifyPresenceSubs(o);break}case"server-broadcast":{const o=t["room-id"],a=t.topic;this._trySetRoomConnected(o,!0),this._notifyBroadcastSubs(o,a,t);break}case"join-room-ok":{const o=t["room-id"];if(!this._rooms[o]){this._roomsPendingLeave[o]&&(this._tryLeaveRoom(o),delete this._roomsPendingLeave[o]);break}this._trySetRoomConnected(o,!0),this._flushEnqueuedRoomData(o);break}case"leave-room-ok":{const o=t["room-id"];this._trySetRoomConnected(o,!1);break}case"join-room-error":const s=t["room-id"],i=this._rooms[s];i&&(i.error=t.error),this._notifyPresenceSubs(s);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){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(e["original-event"]?.hasOwnProperty("q")&&e["original-event"]?.op==="add-query"){const a=e["original-event"]?.q,c=R(a);this.notifyQueryError(R(a),s),this.notifyQueryOnceError(a,c,t,s);return}if(e["original-event"]?.op==="init"){if(e.type==="record-not-found"&&e.hint?.["record-type"]==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ae.ERRORED,s),this.notifyAll();return}switch(e["original-event"]?.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){const i=this.queryOnceDfds[t]?.find(o=>o.eventId===r);i&&(i.dfd.reject(s),this._completeQueryOnce(e,t,i.dfd))}_setAttrs(e){this.attrs=new de(e.reduce((t,r)=>(t[r.id]=r,t),{}),this._linkIndex),this.notifyAttrsSubs()}getPreviousResult=e=>{const t=R(e);return this.dataForQuery(t)?.data};_startQuerySub(e,t){const r=$();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||Ut(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=R(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||Ut(e,this.config.schema),t&&"ruleParams"in t&&(e={$$ruleParams:t.ruleParams,...e});const r=new Vn;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=R(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")),Io),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){return!!(this.queryCbs[e]?.length||this.queryOnceDfds[e]?.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($(),{op:"remove-query",q:e}))}_rewriteMutations(e,t,r){if(!e)return t;if(!t)return new Map;const s=l=>{const[f,d,h]=l["forward-identity"];return L(e,d,h)},i=l=>{const[f,d,h]=l["forward-identity"];return ye(e,d,h)},o={attrIdMap:{},refSwapAttrIds:new Set};let a=!1;const c=(l,f)=>{const d=[];for(const h of l){const[p]=h;if(p==="add-attr"){const[g,y]=h,b=s(y);if(b&&y.id!==b.id){o.attrIdMap[y.id]=b.id,a=!0;continue}if(y["value-type"]==="ref"){const _=i(y);if(_){o.attrIdMap[y.id]=_.id,o.refSwapAttrIds.add(y.id),a=!0;continue}}}if(r&&f&&r>=f&&p==="add-attr"||p==="update-attr"||p==="delete-attr"){a=!0;continue}const m=a?yi(o,h):h;d.push(m)}return a?d:l},u=new Map;for(const[l,f]of t.entries())u.set(l,{...f,"tx-steps":c(f["tx-steps"],f["tx-id"])});return a?u:t}_rewriteMutationsSorted(e,t){return Ft(this._rewriteMutations(e,t).entries())}optimisticAttrs(){const e=[...this._pendingMutations().values()].flatMap(i=>i["tx-steps"]),t=new Set(e.filter(([i,o])=>i==="delete-attr").map(([i,o])=>o)),r=[];for(const[i,o]of e)if(i==="add-attr")r.push(o);else if(i==="update-attr"&&o.id&&this.attrs?.getAttr(o.id)){const a={...this.attrs.getAttr(o.id),...o};r.push(a)}if(!t.size&&!r.length)return this.attrs||new de({},this._linkIndex);const s={...this.attrs?.attrs||{}};for(const i of r)s[i.id]=i;for(const i of t)delete s[i];return new de(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 f=u.store,d=u.attrsStore;const{pageInfo:h,aggregate:p,processedTxId:m}=u,g=this._rewriteMutationsSorted(d,a);if(t){const b=this._applyOptimisticUpdates(f,d,g,m);f=b.store,d=b.attrsStore}return{data:vt({store:f,attrsStore:d,pageInfo:h,aggregate:p},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=ys(e,t,o["tx-steps"]);e=a.store,t=a.attrsStore}return{store:e,attrsStore:t}}notifyOne=e=>{const t=this.queryCbs[e]??[],r=this._dataForQueryCache[e]?.data,s=this.dataForQuery(e);s?.data&&(this._dataForQueryCache[e]=s,!ze(s.data,r)&&t.forEach(i=>i.cb(s.data)))};notifyOneQueryOnce=e=>{const t=this.queryOnceDfds[e]??[],r=this.dataForQuery(e)?.data;t.forEach(s=>{this._completeQueryOnce(s.q,e,s.dfd),s.dfd.resolve(r)})};notifyQueryError=(e,t)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error: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())}pushTx=e=>{this.config.disableValidation||nr(e,this.config.schema);try{const t=Fi({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>r?.result?.store),useDateObjects:this.config.useDateObjects},e);return this.pushOps(t)}catch(t){return this.pushOps([],t)}};pushOps=(e,t)=>{const r=$(),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 Vn;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise};shutdown(){this._log.info("[shutdown]",this.config.appId),this._isShutdown=!0,this._transport?.close()}_sendMutation(e,t){if(t.error){this._handleMutationError("error",e,{message:t.error.message});return}if(this.status!==ae.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}),Ft(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?.processedTxId&&(e=Math.min(e,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===ae.AUTHENTICATED&&this._trySend(...e)}_trySend(e,t,r){if(this._transport.isOpen()){switch(lr[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})}}_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(ae.OPENED),this.getCurrentUser().then(r=>{this._trySend($(),{op:"init","app-id":this.config.appId,"refresh-token":r.user?.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",t.id,r)})};_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)};_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)};_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)};_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(ae.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()};_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=jo({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?.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=$();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(Nt)){const t=e.toString();e.searchParams.delete(Nt),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=>{s||(s=!0,navigation.removeEventListener("navigate",i),!o.userInitiated&&o.navigationType==="replace"&&o.destination?.url===t&&history.replaceState(history.state,"",r))};navigation.addEventListener("navigate",i)}}}async _oauthLoginInit(){if(typeof window>"u"||typeof window.location>"u"||typeof URLSearchParams>"u")return null;const e=new URLSearchParams(window.location.search);if(!e.get(Nt))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 s=await this._getCurrentUser(),i=s?.type==="guest",{user:o}=await qn({apiURI:this.config.apiURI,appId:this.config.appId,code:r,refreshToken:i?s.refresh_token:void 0});return this.setCurrentUser(o),null}catch(s){return s?.body?.type==="record-not-found"&&s?.body?.hint?.["record-type"]==="app-oauth-code"&&await this._hasCurrentUser()?null:{error:{message:s?.body?.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||ze(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 q("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[ke]=e}),await this.kv.waitForKeyToLoad(ke)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(e){e?.forceReadFromStorage&&await this.kv.unloadKey(ke);const t=await this.kv.waitForKeyToLoad(ke);return typeof t=="string"?JSON.parse(t):t}async getCurrentUser(e){const t=await this._waitForOAuthCallbackResponse();if(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?.message||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(ke);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){const{user:t}=await this.getCurrentUser();if(!ze(t,e)){this._frameworkClient=null,await this.setCurrentUser(e),await this.updateUser(e);try{await this.kv.flush(),this._broadcastChannel?.postMessage({type:"auth"})}catch(r){console.error("Error posting message to broadcast channel",r)}}}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.querySubs.clearUnloadedKeys(),this._updatePendingMutations(r=>{for(const[s,i]of r.entries())this.mutationDeferredStore.get(s)&&this._finishTransaction("error",s,{message:"User changed while transaction was in progress.",type:"user-changed"});r.clear()}),this._reconnectTimeoutMs=0,this._transport.close(),this._oauthCallbackResponse=null,this.notifyAuthSubs(t)}sendMagicCode({email:e}){return Bi({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode({email:e,code:t}){const r=await this.getCurrentUser(),s=r?.user?.type==="guest",i=await Gi({apiURI:this.config.apiURI,appId:this.config.appId,email:e,code:t,refreshToken:s?r?.user?.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}async signInWithCustomToken(e){const t=await Hi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(t.user),t}async signInAsGuest(){const e=await Ji({apiURI:this.config.apiURI,appId:this.config.appId});return await this.changeCurrentUser(e.user),e}potentiallyInvalidateToken(e,t){const r=e?.user?.refresh_token;if(!r)return;if(t.invalidateToken===!1){this._log.info("[auth-invalidate] skipped invalidateToken");return}Zi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:r}).then(()=>{this._log.info("[auth-invalidate] completed invalidateToken")}).catch(i=>{})}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}){const r=await this.getCurrentUser(),s=r?.user?.type==="guest",i=await qn({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:t,refreshToken:s?r?.user?.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}issuerURI(){const{apiURI:e,appId:t}=this.config;return`${e}/runtime/${t}`}async signInWithIdToken({idToken:e,clientName:t,nonce:r}){const i=(await this.getCurrentUser())?.user?.refresh_token,o=await Yi({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){if(!this._presence[e]?.handlers?.length&&!Object.keys(this._broadcastSubs[e]??{}).length){const t=this._rooms[e]?.isConnected;delete this._rooms[e],delete this._presence[e],delete this._broadcastSubs[e],t?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:{...so(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($(),{op:"set-presence","room-id":e,data:t})}_tryJoinRoom(e,t,r){this._trySendAuthed($(),{op:"join-room","room-type":e,"room-id":t,data:r}),delete this._roomsPendingLeave[t]}_tryLeaveRoom(e){this._trySendAuthed($(),{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),()=>{this._presence[t].handlers=this._presence[t]?.handlers?.filter(a=>a!==o)??[],i()}}_notifyPresenceSubs(e){this._presence[e]?.handlers?.forEach(t=>{this._notifyPresenceSub(e,t)})}_notifyPresenceSub(e,t){const r=this.getPresence("",e,t);r&&(t.prev&&!io(r,t.prev)||(t.prev=r,t.cb(r)))}_patchPresencePeers(e,t){const r=this._presence[e]?.result?.peers||{};let s=Object.fromEntries(Object.entries(r).map(([o,a])=>[o,{data:a}]));this._presence[e]?.result;const i=Ke(s,o=>{for(let[a,c,u]of t)switch(c){case"+":xr(o,a,u);break;case"r":on(o,a,u);break;case"-":an(o,a);break}delete o[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=Ke(this._presence,i=>{on(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($(),{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){this._broadcastSubs?.[e]?.[t]?.forEach(s=>{const i=r.data?.data,o=r.data["peer-id"]===this._sessionId?this._presence[e]?.result?.user:this._presence[e]?.result?.peers?.[r.data["peer-id"]];return s(i,o)})}async uploadFile(e,t,r){const i=(await this.getCurrentUser())?.user?.refresh_token;return Xi({...r,apiURI:this.config.apiURI,appId:this.config.appId,path:e,file:t,refreshToken:i})}async deleteFile(e){const r=(await this.getCurrentUser())?.user?.refresh_token;return await eo({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}async upload(e,t){const s=(await this.getCurrentUser())?.user?.refresh_token,i=e||t.name,o=await to({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await no(o,t)}async getDownloadUrl(e){const r=(await this.getCurrentUser())?.user?.refresh_token;return await ro({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function No(n,e){return new Ye(fr(n,e),e,void 0)}function Fo(n){return new Je(n,{})}function qo(){return new W("string",!0,!1)}function Ko(){return new W("number",!0,!1)}function zo(){return new W("boolean",!0,!1)}function Wo(){return new W("date",!0,!1)}function Vo(){return new W("json",!0,!1)}function Qo(){return new W("json",!0,!1)}function fr(n,e){const t={fwd:{},rev:{}};for(const s of Object.values(e))t.fwd[s.forward.on]||={},t.rev[s.reverse.on]||={},t.fwd[s.forward.on][s.forward.label]={entityName:s.reverse.on,cardinality:s.forward.has},t.rev[s.reverse.on][s.reverse.label]={entityName:s.forward.on,cardinality:s.reverse.has};return Object.fromEntries(Object.entries(n).map(([s,i])=>[s,new Je(i.attrs,{...t.fwd[s],...t.rev[s]})]))}function Bo({entities:n,links:e,rooms:t}){const r=e??{},s=t??{};return new Ye(fr(n,r),r,s)}const D={graph:No,schema:Bo,entity:Fo,string:qo,number:Ko,boolean:zo,date:Wo,json:Vo,any:Qo};let hr;function Go(n,e){hr?.dispose();const t=ea(e),r=Yo(e,a),s=Jo(Ho(n));function i(l){l.source===s.element.contentWindow&&l.data?.type==="close"&&t.isVisible()&&a()}function o(l){const f=l.shiftKey&&l.ctrlKey&&l.key==="0",d=l.key==="Escape"||l.key==="Esc";(f||d&&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),hr={dispose:c}}return u()}function Ho(n){return`${$t||zn?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${n}`}function Jo(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 Yo(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.167",
|
|
4
4
|
"description": "Instant's core local abstraction",
|
|
5
5
|
"homepage": "https://github.com/instantdb/instant/tree/main/client/packages/core",
|
|
6
6
|
"repository": {
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
"dependencies": {
|
|
57
57
|
"mutative": "^1.0.10",
|
|
58
58
|
"uuid": "^11.1.0",
|
|
59
|
-
"@instantdb/version": "0.22.
|
|
59
|
+
"@instantdb/version": "0.22.167"
|
|
60
60
|
},
|
|
61
61
|
"scripts": {
|
|
62
62
|
"test": "vitest",
|