@instantdb/core 0.22.184 → 0.22.185

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.
@@ -3657,7 +3657,7 @@ function Ot(n) {
3657
3657
  link: t
3658
3658
  }, e), {});
3659
3659
  }
3660
- const or = "v0.22.184";
3660
+ const or = "v0.22.185";
3661
3661
  function eo(n, e) {
3662
3662
  return {
3663
3663
  info: n ? (...t) => console.info(...t, e()) : () => {
@@ -1,4 +1,4 @@
1
- (function(T,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(T=typeof globalThis<"u"?globalThis:T||self,R(T.instant={}))})(this,(function(T){"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"},Jt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),Mr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Ne=Symbol.iterator,Y={mutable:"mutable",immutable:"immutable"},rt={};function Ce(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Yt(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 st(n){return Object.getPrototypeOf(n)===Set.prototype}function it(n){return Object.getPrototypeOf(n)===Map.prototype}function Z(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function he(n){return!!I(n)}function I(n){return typeof n!="object"?null:n?.[Jt]}function ot(n){var e;const t=I(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function ee(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,Y))===Y.immutable||typeof t=="function")}function Zt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=I(ae(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||Ce(t,i)))return null;e.push(i)}if(n.parent)return Zt(n.parent,e);e.reverse();try{Pr(n.copy,e)}catch{return null}return e}function pe(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ae(n,e){return pe(n)===2?n.get(e):n[e]}function Ee(n,e,t){pe(n)===2?n.set(e,t):n[e]=t}function at(n,e){const t=I(n);return(t?Z(t):n)[e]}function ce(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function ct(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function ye(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 Pr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ae(pe(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function jr(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 $r=Object.prototype.propertyIsEnumerable;function Xt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!st(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(!it(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,Y),t!==void 0)&&t!==Y.mutable){if(t===Y.immutable)return jr(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=>{$r.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=Xt(n.original,n.options))}function Me(n){if(!ee(n))return ot(n);if(Array.isArray(n))return n.map(Me);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Me(s)]);if(!it(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(Me);if(!st(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]=Me(n[t]);return e}function Fe(n){return he(n)?Me(n):n}function ie(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&ie(n.parent))}function en(){throw new Error("Cannot modify frozen object")}function me(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)||he(n)){r.pop(),s.pop();return}switch(pe(n)){case 2:for(const[a,c]of n)me(a,a,t,r,s),me(c,a,t,r,s);n.set=n.clear=n.delete=en;break;case 3:for(const a of n)me(a,a,t,r,s);n.add=n.clear=n.delete=en;break;case 1:Object.freeze(n);let o=0;for(const a of n)me(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];me(c,a,t,r,s)})}r.pop(),s.pop()}function ut(n,e){const t=pe(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 tn(n,e,t){if(he(n)||!ee(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),ut(n,(i,o)=>{var a;if(he(o)){const c=I(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ee(r?s:n,i,u)}else tn(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 Rr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&tn(ae(t,e),n.finalities.handledSet,n.options)}function lt(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(ot(e))}))}function dt(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Zt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ft(n,e,t,r){const s=I(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ce(ae(c,e),t)){let u=s.original;s.copy&&(u=s.copy),lt(n),dt(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)),Ee(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),ee(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ce(ae(i,e),t)&&Rr(n,e)})}function Dr(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=ye(l,s);t.push({op:U.Replace,path:f,value:Fe(c[u])}),r.push({op:U.Replace,path:f,value:Fe(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=ye(l,s);t.push({op:U.Add,path:f,value:Fe(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=ye(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=ye(f,s);r.push({op:U.Remove,path:d})}}}function xr({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ae(n,c),l=Fe(ae(e,c)),f=a?Ce(n,c)?U.Replace:U.Add:U.Remove;if(ce(u,l)&&f===U.Replace)return;const d=r.concat(c),h=ye(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 Ur({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=ye(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=ye(c,i);r.push({op:U.Add,path:u,value:a}),s.unshift({op:U.Remove,path:u,value:a})}o+=1})}function Pe(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return xr(n,e,t,r,s);case 1:return Dr(n,e,t,r,s);case 3:return Ur(n,e,t,r,s)}}const Ke=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!ee(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},ht={get size(){return Z(I(this)).size},has(n){return Z(I(this)).has(n)},set(n,e){const t=I(this),r=Z(t);return(!r.has(n)||!ce(r.get(n),e))&&(z(t),ie(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ft(t,n,e,Pe)),this},delete(n){if(!this.has(n))return!1;const e=I(this);return z(e),ie(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=I(this);if(this.size){z(n),ie(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=I(this);Z(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=I(this),s=Z(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,Y))===Y.mutable;if(r.options.strict&&Ke(s,r.options,i),i||r.finalized||!ee(s,r.options)||s!==r.original.get(n))return s;const o=rt.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Z(I(this)).keys()},values(){const n=this.keys();return{[Ne]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Ne]:()=>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]}}}},[Ne](){return this.entries()}},Lr=Reflect.ownKeys(ht),nn=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=I(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,Y))===Y.mutable;if(n.options.strict&&Ke(o,n.options,u),!u&&!c&&ee(o,n.options)&&!n.finalized&&n.original.has(o)){const l=rt.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 I(this).setMap.size},has(n){const e=I(this);if(e.setMap.has(n))return!0;z(e);const t=I(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=I(this);return this.has(n)||(z(e),ie(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ft(e,n,n,Pe)),this},delete(n){if(!this.has(n))return!1;const e=I(this);z(e),ie(e);const t=I(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=I(this);z(n),ie(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=I(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:nn(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:nn(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Ne](){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 Nr=Reflect.ownKeys(qe),rn=new WeakSet,sn={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&rn.has(i))return i;if(e===Jt)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,Y),o===Y.mutable)return n.options.strict&&Ke(u,n.options,!0),u}const a=Z(n);if(a instanceof Map&&Lr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(ht,"size").get.call(n.proxy);const u=ht[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Nr.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(!Ce(a,e)){const u=Yt(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&&Ke(c,n.options),n.finalized||!ee(c,n.options))return c;if(c===at(n.original,e)){if(z(n),n.copy[e]=pt({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=I(n.copy[e]);return z(u),ie(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=Yt(Z(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=at(Z(n),e),a=I(o);return a&&ce(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):(ce(t,o)&&(t!==void 0||Ce(n.original,e))||(z(n),ie(n),Ce(n.original,e)&&ce(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ft(n,e,t,Pe)),!0)},has(n,e){return e in Z(n)},ownKeys(n){return Reflect.ownKeys(Z(n))},getOwnPropertyDescriptor(n,e){const t=Z(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?sn.set.call(this,n,e,void 0,n.proxy):(at(n.original,e)!==void 0||e in n.original?(z(n),ie(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 pt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=pe(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,sn);if(s.revoke.push(u),rn.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=I(c);let g=l.type===3?l.setMap:l.copy;const y=ae(g,r),b=I(y);if(b){let w=b.original;b.operated&&(w=ot(y)),lt(b),dt(b,Pe,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(w,b.original)),Ee(g,r,w)}(p=m.callbacks)===null||p===void 0||p.forEach(w=>{w(f,d)})})}else{const l=I(c);l.finalities.draft.push((f,d)=>{lt(l),dt(l,Pe,f,d)})}return c}rt.createDraft=pt;function Fr(n,e,t,r,s){var i;const o=I(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&&ct(o),s&&me(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 Kr(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,Y))===Y.mutable||!ee(n,e)?n:pt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Fr(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function yt(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;ut(t,(i,o,a)=>{const c=I(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(f=>a.add(i===f?u:f))}else Ee(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,yt(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 on(n){var e;const t=I(n);if(!ee(n,t?.options))return n;const r=pe(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?it(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Xt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(ut(s,(o,a)=>{if(t&&ce(ae(t.original,o),a))return;const c=on(a);c!==a&&(s===n&&i(),Ee(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return st(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function an(n){if(!he(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return on(n)}const ze=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(_,...E){return e(_,P=>t.call(this,P,...E),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=he(c)?an(c):c,d=Array.isArray(l.mark)?((_,E)=>{for(const P of l.mark){if(typeof P!="function")throw new Error(`Invalid mark: ${P}, 'mark' should be a function.`);const q=P(_,E);if(q)return q}}):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(!ee(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]=Kr(f,g);if(typeof r!="function"){if(!ee(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 w;try{w=u(y)}catch(_){throw ct(I(y)),_}const $=_=>{const E=I(y);if(!he(_)){if(_!==void 0&&!ce(_,y)&&E?.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 q=_?.[Mr];if(q){const H=q[0];return g.strict&&typeof _=="object"&&_!==null&&yt({rootDraft:E,value:_,useRawReturn:!0}),b([H])}if(_!==void 0)return typeof _=="object"&&_!==null&&yt({rootDraft:E,value:_}),b([_])}if(_===y||_===void 0)return b([]);const P=I(_);if(g===P.options){if(P.operated)throw new Error("Cannot return a modified child draft.");return b([an(_)])}return b([_])};return w instanceof Promise?w.then($,_=>{throw ct(I(y)),_}):$(w)})();Object.prototype.constructor.toString();function cn(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 un(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function We(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:cn(n,e)?Object.keys(n).every(t=>We(n[t],e[t])):!1}function bt(n){if(!je(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function ln(n,e){if(!je(n)||!je(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=je(n[r])&&je(e[r]);t[r]=s?ln(n[r],e[r]):e[r]}return t}function je(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function qr(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 dn(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 fn(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}fn(n[t],r),zr(n[t])&&delete n[t]}}function zr(n){return n&&Object.keys(n).length===0}const hn=/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$/,Wr={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 Vr(n){return new Date(n)}function Qr(n){return new Date(n+"Z")}const Br=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Gr(n){const e=n.match(Br);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 Hr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Jr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Yr(n){return new Date(n)}function Zr(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 Xr(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 es(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 ts(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 ns(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function rs(n){const e=n.match(hn);if(!e)return null;const[t]=e,r=Wr[t],s=new Date(n.replace(hn,"Z"));return new Date(s.getTime()-r*1e3)}const ss=[Gr,Jr,Zr,ts,Yr,Qr,Xr,Hr,Vr,ns,rs,es];function is(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function gt(n){for(const e of ss){const t=is(e,n);if(t)return t}return null}function os(n){try{const e=JSON.parse(n);return typeof e=="string"?gt(e):null}catch{return null}}function $e(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=gt(n)||os(n)||gt(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 le{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(wt(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 as(n){return n.cardinality==="one"}function mt(n){return n["value-type"]==="ref"}function wt(n){return n["value-type"]==="blob"}function we(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function te(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)&&te(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 pn(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=$e(u),o[2]=u),mt(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 yn(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function bn(n,e){return _e(n,e.triples,e.cardinalityInference,e.useDateObjects)}function gn(n,e){if(n)return new le(n.attrs,n.linkIndex);if(e&&"__type"in e)return new le(e.attrs,e.linkIndex)}function cs(n,e){return we(n.eav,[e])!==void 0}function _e(n,e,t,r){const s=pn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Re(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 mn(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(te(n.eav,[s,i,o]),te(n.aev,[i,s,o]),mt(a)&&te(n.vae,[o,i,s]))}let us=0;function wn(n,e,t){const[r,s,i]=t;let o;const a=we(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+us++}function _n(n,e,t){const r=Re(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=$e(o));const u=we(n.eav,[s,i,o])?.[3]??wn(n,a,r),l=[s,i,o,u];as(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)),mt(a)&&Q(n.vae,[o,i,s],l)}function ls(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!wt(a))throw new Error("merge operation is not supported for links");const c=we(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=ln(l,o),d=[s,i,f,wn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function _t(n,e,t){const[r,s]=t,i=Re(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])=>_t(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(te(n.aev,[u,o]),te(n.eav,[o,u]))}a.size===0&&te(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)&&(te(n.eav,[l,f,d]),te(n.aev,[f,l,d]),te(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&&_t(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&te(n.vae,[o])}function Sn(n,e,t){const r=pn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function ds(n,[e]){n.addAttr(e)}function Tn(n){return B(n.eav,3)}function fs(n,e,[t]){if(!e.getAttr(t))return;const r=Tn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),Sn(n,e,r)}function hs(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),Sn(n,e,Tn(n)))}function ps(n,e,t){const[r,...s]=t;switch(r){case"add-triple":_n(n,e,s);break;case"deep-merge-triple":ls(n,e,s);break;case"retract-triple":mn(n,e,s);break;case"delete-entity":_t(n,e,s);break;case"add-attr":ds(e,s);break;case"delete-attr":fs(n,e,s);break;case"update-attr":hs(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 Ve(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 ys(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function bs(n,[e,t,r]){switch(ys(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?Ve(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...Ve(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(...Ve(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...Ve(n,a,r));return i}default:return B(n.eav,3)}}function gs(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 be(n,e,t){return n.revIdents.get(e)?.get(t)}function ms(n,e){return n.blobAttrs.get(e)}function vn(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function ws(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return we(n.eav,[s,i])}function _s(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=vn(e,f["forward-identity"][1]);l=!!ws(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return ze({store:n,attrsStore:e},s=>{r.forEach(i=>{ps(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof le)return"immutable"}})}function Ss(n){return typeof n=="string"&&n.startsWith("?")}function Ts(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return kn(r,e,t)}return{...t,[n]:e}}function An(n,e,t){return n===e?t:null}function vs(n){return typeof n==="string"&&n.startsWith("?")?Ts:An}const As=["in","$in","$not","$isNull","$comparator"];function ks(n){for(const e of As)if(n.hasOwnProperty(e))return!0;return!1}function kn(n,e,t){return t?typeof n=="object"?ks(n)?t:null:vs(n)(n,e,t):null}function Is(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return kn(s,o,r)},t)}function Os(n,e,t){return Ms(n,e,t).map(r=>Is(e,r,t)).filter(r=>r)}function Cs(n,e,t){return e.or?e.or.patterns.flatMap(r=>St(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>St(n,s,r),t):t.flatMap(r=>Os(n,e,r))}function St(n,e,t=[{}]){return e.reduce((r,s)=>Cs(n,s,r),t)}function Tt(n,e){return Array.isArray(e)?e.map(t=>Tt(n,t)):Ss(e)?n[e]:e}function Es(n,{find:e,where:t}){return St(n,t).map(s=>Tt(s,e))}function Ms(n,e,t){return bs(n,Tt(t,e))}const Ps=/^(?:[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 Se(n){return typeof n=="string"&&Ps.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function js(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 vt;const $s=new Uint8Array(16);function Rs(){if(!vt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");vt=crypto.getRandomValues.bind(crypto)}return vt($s)}const In={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ds(n,e,t){if(In.randomUUID&&!n)return In.randomUUID();n=n||{};const r=n.random??n.rng?.()??Rs();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,js(r)}function On(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 xs(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 Us(n,e){return xs(On(n),On(e))}function j(){return Ds()}function Ls(n,e){return n.localeCompare(e)}function Ns(){let n=Ls;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Fs=Ns();let Cn=!0;const Ks=n=>{Cn=n};let qs=0;function De(n){return Qe(`_${n}`,qs++)}function Qe(n,e){return`?${n}-${e}`}class Te extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function zs(n,e){const t=vn(n,e);if(!t)throw new Te(`Could not find id attr for ${e}`);return t}function En(n,e,t,r){return[Ws(n,e,t,r)]}function Ws(n,e,t,r){return[n(t,r),zs(e,t).id,n(t,r),n("time",r)]}function Vs(n,e,t){return n.map(r=>r===e?t:r)}function Mn(n,e,t,r,s){const i=L(e,t,s),o=be(e,t,s),a=i||o;if(!a)throw new Te(`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),De("time")]:[n(u,d),a.id,n(f,r),De("time")];return[i?f:u,d,h,a,!!i]}function Pn(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=Pn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=Pn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Bs(n,e,t,r,s,i){const o=L(e,t,s),a=be(e,t,s),c=o||a;if(!c)throw new Te(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Te(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},De("time")]}return o?[n(t,r),c.id,Qs(c,i),De("time")]:[i,c.id,n(t,r),De("time")]}function Gs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=Mn(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function At(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Gs(n,e,t,r,o),f=Bs(n,e,c,u,a,i);return l.concat([f])}function Hs(n,e){return e?[e].concat(n):n}function Js([n,e]){return n==="or"&&Array.isArray(e)}function Ys([n,e]){return n==="and"&&Array.isArray(e)}function Zs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function jn(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Zs(n,o,u);return Rn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Xs(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function $n(n,e,t,r,s){return Xs(s).map(i=>At(n,e,t,r,i,{$isNull:!0}))}function Rn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Js([i,o]))return jn(n,"or",e,t,r,o);if(Ys([i,o]))return jn(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=At(n,e,t,r,a,o),u=$n(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:$n(n,e,t,r,a),joinSym:n(t,r)}}]:At(n,e,t,r,a,o)})}function ei(n,e,t,r){const s=Qe;return r?Rn(s,n,e,t,r).concat(En(s,n,e,t)):En(s,n,e,t)}function ti(n,e,t){return[n(e,t),n("time",t)]}function ni(n,e,t,r,s,i){const[o,a,c,u,l]=Mn(n,e,t,r,s),f=Vs(c,n(t,r),i);return[o,a,f,u,l]}function ri(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]=ni(n,t,r,s,h,u),b=Un(e,t,{etype:m,level:g,form:i[h],join:y}),w=p?b[0]:b;return{[h]:w}}catch(m){if(m instanceof Te)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function si(n,e,t){return t==="string"?Fs(n,e):n>e?1:-1}function xe(n,e,t,r,s){return e===r||e==null&&r==null?Us(n,t):r==null?1:e==null?-1:si(e,r,s)}function Be([n,e],[t,r],s){return xe(n,e,t,r,s)}function kt(n){return n==null?n:new Date(n).getTime()}function Dn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Be(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?kt(c):c,f=u==="date"?kt(i):i;return Be([a,l],[r,f],u)}function ii(n,e,t,r){const s=Dn(n,e,r);return t==="desc"?s>0:s<0}function oi(n,e,t,r){const s=Dn(n,e,r);return t==="desc"?s<0:s>0}function ai(n,e){const t=e[1];return n.getAttr(t)}function ci(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function ui(n,e,t,r){if(t)return ai(n,t);if(r)return ci(n,e,r)}function li(n,e,t){if(!Array.isArray(t.fields))return ms(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&&wt(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 di(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=xn(i),c=fi(i);let u=Es(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=ui(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=kt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Be(g,y,d?.["checked-data-type"])}:function(g,y){return Be(y,g,d?.["checked-data-type"])});let h={};const p=li(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ii(l,d,c,m)||f&&d&&oi(f,d,c,m))continue;const y=gs(n,p,g);y&&(h[g]=y)}return h}function fi(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function xn(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function hi(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!xn(s)&&(!o||!o["start-cursor"]))return[];const a=Hs(ei(e,t,r,s.$?.where),i),c=ti(Qe,t,r),u=s.$?.fields,l=di(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&&Cn&&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 pi(n,e,t){try{return hi(n,e,t)}catch(r){if(r instanceof Te)return{};throw r}}function Un(n,e,t){const r=pi(n,e,t);return ri(Qe,n,e,t,r)}function yi(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 It({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]=Un(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=yi(t)),r&&(o.aggregate=r),o}function bi(){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 gi=bi();function Ge(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(gi.has(i))return(o,a)=>Ge(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Ln(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function He(n){return n.startsWith("lookup__")}function Ot(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function mi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Ge(n,Ot(Ln(s,i)),[]);if(t==="__etype")return n;const r=t;return He(r)?Ge(n,Ot(r),[]):Ge(n,r,[])}})}function Ct(){return new Proxy({},{get(n,e){return mi(e)}})}const wi=Ct();function Nn(n){return n.__ops}function _i(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 Si(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 Ti(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Et(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 vi(n,e,t){if(!Ti(n,e,t))return L(n,e,t);const r=Et(t),s=L(n,e,r)||be(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Mt(n){return typeof n=="string"&&!He(n)?null:typeof n=="string"&&He(n)?Ot(n):Si(n)}function G(n,e,t){const r=Mt(t);if(r===null)return t;const[s,i]=r,o=vi(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Fn(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 Ai({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=be(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 Fn(n,e,t,s)}function ki({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=be(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 Fn(n,e,t,s)}function Ii(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 Kn({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:Ii(n,e,t,r)?{mode:"update"}:null}function Oi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(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=$e(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function Ci(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(i),c=G(t,r,s),u=Kn(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=$e(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ei({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function Mi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(i),c=G(t,r,s),u=Kn(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 Pi({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function ji(n){const[e,t,r,s,i]=n;if(!s)return n;const o={...s};return delete o.id,[e,t,r,o,...i?[i]:[]]}function $i(n,e){const[t,...r]=ji(e);switch(t){case"merge":return Mi(n,r);case"create":return Oi(n,r);case"update":return Ci(n,r);case"link":return Ai(n,r);case"unlink":return ki(n,r);case"delete":return Ei(n,r);case"ruleParams":return Pi(n,r);default:throw new Error(`unsupported action ${t}`)}}function Ri(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Di(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=Ri(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Je(n,e,t,r){const s=n?Di(n,e,t):null,i=j(),a=[j(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function xi(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 Ui(n,e,t){const r=xi(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[j(),s.on,s.label],"reverse-identity":[j(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function qn(n,e,t,r){const s=n?Ui(n,e,t):null,i=j(),o=[j(),e,t],a=[j(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const Li=new Set(["create","update","merge","link","unlink"]),Ni=new Set(["link","unlink"]),Fi=new Set(["create","update","merge"]),Ki=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Pt={"unique?":!0,"index?":!0},qi={...Pt,cardinality:"one"};function zi(n){const e=[],[t,r,s,i]=n;if(!Ki.has(t))return e;const o=Mt(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=Mt(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Wi({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 be(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(qn(e,d,h,qi))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of zi(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const w=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(w,g))f(w,Et(g));else{const $=o(w,g);$||c(Je(e,w,g,Pt)),u($)}}else if(l(h,g))f(h,Et(g));else{const y=o(h,g);y||c(Je(e,h,g,Pt)),u(y)}}for(const d of t){const[h,p,m,g]=d;if(Li.has(h)){const y=o(p,"id");u(y),y||c(Je(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const w=o(p,b);if(u(w),Fi.has(h)&&(w||c(Je(e,p,b,b==="id"?{"unique?":!0}:null))),Ni.has(h)){const $=a(p,b);!w&&!$&&c(qn(e,p,b)),u($)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new le(d,n.linkIndex),i]}return[n,i]}function Vi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Nn(c)),[s,i]=Wi(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>$i(o,c));return[...i,...a]}function zn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const ve="__meta";class jt{constructor(e,t){}}class $t{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(ve);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=[[ve,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(ve);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(()=>{zn(()=>{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(()=>{zn(()=>{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]=ze(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===ve||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const Qi=6,Bi=["kv","querySubs","syncSubs"];function Gi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Hi(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 Ji(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,ve);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Wn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Yi(n,e){const t=await Hi(`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=Ji(l,f,o);a.push(d)}else{const d=Wn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Wn(ve,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 Vn=new Map;class Rt extends jt{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=Yi(this._appId,a).catch(u=>{Gi("Error upgrading store from version 5 to 6.")(u)});Vn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=Vn.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 Bi)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 Dt{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 K 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,K),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class Ae extends K{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,Ae),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function ne(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new Ae({status:t.status,body:r}))}function Zi({apiURI:n,appId:e,email:t}){return ne(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Xi({apiURI:n,appId:e,email:t,code:r,refreshToken:s,extraFields:i}){return await ne(`${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}:{},...i?{"extra-fields":i}:{}})})}async function eo({apiURI:n,appId:e,refreshToken:t}){return await ne(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function to({apiURI:n,appId:e}){return await ne(`${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,extraFields:i}){return await ne(`${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,...i?{extra_fields:i}:{}})})}async function no({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i,extraFields:o}){return await ne(`${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,...o?{extra_fields:o}:{}})})}async function ro({apiURI:n,appId:e,refreshToken:t}){return await ne(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function so({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 ne(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function io({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await ne(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function oo({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await ne(`${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 ao(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function co({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await ne(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let xt=!1,Bn=!1,Gn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(xt=!!window.localStorage.getItem("devBackend"),Bn=!!window.localStorage.getItem("__instantLogging"),Gn=!!window.localStorage.getItem("__devtoolLocalDash"));function Hn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function uo(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Hn(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=Hn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function lo(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!un(n.user,e.user))||!cn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!un(n.peers[r],e.peers[r]))return!0;return!1}class Jn{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 Yn(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);Yn(t["child-nodes"],e)})}function Zn(n){const e=[];return Yn(n,e),e}function Ut(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 Lt="v0.22.184";function fo(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 Ye{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Ye(this.attrs,this.links)}}class Ze{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ze(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 Xn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ho=n=>n.valueType||"unknown",er=(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}},po=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!er(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)}},ke=(n,e,t,r,s)=>{const i=ho(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))po(u,l,i,e,r,t,`${s}.${u}`)}else if(!er(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},yo=(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"&&!Se(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);ke(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"&&!Se(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);ke(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)}ke(e,n,u,t,s)},tr=(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&&tr(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){ke(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){yo(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)ke(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!Se(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);ke(i,s,u,e,`${r}.${s}`)}}},bo=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Xn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Xn.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);tr(n.where,e,t,r?`${r}.where`:"where")}},nr=(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&&nr(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}.$`);bo(o,e,t,`${r}.$`,s)}},Nt=(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)}nr(t[r],r,e,r,0)}}},rr=n=>typeof n!="string"?!1:He(n)?!0:Se(n);class X extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const sr=n=>n.length>0?n.join(", "):"none",go=(n,e)=>new X(`Entity '${n}' does not exist in schema. Available entities: ${sr(e)}`),mo={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},wo=(n,e)=>n==null?!0:mo[e.valueType]?.(n)??!1,ir=(n,e)=>{const t=e.entities[n];if(!t)throw go(n,Object.keys(e.entities));return t},Ft=(n,e,t)=>{const r=ir(n,t);if(typeof e!="object"||e===null)throw new X(`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&&!wo(i,o))throw new X(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},or=(n,e,t)=>{const r=ir(n,t);if(typeof e!="object"||e===null)throw new X(`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 X(`Link '${s}' does not exist on entity '${n}'. Available links: ${sr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!rr(a))throw new X(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!rr(i))throw new X(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},_o={create:Ft,update:Ft,merge:Ft,link:or,unlink:or,delete:()=>{}},So=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!Se(s))throw new X(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new X(`Entity name must be a string, but received: ${typeof r}`);const o=_o[t];o&&i!==void 0&&o(r,i,e)},ar=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new X(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new X(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new X(`Transaction operation must be an array, but received: ${typeof s}`);So(s,e)}}};let cr=0;class ur{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${cr++}`,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 lr{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}_${cr++}`,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 To(n,e){const t=n.values;if(t){const r=gn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=bn(r,s.store);t.attrsStore=r}}return n}function vo(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=yn(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function Ao(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 Kt(n,e,t){return It({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function dr(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=we(e.eav,[r,s,r]);return i?i[3]:-1}function fr(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":_n(n,e,s);break;case"removed":mn(n,e,s);break}}function ko(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 Xe(n,e){return{[n.table]:e.map(t=>t.entity)}}function Io(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 Oo(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return xe(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return xe(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 xe(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return xe(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var hr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(hr||{});class Co{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 $t({persister:t,merge:Ao,serialize:vo,parse:(a,c)=>To(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(j(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend(j(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){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:Xe(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=Kt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:dr(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:Xe(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:Xe(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(cs(b.store,m)){fr(b.store,u.attrsStore,g);const w=Kt(s,b.store,u.attrsStore),$=ko(b.store,u.attrsStore,g)[m];w?(f.push({oldEntity:b.entity,newEntity:w,changedFields:$||{}}),b.entity=w):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);fr(y,u.attrsStore,g);const b=Kt(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:dr(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=Io(s,this.getAttrs);Oo(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Xe(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 Eo({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=j();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],w=new TextEncoder;function $(){f=!0;for(const S of d)S(a??void 0)}function _(S){return d.push(S),f&&S(a??void 0),()=>{const O=d.indexOf(S);O!==-1&&d.splice(O,1)}}function E(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 P(){for(const S of p)try{S()}catch{}}function q(S){return h.push(S),o&&S(o),()=>{const O=h.indexOf(S);O!==-1&&h.splice(O,1)}}function H(S){o=S;for(const O of h)O(o)}function de(){m=!0}function v(S){let O=g,V=0,J=0;for(const{byteLen:se}of b){const ue=O+se;if(ue>S)break;O=ue,V++,J+=se}V>0&&(g+=J,y-=J,b.splice(0,V))}function A(S,O){a=O,$(),S.error(O),P()}async function k(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:O,offset:V}=S;o=O,v(V),b.length&&r({streamId:O,chunks:b.map(J=>J.chunk),offset:g}),m=!1;break}case"disconnect":{de();break}case"error":{c&&A(c,S.error);break}}}function M(){de(),k()}function x({offset:S,done:O}){v(S),O&&(l=!0,P())}function N(S){return l?(A(S,new K("Stream has been closed.")),null):o||(A(S,new K("Stream has not been initialized.")),null)}async function re(S){c=S;let O=!0,V=0;for(;O;){let J=Date.now()+Math.min(15e3,500*(V-1));O=!1;const se=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(se.type){case"ok":{const{streamId:ue,offset:Ht}=se;if(Ht!==0){const ge=new K("Write stream is corrupted");A(S,ge);return}H(ue),s(ue,{onDisconnect:de,onFlush:x,onConnectionReconnect:k,onAppendFailed:M}),m=!1;return}case"disconnect":{O=!0,de(),V++,await new Promise(ue=>{setTimeout(ue,Math.max(0,J-Date.now()))});break}case"error":{A(S,se.error);return}}}}class fe extends n{constructor(O,V){super(O,V)}async streamId(){return o||new Promise((O,V)=>{const J=[],se=()=>{for(const ge of J)ge()},ue=ge=>{O(ge),se()},Ht=ge=>{V(ge||new K("Stream is closed.")),se()};J.push(q(ue)),J.push(_(Ht))})}}return{stream:new fe({async start(S){try{await re(S)}catch(O){A(S,O)}},write(S,O){const V=N(O);if(V){const J=w.encode(S).length;b.push({chunk:S,byteLen:J});const se=g+y;y+=J,m||r({streamId:V,chunks:[S],offset:se})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):P(),$()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):P(),$()}}),addCompleteCb:E,closed(){return f}}}class Mo{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 Po({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 w=l.indexOf(b);w!==-1&&l.splice(w,1)}}function h(b,w){b.error(w),f()}let p=0;async function m(b,w){c=j();const $={...b||{},eventId:c};for await(const _ of t($)){if(i)return;if(_.type==="reconnect")return{retry:!0};if(_.type==="error"){h(w,_.error);return}if(_.offset>s){h(w,new K("Stream is corrupted.")),i=!0;return}let E=s-_.offset;if(_.files&&_.files.length){const P=new AbortController;let q=fetch(_.files[0].url,{signal:P.signal});for(let H=0;H<_.files.length;H++){const de=_.files[H+1],A=await q;if(de&&(q=fetch(de.url,{signal:P.signal})),!A.ok){if(p++,p>10){h(w,new K("Unable to process stream."));return}return{retry:!0}}if(A.body){const k=A.body.getReader();try{for(;;){const{done:M,value:x}=await k.read();if(M)break;if(i){P.abort();return}let N=x;if(E>0&&(N=x.subarray(E),E-=x.length-N.length),!N.length)continue;s+=N.length;const re=o.decode(N);w.enqueue(re)}}finally{k.releaseLock()}}else{const k=await A.arrayBuffer();let M=k;if(i){P.abort();return}if(E>0&&(M=new Uint8Array(k).subarray(E),E-=k.byteLength-M.length),!M.byteLength)continue;s+=M.byteLength;const x=o.decode(M);w.enqueue(x)}}}if(p=0,_.content){let P=_.content,q=a.encode(_.content);if(E>0){const H=q.subarray(E);if(E-=q.length-H.length,!H.length)continue;q=H,P=o.decode(H)}s+=q.length,w.enqueue(P)}}}async function g(b){let w=!0,$=0;for(;w;){w=!1;let _=Date.now()+Math.min(15e3,500*($-1));(await m({...e,offset:s},b))?.retry&&(w=!0,$++,_<Date.now()-3e5&&($=0),await new Promise(P=>{setTimeout(P,Math.max(0,_-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 pr{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}=Eo({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}=Po({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=j();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return e.ruleParams&&(i["rule-params"]=e.ruleParams),this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend(j(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new Mo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend(j(),t),delete this.readStreamIterators[e]}onStreamAppend(e){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 K(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!==oe.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 K(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 K(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const oe={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},jo=3e4,$o=3e4,Ro=200,Do=1e3*60,xo={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},qt="_instant_oauth_redirect",zt="_instant_extra_fields_id",et="oauthExtraFields",Ie="currentUser";function Uo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new ur(`${r}?app_id=${e}`);switch(n){case"ws":return new ur(`${r}?app_id=${e}`);case"sse":return new lr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Lo(){return typeof window<"u"||typeof chrome<"u"}const yr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function No(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=gn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=bn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Fo(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:yn(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Ko(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function qo(n,e){return n==="pendingMutations"?[...e.entries()]:e}function zo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function Wt(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 br{attrs;_isOnline=!0;_isShutdown=!1;status=oe.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=Rt,r=Dt,s,i){if(this._EventSource=i,this.config={...xo,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??$o,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Ro,this._log=fo(e.verbose||xt||Bn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":Lt},this.config.schema&&(this._linkIndex=Ut(this.config.schema)),!!Lo()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!Se(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 Co(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>_e(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new pr({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)},Do),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",oe.CLOSED),this._setStatus(oe.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?Ut(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 $t({persister:new e(this.config.appId,"querySubs"),merge:zo,serialize:Fo,parse:(t,r)=>No(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 $t({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:qo,parse:Ko,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(Ie),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 Ae({body:a,status:o??0}))}else s.reject(new K(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=_e(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(yr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(oe.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=Zn(a),d=this.ensureAttrs(),h=_e(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=Wt(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Zn(p),y=this.ensureAttrs(),b=_e(y,g,r,this.config.useDateObjects),{store:w,attrsStore:$}=this._applyOptimisticUpdates(b,y,l,c),_=p?.[0]?.data?.["page-info"],E=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:w,attrsStore:$,pageInfo:_,aggregate:E}});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(oe.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(T,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(T=typeof globalThis<"u"?globalThis:T||self,R(T.instant={}))})(this,(function(T){"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"},Jt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),Mr=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Ne=Symbol.iterator,Y={mutable:"mutable",immutable:"immutable"},rt={};function Ce(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Yt(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 st(n){return Object.getPrototypeOf(n)===Set.prototype}function it(n){return Object.getPrototypeOf(n)===Map.prototype}function Z(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function he(n){return!!I(n)}function I(n){return typeof n!="object"?null:n?.[Jt]}function ot(n){var e;const t=I(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function ee(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,Y))===Y.immutable||typeof t=="function")}function Zt(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=I(ae(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||Ce(t,i)))return null;e.push(i)}if(n.parent)return Zt(n.parent,e);e.reverse();try{Pr(n.copy,e)}catch{return null}return e}function pe(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ae(n,e){return pe(n)===2?n.get(e):n[e]}function Ee(n,e,t){pe(n)===2?n.set(e,t):n[e]=t}function at(n,e){const t=I(n);return(t?Z(t):n)[e]}function ce(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function ct(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function ye(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 Pr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ae(pe(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function jr(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 $r=Object.prototype.propertyIsEnumerable;function Xt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!st(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(!it(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,Y),t!==void 0)&&t!==Y.mutable){if(t===Y.immutable)return jr(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=>{$r.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=Xt(n.original,n.options))}function Me(n){if(!ee(n))return ot(n);if(Array.isArray(n))return n.map(Me);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Me(s)]);if(!it(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(Me);if(!st(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]=Me(n[t]);return e}function Fe(n){return he(n)?Me(n):n}function ie(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&ie(n.parent))}function en(){throw new Error("Cannot modify frozen object")}function me(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)||he(n)){r.pop(),s.pop();return}switch(pe(n)){case 2:for(const[a,c]of n)me(a,a,t,r,s),me(c,a,t,r,s);n.set=n.clear=n.delete=en;break;case 3:for(const a of n)me(a,a,t,r,s);n.add=n.clear=n.delete=en;break;case 1:Object.freeze(n);let o=0;for(const a of n)me(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];me(c,a,t,r,s)})}r.pop(),s.pop()}function ut(n,e){const t=pe(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 tn(n,e,t){if(he(n)||!ee(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),ut(n,(i,o)=>{var a;if(he(o)){const c=I(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ee(r?s:n,i,u)}else tn(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 Rr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&tn(ae(t,e),n.finalities.handledSet,n.options)}function lt(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(ot(e))}))}function dt(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Zt(n);i&&e(n,i,t,r)}n.finalized=!0}}function ft(n,e,t,r){const s=I(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ce(ae(c,e),t)){let u=s.original;s.copy&&(u=s.copy),lt(n),dt(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)),Ee(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),ee(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ce(ae(i,e),t)&&Rr(n,e)})}function Dr(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=ye(l,s);t.push({op:U.Replace,path:f,value:Fe(c[u])}),r.push({op:U.Replace,path:f,value:Fe(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=ye(l,s);t.push({op:U.Add,path:f,value:Fe(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=ye(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=ye(f,s);r.push({op:U.Remove,path:d})}}}function xr({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ae(n,c),l=Fe(ae(e,c)),f=a?Ce(n,c)?U.Replace:U.Add:U.Remove;if(ce(u,l)&&f===U.Replace)return;const d=r.concat(c),h=ye(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 Ur({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=ye(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=ye(c,i);r.push({op:U.Add,path:u,value:a}),s.unshift({op:U.Remove,path:u,value:a})}o+=1})}function Pe(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return xr(n,e,t,r,s);case 1:return Dr(n,e,t,r,s);case 3:return Ur(n,e,t,r,s)}}const Ke=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!ee(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},ht={get size(){return Z(I(this)).size},has(n){return Z(I(this)).has(n)},set(n,e){const t=I(this),r=Z(t);return(!r.has(n)||!ce(r.get(n),e))&&(z(t),ie(t),t.assignedMap.set(n,!0),t.copy.set(n,e),ft(t,n,e,Pe)),this},delete(n){if(!this.has(n))return!1;const e=I(this);return z(e),ie(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=I(this);if(this.size){z(n),ie(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=I(this);Z(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=I(this),s=Z(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,Y))===Y.mutable;if(r.options.strict&&Ke(s,r.options,i),i||r.finalized||!ee(s,r.options)||s!==r.original.get(n))return s;const o=rt.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Z(I(this)).keys()},values(){const n=this.keys();return{[Ne]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Ne]:()=>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]}}}},[Ne](){return this.entries()}},Lr=Reflect.ownKeys(ht),nn=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=I(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,Y))===Y.mutable;if(n.options.strict&&Ke(o,n.options,u),!u&&!c&&ee(o,n.options)&&!n.finalized&&n.original.has(o)){const l=rt.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 I(this).setMap.size},has(n){const e=I(this);if(e.setMap.has(n))return!0;z(e);const t=I(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=I(this);return this.has(n)||(z(e),ie(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),ft(e,n,n,Pe)),this},delete(n){if(!this.has(n))return!1;const e=I(this);z(e),ie(e);const t=I(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=I(this);z(n),ie(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=I(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:nn(n,e,{isValuesIterator:!0})}},entries(){const n=I(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:nn(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Ne](){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 Nr=Reflect.ownKeys(qe),rn=new WeakSet,sn={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&rn.has(i))return i;if(e===Jt)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,Y),o===Y.mutable)return n.options.strict&&Ke(u,n.options,!0),u}const a=Z(n);if(a instanceof Map&&Lr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(ht,"size").get.call(n.proxy);const u=ht[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&Nr.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(!Ce(a,e)){const u=Yt(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&&Ke(c,n.options),n.finalized||!ee(c,n.options))return c;if(c===at(n.original,e)){if(z(n),n.copy[e]=pt({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=I(n.copy[e]);return z(u),ie(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=Yt(Z(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=at(Z(n),e),a=I(o);return a&&ce(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):(ce(t,o)&&(t!==void 0||Ce(n.original,e))||(z(n),ie(n),Ce(n.original,e)&&ce(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,ft(n,e,t,Pe)),!0)},has(n,e){return e in Z(n)},ownKeys(n){return Reflect.ownKeys(Z(n))},getOwnPropertyDescriptor(n,e){const t=Z(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?sn.set.call(this,n,e,void 0,n.proxy):(at(n.original,e)!==void 0||e in n.original?(z(n),ie(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 pt(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=pe(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,sn);if(s.revoke.push(u),rn.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=I(c);let g=l.type===3?l.setMap:l.copy;const y=ae(g,r),b=I(y);if(b){let w=b.original;b.operated&&(w=ot(y)),lt(b),dt(b,Pe,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(w,b.original)),Ee(g,r,w)}(p=m.callbacks)===null||p===void 0||p.forEach(w=>{w(f,d)})})}else{const l=I(c);l.finalities.draft.push((f,d)=>{lt(l),dt(l,Pe,f,d)})}return c}rt.createDraft=pt;function Fr(n,e,t,r,s){var i;const o=I(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&&ct(o),s&&me(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 Kr(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,Y))===Y.mutable||!ee(n,e)?n:pt({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Fr(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function yt(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;ut(t,(i,o,a)=>{const c=I(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(f=>a.add(i===f?u:f))}else Ee(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,yt(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 on(n){var e;const t=I(n);if(!ee(n,t?.options))return n;const r=pe(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?it(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Xt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(ut(s,(o,a)=>{if(t&&ce(ae(t.original,o),a))return;const c=on(a);c!==a&&(s===n&&i(),Ee(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return st(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function an(n){if(!he(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return on(n)}const ze=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(_,...E){return e(_,P=>t.call(this,P,...E),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=he(c)?an(c):c,d=Array.isArray(l.mark)?((_,E)=>{for(const P of l.mark){if(typeof P!="function")throw new Error(`Invalid mark: ${P}, 'mark' should be a function.`);const q=P(_,E);if(q)return q}}):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(!ee(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]=Kr(f,g);if(typeof r!="function"){if(!ee(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 w;try{w=u(y)}catch(_){throw ct(I(y)),_}const $=_=>{const E=I(y);if(!he(_)){if(_!==void 0&&!ce(_,y)&&E?.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 q=_?.[Mr];if(q){const H=q[0];return g.strict&&typeof _=="object"&&_!==null&&yt({rootDraft:E,value:_,useRawReturn:!0}),b([H])}if(_!==void 0)return typeof _=="object"&&_!==null&&yt({rootDraft:E,value:_}),b([_])}if(_===y||_===void 0)return b([]);const P=I(_);if(g===P.options){if(P.operated)throw new Error("Cannot return a modified child draft.");return b([an(_)])}return b([_])};return w instanceof Promise?w.then($,_=>{throw ct(I(y)),_}):$(w)})();Object.prototype.constructor.toString();function cn(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 un(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function We(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:cn(n,e)?Object.keys(n).every(t=>We(n[t],e[t])):!1}function bt(n){if(!je(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function ln(n,e){if(!je(n)||!je(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=je(n[r])&&je(e[r]);t[r]=s?ln(n[r],e[r]):e[r]}return t}function je(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function qr(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 dn(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 fn(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}fn(n[t],r),zr(n[t])&&delete n[t]}}function zr(n){return n&&Object.keys(n).length===0}const hn=/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$/,Wr={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 Vr(n){return new Date(n)}function Qr(n){return new Date(n+"Z")}const Br=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Gr(n){const e=n.match(Br);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 Hr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Jr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Yr(n){return new Date(n)}function Zr(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 Xr(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 es(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 ts(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 ns(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function rs(n){const e=n.match(hn);if(!e)return null;const[t]=e,r=Wr[t],s=new Date(n.replace(hn,"Z"));return new Date(s.getTime()-r*1e3)}const ss=[Gr,Jr,Zr,ts,Yr,Qr,Xr,Hr,Vr,ns,rs,es];function is(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function gt(n){for(const e of ss){const t=is(e,n);if(t)return t}return null}function os(n){try{const e=JSON.parse(n);return typeof e=="string"?gt(e):null}catch{return null}}function $e(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=gt(n)||os(n)||gt(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 le{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(wt(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 as(n){return n.cardinality==="one"}function mt(n){return n["value-type"]==="ref"}function wt(n){return n["value-type"]==="blob"}function we(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function te(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)&&te(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 pn(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=$e(u),o[2]=u),mt(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 yn(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function bn(n,e){return _e(n,e.triples,e.cardinalityInference,e.useDateObjects)}function gn(n,e){if(n)return new le(n.attrs,n.linkIndex);if(e&&"__type"in e)return new le(e.attrs,e.linkIndex)}function cs(n,e){return we(n.eav,[e])!==void 0}function _e(n,e,t,r){const s=pn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function Re(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 mn(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(te(n.eav,[s,i,o]),te(n.aev,[i,s,o]),mt(a)&&te(n.vae,[o,i,s]))}let us=0;function wn(n,e,t){const[r,s,i]=t;let o;const a=we(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+us++}function _n(n,e,t){const r=Re(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=$e(o));const u=we(n.eav,[s,i,o])?.[3]??wn(n,a,r),l=[s,i,o,u];as(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)),mt(a)&&Q(n.vae,[o,i,s],l)}function ls(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!wt(a))throw new Error("merge operation is not supported for links");const c=we(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=ln(l,o),d=[s,i,f,wn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function _t(n,e,t){const[r,s]=t,i=Re(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])=>_t(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(te(n.aev,[u,o]),te(n.eav,[o,u]))}a.size===0&&te(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)&&(te(n.eav,[l,f,d]),te(n.aev,[f,l,d]),te(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&&_t(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&te(n.vae,[o])}function Sn(n,e,t){const r=pn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function ds(n,[e]){n.addAttr(e)}function Tn(n){return B(n.eav,3)}function fs(n,e,[t]){if(!e.getAttr(t))return;const r=Tn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),Sn(n,e,r)}function hs(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),Sn(n,e,Tn(n)))}function ps(n,e,t){const[r,...s]=t;switch(r){case"add-triple":_n(n,e,s);break;case"deep-merge-triple":ls(n,e,s);break;case"retract-triple":mn(n,e,s);break;case"delete-entity":_t(n,e,s);break;case"add-attr":ds(e,s);break;case"delete-attr":fs(n,e,s);break;case"update-attr":hs(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 Ve(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 ys(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function bs(n,[e,t,r]){switch(ys(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?Ve(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...Ve(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(...Ve(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...Ve(n,a,r));return i}default:return B(n.eav,3)}}function gs(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 be(n,e,t){return n.revIdents.get(e)?.get(t)}function ms(n,e){return n.blobAttrs.get(e)}function vn(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function ws(n,e,t){const r=Re(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return we(n.eav,[s,i])}function _s(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=vn(e,f["forward-identity"][1]);l=!!ws(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return ze({store:n,attrsStore:e},s=>{r.forEach(i=>{ps(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof le)return"immutable"}})}function Ss(n){return typeof n=="string"&&n.startsWith("?")}function Ts(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return kn(r,e,t)}return{...t,[n]:e}}function An(n,e,t){return n===e?t:null}function vs(n){return typeof n==="string"&&n.startsWith("?")?Ts:An}const As=["in","$in","$not","$isNull","$comparator"];function ks(n){for(const e of As)if(n.hasOwnProperty(e))return!0;return!1}function kn(n,e,t){return t?typeof n=="object"?ks(n)?t:null:vs(n)(n,e,t):null}function Is(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return kn(s,o,r)},t)}function Os(n,e,t){return Ms(n,e,t).map(r=>Is(e,r,t)).filter(r=>r)}function Cs(n,e,t){return e.or?e.or.patterns.flatMap(r=>St(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>St(n,s,r),t):t.flatMap(r=>Os(n,e,r))}function St(n,e,t=[{}]){return e.reduce((r,s)=>Cs(n,s,r),t)}function Tt(n,e){return Array.isArray(e)?e.map(t=>Tt(n,t)):Ss(e)?n[e]:e}function Es(n,{find:e,where:t}){return St(n,t).map(s=>Tt(s,e))}function Ms(n,e,t){return bs(n,Tt(t,e))}const Ps=/^(?:[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 Se(n){return typeof n=="string"&&Ps.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function js(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 vt;const $s=new Uint8Array(16);function Rs(){if(!vt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");vt=crypto.getRandomValues.bind(crypto)}return vt($s)}const In={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Ds(n,e,t){if(In.randomUUID&&!n)return In.randomUUID();n=n||{};const r=n.random??n.rng?.()??Rs();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,js(r)}function On(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 xs(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 Us(n,e){return xs(On(n),On(e))}function j(){return Ds()}function Ls(n,e){return n.localeCompare(e)}function Ns(){let n=Ls;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Fs=Ns();let Cn=!0;const Ks=n=>{Cn=n};let qs=0;function De(n){return Qe(`_${n}`,qs++)}function Qe(n,e){return`?${n}-${e}`}class Te extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function zs(n,e){const t=vn(n,e);if(!t)throw new Te(`Could not find id attr for ${e}`);return t}function En(n,e,t,r){return[Ws(n,e,t,r)]}function Ws(n,e,t,r){return[n(t,r),zs(e,t).id,n(t,r),n("time",r)]}function Vs(n,e,t){return n.map(r=>r===e?t:r)}function Mn(n,e,t,r,s){const i=L(e,t,s),o=be(e,t,s),a=i||o;if(!a)throw new Te(`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),De("time")]:[n(u,d),a.id,n(f,r),De("time")];return[i?f:u,d,h,a,!!i]}function Pn(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=Pn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=Pn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Bs(n,e,t,r,s,i){const o=L(e,t,s),a=be(e,t,s),c=o||a;if(!c)throw new Te(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Te(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},De("time")]}return o?[n(t,r),c.id,Qs(c,i),De("time")]:[i,c.id,n(t,r),De("time")]}function Gs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=Mn(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function At(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Gs(n,e,t,r,o),f=Bs(n,e,c,u,a,i);return l.concat([f])}function Hs(n,e){return e?[e].concat(n):n}function Js([n,e]){return n==="or"&&Array.isArray(e)}function Ys([n,e]){return n==="and"&&Array.isArray(e)}function Zs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function jn(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Zs(n,o,u);return Rn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Xs(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function $n(n,e,t,r,s){return Xs(s).map(i=>At(n,e,t,r,i,{$isNull:!0}))}function Rn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Js([i,o]))return jn(n,"or",e,t,r,o);if(Ys([i,o]))return jn(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=At(n,e,t,r,a,o),u=$n(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:$n(n,e,t,r,a),joinSym:n(t,r)}}]:At(n,e,t,r,a,o)})}function ei(n,e,t,r){const s=Qe;return r?Rn(s,n,e,t,r).concat(En(s,n,e,t)):En(s,n,e,t)}function ti(n,e,t){return[n(e,t),n("time",t)]}function ni(n,e,t,r,s,i){const[o,a,c,u,l]=Mn(n,e,t,r,s),f=Vs(c,n(t,r),i);return[o,a,f,u,l]}function ri(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]=ni(n,t,r,s,h,u),b=Un(e,t,{etype:m,level:g,form:i[h],join:y}),w=p?b[0]:b;return{[h]:w}}catch(m){if(m instanceof Te)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function si(n,e,t){return t==="string"?Fs(n,e):n>e?1:-1}function xe(n,e,t,r,s){return e===r||e==null&&r==null?Us(n,t):r==null?1:e==null?-1:si(e,r,s)}function Be([n,e],[t,r],s){return xe(n,e,t,r,s)}function kt(n){return n==null?n:new Date(n).getTime()}function Dn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Be(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?kt(c):c,f=u==="date"?kt(i):i;return Be([a,l],[r,f],u)}function ii(n,e,t,r){const s=Dn(n,e,r);return t==="desc"?s>0:s<0}function oi(n,e,t,r){const s=Dn(n,e,r);return t==="desc"?s<0:s>0}function ai(n,e){const t=e[1];return n.getAttr(t)}function ci(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function ui(n,e,t,r){if(t)return ai(n,t);if(r)return ci(n,e,r)}function li(n,e,t){if(!Array.isArray(t.fields))return ms(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&&wt(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 di(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=xn(i),c=fi(i);let u=Es(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=ui(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=kt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Be(g,y,d?.["checked-data-type"])}:function(g,y){return Be(y,g,d?.["checked-data-type"])});let h={};const p=li(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ii(l,d,c,m)||f&&d&&oi(f,d,c,m))continue;const y=gs(n,p,g);y&&(h[g]=y)}return h}function fi(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function xn(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function hi(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!xn(s)&&(!o||!o["start-cursor"]))return[];const a=Hs(ei(e,t,r,s.$?.where),i),c=ti(Qe,t,r),u=s.$?.fields,l=di(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&&Cn&&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 pi(n,e,t){try{return hi(n,e,t)}catch(r){if(r instanceof Te)return{};throw r}}function Un(n,e,t){const r=pi(n,e,t);return ri(Qe,n,e,t,r)}function yi(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 It({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]=Un(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=yi(t)),r&&(o.aggregate=r),o}function bi(){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 gi=bi();function Ge(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(gi.has(i))return(o,a)=>Ge(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Ln(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function He(n){return n.startsWith("lookup__")}function Ot(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function mi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Ge(n,Ot(Ln(s,i)),[]);if(t==="__etype")return n;const r=t;return He(r)?Ge(n,Ot(r),[]):Ge(n,r,[])}})}function Ct(){return new Proxy({},{get(n,e){return mi(e)}})}const wi=Ct();function Nn(n){return n.__ops}function _i(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 Si(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 Ti(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Et(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 vi(n,e,t){if(!Ti(n,e,t))return L(n,e,t);const r=Et(t),s=L(n,e,r)||be(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Mt(n){return typeof n=="string"&&!He(n)?null:typeof n=="string"&&He(n)?Ot(n):Si(n)}function G(n,e,t){const r=Mt(t);if(r===null)return t;const[s,i]=r,o=vi(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Fn(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 Ai({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=be(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 Fn(n,e,t,s)}function ki({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=be(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 Fn(n,e,t,s)}function Ii(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 Kn({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:Ii(n,e,t,r)?{mode:"update"}:null}function Oi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(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=$e(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function Ci(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(i),c=G(t,r,s),u=Kn(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=$e(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ei({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function Mi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=bt(i),c=G(t,r,s),u=Kn(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 Pi({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function ji(n){const[e,t,r,s,i]=n;if(!s)return n;const o={...s};return delete o.id,[e,t,r,o,...i?[i]:[]]}function $i(n,e){const[t,...r]=ji(e);switch(t){case"merge":return Mi(n,r);case"create":return Oi(n,r);case"update":return Ci(n,r);case"link":return Ai(n,r);case"unlink":return ki(n,r);case"delete":return Ei(n,r);case"ruleParams":return Pi(n,r);default:throw new Error(`unsupported action ${t}`)}}function Ri(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function Di(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=Ri(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Je(n,e,t,r){const s=n?Di(n,e,t):null,i=j(),a=[j(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function xi(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 Ui(n,e,t){const r=xi(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[j(),s.on,s.label],"reverse-identity":[j(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function qn(n,e,t,r){const s=n?Ui(n,e,t):null,i=j(),o=[j(),e,t],a=[j(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const Li=new Set(["create","update","merge","link","unlink"]),Ni=new Set(["link","unlink"]),Fi=new Set(["create","update","merge"]),Ki=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Pt={"unique?":!0,"index?":!0},qi={...Pt,cardinality:"one"};function zi(n){const e=[],[t,r,s,i]=n;if(!Ki.has(t))return e;const o=Mt(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=Mt(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Wi({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 be(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(qn(e,d,h,qi))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of zi(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const w=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(w,g))f(w,Et(g));else{const $=o(w,g);$||c(Je(e,w,g,Pt)),u($)}}else if(l(h,g))f(h,Et(g));else{const y=o(h,g);y||c(Je(e,h,g,Pt)),u(y)}}for(const d of t){const[h,p,m,g]=d;if(Li.has(h)){const y=o(p,"id");u(y),y||c(Je(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const w=o(p,b);if(u(w),Fi.has(h)&&(w||c(Je(e,p,b,b==="id"?{"unique?":!0}:null))),Ni.has(h)){const $=a(p,b);!w&&!$&&c(qn(e,p,b)),u($)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new le(d,n.linkIndex),i]}return[n,i]}function Vi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Nn(c)),[s,i]=Wi(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>$i(o,c));return[...i,...a]}function zn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const ve="__meta";class jt{constructor(e,t){}}class $t{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(ve);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=[[ve,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(ve);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(()=>{zn(()=>{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(()=>{zn(()=>{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]=ze(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===ve||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const Qi=6,Bi=["kv","querySubs","syncSubs"];function Gi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Hi(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 Ji(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,ve);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Wn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Yi(n,e){const t=await Hi(`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=Ji(l,f,o);a.push(d)}else{const d=Wn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Wn(ve,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 Vn=new Map;class Rt extends jt{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=Yi(this._appId,a).catch(u=>{Gi("Error upgrading store from version 5 to 6.")(u)});Vn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=Vn.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 Bi)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 Dt{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 K 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,K),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class Ae extends K{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,Ae),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function ne(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new Ae({status:t.status,body:r}))}function Zi({apiURI:n,appId:e,email:t}){return ne(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Xi({apiURI:n,appId:e,email:t,code:r,refreshToken:s,extraFields:i}){return await ne(`${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}:{},...i?{"extra-fields":i}:{}})})}async function eo({apiURI:n,appId:e,refreshToken:t}){return await ne(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function to({apiURI:n,appId:e}){return await ne(`${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,extraFields:i}){return await ne(`${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,...i?{extra_fields:i}:{}})})}async function no({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i,extraFields:o}){return await ne(`${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,...o?{extra_fields:o}:{}})})}async function ro({apiURI:n,appId:e,refreshToken:t}){return await ne(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function so({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 ne(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function io({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await ne(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function oo({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await ne(`${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 ao(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function co({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await ne(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let xt=!1,Bn=!1,Gn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(xt=!!window.localStorage.getItem("devBackend"),Bn=!!window.localStorage.getItem("__instantLogging"),Gn=!!window.localStorage.getItem("__devtoolLocalDash"));function Hn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function uo(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Hn(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=Hn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function lo(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!un(n.user,e.user))||!cn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!un(n.peers[r],e.peers[r]))return!0;return!1}class Jn{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 Yn(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);Yn(t["child-nodes"],e)})}function Zn(n){const e=[];return Yn(n,e),e}function Ut(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 Lt="v0.22.185";function fo(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 Ye{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Ye(this.attrs,this.links)}}class Ze{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ze(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 Xn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ho=n=>n.valueType||"unknown",er=(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}},po=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!er(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)}},ke=(n,e,t,r,s)=>{const i=ho(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))po(u,l,i,e,r,t,`${s}.${u}`)}else if(!er(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},yo=(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"&&!Se(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);ke(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"&&!Se(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);ke(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)}ke(e,n,u,t,s)},tr=(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&&tr(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){ke(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){yo(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)ke(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!Se(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);ke(i,s,u,e,`${r}.${s}`)}}},bo=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Xn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Xn.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);tr(n.where,e,t,r?`${r}.where`:"where")}},nr=(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&&nr(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}.$`);bo(o,e,t,`${r}.$`,s)}},Nt=(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)}nr(t[r],r,e,r,0)}}},rr=n=>typeof n!="string"?!1:He(n)?!0:Se(n);class X extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const sr=n=>n.length>0?n.join(", "):"none",go=(n,e)=>new X(`Entity '${n}' does not exist in schema. Available entities: ${sr(e)}`),mo={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},wo=(n,e)=>n==null?!0:mo[e.valueType]?.(n)??!1,ir=(n,e)=>{const t=e.entities[n];if(!t)throw go(n,Object.keys(e.entities));return t},Ft=(n,e,t)=>{const r=ir(n,t);if(typeof e!="object"||e===null)throw new X(`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&&!wo(i,o))throw new X(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},or=(n,e,t)=>{const r=ir(n,t);if(typeof e!="object"||e===null)throw new X(`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 X(`Link '${s}' does not exist on entity '${n}'. Available links: ${sr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!rr(a))throw new X(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!rr(i))throw new X(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},_o={create:Ft,update:Ft,merge:Ft,link:or,unlink:or,delete:()=>{}},So=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!Se(s))throw new X(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new X(`Entity name must be a string, but received: ${typeof r}`);const o=_o[t];o&&i!==void 0&&o(r,i,e)},ar=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new X(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new X(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new X(`Transaction operation must be an array, but received: ${typeof s}`);So(s,e)}}};let cr=0;class ur{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${cr++}`,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 lr{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}_${cr++}`,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 To(n,e){const t=n.values;if(t){const r=gn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=bn(r,s.store);t.attrsStore=r}}return n}function vo(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=yn(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function Ao(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 Kt(n,e,t){return It({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function dr(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=we(e.eav,[r,s,r]);return i?i[3]:-1}function fr(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":_n(n,e,s);break;case"removed":mn(n,e,s);break}}function ko(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 Xe(n,e){return{[n.table]:e.map(t=>t.entity)}}function Io(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 Oo(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return xe(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return xe(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 xe(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return xe(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var hr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(hr||{});class Co{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 $t({persister:t,merge:Ao,serialize:vo,parse:(a,c)=>To(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(j(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend(j(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){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:Xe(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=Kt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:dr(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:Xe(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:Xe(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(cs(b.store,m)){fr(b.store,u.attrsStore,g);const w=Kt(s,b.store,u.attrsStore),$=ko(b.store,u.attrsStore,g)[m];w?(f.push({oldEntity:b.entity,newEntity:w,changedFields:$||{}}),b.entity=w):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);fr(y,u.attrsStore,g);const b=Kt(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:dr(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=Io(s,this.getAttrs);Oo(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Xe(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 Eo({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=j();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],w=new TextEncoder;function $(){f=!0;for(const S of d)S(a??void 0)}function _(S){return d.push(S),f&&S(a??void 0),()=>{const O=d.indexOf(S);O!==-1&&d.splice(O,1)}}function E(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 P(){for(const S of p)try{S()}catch{}}function q(S){return h.push(S),o&&S(o),()=>{const O=h.indexOf(S);O!==-1&&h.splice(O,1)}}function H(S){o=S;for(const O of h)O(o)}function de(){m=!0}function v(S){let O=g,V=0,J=0;for(const{byteLen:se}of b){const ue=O+se;if(ue>S)break;O=ue,V++,J+=se}V>0&&(g+=J,y-=J,b.splice(0,V))}function A(S,O){a=O,$(),S.error(O),P()}async function k(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:O,offset:V}=S;o=O,v(V),b.length&&r({streamId:O,chunks:b.map(J=>J.chunk),offset:g}),m=!1;break}case"disconnect":{de();break}case"error":{c&&A(c,S.error);break}}}function M(){de(),k()}function x({offset:S,done:O}){v(S),O&&(l=!0,P())}function N(S){return l?(A(S,new K("Stream has been closed.")),null):o||(A(S,new K("Stream has not been initialized.")),null)}async function re(S){c=S;let O=!0,V=0;for(;O;){let J=Date.now()+Math.min(15e3,500*(V-1));O=!1;const se=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(se.type){case"ok":{const{streamId:ue,offset:Ht}=se;if(Ht!==0){const ge=new K("Write stream is corrupted");A(S,ge);return}H(ue),s(ue,{onDisconnect:de,onFlush:x,onConnectionReconnect:k,onAppendFailed:M}),m=!1;return}case"disconnect":{O=!0,de(),V++,await new Promise(ue=>{setTimeout(ue,Math.max(0,J-Date.now()))});break}case"error":{A(S,se.error);return}}}}class fe extends n{constructor(O,V){super(O,V)}async streamId(){return o||new Promise((O,V)=>{const J=[],se=()=>{for(const ge of J)ge()},ue=ge=>{O(ge),se()},Ht=ge=>{V(ge||new K("Stream is closed.")),se()};J.push(q(ue)),J.push(_(Ht))})}}return{stream:new fe({async start(S){try{await re(S)}catch(O){A(S,O)}},write(S,O){const V=N(O);if(V){const J=w.encode(S).length;b.push({chunk:S,byteLen:J});const se=g+y;y+=J,m||r({streamId:V,chunks:[S],offset:se})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):P(),$()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):P(),$()}}),addCompleteCb:E,closed(){return f}}}class Mo{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 Po({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 w=l.indexOf(b);w!==-1&&l.splice(w,1)}}function h(b,w){b.error(w),f()}let p=0;async function m(b,w){c=j();const $={...b||{},eventId:c};for await(const _ of t($)){if(i)return;if(_.type==="reconnect")return{retry:!0};if(_.type==="error"){h(w,_.error);return}if(_.offset>s){h(w,new K("Stream is corrupted.")),i=!0;return}let E=s-_.offset;if(_.files&&_.files.length){const P=new AbortController;let q=fetch(_.files[0].url,{signal:P.signal});for(let H=0;H<_.files.length;H++){const de=_.files[H+1],A=await q;if(de&&(q=fetch(de.url,{signal:P.signal})),!A.ok){if(p++,p>10){h(w,new K("Unable to process stream."));return}return{retry:!0}}if(A.body){const k=A.body.getReader();try{for(;;){const{done:M,value:x}=await k.read();if(M)break;if(i){P.abort();return}let N=x;if(E>0&&(N=x.subarray(E),E-=x.length-N.length),!N.length)continue;s+=N.length;const re=o.decode(N);w.enqueue(re)}}finally{k.releaseLock()}}else{const k=await A.arrayBuffer();let M=k;if(i){P.abort();return}if(E>0&&(M=new Uint8Array(k).subarray(E),E-=k.byteLength-M.length),!M.byteLength)continue;s+=M.byteLength;const x=o.decode(M);w.enqueue(x)}}}if(p=0,_.content){let P=_.content,q=a.encode(_.content);if(E>0){const H=q.subarray(E);if(E-=q.length-H.length,!H.length)continue;q=H,P=o.decode(H)}s+=q.length,w.enqueue(P)}}}async function g(b){let w=!0,$=0;for(;w;){w=!1;let _=Date.now()+Math.min(15e3,500*($-1));(await m({...e,offset:s},b))?.retry&&(w=!0,$++,_<Date.now()-3e5&&($=0),await new Promise(P=>{setTimeout(P,Math.max(0,_-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 pr{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}=Eo({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}=Po({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=j();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return e.ruleParams&&(i["rule-params"]=e.ruleParams),this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend(j(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new Mo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend(j(),t),delete this.readStreamIterators[e]}onStreamAppend(e){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 K(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!==oe.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 K(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 K(e.message||"Unknown error",e.hint)}),s.close(),delete this.readStreamIterators[r]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const oe={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},jo=3e4,$o=3e4,Ro=200,Do=1e3*60,xo={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},qt="_instant_oauth_redirect",zt="_instant_extra_fields_id",et="oauthExtraFields",Ie="currentUser";function Uo({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new ur(`${r}?app_id=${e}`);switch(n){case"ws":return new ur(`${r}?app_id=${e}`);case"sse":return new lr(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Lo(){return typeof window<"u"||typeof chrome<"u"}const yr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function No(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=gn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=bn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Fo(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:yn(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Ko(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function qo(n,e){return n==="pendingMutations"?[...e.entries()]:e}function zo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function Wt(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 br{attrs;_isOnline=!0;_isShutdown=!1;status=oe.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=Rt,r=Dt,s,i){if(this._EventSource=i,this.config={...xo,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??$o,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Ro,this._log=fo(e.verbose||xt||Bn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":Lt},this.config.schema&&(this._linkIndex=Ut(this.config.schema)),!!Lo()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!Se(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 Co(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>_e(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new pr({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)},Do),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",oe.CLOSED),this._setStatus(oe.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?Ut(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 $t({persister:new e(this.config.appId,"querySubs"),merge:zo,serialize:Fo,parse:(t,r)=>No(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 $t({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:qo,parse:Ko,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(Ie),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 Ae({body:a,status:o??0}))}else s.reject(new K(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=_e(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(yr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(oe.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=Zn(a),d=this.ensureAttrs(),h=_e(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=Wt(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Zn(p),y=this.ensureAttrs(),b=_e(y,g,r,this.config.useDateObjects),{store:w,attrsStore:$}=this._applyOptimisticUpdates(b,y,l,c),_=p?.[0]?.data?.["page-info"],E=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:w,attrsStore:$,pageInfo:_,aggregate:E}});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(oe.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 le(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=j();return this.querySubs.updateInPlace(s=>{s[t]=s[t]||{q:e,result:null,eventId:r},s[t].lastAccessed=Date.now()}),this._trySendAuthed(r,{op:"add-query",q:e}),r}subscribeTable(e,t){return this._syncTable.subscribe(e,t)}subscribeQuery(e,t,r){this.config.disableValidation||Nt(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||Nt(e,this.config.schema),t&&"ruleParams"in t&&(e={$$ruleParams:t.ruleParams,...e});const r=new Jn;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")),jo),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(j(),{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 be(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 w=i(y);if(w){o.attrIdMap[y.id]=w.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?_i(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 Wt(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 le({},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 le(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:It({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=_s(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,!We(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||ar(e,this.config.schema);try{const t=Vi({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=j(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:t,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new Jn;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!==oe.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}),Wt(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===oe.AUTHENTICATED&&this._trySend(...e)}_trySend(e,t,r){if(this._transport.isOpen()){switch(yr[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(oe.OPENED),this.getCurrentUser().then(r=>{this._trySend(j(),{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(oe.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=Uo({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=j();return this.kv.updateInPlace(i=>{i[t]||(i[t]=s)}),await this.kv.waitForKeyToLoad(t)}_replaceUrlAfterOAuth(){if(typeof URL>"u")return;const e=new URL(window.location.href);if(e.searchParams.get(qt)){const t=e.toString();e.searchParams.delete(qt),e.searchParams.delete(zt),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(qt))return null;const t=e.get("error");if(t)return this._replaceUrlAfterOAuth(),{error:{message:t}};const r=e.get("code");if(!r)return null;const s=e.get(zt);this._replaceUrlAfterOAuth();try{let i;const o=await this.kv.waitForKeyToLoad(et);s&&o&&(i=o[s]),o&&this.kv.updateInPlace(l=>{delete l[et]});const a=await this._getCurrentUser(),c=a?.type==="guest",{user:u}=await Qn({apiURI:this.config.apiURI,appId:this.config.appId,code:r,refreshToken:c?a.refresh_token:void 0,extraFields:i});return this.setCurrentUser(u),null}catch(i){return i?.body?.type==="record-not-found"&&i?.body?.hint?.["record-type"]==="app-oauth-code"&&await this._hasCurrentUser()?null:{error:{message:i?.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||We(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 K("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[Ie]=e}),await this.kv.waitForKeyToLoad(Ie)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(e){e?.forceReadFromStorage&&await this.kv.unloadKey(Ie);const t=await this.kv.waitForKeyToLoad(Ie);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(Ie);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){const{user:t}=await this.getCurrentUser();if(!We(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 Zi({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode(e){const t=await this.getCurrentUser(),r=t?.user?.type==="guest",s=await Xi({apiURI:this.config.apiURI,appId:this.config.appId,email:e.email,code:e.code,refreshToken:r?t?.user?.refresh_token:void 0,extraFields:e.extraFields});return await this.changeCurrentUser(s.user),s}async signInWithCustomToken(e){const t=await eo({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(t.user),t}async signInAsGuest(){const e=await to({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}ro({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,extraFields:r}){const{apiURI:s,appId:i}=this.config;let o=t;if(r){const a=`${Math.random().toString(36).slice(2)}`;this.kv.updateInPlace(c=>{const u=c[et]||{};u[a]=r,c[et]=u}),o=`${t}${t.includes("?")?"&":"?"}${zt}=${a}`}return`${s}/runtime/oauth/start?app_id=${i}&client_name=${e}&redirect_uri=${encodeURIComponent(o)}`}async exchangeCodeForToken({code:e,codeVerifier:t,extraFields:r}){const s=await this.getCurrentUser(),i=s?.user?.type==="guest",o=await Qn({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:t,refreshToken:i?s?.user?.refresh_token:void 0,extraFields:r});return await this.changeCurrentUser(o.user),o}issuerURI(){const{apiURI:e,appId:t}=this.config;return`${e}/runtime/${t}`}async signInWithIdToken(e){const r=(await this.getCurrentUser())?.user?.refresh_token,s=await no({apiURI:this.config.apiURI,appId:this.config.appId,idToken:e.idToken,clientName:e.clientName,nonce:e.nonce,refreshToken:r,extraFields:e.extraFields});return await this.changeCurrentUser(s.user),s}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:{...uo(i.result,r,this._sessionId),isLoading:!s.isConnected,error:s.error}}publishPresence(e,t,r){const s=this._rooms[t],i=this._presence[t];if(!s||!i)return;i.result=i.result||{};const o={...i.result.user,...r};i.result.user=o,s.isConnected&&(this._trySetPresence(t,o),this._notifyPresenceSubs(t))}_trySetPresence(e,t){this._trySendAuthed(j(),{op:"set-presence","room-id":e,data:t})}_tryJoinRoom(e,t,r){this._trySendAuthed(j(),{op:"join-room","room-type":e,"room-id":t,data:r}),delete this._roomsPendingLeave[t]}_tryLeaveRoom(e){this._trySendAuthed(j(),{op:"leave-room","room-id":e})}_trySetRoomConnected(e,t){const r=this._rooms[e];r&&(r.isConnected=t)}subscribePresence(e,t,r,s){const i=this.joinRoom(e,t,r.initialPresence||r.initialData),o={...r,roomId:t,cb:s,prev:null};return this._presence[t]=this._presence[t]||{},this._presence[t].handlers=this._presence[t].handlers||[],this._presence[t].handlers.push(o),this._notifyPresenceSub(t,o),()=>{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&&!lo(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=ze(s,o=>{for(let[a,c,u]of t)switch(c){case"+":qr(o,a,u);break;case"r":dn(o,a,u);break;case"-":fn(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=ze(this._presence,i=>{dn(i,[e,"result","peers"],s)})}publishTopic({roomType:e,roomId:t,topic:r,data:s}){const i=this._rooms[t];if(i){if(!i.isConnected){this._broadcastQueue[t]=this._broadcastQueue[t]??[],this._broadcastQueue[t].push({topic:r,roomType:e,data:s});return}this._tryBroadcast(t,e,r,s)}}_tryBroadcast(e,t,r,s){this._trySendAuthed(j(),{op:"client-broadcast","room-id":e,roomType:t,topic:r,data:s})}subscribeTopic(e,t,r,s){const i=this.joinRoom(e,t);return this._broadcastSubs[t]=this._broadcastSubs[t]||{},this._broadcastSubs[t][r]=this._broadcastSubs[t][r]||[],this._broadcastSubs[t][r].push(s),this._presence[t]=this._presence[t]||{},()=>{this._broadcastSubs[t][r]=this._broadcastSubs[t][r].filter(o=>o!==s),this._broadcastSubs[t][r].length||delete this._broadcastSubs[t][r],i()}}_notifyBroadcastSubs(e,t,r){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 so({...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 io({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 oo({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await ao(o,t)}async getDownloadUrl(e){const r=(await this.getCurrentUser())?.user?.refresh_token;return await co({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function Wo(n,e){return new Ze(gr(n,e),e,void 0)}function Vo(n){return new Ye(n,{})}function Qo(){return new W("string",!0,!1)}function Bo(){return new W("number",!0,!1)}function Go(){return new W("boolean",!0,!1)}function Ho(){return new W("date",!0,!1)}function Jo(){return new W("json",!0,!1)}function Yo(){return new W("json",!0,!1)}function gr(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 Ye(i.attrs,{...t.fwd[s],...t.rev[s]})]))}function Zo({entities:n,links:e,rooms:t}){const r=e??{},s=t??{};return new Ze(gr(n,r),r,s)}const D={graph:Wo,schema:Zo,entity:Vo,string:Qo,number:Bo,boolean:Go,date:Ho,json:Jo,any:Yo};let mr;function Xo(n,e){mr?.dispose();const t=ia(e),r=na(e,a),s=ta(ea(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.code==="Digit0",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),mr={dispose:c}}return u()}function ea(n){return`${xt||Gn?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${n}`}function ta(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 na(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.184",
3
+ "version": "0.22.185",
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.184"
59
+ "@instantdb/version": "0.22.185"
60
60
  },
61
61
  "scripts": {
62
62
  "test": "vitest",