@instantdb/core 0.22.168 → 0.22.169
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/standalone/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
(function(v,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(v=typeof globalThis<"u"?globalThis:v||self,R(v.instant={}))})(this,(function(v){"use strict";function R(n){if(typeof n=="number")return(Math.abs(n*2654435761)>>>0).toString(16);if(typeof n=="boolean")return n?"1":"0";if(n===null)return"null";if(n===void 0)return"undefined";if(typeof n=="string"){let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(n)){let e=2166136261;for(let t=0;t<n.length;t++){e^=(t+1)*2654435761;const r=R(n[t]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof n=="object"){let e=2166136261;const t=Object.keys(n).sort();for(let r=0;r<t.length;r++){const s=t[r];if(n[s]===void 0)continue;const i=R(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=R(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return R(String(n))}const x={Remove:"remove",Replace:"replace",Add:"add"},Bt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),Or=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Le=Symbol.iterator,J={mutable:"mutable",immutable:"immutable"},tt={};function Oe(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Gt(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 nt(n){return Object.getPrototypeOf(n)===Set.prototype}function rt(n){return Object.getPrototypeOf(n)===Map.prototype}function Y(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function fe(n){return!!k(n)}function k(n){return typeof n!="object"?null:n?.[Bt]}function st(n){var e;const t=k(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function te(n,e){if(!n||typeof n!="object")return!1;let t;return Object.getPrototypeOf(n)===Object.prototype||Array.isArray(n)||n instanceof Map||n instanceof Set||!!e?.mark&&((t=e.mark(n,J))===J.immutable||typeof t=="function")}function Ht(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=k(ce(t,n.key));if(r!==null&&r?.original!==n.original)return null;const s=n.parent.type===3,i=s?Array.from(n.parent.setMap.keys()).indexOf(n.key):n.key;if(!(s&&t.size>i||Oe(t,i)))return null;e.push(i)}if(n.parent)return Ht(n.parent,e);e.reverse();try{Cr(n.copy,e)}catch{return null}return e}function he(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ce(n,e){return he(n)===2?n.get(e):n[e]}function Ce(n,e,t){he(n)===2?n.set(e,t):n[e]=t}function it(n,e){const t=k(n);return(t?Y(t):n)[e]}function ue(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function ot(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function pe(n,e){return e?n:[""].concat(n).map(t=>{const r=`${t}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function Cr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ce(he(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Er(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 Mr=Object.prototype.propertyIsEnumerable;function Jt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!nt(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(!rt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,J),t!==void 0)&&t!==J.mutable){if(t===J.immutable)return Er(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=>{Mr.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=Jt(n.original,n.options))}function Ee(n){if(!te(n))return st(n);if(Array.isArray(n))return n.map(Ee);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ee(s)]);if(!rt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Map(t)}if(n instanceof Set){const t=Array.from(n).map(Ee);if(!nt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Set(t)}const e=Object.create(Object.getPrototypeOf(n));for(const t in n)e[t]=Ee(n[t]);return e}function Ne(n){return fe(n)?Ee(n):n}function oe(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&oe(n.parent))}function Yt(){throw new Error("Cannot modify frozen object")}function ge(n,e,t,r,s){{t=t??new WeakMap,r=r??[],s=s??[];const o=t.has(n)?t.get(n):n;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(n)||fe(n)){r.pop(),s.pop();return}switch(he(n)){case 2:for(const[a,c]of n)ge(a,a,t,r,s),ge(c,a,t,r,s);n.set=n.clear=n.delete=Yt;break;case 3:for(const a of n)ge(a,a,t,r,s);n.add=n.clear=n.delete=Yt;break;case 1:Object.freeze(n);let o=0;for(const a of n)ge(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ge(c,a,t,r,s)})}r.pop(),s.pop()}function at(n,e){const t=he(n);if(t===0)Reflect.ownKeys(n).forEach(r=>{e(r,n[r],n)});else if(t===1){let r=0;for(const s of n)e(r,s,n),r+=1}else n.forEach((r,s)=>e(s,r,n))}function Zt(n,e,t){if(fe(n)||!te(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),at(n,(i,o)=>{var a;if(fe(o)){const c=k(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ce(r?s:n,i,u)}else Zt(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 Pr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Zt(ce(t,e),n.finalities.handledSet,n.options)}function ct(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(st(e))}))}function ut(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Ht(n);i&&e(n,i,t,r)}n.finalized=!0}}function lt(n,e,t,r){const s=k(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ue(ce(c,e),t)){let u=s.original;s.copy&&(u=s.copy),ct(n),ut(n,r,i,o),n.options.enableAutoFreeze&&(n.options.updatedValues=(a=n.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,n.options.updatedValues.set(u,s.original)),Ce(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),te(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ue(ce(i,e),t)&&Pr(n,e)})}function jr(n,e,t,r,s){let{original:i,assignedMap:o,options:a}=n,c=n.copy;c.length<i.length&&([i,c]=[c,i],[t,r]=[r,t]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),f=pe(l,s);t.push({op:x.Replace,path:f,value:Ne(c[u])}),r.push({op:x.Replace,path:f,value:Ne(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=pe(l,s);t.push({op:x.Add,path:f,value:Ne(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=pe(l,s);r.push({op:x.Replace,path:f,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const f=e.concat([l-1]),d=pe(f,s);r.push({op:x.Remove,path:d})}}}function $r({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ce(n,c),l=Ne(ce(e,c)),f=a?Oe(n,c)?x.Replace:x.Add:x.Remove;if(ue(u,l)&&f===x.Replace)return;const d=r.concat(c),h=pe(d,o);s.push(f===x.Remove?{op:f,path:h}:{op:f,path:h,value:l}),i.push(f===x.Add?{op:x.Remove,path:h}:f===x.Remove?{op:x.Add,path:h,value:u}:{op:x.Replace,path:h,value:u})})}function Rr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:x.Remove,path:u,value:a}),s.unshift({op:x.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:x.Add,path:u,value:a}),s.unshift({op:x.Remove,path:u,value:a})}o+=1})}function Me(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return $r(n,e,t,r,s);case 1:return jr(n,e,t,r,s);case 3:return Rr(n,e,t,r,s)}}const Fe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!te(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},dt={get size(){return Y(k(this)).size},has(n){return Y(k(this)).has(n)},set(n,e){const t=k(this),r=Y(t);return(!r.has(n)||!ue(r.get(n),e))&&(z(t),oe(t),t.assignedMap.set(n,!0),t.copy.set(n,e),lt(t,n,e,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);return z(e),oe(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=k(this);if(this.size){z(n),oe(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=k(this);Y(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=k(this),s=Y(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,J))===J.mutable;if(r.options.strict&&Fe(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(n))return s;const o=tt.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Y(k(this)).keys()},values(){const n=this.keys();return{[Le]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Le]:()=>this.entries(),next:()=>{const e=n.next();if(e.done)return e;const t=this.get(e.value);return{done:!1,value:[e.value,t]}}}},[Le](){return this.entries()}},Dr=Reflect.ownKeys(dt),Xt=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=k(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,J))===J.mutable;if(n.options.strict&&Fe(o,n.options,u),!u&&!c&&te(o,n.options)&&!n.finalized&&n.original.has(o)){const l=tt.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]}},Ke={get size(){return k(this).setMap.size},has(n){const e=k(this);if(e.setMap.has(n))return!0;z(e);const t=k(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=k(this);return this.has(n)||(z(e),oe(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),lt(e,n,n,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);z(e),oe(e);const t=k(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=k(this);z(n),oe(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Xt(n,e,{isValuesIterator:!0})}},entries(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Xt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Le](){return this.values()},forEach(n,e){const t=this.values();let r=t.next();for(;!r.done;)n.call(e,r.value,r.value,this),r=t.next()}};Set.prototype.difference&&Object.assign(Ke,{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 xr=Reflect.ownKeys(Ke),en=new WeakSet,tn={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&en.has(i))return i;if(e===Bt)return n;let o;if(n.options.mark){const u=e==="size"&&(n.original instanceof Map||n.original instanceof Set)?Reflect.get(n.original,e):Reflect.get(n.original,e,t);if(o=n.options.mark(u,J),o===J.mutable)return n.options.strict&&Fe(u,n.options,!0),u}const a=Y(n);if(a instanceof Map&&Dr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(dt,"size").get.call(n.proxy);const u=dt[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&xr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(Ke,"size").get.call(n.proxy);const u=Ke[e];if(u)return u.bind(n.proxy)}if(!Oe(a,e)){const u=Gt(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(n.proxy):void 0}const c=a[e];if(n.options.strict&&Fe(c,n.options),n.finalized||!te(c,n.options))return c;if(c===it(n.original,e)){if(z(n),n.copy[e]=ft({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=k(n.copy[e]);return z(u),oe(u),u.copy}return n.copy[e]}return c},set(n,e,t){var r;if(n.type===3||n.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(n.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=Gt(Y(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=it(Y(n),e),a=k(o);return a&&ue(a.original,t)?(n.copy[e]=t,n.assignedMap=(r=n.assignedMap)!==null&&r!==void 0?r:new Map,n.assignedMap.set(e,!1),!0):(ue(t,o)&&(t!==void 0||Oe(n.original,e))||(z(n),oe(n),Oe(n.original,e)&&ue(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,lt(n,e,t,Me)),!0)},has(n,e){return e in Y(n)},ownKeys(n){return Reflect.ownKeys(Y(n))},getOwnPropertyDescriptor(n,e){const t=Y(n),r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:n.type!==1||e!=="length",enumerable:r.enumerable,value:t[e]}},getPrototypeOf(n){return Reflect.getPrototypeOf(n.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(n,e){var t;return n.type===1?tn.set.call(this,n,e,void 0,n.proxy):(it(n.original,e)!==void 0||e in n.original?(z(n),oe(n),n.assignedMap.set(e,!1)):(n.assignedMap=(t=n.assignedMap)!==null&&t!==void 0?t:new Map,n.assignedMap.delete(e)),n.copy&&delete n.copy[e],!0)}};function ft(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=he(e),a={type:o,finalized:!1,parent:t,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in n)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,tn);if(s.revoke.push(u),en.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=k(c);let g=l.type===3?l.setMap:l.copy;const y=ce(g,r),b=k(y);if(b){let _=b.original;b.operated&&(_=st(y)),ct(b),ut(b,Me,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(_,b.original)),Ce(g,r,_)}(p=m.callbacks)===null||p===void 0||p.forEach(_=>{_(f,d)})})}else{const l=k(c);l.finalities.draft.push((f,d)=>{ct(l),ut(l,Me,f,d)})}return c}tt.createDraft=ft;function Ur(n,e,t,r,s){var i;const o=k(n),a=(i=o?.original)!==null&&i!==void 0?i:n,c=!!e.length;if(o?.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(t,r);const u=c?e[0]:o?o.operated?o.copy:o.original:n;return o&&ot(o),s&&ge(u,u,o?.options.updatedValues),[u,t&&c?[{op:x.Replace,path:[],value:e[0]}]:t,r&&c?[{op:x.Replace,path:[],value:a}]:r]}function Lr(n,e){var t;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((t=e.mark)===null||t===void 0?void 0:t.call(e,n,J))===J.mutable||!te(n,e)?n:ft({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Ur(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function ht(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;at(t,(i,o,a)=>{const c=k(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(f=>a.add(i===f?u:f))}else Ce(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ht(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 nn(n){var e;const t=k(n);if(!te(n,t?.options))return n;const r=he(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?rt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Jt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(at(s,(o,a)=>{if(t&&ue(ce(t.original,o),a))return;const c=nn(a);c!==a&&(s===n&&i(),Ce(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return nt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function rn(n){if(!fe(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return nn(n)}const qe=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(w,...M){return e(w,j=>t.call(this,j,...M),r)};const c=t,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},n),l);const f=fe(c)?rn(c):c,d=Array.isArray(l.mark)?((w,M)=>{for(const j of l.mark){if(typeof j!="function")throw new Error(`Invalid mark: ${j}, 'mark' should be a function.`);const q=j(w,M);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(!te(f,g)&&typeof f=="object"&&f!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[y,b]=Lr(f,g);if(typeof r!="function"){if(!te(f,g))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[y,b]}let _;try{_=u(y)}catch(w){throw ot(k(y)),w}const P=w=>{const M=k(y);if(!fe(w)){if(w!==void 0&&!ue(w,y)&&M?.operated)throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const q=w?.[Or];if(q){const X=q[0];return g.strict&&typeof w=="object"&&w!==null&&ht({rootDraft:M,value:w,useRawReturn:!0}),b([X])}if(w!==void 0)return typeof w=="object"&&w!==null&&ht({rootDraft:M,value:w}),b([w])}if(w===y||w===void 0)return b([]);const j=k(w);if(g===j.options){if(j.operated)throw new Error("Cannot return a modified child draft.");return b([rn(w)])}return b([w])};return _ instanceof Promise?_.then(P,w=>{throw ot(k(y)),w}):P(_)})();Object.prototype.constructor.toString();function sn(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 on(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function ze(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:sn(n,e)?Object.keys(n).every(t=>ze(n[t],e[t])):!1}function pt(n){if(!Pe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function an(n,e){if(!Pe(n)||!Pe(e))return e;const t={...n};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete t[r];continue}const s=Pe(n[r])&&Pe(e[r]);t[r]=s?an(n[r],e[r]):e[r]}return t}function Pe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Nr(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 cn(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 un(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}un(n[t],r),Fr(n[t])&&delete n[t]}}function Fr(n){return n&&Object.keys(n).length===0}const ln=/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$/,Kr={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 qr(n){return new Date(n)}function zr(n){return new Date(n+"Z")}const Wr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Vr(n){const e=n.match(Wr);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 Qr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Br(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Gr(n){return new Date(n)}function Hr(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 Jr(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 Yr(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 Zr(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 Xr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function es(n){const e=n.match(ln);if(!e)return null;const[t]=e,r=Kr[t],s=new Date(n.replace(ln,"Z"));return new Date(s.getTime()-r*1e3)}const ts=[Vr,Br,Hr,Zr,Gr,zr,Jr,Qr,qr,Xr,es,Yr];function ns(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function yt(n){for(const e of ts){const t=ns(e,n);if(t)return t}return null}function rs(n){try{const e=JSON.parse(n);return typeof e=="string"?yt(e):null}catch{return null}}function je(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=yt(n)||rs(n)||yt(n.trim());if(!e)throw new Error(`Unable to parse \`${n}\` as a date.`);return e}else if(typeof n=="number")return new Date(n);throw new Error(`Invalid date value \`${n}\`. Expected a date, number, or string, got type ${typeof n}.`)}}class de{attrs;linkIndex;_blobAttrs=null;_primaryKeys=null;_forwardIdents=null;_revIdents=null;constructor(e,t){this.attrs=e,this.linkIndex=t}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const t=this.attrs[e.id];t&&(this.attrs[e.id]={...t,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(gt(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 ss(n){return n.cardinality==="one"}function bt(n){return n["value-type"]==="ref"}function gt(n){return n["value-type"]==="blob"}function me(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function ne(n,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){n.delete(e[0]);return}const[t,...r]=e;n.has(t)&&ne(n.get(t),r)}function Q(n,e,t){let r=n;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],t)}function dn(n,e,t){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=n.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&t&&(u=je(u),o[2]=u),bt(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 fn(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function hn(n,e){return we(n,e.triples,e.cardinalityInference,e.useDateObjects)}function pn(n,e){if(n)return new de(n.attrs,n.linkIndex);if(e&&"__type"in e)return new de(e.attrs,e.linkIndex)}function is(n,e){return me(n.eav,[e])!==void 0}function we(n,e,t,r){const s=dn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function $e(n,e){let t;if(Array.isArray(e[0])){const[s,i]=e[0],o=n.aev.get(s);if(!o)return null;t=B(o,2).find(c=>c[2]===i)?.[0]}else t=e[0];if(!t)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&n.aev.get(r[0])){const[s,i]=r,o=n.aev.get(s);if(!o)return null;const c=B(o,2).find(h=>h[2]===i)?.[0];if(!c)return null;const[u,l,f,...d]=e;return[t,l,c,...d]}else{const[s,...i]=e;return[t,...i]}}function yn(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(n.eav,[s,i,o]),ne(n.aev,[i,s,o]),bt(a)&&ne(n.vae,[o,i,s]))}let os=0;function bn(n,e,t){const[r,s,i]=t;let o;const a=me(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+os++}function gn(n,e,t){const r=$e(n,t);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&n.useDateObjects&&(o=je(o));const u=me(n.eav,[s,i,o])?.[3]??bn(n,a,r),l=[s,i,o,u];ss(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)),bt(a)&&Q(n.vae,[o,i,s],l)}function as(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!gt(a))throw new Error("merge operation is not supported for links");const c=me(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=an(l,o),d=[s,i,f,bn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function mt(n,e,t){const[r,s]=t,i=$e(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const u of a.keys()){const l=e.getAttr(u);l&&l["on-delete-reverse"]==="cascade"&&B(a.get(u),1).forEach(([f,d,h])=>mt(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(ne(n.aev,[u,o]),ne(n.eav,[o,u]))}a.size===0&&ne(n.eav,[o])}const c=n.vae.get(o)&&B(n.vae.get(o),2);c&&c.forEach(u=>{const[l,f,d]=u,h=e.getAttr(f);(!s||!h||h["reverse-identity"]?.[1]===s)&&(ne(n.eav,[l,f,d]),ne(n.aev,[f,l,d]),ne(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&&mt(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&ne(n.vae,[o])}function mn(n,e,t){const r=dn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function cs(n,[e]){n.addAttr(e)}function wn(n){return B(n.eav,3)}function us(n,e,[t]){if(!e.getAttr(t))return;const r=wn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),mn(n,e,r)}function ls(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),mn(n,e,wn(n)))}function ds(n,e,t){const[r,...s]=t;switch(r){case"add-triple":gn(n,e,s);break;case"deep-merge-triple":as(n,e,s);break;case"retract-triple":yn(n,e,s);break;case"delete-entity":mt(n,e,s);break;case"add-attr":cs(e,s);break;case"delete-attr":us(n,e,s);break;case"update-attr":ls(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(n,e,t=[]){if(!n||e===0)return t;if(e===1){for(const r of n.values())t.push(r);return t}for(const r of n.values())B(r,e-1,t);return t}function We(n,e,t){const r=[];if(t?.hasOwnProperty("$not")){for(const i of e.keys())t.$not!==i&&r.push(e.get(i));return r}if(t?.hasOwnProperty("$isNull")){const{attrId:i,isNull:o,reverse:a}=t.$isNull;if(a)for(const c of e.keys()){const u=n.vae.get(c),l=!u||!u.get(i);(o?l:!l)&&r.push(e.get(c))}else{const c=n.aev.get(i);for(const u of e.keys()){const l=!c||c.get(u)?.get(null)||!c.get(u);(o?l:!l)&&r.push(e.get(u))}}return r}if(t?.$comparator)return B(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const i of s){const o=e.get(i);o&&r.push(o)}return r}function fs(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function hs(n,[e,t,r]){switch(fs(e,t,r)){case"e":{const i=n.eav.get(e);return B(i,2)}case"ea":{const i=n.eav.get(e)?.get(t);return B(i,1)}case"eav":{const i=n.eav.get(e)?.get(t);return i?We(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"a":{const i=n.aev.get(t);return B(i,2)}case"av":{const i=n.aev.get(t);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...We(n,a,r));return i}default:return B(n.eav,3)}}function ps(n,e,t){const r={};if(!e)return r;for(const[s,i]of e.entries()){const o=n.eav.get(t)?.get(i.id),a=B(o,1);for(const c of a)r[s]=c[2]}return r}function L(n,e,t){return n.forwardIdents.get(e)?.get(t)}function ye(n,e,t){return n.revIdents.get(e)?.get(t)}function ys(n,e){return n.blobAttrs.get(e)}function _n(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function bs(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return me(n.eav,[s,i])}function gs(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=_n(e,f["forward-identity"][1]);l=!!bs(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return qe({store:n,attrsStore:e},s=>{r.forEach(i=>{ds(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof de)return"immutable"}})}function ms(n){return typeof n=="string"&&n.startsWith("?")}function ws(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return Tn(r,e,t)}return{...t,[n]:e}}function Sn(n,e,t){return n===e?t:null}function _s(n){return typeof n==="string"&&n.startsWith("?")?ws:Sn}const Ss=["in","$in","$not","$isNull","$comparator"];function Ts(n){for(const e of Ss)if(n.hasOwnProperty(e))return!0;return!1}function Tn(n,e,t){return t?typeof n=="object"?Ts(n)?t:null:_s(n)(n,e,t):null}function vs(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return Tn(s,o,r)},t)}function As(n,e,t){return Os(n,e,t).map(r=>vs(e,r,t)).filter(r=>r)}function ks(n,e,t){return e.or?e.or.patterns.flatMap(r=>wt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>wt(n,s,r),t):t.flatMap(r=>As(n,e,r))}function wt(n,e,t=[{}]){return e.reduce((r,s)=>ks(n,s,r),t)}function _t(n,e){return Array.isArray(e)?e.map(t=>_t(n,t)):ms(e)?n[e]:e}function Is(n,{find:e,where:t}){return wt(n,t).map(s=>_t(s,e))}function Os(n,e,t){return hs(n,_t(t,e))}const Cs=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function _e(n){return typeof n=="string"&&Cs.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function Es(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 St;const Ms=new Uint8Array(16);function Ps(){if(!St){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");St=crypto.getRandomValues.bind(crypto)}return St(Ms)}const vn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function js(n,e,t){if(vn.randomUUID&&!n)return vn.randomUUID();n=n||{};const r=n.random??n.rng?.()??Ps();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,Es(r)}function An(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 $s(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 Rs(n,e){return $s(An(n),An(e))}function $(){return js()}function Ds(n,e){return n.localeCompare(e)}function xs(){let n=Ds;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Us=xs();let kn=!0;const Ls=n=>{kn=n};let Ns=0;function Re(n){return Ve(`_${n}`,Ns++)}function Ve(n,e){return`?${n}-${e}`}class Se extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Fs(n,e){const t=_n(n,e);if(!t)throw new Se(`Could not find id attr for ${e}`);return t}function In(n,e,t,r){return[Ks(n,e,t,r)]}function Ks(n,e,t,r){return[n(t,r),Fs(e,t).id,n(t,r),n("time",r)]}function qs(n,e,t){return n.map(r=>r===e?t:r)}function On(n,e,t,r,s){const i=L(e,t,s),o=ye(e,t,s),a=i||o;if(!a)throw new Se(`Could not find attr for ${[t,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,f]=a["reverse-identity"],d=r+1,h=i?[n(u,r),a.id,n(f,d),Re("time")]:[n(u,d),a.id,n(f,r),Re("time")];return[i?f:u,d,h,a,!!i]}function Cn(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 zs(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=Cn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=Cn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Ws(n,e,t,r,s,i){const o=L(e,t,s),a=ye(e,t,s),c=o||a;if(!c)throw new Se(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Se(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Re("time")]}return o?[n(t,r),c.id,zs(c,i),Re("time")]:[i,c.id,n(t,r),Re("time")]}function Vs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=On(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function Tt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Vs(n,e,t,r,o),f=Ws(n,e,c,u,a,i);return l.concat([f])}function Qs(n,e){return e?[e].concat(n):n}function Bs([n,e]){return n==="or"&&Array.isArray(e)}function Gs([n,e]){return n==="and"&&Array.isArray(e)}function Hs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function En(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Hs(n,o,u);return Pn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Js(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function Mn(n,e,t,r,s){return Js(s).map(i=>Tt(n,e,t,r,i,{$isNull:!0}))}function Pn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Bs([i,o]))return En(n,"or",e,t,r,o);if(Gs([i,o]))return En(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=Tt(n,e,t,r,a,o),u=Mn(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:Mn(n,e,t,r,a),joinSym:n(t,r)}}]:Tt(n,e,t,r,a,o)})}function Ys(n,e,t,r){const s=Ve;return r?Pn(s,n,e,t,r).concat(In(s,n,e,t)):In(s,n,e,t)}function Zs(n,e,t){return[n(e,t),n("time",t)]}function Xs(n,e,t,r,s,i){const[o,a,c,u,l]=On(n,e,t,r,s),f=qs(c,n(t,r),i);return[o,a,f,u,l]}function ei(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]=Xs(n,t,r,s,h,u),b=Rn(e,t,{etype:m,level:g,form:i[h],join:y}),_=p?b[0]:b;return{[h]:_}}catch(m){if(m instanceof Se)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function ti(n,e,t){return t==="string"?Us(n,e):n>e?1:-1}function De(n,e,t,r,s){return e===r||e==null&&r==null?Rs(n,t):r==null?1:e==null?-1:ti(e,r,s)}function Qe([n,e],[t,r],s){return De(n,e,t,r,s)}function vt(n){return n==null?n:new Date(n).getTime()}function jn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Qe(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?vt(c):c,f=u==="date"?vt(i):i;return Qe([a,l],[r,f],u)}function ni(n,e,t,r){const s=jn(n,e,r);return t==="desc"?s>0:s<0}function ri(n,e,t,r){const s=jn(n,e,r);return t==="desc"?s<0:s>0}function si(n,e){const t=e[1];return n.getAttr(t)}function ii(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function oi(n,e,t,r){if(t)return si(n,t);if(r)return ii(n,e,r)}function ai(n,e,t){if(!Array.isArray(t.fields))return ys(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&>(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 ci(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=$n(i),c=ui(i);let u=Is(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=oi(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=vt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Qe(g,y,d?.["checked-data-type"])}:function(g,y){return Qe(y,g,d?.["checked-data-type"])});let h={};const p=ai(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ni(l,d,c,m)||f&&d&&ri(f,d,c,m))continue;const y=ps(n,p,g);y&&(h[g]=y)}return h}function ui(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function $n(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function li(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!$n(s)&&(!o||!o["start-cursor"]))return[];const a=Qs(Ys(e,t,r,s.$?.where),i),c=Zs(Ve,t,r),u=s.$?.fields,l=ci(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&&kn&&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 di(n,e,t){try{return li(n,e,t)}catch(r){if(r instanceof Se)return{};throw r}}function Rn(n,e,t){const r=di(n,e,t);return ei(Ve,n,e,t,r)}function fi(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 At({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]=Rn(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=fi(t)),r&&(o.aggregate=r),o}function hi(){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 pi=hi();function Be(n,e,t){const r={__etype:n,__ops:t};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return t;if(i==="__etype")return n;if(pi.has(i))return(o,a)=>Be(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Dn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function Ge(n){return n.startsWith("lookup__")}function kt(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function yi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Be(n,kt(Dn(s,i)),[]);if(t==="__etype")return n;const r=t;return Ge(r)?Be(n,kt(r),[]):Be(n,r,[])}})}function It(){return new Proxy({},{get(n,e){return yi(e)}})}const bi=It();function xn(n){return n.__ops}function gi(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 mi(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 wi(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Ot(n){const[e,t,...r]=n.split(".");if(r.length>0||t!=="id")throw new Error(`${n} is not a valid lookup attribute.`);return e}function _i(n,e,t){if(!wi(n,e,t))return L(n,e,t);const r=Ot(t),s=L(n,e,r)||ye(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Ct(n){return typeof n=="string"&&!Ge(n)?null:typeof n=="string"&&Ge(n)?kt(n):mi(n)}function G(n,e,t){const r=Ct(t);if(r===null)return t;const[s,i]=r,o=_i(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Un(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 Si({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["add-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["add-triple",G(n,u["forward-identity"][1],l),u?.id,G(n,e,t)])});return Un(n,e,t,s)}function Ti({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["retract-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["retract-triple",G(n,u["forward-identity"][1],l),u.id,G(n,e,t)])});return Un(n,e,t,s)}function vi(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 Ln({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:vi(n,e,t,r)?{mode:"update"}:null}function Ai(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,f])=>{const d=L(t,r,l);return d["checked-data-type"]==="date"&&n.useDateObjects&&(f=je(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function ki(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s),u=Ln(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([f,d])=>{const h=L(t,r,f);return h["checked-data-type"]==="date"&&n.useDateObjects&&(d=je(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ii({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function Oi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s),u=Ln(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 Ci({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function Ei(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 Mi(n,e){const[t,...r]=Ei(e);switch(t){case"merge":return Oi(n,r);case"create":return Ai(n,r);case"update":return ki(n,r);case"link":return Si(n,r);case"unlink":return Ti(n,r);case"delete":return Ii(n,r);case"ruleParams":return Ci(n,r);default:throw new Error(`unsupported action ${t}`)}}function Pi(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function ji(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=Pi(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function He(n,e,t,r){const s=n?ji(n,e,t):null,i=$(),a=[$(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function $i(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 Ri(n,e,t){const r=$i(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[$(),s.on,s.label],"reverse-identity":[$(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Nn(n,e,t,r){const s=n?Ri(n,e,t):null,i=$(),o=[$(),e,t],a=[$(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const Di=new Set(["create","update","merge","link","unlink"]),xi=new Set(["link","unlink"]),Ui=new Set(["create","update","merge"]),Li=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Et={"unique?":!0,"index?":!0},Ni={...Et,cardinality:"one"};function Fi(n){const e=[],[t,r,s,i]=n;if(!Li.has(t))return e;const o=Ct(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=Ct(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Ki({attrsStore:n,schema:e},t){const r=new Set,s=[],i=[];function o(d,h){return L(n,d,h)||s.find(p=>p["forward-identity"][1]===d&&p["forward-identity"][2]===h)}function a(d,h){return ye(n,d,h)||s.find(p=>p["reverse-identity"]?.[1]===d&&p["reverse-identity"]?.[2]===h)}function c(d){s.push(d),i.push(["add-attr",d]),r.add(d.id)}function u(d){d&&"isUnsynced"in d&&d.isUnsynced&&!r.has(d.id)&&(s.push(d),i.push(["add-attr",d]),r.add(d.id))}function l(d,h){return h.indexOf(".")!==-1&&!o(d,h)}function f(d,h){const p=o(d,h),m=a(d,h);u(p),u(m),!p&&!m&&c(Nn(e,d,h,Ni))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of Fi(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const _=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(_,g))f(_,Ot(g));else{const P=o(_,g);P||c(He(e,_,g,Et)),u(P)}}else if(l(h,g))f(h,Ot(g));else{const y=o(h,g);y||c(He(e,h,g,Et)),u(y)}}for(const d of t){const[h,p,m,g]=d;if(Di.has(h)){const y=o(p,"id");u(y),y||c(He(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const _=o(p,b);if(u(_),Ui.has(h)&&(_||c(He(e,p,b,b==="id"?{"unique?":!0}:null))),xi.has(h)){const P=a(p,b);!_&&!P&&c(Nn(e,p,b)),u(P)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new de(d,n.linkIndex),i]}return[n,i]}function qi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>xn(c)),[s,i]=Ki(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Mi(o,c));return[...i,...a]}function Fn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Te="__meta";class Mt{constructor(e,t){}}class Pt{currentValue;_subs=[];_persister;_merge;serialize;parse;_saveThrottleMs;_idleCallbackMaxWaitMs;_nextSave=null;_nextGc=null;_pendingSaveKeys=new Set;_loadedKeys=new Set;_loadingKeys;_objectSize;_log;onKeyLoaded;_version=0;_meta={isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0};_gcOpts;constructor(e){this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){this._meta.loadingPromise&&await this._meta.loadingPromise;try{const e=this._persister.getItem(Te);this._meta.loadingPromise=e;const t=await e;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const r=this._meta.value?.objects??{},s=t??{},i=s.objects??{};this._meta.value={...s,objects:{...r,...i}}}catch(e){this._meta.error=e,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const t=await this.waitForMetaToLoad();if(!t)return;const r=Object.entries(t.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const t=await this._persister.getItem(e);return t&&this.parse(e,t)}catch(t){return console.error(`Unable to read from storage for key=${e}`,t),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const t=this._getFromStorage(e);this._loadingKeys[e]=t;const r=await t;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const t=[],r=e?.skipGc;if(this._meta.isLoading){const f=new Promise((d,h)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(d).catch(h),10+(e?.attempts??0)*1e3)});return t.push(f),Promise.all(t).then(d=>d.reduce((h,p)=>h+p,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const f of this._pendingSaveKeys)f in this.currentValue?o.push(f):(i.push(f),delete s.objects[f]);for(const f of i){const d=this._persister.removeItem(f);t.push(d.then(()=>1)),this._loadedKeys.delete(f),this._pendingSaveKeys.delete(f)}const a=[],c=[[Te,s]],u=s.objects??{};s.objects=u;for(const f of o)if(this._loadedKeys.has(f)){const d=this.serialize(f,this.currentValue[f]);c.push([f,d]);const h=this._objectSize(d),p=u[f]??{createdAt:Date.now(),updatedAt:Date.now(),size:h};p.updatedAt=Date.now(),p.size=h,u[f]=p,this._pendingSaveKeys.delete(f)}else a.push(f);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const f of a){const d=this._loadKey(f).then(()=>this._enqueuePersist(e));t.push(d)}return r||this.gc(),Promise.all(t).then(f=>f.reduce((d,h)=>d+h,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Te);const t=new Set(Object.keys(this.currentValue));for(const d of Object.keys(this._loadingKeys))t.add(d);for(const d of this._loadedKeys)t.add(d);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:t,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const d of e)t.has(d)||d in r.objects||(this._log.info("Lost track of key in meta",d),s.push(this._persister.removeItem(d)),i.removed.push(d),i.removedMissingCount++);const o=Date.now();for(const[d,h]of Object.entries(r.objects))!t.has(d)&&h.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const c=a.filter(([d])=>!t.has(d));if(a.length>this._gcOpts.maxEntries)for(const[d]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const l=u.filter(([d])=>!t.has(d));let f=u.reduce((d,[h,p])=>d+p.size,0);for(;f>0&&f>this._gcOpts.maxSize&&l.length;){const[[d,h]]=l.splice(0,1);f-=h.size,s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedSizeCount++}for(const d of Object.keys(r.objects))!e.has(d)&&!t.has(d)&&delete r.objects[d];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{Fn(()=>{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(()=>{Fn(()=>{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]=qe(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=t,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return t}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(t=>t!==e)}}async clearUnloadedKeys(){let e=!1;for(const t of await this._persister.getAllKeys())t===Te||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const zi=6,Wi=["kv","querySubs","syncSubs"];function Vi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Qi(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 Bi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{const a={};for(const[l,f]of Object.entries(r)){const d=typeof f=="string"?JSON.parse(f):f;if(d.lastAccessed){const p={createdAt:d.lastAccessed,updatedAt:d.lastAccessed,size:d.result?.store?.triples?.length??0};a[l]=p}const h=t.put(d,l);s.add(h)}const c={objects:a},u=t.put(c,Te);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Kn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Gi(n,e){const t=await Qi(`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=Bi(l,f,o);a.push(d)}else{const d=Kn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Kn(Te,c,i);a.push(u),await Promise.all(a),await new Promise((l,f)=>{s.oncomplete=d=>l(d),s.onerror=d=>f(d),s.onabort=d=>f(d)})}const qn=new Map;class jt extends Mt{dbName;_storeName;_appId;_prefix;_dbPromise;constructor(e,t){super(e,t),this.dbName=`instant_${e}_${zi}`,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=Gi(this._appId,a).catch(u=>{Vi("Error upgrading store from version 5 to 6.")(u)});qn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=qn.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 Wi)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 $t{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 ve 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,ve),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new ve({status:t.status,body:r}))}function Hi({apiURI:n,appId:e,email:t}){return re(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Ji({apiURI:n,appId:e,email:t,code:r,refreshToken:s,extraFields:i}){return await re(`${n}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t,code:r,...s?{"refresh-token":s}:{},...i?{"extra-fields":i}:{}})})}async function Yi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function Zi({apiURI:n,appId:e}){return await re(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function zn({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s,extraFields:i}){return await re(`${n}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:t,code_verifier:r,refresh_token:s,...i?{extra_fields:i}:{}})})}async function Xi({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i,extraFields:o}){return await re(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i,...o?{extra_fields:o}:{}})})}async function eo({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function to({apiURI:n,appId:e,path:t,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:t,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await re(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function no({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function ro({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${n}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:t})});return i}async function so(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function io({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let Rt=!1,Wn=!1,Vn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(Rt=!!window.localStorage.getItem("devBackend"),Wn=!!window.localStorage.getItem("__instantLogging"),Vn=!!window.localStorage.getItem("__devtoolLocalDash"));function Qn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function oo(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Qn(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=Qn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function ao(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!on(n.user,e.user))||!sn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!on(n.peers[r],e.peers[r]))return!0;return!1}class Bn{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 Gn(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);Gn(t["child-nodes"],e)})}function Hn(n){const e=[];return Gn(n,e),e}function Dt(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 xt="v0.22.168";function co(n,e){return{info:n?(...t)=>console.info(...t,e()):()=>{},debug:n?(...t)=>console.debug(...t,e()):()=>{},error:n?(...t)=>console.error(...t,e()):()=>{}}}class W{constructor(e,t,r,s={indexed:!1,unique:!1}){this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}metadata={};clientRequired(){return new W(this.valueType,!1,this.isIndexed,this.config)}optional(){return new W(this.valueType,!1,this.isIndexed,this.config)}unique(){return new W(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new W(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Je{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Je(this.attrs,this.links)}}class Ye{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ye(this.entities,this.links,{})}}class C extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Jn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],uo=n=>n.valueType||"unknown",Yn=(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}},lo=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!Yn(f,l,a))throw new C(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof f}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new C(`Operator '${n}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(n,t,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(n,t,e);break;case"$like":case"$ilike":if(c(n,"string",e),n==="$ilike"&&!i.isIndexed)throw new C(`Operator '${n}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(n,"boolean",e);break;default:throw new C(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},Ae=(n,e,t,r,s)=>{const i=uo(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))lo(u,l,i,e,r,t,`${s}.${u}`)}else if(!Yn(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},fo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new C(`Invalid dot notation path '${n}'. Must contain at least one dot.`,s);let o=t;for(let l=0;l<i.length-1;l++){const f=i[l],d=r.entities[o];if(!d)throw new C(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const h=d.links[f];if(!h){const p=Object.keys(d.links);throw new C(`Link '${f}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${p.length>0?p.join(", "):"none"}`,s)}o=h.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new C(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new C(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Ae(e,n,u,t,s)},Zn=(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&&Zn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){Ae(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){fo(s,i,e,t,`${r}.${s}`);continue}const o=t.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new C(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)Ae(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!_e(i))throw new C(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new W("string",!1,!0);Ae(i,s,u,e,`${r}.${s}`)}}},ho=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Jn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Jn.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);Zn(n.where,e,t,r?`${r}.where`:"where")}},Xn=(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&&Xn(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}.$`);ho(o,e,t,`${r}.$`,s)}},Ut=(n,e)=>{if(typeof n!="object"||n===null)throw new C(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new C(`Query must be an object, but received: ${typeof n}`);const t=n;for(const r of Object.keys(t)){if(Array.isArray(n[r]))throw new C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new C(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Xn(t[r],r,e,r,0)}}},er=n=>typeof n!="string"?!1:Ge(n)?!0:_e(n);class Z extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const tr=n=>n.length>0?n.join(", "):"none",po=(n,e)=>new Z(`Entity '${n}' does not exist in schema. Available entities: ${tr(e)}`),yo={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},bo=(n,e)=>n==null?!0:yo[e.valueType]?.(n)??!1,nr=(n,e)=>{const t=e.entities[n];if(!t)throw po(n,Object.keys(e.entities));return t},Lt=(n,e,t)=>{const r=nr(n,t);if(typeof e!="object"||e===null)throw new Z(`Arguments for data operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!bo(i,o))throw new Z(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},rr=(n,e,t)=>{const r=nr(n,t);if(typeof e!="object"||e===null)throw new Z(`Arguments for link operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new Z(`Link '${s}' does not exist on entity '${n}'. Available links: ${tr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!er(a))throw new Z(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!er(i))throw new Z(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},go={create:Lt,update:Lt,merge:Lt,link:rr,unlink:rr,delete:()=>{}},mo=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!_e(s))throw new Z(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new Z(`Entity name must be a string, but received: ${typeof r}`);const o=go[t];o&&i!==void 0&&o(r,i,e)},sr=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new Z(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new Z(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new Z(`Transaction operation must be an array, but received: ${typeof s}`);mo(s,e)}}};let ir=0;class or{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${ir++}`,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 ar{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}_${ir++}`,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 wo(n,e){const t=n.values;if(t){const r=pn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=hn(r,s.store);t.attrsStore=r}}return n}function _o(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=fn(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function So(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 Nt(n,e,t){return At({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function cr(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=me(e.eav,[r,s,r]);return i?i[3]:-1}function ur(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":gn(n,e,s);break;case"removed":yn(n,e,s);break}}function To(n,e,t){const r={};for(const{action:s,triple:i}of t){const[o,a,c]=i,u=e.getAttr(a)?.["forward-identity"]?.[2];if(!u)continue;const l=r[o]??{};r[o]=l;const f=l[u]??{};switch(s){case"added":f.newValue=c;break;case"removed":f.oldValue===void 0&&(f.oldValue=c);break}l[u]=f}for(const[s,i]of Object.entries(r))for(const[o,{oldValue:a,newValue:c}]of Object.entries(i))a===c&&delete i[o];return r}function Ze(n,e){return{[n.table]:e.map(t=>t.entity)}}function vo(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 Ao(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return De(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=n.orderField;t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return De(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var lr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(lr||{});class ko{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 Pt({persister:t,merge:So,serialize:_o,parse:(a,c)=>wo(c,this.config.useDateObjects),objectSize:a=>a.values?.entities.length||0,logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,t){const r=R(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,s?.keepSubscription)}}unsubscribe(e,t,r){const s=(this.callbacks[e]||[]).filter(i=>i!==t);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i?.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend($(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend($(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){await this.subs.waitForKeyToLoad(t);const s=this.subs.currentValue[t];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),s.values?.entities&&r&&r({type:"LoadFromStorage",data:Ze(s,s.values?.entities)});return}const i=Object.keys(e)[0],o=e[i]?.$?.order||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(u=>{u[t]={query:e,hash:t,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const t=this.subs.currentValue[e];t?await this.initSubscription(t.query,t.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const t=e["subscription-id"],r=e.q,s=R(r);this.idToHash[t]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",t,"query",r),i;o.state={subscriptionId:t,token:e.token}})}notifyCbs(e,t){for(const r of this.callbacks[e]||[])r(t)}onSyncLoadBatch(e){const t=e["subscription-id"],r=e["join-rows"],s=this.idToHash[t];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),f=Nt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:cr(o,l,a.attrsStore,f.id)}),i.push(f)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ze(o,o.values.entities),batch:i})}onSyncInitFinish(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(i=>{const o=i[r];if(!o){this.log.error("Missing sub for hash",r,e);return}const a=o.state;if(!a)return this.log.error("Sub never set init, missing result",o,e),i;a.txId=e["tx-id"],o.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ze(s,s.values?.entities||[])})}onSyncUpdateTriples(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const o of e.txes){if(i.txId&&i.txId>=o["tx-id"])continue;i.txId=o["tx-id"];const a=[],c={};for(const m of o.changes){const g=c[m.triple[0]]??[];c[m.triple[0]]=g,g.push(m)}const u=s.values??{entities:[],attrsStore:this.getAttrs()},l=u.entities;s.values=u;const f=[];e:for(const[m,g]of Object.entries(c))for(let y=0;y<l.length;y++){const b=l[y];if(is(b.store,m)){ur(b.store,u.attrsStore,g);const _=Nt(s,b.store,u.attrsStore),P=To(b.store,u.attrsStore,g)[m];_?(f.push({oldEntity:b.entity,newEntity:_,changedFields:P||{}}),b.entity=_):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);ur(y,u.attrsStore,g);const b=Nt(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:cr(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=vo(s,this.getAttrs);Ao(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Ze(s,s.values?.entities),added:d,removed:h,updated:f})}this.subs.updateInPlace(o=>{o[r]=s,o[r].updatedAt=Date.now()})}clearSubscriptionData(e,t){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,t),t?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const t=R(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(t,{type:"Error",data:{[s]:[]},error:r})}onResyncError(e){const t=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(t,!1);r&&this.initSubscription(r.query,r.hash)}}function Io({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=$();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],_=new TextEncoder;function P(){f=!0;for(const S of d)S(a??void 0)}function w(S){return d.push(S),f&&S(a??void 0),()=>{const I=d.indexOf(S);I!==-1&&d.splice(I,1)}}function M(S){return p.push(S),()=>{const I=p.indexOf(S);I!==-1&&p.splice(I,1)}}e.waitUntil&&e.waitUntil(new Promise(S=>{p.push(S)}));function j(){for(const S of p)try{S()}catch{}}function q(S){return h.push(S),o&&S(o),()=>{const I=h.indexOf(S);I!==-1&&h.splice(I,1)}}function X(S){o=S;for(const I of h)I(o)}function T(){m=!0}function E(S){let I=g,V=0,H=0;for(const{byteLen:ie}of b){const le=I+ie;if(le>S)break;I=le,V++,H+=ie}V>0&&(g+=H,y-=H,b.splice(0,V))}function A(S,I){a=I,P(),S.error(I),j()}async function O(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:I,offset:V}=S;o=I,E(V),b.length&&r({streamId:I,chunks:b.map(H=>H.chunk),offset:g}),m=!1;break}case"disconnect":{T();break}case"error":{c&&A(c,S.error);break}}}function N(){T(),O()}function U({offset:S,done:I}){E(S),I&&(l=!0,j())}function ee(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 se(S){c=S;let I=!0,V=0;for(;I;){let H=Date.now()+Math.min(15e3,500*(V-1));I=!1;const ie=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(ie.type){case"ok":{const{streamId:le,offset:Qt}=ie;if(Qt!==0){const be=new K("Write stream is corrupted");A(S,be);return}X(le),s(le,{onDisconnect:T,onFlush:U,onConnectionReconnect:O,onAppendFailed:N}),m=!1;return}case"disconnect":{I=!0,T(),V++,await new Promise(le=>{setTimeout(le,Math.max(0,H-Date.now()))});break}case"error":{A(S,ie.error);return}}}}class _a extends n{constructor(I,V){super(I,V)}async streamId(){return o||new Promise((I,V)=>{const H=[],ie=()=>{for(const be of H)be()},le=be=>{I(be),ie()},Qt=be=>{V(be||new K("Stream is closed.")),ie()};H.push(q(le)),H.push(w(Qt))})}}return{stream:new _a({async start(S){try{await se(S)}catch(I){A(S,I)}},write(S,I){const V=ee(I);if(V){const H=_.encode(S).length;b.push({chunk:S,byteLen:H});const ie=g+y;y+=H,m||r({streamId:V,chunks:[S],offset:ie})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):j(),P()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):j(),P()}}),addCompleteCb:M,closed(){return f}}}class Oo{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 Co({RStream:n,opts:e,startStream:t,cancelStream:r}){let s=e.byteOffset||0,i=!1;const o=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[];function f(){u=!0;for(const b of l)b()}function d(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function h(b,_){b.error(_),f()}let p=0;async function m(b,_){c=$();const P={...b||{},eventId:c};for await(const w of t(P)){if(i)return;if(w.type==="reconnect")return{retry:!0};if(w.type==="error"){h(_,w.error);return}if(w.offset>s){h(_,new K("Stream is corrupted.")),i=!0;return}let M=s-w.offset;if(w.files&&w.files.length){const j=new AbortController;let q=fetch(w.files[0].url,{signal:j.signal});for(let X=0;X<w.files.length;X++){const T=w.files[X+1],A=await q;if(T&&(q=fetch(T.url,{signal:j.signal})),!A.ok){if(p++,p>10){h(_,new K("Unable to process stream."));return}return{retry:!0}}if(A.body){const O=A.body.getReader();try{for(;;){const{done:N,value:U}=await O.read();if(N)break;if(i){j.abort();return}let ee=U;if(M>0&&(ee=U.subarray(M),M-=U.length-ee.length),!ee.length)continue;s+=ee.length;const se=o.decode(ee);_.enqueue(se)}}finally{O.releaseLock()}}else{const O=await A.arrayBuffer();let N=O;if(i){j.abort();return}if(M>0&&(N=new Uint8Array(O).subarray(M),M-=O.byteLength-N.length),!N.byteLength)continue;s+=N.byteLength;const U=o.decode(N);_.enqueue(U)}}}if(p=0,w.content){let j=w.content,q=a.encode(w.content);if(M>0){const X=q.subarray(M);if(M-=q.length-X.length,!X.length)continue;q=X,j=o.decode(X)}s+=q.length,_.enqueue(j)}}}async function g(b){let _=!0,P=0;for(;_;){_=!1;let w=Date.now()+Math.min(15e3,500*(P-1));(await m({...e,offset:s},b))?.retry&&(_=!0,P++,w<Date.now()-3e5&&(P=0),await new Promise(j=>{setTimeout(j,Math.max(0,w-Date.now()))}))}!i&&!u&&(b.close(),f())}return{stream:new n({start(b){g(b)},cancel(b){i=!0,c&&r({eventId:c}),f()}}),addCloseCb:d,closed(){return u}}}class dr{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}=Io({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}=Co({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=$();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return e.ruleParams&&(i["rule-params"]=e.ruleParams),this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend($(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new Oo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend($(),t),delete this.readStreamIterators[e]}onStreamAppend(e){const t=e["client-event-id"],r=this.readStreamIterators[t];if(!r){this.log.info("No iterator for read stream",e);return}if(e.error){e.retry?r.push({type:"reconnect"}):r.push({type:"error",error:new 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!==ae.AUTHENTICATED)for(const{onDisconnect:t}of Object.values(this.writeStreams))t();else{for(const{onConnectionReconnect:t}of Object.values(this.writeStreams))t();for(const t of Object.values(this.readStreamIterators))t.push({type:"reconnect"}),t.close();this.readStreamIterators={}}}onRecieveError(e){const t=e["original-event"];switch(t.op){case"append-stream":{const r=t["stream-id"];this.writeStreams[r]?.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new 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 ae={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},Eo=3e4,Mo=3e4,Po=200,jo=1e3*60,$o={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ft="_instant_oauth_redirect",Kt="_instant_extra_fields_id",Xe="oauthExtraFields",ke="currentUser";function Ro({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new or(`${r}?app_id=${e}`);switch(n){case"ws":return new or(`${r}?app_id=${e}`);case"sse":return new ar(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Do(){return typeof window<"u"||typeof chrome<"u"}const fr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function xo(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=pn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=hn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Uo(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:fn(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Lo(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function No(n,e){return n==="pendingMutations"?[...e.entries()]:e}function Fo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function qt(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 hr{attrs;_isOnline=!0;_isShutdown=!1;status=ae.CONNECTING;querySubs;kv;_syncTable;_instantStream;queryCbs={};queryOnceDfds={};authCbs=[];attrsCbs=[];mutationErrorCbs=[];connectionStatusCbs=[];config;mutationDeferredStore=new Map;_reconnectTimeoutId=null;_reconnectTimeoutMs=0;_transport;_transportType="ws";_EventSource;_wsOk=null;_localIdPromises={};_errorMessage=null;_oauthCallbackResponse=null;_linkIndex=null;_broadcastChannel;_rooms={};_roomsPendingLeave={};_presence={};_broadcastQueue=[];_broadcastSubs={};_currentUserCached={isLoading:!0,error:void 0,user:void 0};_beforeUnloadCbs=[];_dataForQueryCache={};_log;_pendingTxCleanupTimeout;_pendingMutationCleanupThreshold;_inFlightMutationEventIds=new Set;_frameworkClient=null;constructor(e,t=jt,r=$t,s,i){if(this._EventSource=i,this.config={...$o,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??Mo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Po,this._log=co(e.verbose||Rt||Wn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":xt},this.config.schema&&(this._linkIndex=Dt(this.config.schema)),!!Do()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!_e(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{try{if(o.data?.type==="auth"){const a=await this.getCurrentUser({forceReadFromStorage:!0});await this.updateUser(a.user).catch(c=>{this._log.error("[error] update user",c)})}}catch(a){this._log.error("[error] handle broadcast channel",a)}})),this._initStorage(t),this._syncTable=new ko(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>we(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new dr({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)},jo),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",ae.CLOSED),this._setStatus(ae.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}getFrameworkClient(){return this._frameworkClient}setFrameworkClient(e){this._frameworkClient=e}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?Dt(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new Pt({persister:new e(this.config.appId,"querySubs"),merge:Fo,serialize:Uo,parse:(t,r)=>xo(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 Pt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:No,parse:Lo,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=t=>{t==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(ke),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,t,r){const s=this.mutationDeferredStore.get(t);this.mutationDeferredStore.delete(t);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:t,...r}),!!s)if(i)s.resolve({status:e,eventId:t});else if(r?.type){const{status:o,...a}=r;s.reject(new ve({body:a,status:o??0}))}else s.reject(new 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=we(this.attrs,t.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:t.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,t){const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(fr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ae.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const o of Object.keys(this._rooms)){const a=this._presence[o]?.result?.user,c=this._rooms[o]?.roomType;this._tryJoinRoom(c,o,a)}break}case"add-query-exists":{this.notifyOneQueryOnce(R(t.q));break}case"add-query-ok":{const{q:o,result:a}=t,c=R(o);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[c])break;const u=a?.[0]?.data?.["page-info"],l=a?.[0]?.data?.aggregate,f=Hn(a),d=this.ensureAttrs(),h=we(d,f,r,this.config.useDateObjects);this.querySubs.updateInPlace(p=>{if(!p[c]){this._log.info("Missing value in querySubs",{hash:c,q:o});return}p[c].result={store:h,attrsStore:d,pageInfo:u,aggregate:l,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(c),this.notifyOneQueryOnce(c),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(t);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(t);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(t);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(t);break}case"start-stream-ok":{this._instantStream.onStartStreamOk(t);break}case"stream-flushed":{this._instantStream.onStreamFlushed(t);break}case"append-failed":{this._instantStream.onAppendFailed(t);break}case"stream-append":{this._instantStream.onStreamAppend(t);break}case"refresh-ok":{const{computations:o,attrs:a}=t,c=t["processed-tx-id"];a&&this._setAttrs(a),this._cleanupPendingMutationsTimeout();const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),c);u!==this._pendingMutations()&&this.kv.updateInPlace(d=>{d.pendingMutations=u});const l=qt(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Hn(p),y=this.ensureAttrs(),b=we(y,g,r,this.config.useDateObjects),{store:_,attrsStore:P}=this._applyOptimisticUpdates(b,y,l,c),w=p?.[0]?.data?.["page-info"],M=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:_,attrsStore:P,pageInfo:w,aggregate:M}});f.forEach(({hash:d,q:h,store:p,attrsStore:m,pageInfo:g,aggregate:y})=>{this.querySubs.updateInPlace(b=>{if(!b[d]){this._log.error("Missing value in querySubs",{hash:d,q:h});return}b[d].result={store:p,attrsStore:m,pageInfo:g,aggregate:y,processedTxId:c}})}),this._cleanupPendingMutationsQueries(),f.forEach(({hash:d})=>{this.notifyOne(d)});break}case"transact-ok":{const{"client-event-id":o,"tx-id":a}=t;this._inFlightMutationEventIds.delete(o);const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(o);if(!u)break;this._updatePendingMutations(f=>{f.set(o,{...f.get(o),"tx-id":a,confirmed:Date.now()})});const l=[];for(const f of u["tx-steps"])if(f[0]==="add-attr"){const d=f[1];l.push(d)}if(l.length){const f=Object.values(this.ensureAttrs().attrs);this._setAttrs([...f,...l])}this._finishTransaction("synced",o),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._patchPresencePeers(o,t.edits),this._notifyPresenceSubs(o);break}case"refresh-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._setPresencePeers(o,t.data),this._notifyPresenceSubs(o);break}case"server-broadcast":{const o=t["room-id"],a=t.topic;this._trySetRoomConnected(o,!0),this._notifyBroadcastSubs(o,a,t);break}case"join-room-ok":{const o=t["room-id"];if(!this._rooms[o]){this._roomsPendingLeave[o]&&(this._tryLeaveRoom(o),delete this._roomsPendingLeave[o]);break}this._trySetRoomConnected(o,!0),this._flushEnqueuedRoomData(o);break}case"leave-room-ok":{const o=t["room-id"];this._trySetRoomConnected(o,!1);break}case"join-room-error":const s=t["room-id"],i=this._rooms[s];i&&(i.error=t.error),this._notifyPresenceSubs(s);break;case"error":this._handleReceiveError(t);break;default:this._log.info("Unknown op",t.op,t);break}}createWriteStream(e){return this._instantStream.createWriteStream(e)}createReadStream(e){return this._instantStream.createReadStream(e)}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(t=>{const r=t.pendingMutations??new Map;t.pendingMutations=r,e(r)})}_handleMutationError(e,t,r){const s=this._pendingMutations().get(t);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(t),o)),this._inFlightMutationEventIds.delete(t);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,t,r)}}_handleReceiveError(e){console.log("error",e);const t=e["client-event-id"];this._inFlightMutationEventIds.delete(t);const r=this._pendingMutations().get(t),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",t,e);return}if(e["original-event"]?.hasOwnProperty("q")&&e["original-event"]?.op==="add-query"){const a=e["original-event"]?.q,c=R(a);this.notifyQueryError(R(a),s),this.notifyQueryOnceError(a,c,t,s);return}if(e["original-event"]?.op==="init"){if(e.type==="record-not-found"&&e.hint?.["record-type"]==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ae.ERRORED,s),this.notifyAll();return}switch(e["original-event"]?.op){case"resync-table":{this._syncTable.onResyncError(e);return}case"start-sync":{this._syncTable.onStartSyncError(e);return}case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{this._instantStream.onRecieveError(e);return}}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
|
|
1
|
+
(function(v,R){typeof exports=="object"&&typeof module<"u"?R(exports):typeof define=="function"&&define.amd?define(["exports"],R):(v=typeof globalThis<"u"?globalThis:v||self,R(v.instant={}))})(this,(function(v){"use strict";function R(n){if(typeof n=="number")return(Math.abs(n*2654435761)>>>0).toString(16);if(typeof n=="boolean")return n?"1":"0";if(n===null)return"null";if(n===void 0)return"undefined";if(typeof n=="string"){let e=2166136261;for(let t=0;t<n.length;t++)e^=n.charCodeAt(t),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(n)){let e=2166136261;for(let t=0;t<n.length;t++){e^=(t+1)*2654435761;const r=R(n[t]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof n=="object"){let e=2166136261;const t=Object.keys(n).sort();for(let r=0;r<t.length;r++){const s=t[r];if(n[s]===void 0)continue;const i=R(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=R(n[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return R(String(n))}const x={Remove:"remove",Replace:"replace",Add:"add"},Bt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),Or=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Le=Symbol.iterator,J={mutable:"mutable",immutable:"immutable"},tt={};function Oe(n,e){return n instanceof Map?n.has(e):Object.prototype.hasOwnProperty.call(n,e)}function Gt(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 nt(n){return Object.getPrototypeOf(n)===Set.prototype}function rt(n){return Object.getPrototypeOf(n)===Map.prototype}function Y(n){var e;return(e=n.copy)!==null&&e!==void 0?e:n.original}function fe(n){return!!k(n)}function k(n){return typeof n!="object"?null:n?.[Bt]}function st(n){var e;const t=k(n);return t?(e=t.copy)!==null&&e!==void 0?e:t.original:n}function te(n,e){if(!n||typeof n!="object")return!1;let t;return Object.getPrototypeOf(n)===Object.prototype||Array.isArray(n)||n instanceof Map||n instanceof Set||!!e?.mark&&((t=e.mark(n,J))===J.immutable||typeof t=="function")}function Ht(n,e=[]){if(Object.hasOwnProperty.call(n,"key")){const t=n.parent.copy,r=k(ce(t,n.key));if(r!==null&&r?.original!==n.original)return null;const s=n.parent.type===3,i=s?Array.from(n.parent.setMap.keys()).indexOf(n.key):n.key;if(!(s&&t.size>i||Oe(t,i)))return null;e.push(i)}if(n.parent)return Ht(n.parent,e);e.reverse();try{Cr(n.copy,e)}catch{return null}return e}function he(n){return Array.isArray(n)?1:n instanceof Map?2:n instanceof Set?3:0}function ce(n,e){return he(n)===2?n.get(e):n[e]}function Ce(n,e,t){he(n)===2?n.set(e,t):n[e]=t}function it(n,e){const t=k(n);return(t?Y(t):n)[e]}function ue(n,e){return n===e?n!==0||1/n===1/e:n!==n&&e!==e}function ot(n){if(n)for(;n.finalities.revoke.length>0;)n.finalities.revoke.pop()()}function pe(n,e){return e?n:[""].concat(n).map(t=>{const r=`${t}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function Cr(n,e){for(let t=0;t<e.length-1;t+=1){const r=e[t];if(n=ce(he(n)===3?Array.from(n):n,r),typeof n!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return n}function Er(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 Mr=Object.prototype.propertyIsEnumerable;function Jt(n,e){let t;if(Array.isArray(n))return Array.prototype.concat.call(n);if(n instanceof Set){if(!nt(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(!rt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(n)}return new Map(n)}else if(e?.mark&&(t=e.mark(n,J),t!==void 0)&&t!==J.mutable){if(t===J.immutable)return Er(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=>{Mr.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=Jt(n.original,n.options))}function Ee(n){if(!te(n))return st(n);if(Array.isArray(n))return n.map(Ee);if(n instanceof Map){const t=Array.from(n.entries()).map(([r,s])=>[r,Ee(s)]);if(!rt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Map(t)}if(n instanceof Set){const t=Array.from(n).map(Ee);if(!nt(n)){const r=Object.getPrototypeOf(n).constructor;return new r(t)}return new Set(t)}const e=Object.create(Object.getPrototypeOf(n));for(const t in n)e[t]=Ee(n[t]);return e}function Ne(n){return fe(n)?Ee(n):n}function oe(n){var e;n.assignedMap=(e=n.assignedMap)!==null&&e!==void 0?e:new Map,n.operated||(n.operated=!0,n.parent&&oe(n.parent))}function Yt(){throw new Error("Cannot modify frozen object")}function ge(n,e,t,r,s){{t=t??new WeakMap,r=r??[],s=s??[];const o=t.has(n)?t.get(n):n;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(n)||fe(n)){r.pop(),s.pop();return}switch(he(n)){case 2:for(const[a,c]of n)ge(a,a,t,r,s),ge(c,a,t,r,s);n.set=n.clear=n.delete=Yt;break;case 3:for(const a of n)ge(a,a,t,r,s);n.add=n.clear=n.delete=Yt;break;case 1:Object.freeze(n);let o=0;for(const a of n)ge(a,o,t,r,s),o+=1;break;default:Object.freeze(n),Object.keys(n).forEach(a=>{const c=n[a];ge(c,a,t,r,s)})}r.pop(),s.pop()}function at(n,e){const t=he(n);if(t===0)Reflect.ownKeys(n).forEach(r=>{e(r,n[r],n)});else if(t===1){let r=0;for(const s of n)e(r,s,n),r+=1}else n.forEach((r,s)=>e(s,r,n))}function Zt(n,e,t){if(fe(n)||!te(n,t)||e.has(n)||Object.isFrozen(n))return;const r=n instanceof Set,s=r?new Map:void 0;if(e.add(n),at(n,(i,o)=>{var a;if(fe(o)){const c=k(o);z(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;Ce(r?s:n,i,u)}else Zt(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 Pr(n,e){const t=n.type===3?n.setMap:n.copy;n.finalities.revoke.length>1&&n.assignedMap.get(e)&&t&&Zt(ce(t,e),n.finalities.handledSet,n.options)}function ct(n){n.type===3&&n.copy&&(n.copy.clear(),n.setMap.forEach(e=>{n.copy.add(st(e))}))}function ut(n,e,t,r){if(n.operated&&n.assignedMap&&n.assignedMap.size>0&&!n.finalized){if(t&&r){const i=Ht(n);i&&e(n,i,t,r)}n.finalized=!0}}function lt(n,e,t,r){const s=k(t);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=n.type===3?n.setMap:n.copy;if(ue(ce(c,e),t)){let u=s.original;s.copy&&(u=s.copy),ct(n),ut(n,r,i,o),n.options.enableAutoFreeze&&(n.options.updatedValues=(a=n.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,n.options.updatedValues.set(u,s.original)),Ce(c,e,u)}}),n.options.enableAutoFreeze&&s.finalities!==n.finalities&&(n.options.enableAutoFreeze=!1)),te(t,n.options)&&n.finalities.draft.push(()=>{const i=n.type===3?n.setMap:n.copy;ue(ce(i,e),t)&&Pr(n,e)})}function jr(n,e,t,r,s){let{original:i,assignedMap:o,options:a}=n,c=n.copy;c.length<i.length&&([i,c]=[c,i],[t,r]=[r,t]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),f=pe(l,s);t.push({op:x.Replace,path:f,value:Ne(c[u])}),r.push({op:x.Replace,path:f,value:Ne(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=pe(l,s);t.push({op:x.Add,path:f,value:Ne(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=pe(l,s);r.push({op:x.Replace,path:f,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const f=e.concat([l-1]),d=pe(f,s);r.push({op:x.Remove,path:d})}}}function $r({original:n,copy:e,assignedMap:t},r,s,i,o){t.forEach((a,c)=>{const u=ce(n,c),l=Ne(ce(e,c)),f=a?Oe(n,c)?x.Replace:x.Add:x.Remove;if(ue(u,l)&&f===x.Replace)return;const d=r.concat(c),h=pe(d,o);s.push(f===x.Remove?{op:f,path:h}:{op:f,path:h,value:l}),i.push(f===x.Add?{op:x.Remove,path:h}:f===x.Remove?{op:x.Add,path:h,value:u}:{op:x.Replace,path:h,value:u})})}function Rr({original:n,copy:e},t,r,s,i){let o=0;n.forEach(a=>{if(!e.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:x.Remove,path:u,value:a}),s.unshift({op:x.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!n.has(a)){const c=t.concat([o]),u=pe(c,i);r.push({op:x.Add,path:u,value:a}),s.unshift({op:x.Remove,path:u,value:a})}o+=1})}function Me(n,e,t,r){const{pathAsArray:s=!0}=n.options.enablePatches;switch(n.type){case 0:case 2:return $r(n,e,t,r,s);case 1:return jr(n,e,t,r,s);case 3:return Rr(n,e,t,r,s)}}const Fe=(n,e,t=!1)=>{if(typeof n=="object"&&n!==null&&(!te(n,e)||t))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},dt={get size(){return Y(k(this)).size},has(n){return Y(k(this)).has(n)},set(n,e){const t=k(this),r=Y(t);return(!r.has(n)||!ue(r.get(n),e))&&(z(t),oe(t),t.assignedMap.set(n,!0),t.copy.set(n,e),lt(t,n,e,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);return z(e),oe(e),e.original.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.copy.delete(n),!0},clear(){const n=k(this);if(this.size){z(n),oe(n),n.assignedMap=new Map;for(const[e]of n.original)n.assignedMap.set(e,!1);n.copy.clear()}},forEach(n,e){const t=k(this);Y(t).forEach((r,s)=>{n.call(e,this.get(s),s,this)})},get(n){var e,t;const r=k(this),s=Y(r).get(n),i=((t=(e=r.options).mark)===null||t===void 0?void 0:t.call(e,s,J))===J.mutable;if(r.options.strict&&Fe(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(n))return s;const o=tt.createDraft({original:s,parentDraft:r,key:n,finalities:r.finalities,options:r.options});return z(r),r.copy.set(n,o),o},keys(){return Y(k(this)).keys()},values(){const n=this.keys();return{[Le]:()=>this.values(),next:()=>{const e=n.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const n=this.keys();return{[Le]:()=>this.entries(),next:()=>{const e=n.next();if(e.done)return e;const t=this.get(e.value);return{done:!1,value:[e.value,t]}}}},[Le](){return this.entries()}},Dr=Reflect.ownKeys(dt),Xt=(n,e,{isValuesIterator:t})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=n.setMap.get(o);const c=k(a),u=((s=(r=n.options).mark)===null||s===void 0?void 0:s.call(r,a,J))===J.mutable;if(n.options.strict&&Fe(o,n.options,u),!u&&!c&&te(o,n.options)&&!n.finalized&&n.original.has(o)){const l=tt.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]}},Ke={get size(){return k(this).setMap.size},has(n){const e=k(this);if(e.setMap.has(n))return!0;z(e);const t=k(n);return!!(t&&e.setMap.has(t.original))},add(n){const e=k(this);return this.has(n)||(z(e),oe(e),e.assignedMap.set(n,!0),e.setMap.set(n,n),lt(e,n,n,Me)),this},delete(n){if(!this.has(n))return!1;const e=k(this);z(e),oe(e);const t=k(n);return t&&e.setMap.has(t.original)?(e.assignedMap.set(t.original,!1),e.setMap.delete(t.original)):(!t&&e.setMap.has(n)?e.assignedMap.set(n,!1):e.assignedMap.delete(n),e.setMap.delete(n))},clear(){if(!this.size)return;const n=k(this);z(n),oe(n);for(const e of n.original)n.assignedMap.set(e,!1);n.setMap.clear()},values(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Xt(n,e,{isValuesIterator:!0})}},entries(){const n=k(this);z(n);const e=n.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Xt(n,e,{isValuesIterator:!1})}},keys(){return this.values()},[Le](){return this.values()},forEach(n,e){const t=this.values();let r=t.next();for(;!r.done;)n.call(e,r.value,r.value,this),r=t.next()}};Set.prototype.difference&&Object.assign(Ke,{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 xr=Reflect.ownKeys(Ke),en=new WeakSet,tn={get(n,e,t){var r,s;const i=(r=n.copy)===null||r===void 0?void 0:r[e];if(i&&en.has(i))return i;if(e===Bt)return n;let o;if(n.options.mark){const u=e==="size"&&(n.original instanceof Map||n.original instanceof Set)?Reflect.get(n.original,e):Reflect.get(n.original,e,t);if(o=n.options.mark(u,J),o===J.mutable)return n.options.strict&&Fe(u,n.options,!0),u}const a=Y(n);if(a instanceof Map&&Dr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(dt,"size").get.call(n.proxy);const u=dt[e];if(u)return u.bind(n.proxy)}if(a instanceof Set&&xr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(Ke,"size").get.call(n.proxy);const u=Ke[e];if(u)return u.bind(n.proxy)}if(!Oe(a,e)){const u=Gt(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(n.proxy):void 0}const c=a[e];if(n.options.strict&&Fe(c,n.options),n.finalized||!te(c,n.options))return c;if(c===it(n.original,e)){if(z(n),n.copy[e]=ft({original:n.original[e],parentDraft:n,key:n.type===1?Number(e):e,finalities:n.finalities,options:n.options}),typeof o=="function"){const u=k(n.copy[e]);return z(u),oe(u),u.copy}return n.copy[e]}return c},set(n,e,t){var r;if(n.type===3||n.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(n.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=Gt(Y(n),e);if(i?.set)return i.set.call(n.proxy,t),!0;const o=it(Y(n),e),a=k(o);return a&&ue(a.original,t)?(n.copy[e]=t,n.assignedMap=(r=n.assignedMap)!==null&&r!==void 0?r:new Map,n.assignedMap.set(e,!1),!0):(ue(t,o)&&(t!==void 0||Oe(n.original,e))||(z(n),oe(n),Oe(n.original,e)&&ue(t,n.original[e])?n.assignedMap.delete(e):n.assignedMap.set(e,!0),n.copy[e]=t,lt(n,e,t,Me)),!0)},has(n,e){return e in Y(n)},ownKeys(n){return Reflect.ownKeys(Y(n))},getOwnPropertyDescriptor(n,e){const t=Y(n),r=Reflect.getOwnPropertyDescriptor(t,e);return r&&{writable:!0,configurable:n.type!==1||e!=="length",enumerable:r.enumerable,value:t[e]}},getPrototypeOf(n){return Reflect.getPrototypeOf(n.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(n,e){var t;return n.type===1?tn.set.call(this,n,e,void 0,n.proxy):(it(n.original,e)!==void 0||e in n.original?(z(n),oe(n),n.assignedMap.set(e,!1)):(n.assignedMap=(t=n.assignedMap)!==null&&t!==void 0?t:new Map,n.assignedMap.delete(e)),n.copy&&delete n.copy[e],!0)}};function ft(n){const{original:e,parentDraft:t,key:r,finalities:s,options:i}=n,o=he(e),a={type:o,finalized:!1,parent:t,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in n)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,tn);if(s.revoke.push(u),en.add(c),a.proxy=c,t){const l=t;l.finalities.draft.push((f,d)=>{var h,p;const m=k(c);let g=l.type===3?l.setMap:l.copy;const y=ce(g,r),b=k(y);if(b){let _=b.original;b.operated&&(_=st(y)),ct(b),ut(b,Me,f,d),l.options.enableAutoFreeze&&(l.options.updatedValues=(h=l.options.updatedValues)!==null&&h!==void 0?h:new WeakMap,l.options.updatedValues.set(_,b.original)),Ce(g,r,_)}(p=m.callbacks)===null||p===void 0||p.forEach(_=>{_(f,d)})})}else{const l=k(c);l.finalities.draft.push((f,d)=>{ct(l),ut(l,Me,f,d)})}return c}tt.createDraft=ft;function Ur(n,e,t,r,s){var i;const o=k(n),a=(i=o?.original)!==null&&i!==void 0?i:n,c=!!e.length;if(o?.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(t,r);const u=c?e[0]:o?o.operated?o.copy:o.original:n;return o&&ot(o),s&&ge(u,u,o?.options.updatedValues),[u,t&&c?[{op:x.Replace,path:[],value:e[0]}]:t,r&&c?[{op:x.Replace,path:[],value:a}]:r]}function Lr(n,e){var t;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((t=e.mark)===null||t===void 0?void 0:t.call(e,n,J))===J.mutable||!te(n,e)?n:ft({original:n,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=Ur(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function ht(n){const{rootDraft:e,value:t,useRawReturn:r=!1,isRoot:s=!0}=n;at(t,(i,o,a)=>{const c=k(o);if(c&&e&&c.finalities===e.finalities){n.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(f=>a.add(i===f?u:f))}else Ce(a,i,u)}else typeof o=="object"&&o!==null&&(n.value=o,n.isRoot=!1,ht(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 nn(n){var e;const t=k(n);if(!te(n,t?.options))return n;const r=he(n);if(t&&!t.operated)return t.original;let s;function i(){s=r===2?rt(n)?new Map(n):new(Object.getPrototypeOf(n)).constructor(n):r===3?Array.from(t.setMap.values()):Jt(n,t?.options)}if(t){t.finalized=!0;try{i()}finally{t.finalized=!1}}else s=n;if(at(s,(o,a)=>{if(t&&ue(ce(t.original,o),a))return;const c=nn(a);c!==a&&(s===n&&i(),Ce(s,o,c))}),r===3){const o=(e=t?.original)!==null&&e!==void 0?e:s;return nt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function rn(n){if(!fe(n))throw new Error(`current() is only used for Draft, parameter: ${n}`);return nn(n)}const qe=(n=>function e(t,r,s){var i,o,a;if(typeof t=="function"&&typeof r!="function")return function(w,...M){return e(w,j=>t.call(this,j,...M),r)};const c=t,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},n),l);const f=fe(c)?rn(c):c,d=Array.isArray(l.mark)?((w,M)=>{for(const j of l.mark){if(typeof j!="function")throw new Error(`Invalid mark: ${j}, 'mark' should be a function.`);const q=j(w,M);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(!te(f,g)&&typeof f=="object"&&f!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[y,b]=Lr(f,g);if(typeof r!="function"){if(!te(f,g))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[y,b]}let _;try{_=u(y)}catch(w){throw ot(k(y)),w}const P=w=>{const M=k(y);if(!fe(w)){if(w!==void 0&&!ue(w,y)&&M?.operated)throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const q=w?.[Or];if(q){const X=q[0];return g.strict&&typeof w=="object"&&w!==null&&ht({rootDraft:M,value:w,useRawReturn:!0}),b([X])}if(w!==void 0)return typeof w=="object"&&w!==null&&ht({rootDraft:M,value:w}),b([w])}if(w===y||w===void 0)return b([]);const j=k(w);if(g===j.options){if(j.operated)throw new Error("Cannot return a modified child draft.");return b([rn(w)])}return b([w])};return _ instanceof Promise?_.then(P,w=>{throw ot(k(y)),w}):P(_)})();Object.prototype.constructor.toString();function sn(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 on(n,e){return Object.keys(n).length===Object.keys(e).length&&Object.keys(n).every(t=>e.hasOwnProperty(t)&&n[t]===e[t])}function ze(n,e){return typeof n!="object"||typeof e!="object"||n===null||e===null?n===e:sn(n,e)?Object.keys(n).every(t=>ze(n[t],e[t])):!1}function pt(n){if(!Pe(n))return n;const e={};for(const[t,r]of Object.entries(n))r!==void 0&&(e[t]=r);return e}function an(n,e){if(!Pe(n)||!Pe(e))return e;const t={...n};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete t[r];continue}const s=Pe(n[r])&&Pe(e[r]);t[r]=s?an(n[r],e[r]):e[r]}return t}function Pe(n){return typeof n=="object"&&n!==null&&!Array.isArray(n)}function Nr(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 cn(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 un(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}un(n[t],r),Fr(n[t])&&delete n[t]}}function Fr(n){return n&&Object.keys(n).length===0}const ln=/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$/,Kr={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 qr(n){return new Date(n)}function zr(n){return new Date(n+"Z")}const Wr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Vr(n){const e=n.match(Wr);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 Qr(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Br(n){const[e,t]=n.split(" ");return new Date(e+"T"+t+"Z")}function Gr(n){return new Date(n)}function Hr(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 Jr(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 Yr(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 Zr(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 Xr(n){switch(n){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function es(n){const e=n.match(ln);if(!e)return null;const[t]=e,r=Kr[t],s=new Date(n.replace(ln,"Z"));return new Date(s.getTime()-r*1e3)}const ts=[Vr,Br,Hr,Zr,Gr,zr,Jr,Qr,qr,Xr,es,Yr];function ns(n,e){try{const t=n(e);return t instanceof Date&&!isNaN(t.getTime())?t:null}catch{return null}}function yt(n){for(const e of ts){const t=ns(e,n);if(t)return t}return null}function rs(n){try{const e=JSON.parse(n);return typeof e=="string"?yt(e):null}catch{return null}}function je(n){if(n!==void 0){if(n===null)return null;if(n instanceof Date)return n;if(typeof n=="string"){const e=yt(n)||rs(n)||yt(n.trim());if(!e)throw new Error(`Unable to parse \`${n}\` as a date.`);return e}else if(typeof n=="number")return new Date(n);throw new Error(`Invalid date value \`${n}\`. Expected a date, number, or string, got type ${typeof n}.`)}}class de{attrs;linkIndex;_blobAttrs=null;_primaryKeys=null;_forwardIdents=null;_revIdents=null;constructor(e,t){this.attrs=e,this.linkIndex=t}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const t=this.attrs[e.id];t&&(this.attrs[e.id]={...t,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(gt(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 ss(n){return n.cardinality==="one"}function bt(n){return n["value-type"]==="ref"}function gt(n){return n["value-type"]==="blob"}function me(n,e){return e.reduce((t,r)=>t&&t.get(r),n)}function ne(n,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){n.delete(e[0]);return}const[t,...r]=e;n.has(t)&&ne(n.get(t),r)}function Q(n,e,t){let r=n;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],t)}function dn(n,e,t){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=n.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&t&&(u=je(u),o[2]=u),bt(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 fn(n){return{triples:B(n.eav,3),cardinalityInference:n.cardinalityInference,useDateObjects:n.useDateObjects,version:1}}function hn(n,e){return we(n,e.triples,e.cardinalityInference,e.useDateObjects)}function pn(n,e){if(n)return new de(n.attrs,n.linkIndex);if(e&&"__type"in e)return new de(e.attrs,e.linkIndex)}function is(n,e){return me(n.eav,[e])!==void 0}function we(n,e,t,r){const s=dn(n,e,r);return s.cardinalityInference=t,s.useDateObjects=r,s}function $e(n,e){let t;if(Array.isArray(e[0])){const[s,i]=e[0],o=n.aev.get(s);if(!o)return null;t=B(o,2).find(c=>c[2]===i)?.[0]}else t=e[0];if(!t)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&n.aev.get(r[0])){const[s,i]=r,o=n.aev.get(s);if(!o)return null;const c=B(o,2).find(h=>h[2]===i)?.[0];if(!c)return null;const[u,l,f,...d]=e;return[t,l,c,...d]}else{const[s,...i]=e;return[t,...i]}}function yn(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(n.eav,[s,i,o]),ne(n.aev,[i,s,o]),bt(a)&&ne(n.vae,[o,i,s]))}let os=0;function bn(n,e,t){const[r,s,i]=t;let o;const a=me(n.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+os++}function gn(n,e,t){const r=$e(n,t);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&n.useDateObjects&&(o=je(o));const u=me(n.eav,[s,i,o])?.[3]??bn(n,a,r),l=[s,i,o,u];ss(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)),bt(a)&&Q(n.vae,[o,i,s],l)}function as(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!gt(a))throw new Error("merge operation is not supported for links");const c=me(n.eav,[s,i]);if(!c)return;const u=c.values().next()?.value;if(!u)return;const l=u[2],f=an(l,o),d=[s,i,f,bn(n,a,u)];Q(n.eav,[s,i],new Map([[f,d]])),Q(n.aev,[i,s],new Map([[f,d]]))}function mt(n,e,t){const[r,s]=t,i=$e(n,[r]);if(!i)return;const[o]=i,a=n.eav.get(o);if(a){for(const u of a.keys()){const l=e.getAttr(u);l&&l["on-delete-reverse"]==="cascade"&&B(a.get(u),1).forEach(([f,d,h])=>mt(n,e,[h,l["reverse-identity"]?.[1]])),(!s||!l||l["forward-identity"]?.[1]===s)&&(ne(n.aev,[u,o]),ne(n.eav,[o,u]))}a.size===0&&ne(n.eav,[o])}const c=n.vae.get(o)&&B(n.vae.get(o),2);c&&c.forEach(u=>{const[l,f,d]=u,h=e.getAttr(f);(!s||!h||h["reverse-identity"]?.[1]===s)&&(ne(n.eav,[l,f,d]),ne(n.aev,[f,l,d]),ne(n.vae,[d,f,l])),h&&h["on-delete"]==="cascade"&&h["reverse-identity"]?.[1]===s&&mt(n,e,[l,h["forward-identity"]?.[1]])}),n.vae.get(o)?.size===0&&ne(n.vae,[o])}function mn(n,e,t){const r=dn(e,t,n.useDateObjects);Object.keys(r).forEach(s=>{n[s]=r[s]})}function cs(n,[e]){n.addAttr(e)}function wn(n){return B(n.eav,3)}function us(n,e,[t]){if(!e.getAttr(t))return;const r=wn(n).filter(([s,i])=>i!==t);e.deleteAttr(t),mn(n,e,r)}function ls(n,e,[t]){e.getAttr(t.id)&&(e.updateAttr(t),mn(n,e,wn(n)))}function ds(n,e,t){const[r,...s]=t;switch(r){case"add-triple":gn(n,e,s);break;case"deep-merge-triple":as(n,e,s);break;case"retract-triple":yn(n,e,s);break;case"delete-entity":mt(n,e,s);break;case"add-attr":cs(e,s);break;case"delete-attr":us(n,e,s);break;case"update-attr":ls(n,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(n,e,t=[]){if(!n||e===0)return t;if(e===1){for(const r of n.values())t.push(r);return t}for(const r of n.values())B(r,e-1,t);return t}function We(n,e,t){const r=[];if(t?.hasOwnProperty("$not")){for(const i of e.keys())t.$not!==i&&r.push(e.get(i));return r}if(t?.hasOwnProperty("$isNull")){const{attrId:i,isNull:o,reverse:a}=t.$isNull;if(a)for(const c of e.keys()){const u=n.vae.get(c),l=!u||!u.get(i);(o?l:!l)&&r.push(e.get(c))}else{const c=n.aev.get(i);for(const u of e.keys()){const l=!c||c.get(u)?.get(null)||!c.get(u);(o?l:!l)&&r.push(e.get(u))}}return r}if(t?.$comparator)return B(e,1).filter(t.$op);const s=t.in||t.$in||[t];for(const i of s){const o=e.get(i);o&&r.push(o)}return r}function fs(n,e,t){let r="";return n!==void 0&&(r+="e"),e!==void 0&&(r+="a"),t!==void 0&&(r+="v"),r}function hs(n,[e,t,r]){switch(fs(e,t,r)){case"e":{const i=n.eav.get(e);return B(i,2)}case"ea":{const i=n.eav.get(e)?.get(t);return B(i,1)}case"eav":{const i=n.eav.get(e)?.get(t);return i?We(n,i,r):[]}case"ev":{const i=n.eav.get(e);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"a":{const i=n.aev.get(t);return B(i,2)}case"av":{const i=n.aev.get(t);if(!i)return[];const o=[];for(const a of i.values())o.push(...We(n,a,r));return o}case"v":{const i=[];for(const o of n.eav.values())for(const a of o.values())i.push(...We(n,a,r));return i}default:return B(n.eav,3)}}function ps(n,e,t){const r={};if(!e)return r;for(const[s,i]of e.entries()){const o=n.eav.get(t)?.get(i.id),a=B(o,1);for(const c of a)r[s]=c[2]}return r}function L(n,e,t){return n.forwardIdents.get(e)?.get(t)}function ye(n,e,t){return n.revIdents.get(e)?.get(t)}function ys(n,e){return n.blobAttrs.get(e)}function _n(n,e){const t=n.primaryKeys.get(e);return t||n.forwardIdents.get(e)?.get("id")}function bs(n,e,t){const r=$e(n,t);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return me(n.eav,[s,i])}function gs(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=_n(e,f["forward-identity"][1]);l=!!bs(n,e,[i,d?.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return qe({store:n,attrsStore:e},s=>{r.forEach(i=>{ds(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof de)return"immutable"}})}function ms(n){return typeof n=="string"&&n.startsWith("?")}function ws(n,e,t){if(t.hasOwnProperty(n)){const r=t[n];return Tn(r,e,t)}return{...t,[n]:e}}function Sn(n,e,t){return n===e?t:null}function _s(n){return typeof n==="string"&&n.startsWith("?")?ws:Sn}const Ss=["in","$in","$not","$isNull","$comparator"];function Ts(n){for(const e of Ss)if(n.hasOwnProperty(e))return!0;return!1}function Tn(n,e,t){return t?typeof n=="object"?Ts(n)?t:null:_s(n)(n,e,t):null}function vs(n,e,t){return n.reduce((r,s,i)=>{const o=e[i];return Tn(s,o,r)},t)}function As(n,e,t){return Os(n,e,t).map(r=>vs(e,r,t)).filter(r=>r)}function ks(n,e,t){return e.or?e.or.patterns.flatMap(r=>wt(n,r,t)):e.and?e.and.patterns.reduce((r,s)=>wt(n,s,r),t):t.flatMap(r=>As(n,e,r))}function wt(n,e,t=[{}]){return e.reduce((r,s)=>ks(n,s,r),t)}function _t(n,e){return Array.isArray(e)?e.map(t=>_t(n,t)):ms(e)?n[e]:e}function Is(n,{find:e,where:t}){return wt(n,t).map(s=>_t(s,e))}function Os(n,e,t){return hs(n,_t(t,e))}const Cs=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function _e(n){return typeof n=="string"&&Cs.test(n)}const F=[];for(let n=0;n<256;++n)F.push((n+256).toString(16).slice(1));function Es(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 St;const Ms=new Uint8Array(16);function Ps(){if(!St){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");St=crypto.getRandomValues.bind(crypto)}return St(Ms)}const vn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function js(n,e,t){if(vn.randomUUID&&!n)return vn.randomUUID();n=n||{};const r=n.random??n.rng?.()??Ps();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,Es(r)}function An(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 $s(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 Rs(n,e){return $s(An(n),An(e))}function $(){return js()}function Ds(n,e){return n.localeCompare(e)}function xs(){let n=Ds;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{n=Intl.Collator("en-US").compare}catch{}return n}const Us=xs();let kn=!0;const Ls=n=>{kn=n};let Ns=0;function Re(n){return Ve(`_${n}`,Ns++)}function Ve(n,e){return`?${n}-${e}`}class Se extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Fs(n,e){const t=_n(n,e);if(!t)throw new Se(`Could not find id attr for ${e}`);return t}function In(n,e,t,r){return[Ks(n,e,t,r)]}function Ks(n,e,t,r){return[n(t,r),Fs(e,t).id,n(t,r),n("time",r)]}function qs(n,e,t){return n.map(r=>r===e?t:r)}function On(n,e,t,r,s){const i=L(e,t,s),o=ye(e,t,s),a=i||o;if(!a)throw new Se(`Could not find attr for ${[t,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,f]=a["reverse-identity"],d=r+1,h=i?[n(u,r),a.id,n(f,d),Re("time")]:[n(u,d),a.id,n(f,r),Re("time")];return[i?f:u,d,h,a,!!i]}function Cn(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 zs(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=Cn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=Cn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Ws(n,e,t,r,s,i){const o=L(e,t,s),a=ye(e,t,s),c=o||a;if(!c)throw new Se(`No attr for etype = ${t} label = ${s}`);if(i?.hasOwnProperty("$isNull")){const u=L(e,t,"id");if(!u)throw new Se(`No attr for etype = ${t} label = id`);return[n(t,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Re("time")]}return o?[n(t,r),c.id,zs(c,i),Re("time")]:[i,c.id,n(t,r),Re("time")]}function Vs(n,e,t,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,d]=c,[h,p,m]=On(n,e,l,f,u);return[h,p,[...d,m]]},[t,r,[]]);return[i,o,a]}function Tt(n,e,t,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Vs(n,e,t,r,o),f=Ws(n,e,c,u,a,i);return l.concat([f])}function Qs(n,e){return e?[e].concat(n):n}function Bs([n,e]){return n==="or"&&Array.isArray(e)}function Gs([n,e]){return n==="and"&&Array.isArray(e)}function Hs(n,e,t){return(r,s)=>{const i=n(r,s);return e==i?i:`${i}-${t}`}}function En(n,e,t,r,s,i){const o=n(r,s),a=i.map((c,u)=>{const l=Hs(n,o,u);return Pn(l,t,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Js(n){const e=[];for(let t=1;t<=n.length;t++)e.push(n.slice(0,t));return e}function Mn(n,e,t,r,s){return Js(s).map(i=>Tt(n,e,t,r,i,{$isNull:!0}))}function Pn(n,e,t,r,s){return Object.entries(s).flatMap(([i,o])=>{if(Bs([i,o]))return En(n,"or",e,t,r,o);if(Gs([i,o]))return En(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=Tt(n,e,t,r,a,o),u=Mn(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:Mn(n,e,t,r,a),joinSym:n(t,r)}}]:Tt(n,e,t,r,a,o)})}function Ys(n,e,t,r){const s=Ve;return r?Pn(s,n,e,t,r).concat(In(s,n,e,t)):In(s,n,e,t)}function Zs(n,e,t){return[n(e,t),n("time",t)]}function Xs(n,e,t,r,s,i){const[o,a,c,u,l]=On(n,e,t,r,s),f=qs(c,n(t,r),i);return[o,a,f,u,l]}function ei(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]=Xs(n,t,r,s,h,u),b=Rn(e,t,{etype:m,level:g,form:i[h],join:y}),_=p?b[0]:b;return{[h]:_}}catch(m){if(m instanceof Se)return{[h]:p?void 0:[]};throw m}}).reduce(function(h,p){return{...h,...p}},l)}):Object.values(o)}function ti(n,e,t){return t==="string"?Us(n,e):n>e?1:-1}function De(n,e,t,r,s){return e===r||e==null&&r==null?Rs(n,t):r==null?1:e==null?-1:ti(e,r,s)}function Qe([n,e],[t,r],s){return De(n,e,t,r,s)}function vt(n){return n==null?n:new Date(n).getTime()}function jn(n,e,t){const[r,s,i,o]=n;if(e["forward-identity"]?.[2]==="id")return Qe(t,[r,o],null);const[a,c]=t,u=e["checked-data-type"],l=u==="date"?vt(c):c,f=u==="date"?vt(i):i;return Qe([a,l],[r,f],u)}function ni(n,e,t,r){const s=jn(n,e,r);return t==="desc"?s>0:s<0}function ri(n,e,t,r){const s=jn(n,e,r);return t==="desc"?s<0:s>0}function si(n,e){const t=e[1];return n.getAttr(t)}function ii(n,e,t){const r=Object.keys(t)[0];return L(n,e,r)}function oi(n,e,t,r){if(t)return si(n,t);if(r)return ii(n,e,r)}function ai(n,e,t){if(!Array.isArray(t.fields))return ys(n,e);const r=new Map;for(const s of t.fields){const i=L(n,e,s),o=i?.["forward-identity"]?.[2];o&>(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 ci(n,e,{etype:t,pageInfo:r,dq:s,form:i}){const o=i?.$?.order,a=$n(i),c=ui(i);let u=Is(n,s);const l=r?.["start-cursor"],f=r?.["end-cursor"],d=oi(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=vt(b)),[y,b]})}u.sort(c==="asc"?function(g,y){return Qe(g,y,d?.["checked-data-type"])}:function(g,y){return Qe(y,g,d?.["checked-data-type"])});let h={};const p=ai(e,t,s);for(const m of u){const[g]=m;if(h[g]||!a&&l&&d&&ni(l,d,c,m)||f&&d&&ri(f,d,c,m))continue;const y=ps(n,p,g);y&&(h[g]=y)}return h}function ui(n){const e=n.$?.order;return e&&e[Object.keys(e)[0]]||"asc"}function $n(n){const e=n.$?.offset,t=n.$?.before,r=n.$?.after;return!e&&!t&&!r}function li(n,e,{etype:t,level:r,form:s,join:i,pageInfo:o}){if(!$n(s)&&(!o||!o["start-cursor"]))return[];const a=Qs(Ys(e,t,r,s.$?.where),i),c=Zs(Ve,t,r),u=s.$?.fields,l=ci(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&&kn&&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 di(n,e,t){try{return li(n,e,t)}catch(r){if(r instanceof Se)return{};throw r}}function Rn(n,e,t){const r=di(n,e,t);return ei(Ve,n,e,t,r)}function fi(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 At({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]=Rn(n,e,{etype:u,form:s[u],level:0,pageInfo:t?.[u]})),c},{})};return t&&(o.pageInfo=fi(t)),r&&(o.aggregate=r),o}function hi(){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 pi=hi();function Be(n,e,t){const r={__etype:n,__ops:t};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return t;if(i==="__etype")return n;if(pi.has(i))return(o,a)=>Be(n,e,[...t,a?[i,n,e,o,a]:[i,n,e,o]])}})}function Dn(n,e){return`lookup__${n}__${JSON.stringify(e)}`}function Ge(n){return n.startsWith("lookup__")}function kt(n){const[e,t,...r]=n.split("__");return[t,JSON.parse(r.join("__"))]}function yi(n){return new Proxy({__etype:n},{get(e,t){if(t==="lookup")return(s,i)=>Be(n,kt(Dn(s,i)),[]);if(t==="__etype")return n;const r=t;return Ge(r)?Be(n,kt(r),[]):Be(n,r,[])}})}function It(){return new Proxy({},{get(n,e){return yi(e)}})}const bi=It();function xn(n){return n.__ops}function gi(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 mi(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 wi(n,e,t){return t.indexOf(".")!==-1&&!L(n,e,t)}function Ot(n){const[e,t,...r]=n.split(".");if(r.length>0||t!=="id")throw new Error(`${n} is not a valid lookup attribute.`);return e}function _i(n,e,t){if(!wi(n,e,t))return L(n,e,t);const r=Ot(t),s=L(n,e,r)||ye(n,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${t} does not reference a valid link attribute.`);return s}function Ct(n){return typeof n=="string"&&!Ge(n)?null:typeof n=="string"&&Ge(n)?kt(n):mi(n)}function G(n,e,t){const r=Ct(t);if(r===null)return t;const[s,i]=r,o=_i(n,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Un(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 Si({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["add-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["add-triple",G(n,u["forward-identity"][1],l),u?.id,G(n,e,t)])});return Un(n,e,t,s)}function Ti({attrsStore:n},[e,t,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=L(n,e,i),u=ye(n,e,i);return a.map(l=>c?["retract-triple",G(n,e,t),c.id,G(n,c["reverse-identity"][1],l)]:["retract-triple",G(n,u["forward-identity"][1],l),u.id,G(n,e,t)])});return Un(n,e,t,s)}function vi(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 Ln({stores:n,attrsStore:e},[t,r,s,i]){return i?.upsert===!1?{mode:"update"}:i?.upsert===!0?null:vi(n,e,t,r)?{mode:"update"}:null}function Ai(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,f])=>{const d=L(t,r,l);return d["checked-data-type"]==="date"&&n.useDateObjects&&(f=je(f)),["add-triple",c,d.id,f,{mode:"create"}]})}function ki(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s),u=Ln(n,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([f,d])=>{const h=L(t,r,f);return h["checked-data-type"]==="date"&&n.useDateObjects&&(d=je(d)),["add-triple",c,h.id,d,...u?[u]:[]]})}function Ii({attrsStore:n},[e,t]){return[["delete-entity",G(n,e,t),e]]}function Oi(n,e){const{attrsStore:t}=n,[r,s,i,o]=e,a=pt(i),c=G(t,r,s),u=Ln(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 Ci({attrsStore:n},[e,t,r]){return[["rule-params",G(n,e,t),e,r]]}function Ei(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 Mi(n,e){const[t,...r]=Ei(e);switch(t){case"merge":return Oi(n,r);case"create":return Ai(n,r);case"update":return ki(n,r);case"link":return Si(n,r);case"unlink":return Ti(n,r);case"delete":return Ii(n,r);case"ruleParams":return Ci(n,r);default:throw new Error(`unsupported action ${t}`)}}function Pi(n){switch(n){case"string":case"date":case"boolean":case"number":return n;default:return}}function ji(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=Pi(r?.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function He(n,e,t,r){const s=n?ji(n,e,t):null,i=$(),a=[$(),e,t];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function $i(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 Ri(n,e,t){const r=$i(n,e,t);if(!r)throw new Error(`Couldn't find the link ${e}.${t} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[$(),s.on,s.label],"reverse-identity":[$(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Nn(n,e,t,r){const s=n?Ri(n,e,t):null,i=$(),o=[$(),e,t],a=[$(),t,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const Di=new Set(["create","update","merge","link","unlink"]),xi=new Set(["link","unlink"]),Ui=new Set(["create","update","merge"]),Li=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Et={"unique?":!0,"index?":!0},Ni={...Et,cardinality:"one"};function Fi(n){const e=[],[t,r,s,i]=n;if(!Li.has(t))return e;const o=Ct(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=Ct(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function Ki({attrsStore:n,schema:e},t){const r=new Set,s=[],i=[];function o(d,h){return L(n,d,h)||s.find(p=>p["forward-identity"][1]===d&&p["forward-identity"][2]===h)}function a(d,h){return ye(n,d,h)||s.find(p=>p["reverse-identity"]?.[1]===d&&p["reverse-identity"]?.[2]===h)}function c(d){s.push(d),i.push(["add-attr",d]),r.add(d.id)}function u(d){d&&"isUnsynced"in d&&d.isUnsynced&&!r.has(d.id)&&(s.push(d),i.push(["add-attr",d]),r.add(d.id))}function l(d,h){return h.indexOf(".")!==-1&&!o(d,h)}function f(d,h){const p=o(d,h),m=a(d,h);u(p),u(m),!p&&!m&&c(Nn(e,d,h,Ni))}for(const d of t)for(const{etype:h,lookupPair:p,linkLabel:m}of Fi(d)){const g=p[0];if(m){f(h,m);const y=o(h,m),b=a(h,m);u(y),u(b);const _=y?.["reverse-identity"]?.[1]||b?.["forward-identity"]?.[1]||m;if(l(_,g))f(_,Ot(g));else{const P=o(_,g);P||c(He(e,_,g,Et)),u(P)}}else if(l(h,g))f(h,Ot(g));else{const y=o(h,g);y||c(He(e,h,g,Et)),u(y)}}for(const d of t){const[h,p,m,g]=d;if(Di.has(h)){const y=o(p,"id");u(y),y||c(He(e,p,"id",{"unique?":!0}));for(const b of Object.keys(g)){const _=o(p,b);if(u(_),Ui.has(h)&&(_||c(He(e,p,b,b==="id"?{"unique?":!0}:null))),xi.has(h)){const P=a(p,b);!_&&!P&&c(Nn(e,p,b)),u(P)}}}}if(s.length){const d={...n.attrs};for(const h of s)d[h.id]=h;return[new de(d,n.linkIndex),i]}return[n,i]}function qi(n,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>xn(c)),[s,i]=Ki(n,r),o={...n,attrsStore:s},a=r.flatMap(c=>Mi(o,c));return[...i,...a]}function Fn(n,e){typeof requestIdleCallback>"u"?n():requestIdleCallback(n,{timeout:e})}const Te="__meta";class Mt{constructor(e,t){}}class Pt{currentValue;_subs=[];_persister;_merge;serialize;parse;_saveThrottleMs;_idleCallbackMaxWaitMs;_nextSave=null;_nextGc=null;_pendingSaveKeys=new Set;_loadedKeys=new Set;_loadingKeys;_objectSize;_log;onKeyLoaded;_version=0;_meta={isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0};_gcOpts;constructor(e){this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){this._meta.loadingPromise&&await this._meta.loadingPromise;try{const e=this._persister.getItem(Te);this._meta.loadingPromise=e;const t=await e;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const r=this._meta.value?.objects??{},s=t??{},i=s.objects??{};this._meta.value={...s,objects:{...r,...i}}}catch(e){this._meta.error=e,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const t=await this.waitForMetaToLoad();if(!t)return;const r=Object.entries(t.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const t=await this._persister.getItem(e);return t&&this.parse(e,t)}catch(t){return console.error(`Unable to read from storage for key=${e}`,t),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const t=this._getFromStorage(e);this._loadingKeys[e]=t;const r=await t;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const t=[],r=e?.skipGc;if(this._meta.isLoading){const f=new Promise((d,h)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(d).catch(h),10+(e?.attempts??0)*1e3)});return t.push(f),Promise.all(t).then(d=>d.reduce((h,p)=>h+p,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const f of this._pendingSaveKeys)f in this.currentValue?o.push(f):(i.push(f),delete s.objects[f]);for(const f of i){const d=this._persister.removeItem(f);t.push(d.then(()=>1)),this._loadedKeys.delete(f),this._pendingSaveKeys.delete(f)}const a=[],c=[[Te,s]],u=s.objects??{};s.objects=u;for(const f of o)if(this._loadedKeys.has(f)){const d=this.serialize(f,this.currentValue[f]);c.push([f,d]);const h=this._objectSize(d),p=u[f]??{createdAt:Date.now(),updatedAt:Date.now(),size:h};p.updatedAt=Date.now(),p.size=h,u[f]=p,this._pendingSaveKeys.delete(f)}else a.push(f);const l=this._persister.multiSet(c);t.push(l.then(()=>1));for(const f of a){const d=this._loadKey(f).then(()=>this._enqueuePersist(e));t.push(d)}return r||this.gc(),Promise.all(t).then(f=>f.reduce((d,h)=>d+h,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Te);const t=new Set(Object.keys(this.currentValue));for(const d of Object.keys(this._loadingKeys))t.add(d);for(const d of this._loadedKeys)t.add(d);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:t,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const d of e)t.has(d)||d in r.objects||(this._log.info("Lost track of key in meta",d),s.push(this._persister.removeItem(d)),i.removed.push(d),i.removedMissingCount++);const o=Date.now();for(const[d,h]of Object.entries(r.objects))!t.has(d)&&h.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const c=a.filter(([d])=>!t.has(d));if(a.length>this._gcOpts.maxEntries)for(const[d]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([d,h],[p,m])=>h.updatedAt-m.updatedAt);const l=u.filter(([d])=>!t.has(d));let f=u.reduce((d,[h,p])=>d+p.size,0);for(;f>0&&f>this._gcOpts.maxSize&&l.length;){const[[d,h]]=l.splice(0,1);f-=h.size,s.push(this._persister.removeItem(d)),delete r.objects[d],i.removed.push(d),i.removedSizeCount++}for(const d of Object.keys(r.objects))!e.has(d)&&!t.has(d)&&delete r.objects[d];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{Fn(()=>{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(()=>{Fn(()=>{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]=qe(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=t,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return t}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(t=>t!==e)}}async clearUnloadedKeys(){let e=!1;for(const t of await this._persister.getAllKeys())t===Te||t in this.currentValue||(this._pendingSaveKeys.add(t),e=!0);e&&await this._enqueuePersist()}}const zi=6,Wi=["kv","querySubs","syncSubs"];function Vi(n){return function(t){console.error("Error in IndexedDB event",{source:n,event:t})}}async function Qi(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 Bi(n,e,t){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{const a={};for(const[l,f]of Object.entries(r)){const d=typeof f=="string"?JSON.parse(f):f;if(d.lastAccessed){const p={createdAt:d.lastAccessed,updatedAt:d.lastAccessed,size:d.result?.store?.triples?.length??0};a[l]=p}const h=t.put(d,l);s.add(h)}const c={objects:a},u=t.put(c,Te);s.add(u);for(const l of s)l.onsuccess=()=>{s.delete(l),s.size===0&&i()},l.onerror=f=>{o(f)}})}async function Kn(n,e,t){const r=t.put(e,n);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Gi(n,e){const t=await Qi(`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=Bi(l,f,o);a.push(d)}else{const d=Kn(l,f,i);a.push(d);const h={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=h}const u=Kn(Te,c,i);a.push(u),await Promise.all(a),await new Promise((l,f)=>{s.oncomplete=d=>l(d),s.onerror=d=>f(d),s.onabort=d=>f(d)})}const qn=new Map;class jt extends Mt{dbName;_storeName;_appId;_prefix;_dbPromise;constructor(e,t){super(e,t),this.dbName=`instant_${e}_${zi}`,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=Gi(this._appId,a).catch(u=>{Vi("Error upgrading store from version 5 to 6.")(u)});qn.set(this.dbName,c),c.then(()=>e(a)).catch(()=>e(a))}else{const c=qn.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 Wi)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 $t{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 ve 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,ve),this.name="InstantAPIError",this.status=e.status,this.body=e.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(n,e){const t=await fetch(n,e),r=await t.json();return t.status===200?Promise.resolve(r):Promise.reject(new ve({status:t.status,body:r}))}function Hi({apiURI:n,appId:e,email:t}){return re(`${n}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t})})}async function Ji({apiURI:n,appId:e,email:t,code:r,refreshToken:s,extraFields:i}){return await re(`${n}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:t,code:r,...s?{"refresh-token":s}:{},...i?{"extra-fields":i}:{}})})}async function Yi({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":t})})}async function Zi({apiURI:n,appId:e}){return await re(`${n}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function zn({apiURI:n,appId:e,code:t,codeVerifier:r,refreshToken:s,extraFields:i}){return await re(`${n}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:t,code_verifier:r,refresh_token:s,...i?{extra_fields:i}:{}})})}async function Xi({apiURI:n,appId:e,nonce:t,idToken:r,clientName:s,refreshToken:i,extraFields:o}){return await re(`${n}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:t,id_token:r,client_name:s,refresh_token:i,...o?{extra_fields:o}:{}})})}async function eo({apiURI:n,appId:e,refreshToken:t}){return await re(`${n}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:t})})}async function to({apiURI:n,appId:e,path:t,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:t,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await re(`${n}/storage/upload`,{method:"PUT",headers:a,body:r})}async function no({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/files?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function ro({apiURI:n,appId:e,fileName:t,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${n}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:t})});return i}async function so(n,e){return(await fetch(n,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function io({apiURI:n,appId:e,path:t,refreshToken:r}){const{data:s}=await re(`${n}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let Rt=!1,Wn=!1,Vn=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(Rt=!!window.localStorage.getItem("devBackend"),Wn=!!window.localStorage.getItem("__instantLogging"),Vn=!!window.localStorage.getItem("__devtoolLocalDash"));function Qn(n,e){if(!e)return n;const t={};return e.forEach(r=>{t[r]=n[r]}),t}function oo(n,e,t){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Qn(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=Qn(n.peers[i],e?.keys);r.peers[i]={...c,peerId:i}}}return r}function ao(n,e){if(n.isLoading!==e.isLoading||n.error!==e.error||(n.user||e.user)&&(!n.user||!e.user||!on(n.user,e.user))||!sn(n.peers,e.peers))return!0;for(const r of Object.keys(n.peers))if(!on(n.peers[r],e.peers[r]))return!0;return!1}class Bn{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 Gn(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);Gn(t["child-nodes"],e)})}function Hn(n){const e=[];return Gn(n,e),e}function Dt(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 xt="v0.22.169";function co(n,e){return{info:n?(...t)=>console.info(...t,e()):()=>{},debug:n?(...t)=>console.debug(...t,e()):()=>{},error:n?(...t)=>console.error(...t,e()):()=>{}}}class W{constructor(e,t,r,s={indexed:!1,unique:!1}){this.valueType=e,this.required=t,this.isIndexed=r,this.config=s}metadata={};clientRequired(){return new W(this.valueType,!1,this.isIndexed,this.config)}optional(){return new W(this.valueType,!1,this.isIndexed,this.config)}unique(){return new W(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new W(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Je{constructor(e,t){this.attrs=e,this.links=t}asType(){return new Je(this.attrs,this.links)}}class Ye{constructor(e,t,r){this.entities=e,this.links=t,this.rooms=r}withRoomSchema(){return new Ye(this.entities,this.links,{})}}class C extends Error{constructor(e,t){const r=t?`At path '${t}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Jn=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],uo=n=>n.valueType||"unknown",Yn=(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}},lo=(n,e,t,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!Yn(f,l,a))throw new C(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof f}`,o)};switch(n){case"in":case"$in":if(!Array.isArray(e))throw new C(`Operator '${n}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(n,t,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(n,t,e);break;case"$like":case"$ilike":if(c(n,"string",e),n==="$ilike"&&!i.isIndexed)throw new C(`Operator '${n}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(n,"boolean",e);break;default:throw new C(`Unknown operator '${n}' for attribute '${r}' in entity '${s}'`,o)}},Ae=(n,e,t,r,s)=>{const i=uo(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))lo(u,l,i,e,r,t,`${s}.${u}`)}else if(!Yn(n,i,o))throw new C(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof n}`,s)},fo=(n,e,t,r,s)=>{const i=n.split(".");if(i.length<2)throw new C(`Invalid dot notation path '${n}'. Must contain at least one dot.`,s);let o=t;for(let l=0;l<i.length-1;l++){const f=i[l],d=r.entities[o];if(!d)throw new C(`Entity '${o}' does not exist in schema while traversing dot notation path '${n}'.`,s);const h=d.links[f];if(!h){const p=Object.keys(d.links);throw new C(`Link '${f}' does not exist on entity '${o}' in dot notation path '${n}'. Available links: ${p.length>0?p.join(", "):"none"}`,s)}o=h.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new C(`Target entity '${o}' does not exist in schema for dot notation path '${n}'.`,s);if(a==="id"){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!_e(e))throw new C(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Ae(e,n,new W("string",!1,!0),t,s);return}if(!u){const l=Object.keys(c.attrs);throw new C(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${n}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Ae(e,n,u,t,s)},Zn=(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&&Zn(u,e,t,`${r}.${s}[${u}]`);continue}if(s==="id"){Ae(i,"id",new W("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){fo(s,i,e,t,`${r}.${s}`);continue}const o=t.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new C(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)Ae(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!_e(i))throw new C(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new W("string",!1,!0);Ae(i,s,u,e,`${r}.${s}`)}}},ho=(n,e,t,r,s=0)=>{for(const o of Object.keys(n))if(!Jn.includes(o))throw new C(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Jn.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);Zn(n.where,e,t,r?`${r}.where`:"where")}},Xn=(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&&Xn(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}.$`);ho(o,e,t,`${r}.$`,s)}},Ut=(n,e)=>{if(typeof n!="object"||n===null)throw new C(`Query must be an object, but received: ${typeof n}${n===null?" (null)":""}`);if(Array.isArray(n))throw new C(`Query must be an object, but received: ${typeof n}`);const t=n;for(const r of Object.keys(t)){if(Array.isArray(n[r]))throw new C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new C(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new C(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Xn(t[r],r,e,r,0)}}},er=n=>typeof n!="string"?!1:Ge(n)?!0:_e(n);class Z extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const tr=n=>n.length>0?n.join(", "):"none",po=(n,e)=>new Z(`Entity '${n}' does not exist in schema. Available entities: ${tr(e)}`),yo={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},bo=(n,e)=>n==null?!0:yo[e.valueType]?.(n)??!1,nr=(n,e)=>{const t=e.entities[n];if(!t)throw po(n,Object.keys(e.entities));return t},Lt=(n,e,t)=>{const r=nr(n,t);if(typeof e!="object"||e===null)throw new Z(`Arguments for data operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!bo(i,o))throw new Z(`Invalid value for attribute '${s}' in entity '${n}'. Expected ${o.valueType}, but received: ${typeof i}`)}},rr=(n,e,t)=>{const r=nr(n,t);if(typeof e!="object"||e===null)throw new Z(`Arguments for link operation on entity '${n}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new Z(`Link '${s}' does not exist on entity '${n}'. Available links: ${tr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!er(a))throw new Z(`Invalid entity ID in link '${s}' for entity '${n}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!er(i))throw new Z(`Invalid UUID in link '${s}' for entity '${n}'. Expected a UUID, but received: ${i}`)}}},go={create:Lt,update:Lt,merge:Lt,link:rr,unlink:rr,delete:()=>{}},mo=(n,e)=>{if(!e)return;const[t,r,s,i]=n;if(!Array.isArray(s)&&!_e(s))throw new Z(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new Z(`Entity name must be a string, but received: ${typeof r}`);const o=go[t];o&&i!==void 0&&o(r,i,e)},sr=(n,e)=>{const t=Array.isArray(n)?n:[n];for(const r of t){if(!r||typeof r!="object")throw new Z(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new Z(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new Z(`Transaction operation must be an array, but received: ${typeof s}`);mo(s,e)}}};let ir=0;class or{type="ws";conn;id;onopen;onmessage;onclose;onerror;constructor(e){this.id=`${this.type}_${ir++}`,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 ar{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}_${ir++}`,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 wo(n,e){const t=n.values;if(t){const r=pn(t.attrsStore,null);if(r){for(const s of t.entities||[])s.store.useDateObjects=e,s.store=hn(r,s.store);t.attrsStore=r}}return n}function _o(n,e){if(e.values){const t=[];for(const r of e.values?.entities){const s=fn(r.store);t.push({...r,store:s})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:t}}}else return e}function So(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 Nt(n,e,t){return At({store:e,attrsStore:t,pageInfo:null,aggregate:null},n.query).data[n.table][0]}function cr(n,e,t,r){const s=L(t,n.table,"id")?.id;if(!s)return-1;const i=me(e.eav,[r,s,r]);return i?i[3]:-1}function ur(n,e,t){for(const{action:r,triple:s}of t)switch(r){case"added":gn(n,e,s);break;case"removed":yn(n,e,s);break}}function To(n,e,t){const r={};for(const{action:s,triple:i}of t){const[o,a,c]=i,u=e.getAttr(a)?.["forward-identity"]?.[2];if(!u)continue;const l=r[o]??{};r[o]=l;const f=l[u]??{};switch(s){case"added":f.newValue=c;break;case"removed":f.oldValue===void 0&&(f.oldValue=c);break}l[u]=f}for(const[s,i]of Object.entries(r))for(const[o,{oldValue:a,newValue:c}]of Object.entries(i))a===c&&delete i[o];return r}function Ze(n,e){return{[n.table]:e.map(t=>t.entity)}}function vo(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 Ao(n,e,t){const r=e;if(n.orderField==="serverCreatedAt"){t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return De(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=n.orderField;t.sort(n.orderDirection==="asc"?function(o,a){return De(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return De(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var lr=(n=>(n.InitialSyncBatch="InitialSyncBatch",n.InitialSyncComplete="InitialSyncComplete",n.LoadFromStorage="LoadFromStorage",n.SyncTransaction="SyncTransaction",n.Error="Error",n))(lr||{});class ko{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 Pt({persister:t,merge:So,serialize:_o,parse:(a,c)=>wo(c,this.config.useDateObjects),objectSize:a=>a.values?.entities.length||0,logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,t){const r=R(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(t),this.initSubscription(e,r,t),s=>{this.unsubscribe(r,t,s?.keepSubscription)}}unsubscribe(e,t,r){const s=(this.callbacks[e]||[]).filter(i=>i!==t);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i?.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend($(),{op:"start-sync",q:e})}sendResync(e,t,r){this.idToHash[t.subscriptionId]=e.hash,this.trySend(t.subscriptionId,{op:"resync-table","subscription-id":t.subscriptionId,"tx-id":r,token:t.token})}sendRemove(e,t){this.trySend($(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":t})}async initSubscription(e,t,r){await this.subs.waitForKeyToLoad(t);const s=this.subs.currentValue[t];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),s.values?.entities&&r&&r({type:"LoadFromStorage",data:Ze(s,s.values?.entities)});return}const i=Object.keys(e)[0],o=e[i]?.$?.order||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(u=>{u[t]={query:e,hash:t,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const t=this.subs.currentValue[e];t?await this.initSubscription(t.query,t.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const t=e["subscription-id"],r=e.q,s=R(r);this.idToHash[t]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",t,"query",r),i;o.state={subscriptionId:t,token:e.token}})}notifyCbs(e,t){for(const r of this.callbacks[e]||[])r(t)}onSyncLoadBatch(e){const t=e["subscription-id"],r=e["join-rows"],s=this.idToHash[t];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),f=Nt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:cr(o,l,a.attrsStore,f.id)}),i.push(f)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:"InitialSyncBatch",data:Ze(o,o.values.entities),batch:i})}onSyncInitFinish(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(i=>{const o=i[r];if(!o){this.log.error("Missing sub for hash",r,e);return}const a=o.state;if(!a)return this.log.error("Sub never set init, missing result",o,e),i;a.txId=e["tx-id"],o.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:"InitialSyncComplete",data:Ze(s,s.values?.entities||[])})}onSyncUpdateTriples(e){const t=e["subscription-id"],r=this.idToHash[t];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const o of e.txes){if(i.txId&&i.txId>=o["tx-id"])continue;i.txId=o["tx-id"];const a=[],c={};for(const m of o.changes){const g=c[m.triple[0]]??[];c[m.triple[0]]=g,g.push(m)}const u=s.values??{entities:[],attrsStore:this.getAttrs()},l=u.entities;s.values=u;const f=[];e:for(const[m,g]of Object.entries(c))for(let y=0;y<l.length;y++){const b=l[y];if(is(b.store,m)){ur(b.store,u.attrsStore,g);const _=Nt(s,b.store,u.attrsStore),P=To(b.store,u.attrsStore,g)[m];_?(f.push({oldEntity:b.entity,newEntity:_,changedFields:P||{}}),b.entity=_):a.push(y),delete c[m];continue e}}const d=[];for(const[m,g]of Object.entries(c)){const y=this.createStore([]);ur(y,u.attrsStore,g);const b=Nt(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:cr(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=vo(s,this.getAttrs);Ao(s,p,l),this.notifyCbs(r,{type:"SyncTransaction",data:Ze(s,s.values?.entities),added:d,removed:h,updated:f})}this.subs.updateInPlace(o=>{o[r]=s,o[r].updatedAt=Date.now()})}clearSubscriptionData(e,t){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,t),t?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const t=R(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(t,{type:"Error",data:{[s]:[]},error:r})}onResyncError(e){const t=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(t,!1);r&&this.initSubscription(r.query,r.hash)}}function Io({WStream:n,opts:e,startStream:t,appendStream:r,registerStream:s}){const i=e.clientId;let o=null,a=null,c=null;const u=$();let l=!1,f=!1;const d=[],h=[],p=[];let m=!1,g=0,y=0;const b=[],_=new TextEncoder;function P(){f=!0;for(const S of d)S(a??void 0)}function w(S){return d.push(S),f&&S(a??void 0),()=>{const I=d.indexOf(S);I!==-1&&d.splice(I,1)}}function M(S){return p.push(S),()=>{const I=p.indexOf(S);I!==-1&&p.splice(I,1)}}e.waitUntil&&e.waitUntil(new Promise(S=>{p.push(S)}));function j(){for(const S of p)try{S()}catch{}}function q(S){return h.push(S),o&&S(o),()=>{const I=h.indexOf(S);I!==-1&&h.splice(I,1)}}function X(S){o=S;for(const I of h)I(o)}function T(){m=!0}function E(S){let I=g,V=0,H=0;for(const{byteLen:ie}of b){const le=I+ie;if(le>S)break;I=le,V++,H+=ie}V>0&&(g+=H,y-=H,b.splice(0,V))}function A(S,I){a=I,P(),S.error(I),j()}async function O(){const S=await t({clientId:i,reconnectToken:u,ruleParams:e.ruleParams});switch(S.type){case"ok":{const{streamId:I,offset:V}=S;o=I,E(V),b.length&&r({streamId:I,chunks:b.map(H=>H.chunk),offset:g}),m=!1;break}case"disconnect":{T();break}case"error":{c&&A(c,S.error);break}}}function N(){T(),O()}function U({offset:S,done:I}){E(S),I&&(l=!0,j())}function ee(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 se(S){c=S;let I=!0,V=0;for(;I;){let H=Date.now()+Math.min(15e3,500*(V-1));I=!1;const ie=await t({clientId:e.clientId,reconnectToken:u,ruleParams:e.ruleParams});switch(ie.type){case"ok":{const{streamId:le,offset:Qt}=ie;if(Qt!==0){const be=new K("Write stream is corrupted");A(S,be);return}X(le),s(le,{onDisconnect:T,onFlush:U,onConnectionReconnect:O,onAppendFailed:N}),m=!1;return}case"disconnect":{I=!0,T(),V++,await new Promise(le=>{setTimeout(le,Math.max(0,H-Date.now()))});break}case"error":{A(S,ie.error);return}}}}class _a extends n{constructor(I,V){super(I,V)}async streamId(){return o||new Promise((I,V)=>{const H=[],ie=()=>{for(const be of H)be()},le=be=>{I(be),ie()},Qt=be=>{V(be||new K("Stream is closed.")),ie()};H.push(q(le)),H.push(w(Qt))})}}return{stream:new _a({async start(S){try{await se(S)}catch(I){A(S,I)}},write(S,I){const V=ee(I);if(V){const H=_.encode(S).length;b.push({chunk:S,byteLen:H});const ie=g+y;y+=H,m||r({streamId:V,chunks:[S],offset:ie})}},close(){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0}):j(),P()},abort(S){o?r({streamId:o,chunks:[],offset:g+y,isDone:!0,abortReason:S}):j(),P()}}),addCompleteCb:M,closed(){return f}}}class Oo{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 Co({RStream:n,opts:e,startStream:t,cancelStream:r}){let s=e.byteOffset||0,i=!1;const o=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[];function f(){u=!0;for(const b of l)b()}function d(b){return l.push(b),()=>{const _=l.indexOf(b);_!==-1&&l.splice(_,1)}}function h(b,_){b.error(_),f()}let p=0;async function m(b,_){c=$();const P={...b||{},eventId:c};for await(const w of t(P)){if(i)return;if(w.type==="reconnect")return{retry:!0};if(w.type==="error"){h(_,w.error);return}if(w.offset>s){h(_,new K("Stream is corrupted.")),i=!0;return}let M=s-w.offset;if(w.files&&w.files.length){const j=new AbortController;let q=fetch(w.files[0].url,{signal:j.signal});for(let X=0;X<w.files.length;X++){const T=w.files[X+1],A=await q;if(T&&(q=fetch(T.url,{signal:j.signal})),!A.ok){if(p++,p>10){h(_,new K("Unable to process stream."));return}return{retry:!0}}if(A.body){const O=A.body.getReader();try{for(;;){const{done:N,value:U}=await O.read();if(N)break;if(i){j.abort();return}let ee=U;if(M>0&&(ee=U.subarray(M),M-=U.length-ee.length),!ee.length)continue;s+=ee.length;const se=o.decode(ee);_.enqueue(se)}}finally{O.releaseLock()}}else{const O=await A.arrayBuffer();let N=O;if(i){j.abort();return}if(M>0&&(N=new Uint8Array(O).subarray(M),M-=O.byteLength-N.length),!N.byteLength)continue;s+=N.byteLength;const U=o.decode(N);_.enqueue(U)}}}if(p=0,w.content){let j=w.content,q=a.encode(w.content);if(M>0){const X=q.subarray(M);if(M-=q.length-X.length,!X.length)continue;q=X,j=o.decode(X)}s+=q.length,_.enqueue(j)}}}async function g(b){let _=!0,P=0;for(;_;){_=!1;let w=Date.now()+Math.min(15e3,500*(P-1));(await m({...e,offset:s},b))?.retry&&(_=!0,P++,w<Date.now()-3e5&&(P=0),await new Promise(j=>{setTimeout(j,Math.max(0,w-Date.now()))}))}!i&&!u&&(b.close(),f())}return{stream:new n({start(b){g(b)},cancel(b){i=!0,c&&r({eventId:c}),f()}}),addCloseCb:d,closed(){return u}}}class dr{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}=Io({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}=Co({RStream:this.RStream,opts:e,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(t),r(()=>{this.activeStreams.delete(t)}),t}startWriteStream(e){const t=$();let r=null;const s=new Promise(o=>{r=o});this.startWriteStreamCbs[t]=r;const i={op:"start-stream","client-id":e.clientId,"reconnect-token":e.reconnectToken};return e.ruleParams&&(i["rule-params"]=e.ruleParams),this.trySend(t,i),s}registerWriteStream(e,t){this.writeStreams[e]=t}appendStream({streamId:e,chunks:t,isDone:r,offset:s,abortReason:i}){const o={op:"append-stream","stream-id":e,chunks:t,offset:s,done:!!r};i&&(o["abort-reason"]=i),this.trySend($(),o)}onAppendFailed(e){const t=this.writeStreams[e["stream-id"]];t&&t.onAppendFailed()}onStartStreamOk(e){const t=this.startWriteStreamCbs[e["client-event-id"]];if(!t){this.log.info("No stream for start-stream-ok",e);return}t({type:"ok",streamId:e["stream-id"],offset:e.offset}),delete this.startWriteStreamCbs[e["client-event-id"]]}onStreamFlushed(e){const t=e["stream-id"],r=this.writeStreams[t];if(!r){this.log.info("No stream cbs for stream-flushed",e);return}r.onFlush({offset:e.offset,done:e.done}),e.done&&delete this.writeStreams[t]}startReadStream({eventId:e,clientId:t,streamId:r,offset:s,ruleParams:i}){const o={op:"subscribe-stream"};if(!r&&!t)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");r&&(o["stream-id"]=r),t&&(o["client-id"]=t),s&&(o.offset=s),i&&(o["rule-params"]=i);const a=new Oo;return this.readStreamIterators[e]=a,this.trySend(e,o),a}cancelReadStream({eventId:e}){const t={op:"unsubscribe-stream","subscribe-event-id":e};this.trySend($(),t),delete this.readStreamIterators[e]}onStreamAppend(e){const t=e["client-event-id"],r=this.readStreamIterators[t];if(!r){this.log.info("No iterator for read stream",e);return}if(e.error){e.retry?r.push({type:"reconnect"}):r.push({type:"error",error:new 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!==ae.AUTHENTICATED)for(const{onDisconnect:t}of Object.values(this.writeStreams))t();else{for(const{onConnectionReconnect:t}of Object.values(this.writeStreams))t();for(const t of Object.values(this.readStreamIterators))t.push({type:"reconnect"}),t.close();this.readStreamIterators={}}}onRecieveError(e){const t=e["original-event"];switch(t.op){case"append-stream":{const r=t["stream-id"];this.writeStreams[r]?.onAppendFailed();break}case"start-stream":{const r=e["client-event-id"],s=this.startWriteStreamCbs[r];s&&(s({type:"error",error:new 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 ae={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},Eo=3e4,Mo=3e4,Po=200,jo=1e3*60,$o={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Ft="_instant_oauth_redirect",Kt="_instant_extra_fields_id",Xe="oauthExtraFields",ke="currentUser";function Ro({transportType:n,appId:e,apiURI:t,wsURI:r,EventSourceImpl:s}){if(!s)return new or(`${r}?app_id=${e}`);switch(n){case"ws":return new or(`${r}?app_id=${e}`);case"sse":return new ar(s,`${t}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+n)}}function Do(){return typeof window<"u"||typeof chrome<"u"}const fr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function xo(n,e){const t=typeof n=="string"?JSON.parse(n):n;if(t?.result?.store){const r=pn(t.result.attrsStore,t.result.store);if(r){const s=t.result.store;t.result.store=hn(r,{...s,useDateObjects:e}),t.result.attrsStore=r}}return t}function Uo(n,e){const{result:t,...r}=e,s=r;if(t){const i={...t,store:fn(t.store),attrsStore:t.attrsStore.toJSON()};s.result=i}return s}function Lo(n,e){return n==="pendingMutations"?new Map(typeof e=="string"?JSON.parse(e):e):e}function No(n,e){return n==="pendingMutations"?[...e.entries()]:e}function Fo(n,e,t){const r=e?.result,s=t?.result;return r&&!s&&t&&(t.result=r),t||e}function qt(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 hr{attrs;_isOnline=!0;_isShutdown=!1;status=ae.CONNECTING;querySubs;kv;_syncTable;_instantStream;queryCbs={};queryOnceDfds={};authCbs=[];attrsCbs=[];mutationErrorCbs=[];connectionStatusCbs=[];config;mutationDeferredStore=new Map;_reconnectTimeoutId=null;_reconnectTimeoutMs=0;_transport;_transportType="ws";_EventSource;_wsOk=null;_localIdPromises={};_errorMessage=null;_oauthCallbackResponse=null;_linkIndex=null;_broadcastChannel;_rooms={};_roomsPendingLeave={};_presence={};_broadcastQueue=[];_broadcastSubs={};_currentUserCached={isLoading:!0,error:void 0,user:void 0};_beforeUnloadCbs=[];_dataForQueryCache={};_log;_pendingTxCleanupTimeout;_pendingMutationCleanupThreshold;_inFlightMutationEventIds=new Set;_frameworkClient=null;constructor(e,t=jt,r=$t,s,i){if(this._EventSource=i,this.config={...$o,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??Mo,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??Po,this._log=co(e.verbose||Rt||Wn,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":xt},this.config.schema&&(this._linkIndex=Dt(this.config.schema)),!!Do()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!_e(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{try{if(o.data?.type==="auth"){const a=await this.getCurrentUser({forceReadFromStorage:!0});await this.updateUser(a.user).catch(c=>{this._log.error("[error] update user",c)})}}catch(a){this._log.error("[error] handle broadcast channel",a)}})),this._initStorage(t),this._syncTable=new ko(this._trySendAuthed.bind(this),new t(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>we(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._instantStream=new dr({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)},jo),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",ae.CLOSED),this._setStatus(ae.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}getFrameworkClient(){return this._frameworkClient}setFrameworkClient(e){this._frameworkClient=e}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?Dt(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new Pt({persister:new e(this.config.appId,"querySubs"),merge:Fo,serialize:Uo,parse:(t,r)=>xo(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 Pt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:No,parse:Lo,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=t=>{t==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(ke),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,t,r){const s=this.mutationDeferredStore.get(t);this.mutationDeferredStore.delete(t);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:t,...r}),!!s)if(i)s.resolve({status:e,eventId:t});else if(r?.type){const{status:o,...a}=r;s.reject(new ve({body:a,status:o??0}))}else s.reject(new 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=we(this.attrs,t.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:t.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,t){const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(fr[t.op]||this._log.info("[receive]",e,t.op,t),t.op){case"init-ok":{this._setStatus(ae.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(t.attrs),this._flushPendingMessages(),this._sessionId=t["session-id"];for(const o of Object.keys(this._rooms)){const a=this._presence[o]?.result?.user,c=this._rooms[o]?.roomType;this._tryJoinRoom(c,o,a)}break}case"add-query-exists":{this.notifyOneQueryOnce(R(t.q));break}case"add-query-ok":{const{q:o,result:a}=t,c=R(o);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[c])break;const u=a?.[0]?.data?.["page-info"],l=a?.[0]?.data?.aggregate,f=Hn(a),d=this.ensureAttrs(),h=we(d,f,r,this.config.useDateObjects);this.querySubs.updateInPlace(p=>{if(!p[c]){this._log.info("Missing value in querySubs",{hash:c,q:o});return}p[c].result={store:h,attrsStore:d,pageInfo:u,aggregate:l,processedTxId:t["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(c),this.notifyOneQueryOnce(c),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(t);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(t);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(t);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(t);break}case"start-stream-ok":{this._instantStream.onStartStreamOk(t);break}case"stream-flushed":{this._instantStream.onStreamFlushed(t);break}case"append-failed":{this._instantStream.onAppendFailed(t);break}case"stream-append":{this._instantStream.onStreamAppend(t);break}case"refresh-ok":{const{computations:o,attrs:a}=t,c=t["processed-tx-id"];a&&this._setAttrs(a),this._cleanupPendingMutationsTimeout();const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),c);u!==this._pendingMutations()&&this.kv.updateInPlace(d=>{d.pendingMutations=u});const l=qt(u.entries()),f=o.map(d=>{const h=d["instaql-query"],p=d["instaql-result"],m=R(h),g=Hn(p),y=this.ensureAttrs(),b=we(y,g,r,this.config.useDateObjects),{store:_,attrsStore:P}=this._applyOptimisticUpdates(b,y,l,c),w=p?.[0]?.data?.["page-info"],M=p?.[0]?.data?.aggregate;return{q:h,hash:m,store:_,attrsStore:P,pageInfo:w,aggregate:M}});f.forEach(({hash:d,q:h,store:p,attrsStore:m,pageInfo:g,aggregate:y})=>{this.querySubs.updateInPlace(b=>{if(!b[d]){this._log.error("Missing value in querySubs",{hash:d,q:h});return}b[d].result={store:p,attrsStore:m,pageInfo:g,aggregate:y,processedTxId:c}})}),this._cleanupPendingMutationsQueries(),f.forEach(({hash:d})=>{this.notifyOne(d)});break}case"transact-ok":{const{"client-event-id":o,"tx-id":a}=t;this._inFlightMutationEventIds.delete(o);const u=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(o);if(!u)break;this._updatePendingMutations(f=>{f.set(o,{...f.get(o),"tx-id":a,confirmed:Date.now()})});const l=[];for(const f of u["tx-steps"])if(f[0]==="add-attr"){const d=f[1];l.push(d)}if(l.length){const f=Object.values(this.ensureAttrs().attrs);this._setAttrs([...f,...l])}this._finishTransaction("synced",o),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._patchPresencePeers(o,t.edits),this._notifyPresenceSubs(o);break}case"refresh-presence":{const o=t["room-id"];this._trySetRoomConnected(o,!0),this._setPresencePeers(o,t.data),this._notifyPresenceSubs(o);break}case"server-broadcast":{const o=t["room-id"],a=t.topic;this._trySetRoomConnected(o,!0),this._notifyBroadcastSubs(o,a,t);break}case"join-room-ok":{const o=t["room-id"];if(!this._rooms[o]){this._roomsPendingLeave[o]&&(this._tryLeaveRoom(o),delete this._roomsPendingLeave[o]);break}this._trySetRoomConnected(o,!0),this._flushEnqueuedRoomData(o);break}case"leave-room-ok":{const o=t["room-id"];this._trySetRoomConnected(o,!1);break}case"join-room-error":const s=t["room-id"],i=this._rooms[s];i&&(i.error=t.error),this._notifyPresenceSubs(s);break;case"error":this._handleReceiveError(t);break;default:this._log.info("Unknown op",t.op,t);break}}createWriteStream(e){return this._instantStream.createWriteStream(e)}createReadStream(e){return this._instantStream.createReadStream(e)}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(t=>{const r=t.pendingMutations??new Map;t.pendingMutations=r,e(r)})}_handleMutationError(e,t,r){const s=this._pendingMutations().get(t);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(t),o)),this._inFlightMutationEventIds.delete(t);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,t,r)}}_handleReceiveError(e){console.log("error",e);const t=e["client-event-id"];this._inFlightMutationEventIds.delete(t);const r=this._pendingMutations().get(t),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",t,e);return}if(e["original-event"]?.hasOwnProperty("q")&&e["original-event"]?.op==="add-query"){const a=e["original-event"]?.q,c=R(a);this.notifyQueryError(R(a),s),this.notifyQueryOnceError(a,c,t,s);return}if(e["original-event"]?.op==="init"){if(e.type==="record-not-found"&&e.hint?.["record-type"]==="app-user"){this.changeCurrentUser(null);return}this._setStatus(ae.ERRORED,s),this.notifyAll();return}switch(e["original-event"]?.op){case"resync-table":{this._syncTable.onResyncError(e);return}case"start-sync":{this._syncTable.onStartSyncError(e);return}case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{this._instantStream.onRecieveError(e);return}}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
|
|
2
2
|
`,e.hint)}notifyQueryOnceError(e,t,r,s){const i=this.queryOnceDfds[t]?.find(o=>o.eventId===r);i&&(i.dfd.reject(s),this._completeQueryOnce(e,t,i.dfd))}_setAttrs(e){this.attrs=new de(e.reduce((t,r)=>(t[r.id]=r,t),{}),this._linkIndex),this.notifyAttrsSubs()}getPreviousResult=e=>{const t=R(e);return this.dataForQuery(t)?.data};_startQuerySub(e,t){const r=$();return this.querySubs.updateInPlace(s=>{s[t]=s[t]||{q:e,result:null,eventId:r},s[t].lastAccessed=Date.now()}),this._trySendAuthed(r,{op:"add-query",q:e}),r}subscribeTable(e,t){return this._syncTable.subscribe(e,t)}subscribeQuery(e,t,r){this.config.disableValidation||Ut(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=R(e),i=this.getPreviousResult(e);return i&&t(i),this.queryCbs[s]=this.queryCbs[s]??[],this.queryCbs[s].push({q:e,cb:t}),this._startQuerySub(e,s),()=>{this._unsubQuery(e,s,t)}}queryOnce(e,t){this.config.disableValidation||Ut(e,this.config.schema),t&&"ruleParams"in t&&(e={$$ruleParams:t.ruleParams,...e});const r=new Bn;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")),Eo),r.promise}_completeQueryOnce(e,t,r){this.queryOnceDfds[t]&&(this.queryOnceDfds[t]=this.queryOnceDfds[t].filter(s=>s.dfd!==r),this._cleanupQuery(e,t))}_unsubQuery(e,t,r){this.queryCbs[t]&&(this.queryCbs[t]=this.queryCbs[t].filter(s=>s.cb!==r),this._cleanupQuery(e,t))}_hasQueryListeners(e){return!!(this.queryCbs[e]?.length||this.queryOnceDfds[e]?.length)}_cleanupQuery(e,t){this._hasQueryListeners(t)||(delete this.queryCbs[t],delete this.queryOnceDfds[t],delete this._dataForQueryCache[t],this.querySubs.unloadKey(t),this._trySendAuthed($(),{op:"remove-query",q:e}))}_rewriteMutations(e,t,r){if(!e)return t;if(!t)return new Map;const s=l=>{const[f,d,h]=l["forward-identity"];return L(e,d,h)},i=l=>{const[f,d,h]=l["forward-identity"];return ye(e,d,h)},o={attrIdMap:{},refSwapAttrIds:new Set};let a=!1;const c=(l,f)=>{const d=[];for(const h of l){const[p]=h;if(p==="add-attr"){const[g,y]=h,b=s(y);if(b&&y.id!==b.id){o.attrIdMap[y.id]=b.id,a=!0;continue}if(y["value-type"]==="ref"){const _=i(y);if(_){o.attrIdMap[y.id]=_.id,o.refSwapAttrIds.add(y.id),a=!0;continue}}}if(r&&f&&r>=f&&p==="add-attr"||p==="update-attr"||p==="delete-attr"){a=!0;continue}const m=a?gi(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 qt(this._rewriteMutations(e,t).entries())}optimisticAttrs(){const e=[...this._pendingMutations().values()].flatMap(i=>i["tx-steps"]),t=new Set(e.filter(([i,o])=>i==="delete-attr").map(([i,o])=>o)),r=[];for(const[i,o]of e)if(i==="add-attr")r.push(o);else if(i==="update-attr"&&o.id&&this.attrs?.getAttr(o.id)){const a={...this.attrs.getAttr(o.id),...o};r.push(a)}if(!t.size&&!r.length)return this.attrs||new de({},this._linkIndex);const s={...this.attrs?.attrs||{}};for(const i of r)s[i.id]=i;for(const i of t)delete s[i];return new de(s,this._linkIndex)}dataForQuery(e,t=!0){const r=this._errorMessage;if(r)return{error:r};if(!this.querySubs||!this.kv.currentValue.pendingMutations)return;const s=this.querySubs.version(),i=this.querySubs.currentValue,o=this.kv.version(),a=this._pendingMutations(),{q:c,result:u}=i[e]||{};if(!u)return;const l=this._dataForQueryCache[e];if(l&&s===l.querySubVersion&&o===l.pendingMutationsVersion)return l;let f=u.store,d=u.attrsStore;const{pageInfo:h,aggregate:p,processedTxId:m}=u,g=this._rewriteMutationsSorted(d,a);if(t){const b=this._applyOptimisticUpdates(f,d,g,m);f=b.store,d=b.attrsStore}return{data:At({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=gs(e,t,o["tx-steps"]);e=a.store,t=a.attrsStore}return{store:e,attrsStore:t}}notifyOne=e=>{const t=this.queryCbs[e]??[],r=this._dataForQueryCache[e]?.data,s=this.dataForQuery(e);s?.data&&(this._dataForQueryCache[e]=s,!ze(s.data,r)&&t.forEach(i=>i.cb(s.data)))};notifyOneQueryOnce=e=>{const t=this.queryOnceDfds[e]??[],r=this.dataForQuery(e)?.data;t.forEach(s=>{this._completeQueryOnce(s.q,e,s.dfd),s.dfd.resolve(r)})};notifyQueryError=(e,t)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:t}))};notifyAll(){Object.keys(this.queryCbs).forEach(e=>{this.querySubs.waitForKeyToLoad(e).then(()=>this.notifyOne(e)).catch(()=>this.notifyOne(e))})}loadedNotifyAll(){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyAll()).catch(()=>this.notifyAll())}pushTx=e=>{this.config.disableValidation||sr(e,this.config.schema);try{const t=qi({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>r?.result?.store),useDateObjects:this.config.useDateObjects},e);return this.pushOps(t)}catch(t){return this.pushOps([],t)}};pushOps=(e,t)=>{const r=$(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:t,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new Bn;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise};shutdown(){this._log.info("[shutdown]",this.config.appId),this._isShutdown=!0,this._transport?.close()}_sendMutation(e,t){if(t.error){this._handleMutationError("error",e,{message:t.error.message});return}if(this.status!==ae.AUTHENTICATED){this._finishTransaction("enqueued",e);return}const r=Math.max(6e3,Math.min(this._inFlightMutationEventIds.size+1,this._pendingMutations().size+1)*6e3);this._isOnline?(this._trySend(e,t),setTimeout(()=>{this._isOnline&&this._handleMutationError("timeout",e,{message:"transaction timed out"})},r)):this._finishTransaction("enqueued",e)}_flushPendingMessages(){Object.keys(this.queryCbs).map(i=>this.querySubs.currentValue[i]).filter(i=>i).forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})}),Object.values(this.queryOnceDfds).flat().forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})});const r=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations());r!==this._pendingMutations()&&this.kv.updateInPlace(i=>{i.pendingMutations=r}),qt(r.entries()).forEach(([i,o])=>{o["tx-id"]||this._sendMutation(i,o)}),this._syncTable.flushPending()}_cleanupPendingMutationsQueries(){let e=Number.MAX_SAFE_INTEGER;for(const{result:t}of Object.values(this.querySubs.currentValue))t?.processedTxId&&(e=Math.min(e,t?.processedTxId));this._updatePendingMutations(t=>{for(const[r,s]of Array.from(t.entries()))s["tx-id"]&&s["tx-id"]<=e&&t.delete(r)})}_cleanupPendingMutationsTimeout(){if(this._pendingMutations().size<this._pendingMutationCleanupThreshold)return;const e=Date.now();this._updatePendingMutations(t=>{for(const[r,s]of Array.from(t.entries()))s.confirmed&&s.confirmed+this._pendingTxCleanupTimeout<e&&t.delete(r)})}_trySendAuthed(...e){this.status===ae.AUTHENTICATED&&this._trySend(...e)}_trySend(e,t,r){if(this._transport.isOpen()){switch(fr[t.op]||this._log.info("[send]",this._transport.id,t.op,{"client-event-id":e,...t}),t.op){case"transact":{this._inFlightMutationEventIds.add(e);break}case"init":this._inFlightMutationEventIds.clear()}this._transport.send({"client-event-id":e,...t})}}_transportOnOpen=e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][open]",t.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(ae.OPENED),this.getCurrentUser().then(r=>{this._trySend($(),{op:"init","app-id":this.config.appId,"refresh-token":r.user?.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",t.id,r)})};_transportOnMessage=e=>{const t=e.target,r=e.message;if(this._transport!==t){this._log.info("[socket][message]",t.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&t.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(t.id,s);else this._handleReceive(t.id,e.message)};_transportOnError=e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][error]",t.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",t.id,e)};_scheduleReconnect=()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)};_transportOnClose=e=>{const t=e.target;if(this._transport!==t){this._log.info("[socket][close]",t.id,"skip; this is no longer the current transport");return}this._setStatus(ae.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",t.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",t.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()};_startSocket(){if(this._wsOk=null,this._isShutdown){this._log.info("[socket][start]",this.config.appId,"Reactor has been shut down and will not start a new socket");return}if(this._transport&&this._transport.isConnecting()){this._log.info("[socket][start]",this._transport.id,"maintained as current transport, we were still in a connecting state");return}const e=this._transport;this._transport=Ro({transportType:this._transportType,appId:this.config.appId,apiURI:this.config.apiURI,wsURI:this.config.websocketURI,EventSourceImpl:this._EventSource}),this._transport.onopen=this._transportOnOpen,this._transport.onmessage=this._transportOnMessage,this._transport.onclose=this._transportOnClose,this._transport.onerror=this._transportOnError,this._log.info("[socket][start]",this._transport.id),e?.isOpen()&&(this._log.info("[socket][start]",this._transport.id,"close previous transport id = ",e.id),e.close())}async getLocalId(e){const t=`localToken_${e}`;if(this.kv.currentValue[t])return this.kv.currentValue[t];const r=await this.kv.waitForKeyToLoad(t);if(r)return r;const s=$();return this.kv.updateInPlace(i=>{i[t]||(i[t]=s)}),await this.kv.waitForKeyToLoad(t)}_replaceUrlAfterOAuth(){if(typeof URL>"u")return;const e=new URL(window.location.href);if(e.searchParams.get(Ft)){const t=e.toString();e.searchParams.delete(Ft),e.searchParams.delete(Kt),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(Ft))return null;const t=e.get("error");if(t)return this._replaceUrlAfterOAuth(),{error:{message:t}};const r=e.get("code");if(!r)return null;const s=e.get(Kt);this._replaceUrlAfterOAuth();try{let i;const o=await this.kv.waitForKeyToLoad(Xe);s&&o&&(i=o[s]),o&&this.kv.updateInPlace(l=>{delete l[Xe]});const a=await this._getCurrentUser(),c=a?.type==="guest",{user:u}=await zn({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||ze(s,t)||e(s)}),()=>{r=!0,this.authCbs=this.authCbs.filter(s=>s!==e)}}async getAuth(){const{user:e,error:t}=await this.getCurrentUser();if(t)throw new 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[ke]=e}),await this.kv.waitForKeyToLoad(ke)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(e){e?.forceReadFromStorage&&await this.kv.unloadKey(ke);const t=await this.kv.waitForKeyToLoad(ke);return typeof t=="string"?JSON.parse(t):t}async getCurrentUser(e){const t=await this._waitForOAuthCallbackResponse();if(t?.error){const r={error:t.error,user:void 0};return this._currentUserCached={isLoading:!1,...r},this._currentUserCached}try{const s={user:await this._getCurrentUser(e),error:void 0};return this._currentUserCached={isLoading:!1,...s},this._currentUserCached}catch(r){return{user:void 0,isLoading:!1,error:{message:r?.message||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(ke);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){const{user:t}=await this.getCurrentUser();if(!ze(t,e)){this._frameworkClient=null,await this.setCurrentUser(e),await this.updateUser(e);try{await this.kv.flush(),this._broadcastChannel?.postMessage({type:"auth"})}catch(r){console.error("Error posting message to broadcast channel",r)}}}async syncUserToEndpoint(e){if(this.config.firstPartyPath)try{await fetch(this.config.firstPartyPath+"/",{method:"POST",body:JSON.stringify({type:"sync-user",appId:this.config.appId,user:e}),headers:{"Content-Type":"application/json"}})}catch(t){this._log.error("Error syncing user with external endpoint",t)}}async updateUser(e){try{await this.syncUserToEndpoint(e)}catch(r){this._log.error("Error syncing user with external endpoint",r)}const t={error:void 0,user:e};this._currentUserCached={isLoading:!1,...t},this._dataForQueryCache={},this.querySubs.updateInPlace(r=>{Object.keys(r).forEach(s=>{delete r[s].result})}),this.querySubs.clearUnloadedKeys(),this._updatePendingMutations(r=>{for(const[s,i]of r.entries())this.mutationDeferredStore.get(s)&&this._finishTransaction("error",s,{message:"User changed while transaction was in progress.",type:"user-changed"});r.clear()}),this._reconnectTimeoutMs=0,this._transport.close(),this._oauthCallbackResponse=null,this.notifyAuthSubs(t)}sendMagicCode({email:e}){return Hi({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 Ji({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 Yi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(t.user),t}async signInAsGuest(){const e=await Zi({apiURI:this.config.apiURI,appId:this.config.appId});return await this.changeCurrentUser(e.user),e}potentiallyInvalidateToken(e,t){const r=e?.user?.refresh_token;if(!r)return;if(t.invalidateToken===!1){this._log.info("[auth-invalidate] skipped invalidateToken");return}eo({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[Xe]||{};u[a]=r,c[Xe]=u}),o=`${t}${t.includes("?")?"&":"?"}${Kt}=${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 zn({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 Xi({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:{...oo(i.result,r,this._sessionId),isLoading:!s.isConnected,error:s.error}}publishPresence(e,t,r){const s=this._rooms[t],i=this._presence[t];if(!s||!i)return;i.result=i.result||{};const o={...i.result.user,...r};i.result.user=o,s.isConnected&&(this._trySetPresence(t,o),this._notifyPresenceSubs(t))}_trySetPresence(e,t){this._trySendAuthed($(),{op:"set-presence","room-id":e,data:t})}_tryJoinRoom(e,t,r){this._trySendAuthed($(),{op:"join-room","room-type":e,"room-id":t,data:r}),delete this._roomsPendingLeave[t]}_tryLeaveRoom(e){this._trySendAuthed($(),{op:"leave-room","room-id":e})}_trySetRoomConnected(e,t){const r=this._rooms[e];r&&(r.isConnected=t)}subscribePresence(e,t,r,s){const i=this.joinRoom(e,t,r.initialPresence||r.initialData),o={...r,roomId:t,cb:s,prev:null};return this._presence[t]=this._presence[t]||{},this._presence[t].handlers=this._presence[t].handlers||[],this._presence[t].handlers.push(o),this._notifyPresenceSub(t,o),()=>{this._presence[t].handlers=this._presence[t]?.handlers?.filter(a=>a!==o)??[],i()}}_notifyPresenceSubs(e){this._presence[e]?.handlers?.forEach(t=>{this._notifyPresenceSub(e,t)})}_notifyPresenceSub(e,t){const r=this.getPresence("",e,t);r&&(t.prev&&!ao(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=qe(s,o=>{for(let[a,c,u]of t)switch(c){case"+":Nr(o,a,u);break;case"r":cn(o,a,u);break;case"-":un(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=qe(this._presence,i=>{cn(i,[e,"result","peers"],s)})}publishTopic({roomType:e,roomId:t,topic:r,data:s}){const i=this._rooms[t];if(i){if(!i.isConnected){this._broadcastQueue[t]=this._broadcastQueue[t]??[],this._broadcastQueue[t].push({topic:r,roomType:e,data:s});return}this._tryBroadcast(t,e,r,s)}}_tryBroadcast(e,t,r,s){this._trySendAuthed($(),{op:"client-broadcast","room-id":e,roomType:t,topic:r,data:s})}subscribeTopic(e,t,r,s){const i=this.joinRoom(e,t);return this._broadcastSubs[t]=this._broadcastSubs[t]||{},this._broadcastSubs[t][r]=this._broadcastSubs[t][r]||[],this._broadcastSubs[t][r].push(s),this._presence[t]=this._presence[t]||{},()=>{this._broadcastSubs[t][r]=this._broadcastSubs[t][r].filter(o=>o!==s),this._broadcastSubs[t][r].length||delete this._broadcastSubs[t][r],i()}}_notifyBroadcastSubs(e,t,r){this._broadcastSubs?.[e]?.[t]?.forEach(s=>{const i=r.data?.data,o=r.data["peer-id"]===this._sessionId?this._presence[e]?.result?.user:this._presence[e]?.result?.peers?.[r.data["peer-id"]];return s(i,o)})}async uploadFile(e,t,r){const i=(await this.getCurrentUser())?.user?.refresh_token;return to({...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 no({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 ro({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await so(o,t)}async getDownloadUrl(e){const r=(await this.getCurrentUser())?.user?.refresh_token;return await io({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function Ko(n,e){return new Ye(pr(n,e),e,void 0)}function qo(n){return new Je(n,{})}function zo(){return new W("string",!0,!1)}function Wo(){return new W("number",!0,!1)}function Vo(){return new W("boolean",!0,!1)}function Qo(){return new W("date",!0,!1)}function Bo(){return new W("json",!0,!1)}function Go(){return new W("json",!0,!1)}function pr(n,e){const t={fwd:{},rev:{}};for(const s of Object.values(e))t.fwd[s.forward.on]||={},t.rev[s.reverse.on]||={},t.fwd[s.forward.on][s.forward.label]={entityName:s.reverse.on,cardinality:s.forward.has},t.rev[s.reverse.on][s.reverse.label]={entityName:s.forward.on,cardinality:s.reverse.has};return Object.fromEntries(Object.entries(n).map(([s,i])=>[s,new Je(i.attrs,{...t.fwd[s],...t.rev[s]})]))}function Ho({entities:n,links:e,rooms:t}){const r=e??{},s=t??{};return new Ye(pr(n,r),r,s)}const D={graph:Ko,schema:Ho,entity:qo,string:zo,number:Wo,boolean:Vo,date:Qo,json:Bo,any:Go};let yr;function Jo(n,e){yr?.dispose();const t=na(e),r=Xo(e,a),s=Zo(Yo(n));function i(l){l.source===s.element.contentWindow&&l.data?.type==="close"&&t.isVisible()&&a()}function o(l){const f=l.shiftKey&&l.ctrlKey&&l.key==="0",d=l.key==="Escape"||l.key==="Esc";(f||d&&t.isVisible())&&a()}function a(){t.isVisible()?t.element.style.display="none":(t.element.style.display="block",t.element.contains(s.element)||t.element.appendChild(s.element))}function c(){t.element.remove(),r.element.remove(),removeEventListener("keydown",o),removeEventListener("message",i)}function u(){document.body.appendChild(t.element),document.body.appendChild(r.element),addEventListener("keydown",o),addEventListener("message",i),yr={dispose:c}}return u()}function Yo(n){return`${Rt||Vn?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${n}`}function Zo(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 Xo(n,e){const t=`
|
|
3
3
|
<svg width="32" height="32" viewBox="0 0 512 512" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
4
4
|
<rect width="512" height="512" fill="black"/>
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@instantdb/core",
|
|
3
|
-
"version": "0.22.
|
|
3
|
+
"version": "0.22.169",
|
|
4
4
|
"description": "Instant's core local abstraction",
|
|
5
5
|
"homepage": "https://github.com/instantdb/instant/tree/main/client/packages/core",
|
|
6
6
|
"repository": {
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
"dependencies": {
|
|
57
57
|
"mutative": "^1.0.10",
|
|
58
58
|
"uuid": "^11.1.0",
|
|
59
|
-
"@instantdb/version": "0.22.
|
|
59
|
+
"@instantdb/version": "0.22.169"
|
|
60
60
|
},
|
|
61
61
|
"scripts": {
|
|
62
62
|
"test": "vitest",
|