@instantdb/solidjs 0.0.1
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/.tshy/build.json +8 -0
- package/.tshy/commonjs.json +16 -0
- package/.tshy/esm.json +15 -0
- package/.turbo/turbo-build.log +69 -0
- package/dist/commonjs/InstantSolidDatabase.d.ts +156 -0
- package/dist/commonjs/InstantSolidDatabase.d.ts.map +1 -0
- package/dist/commonjs/InstantSolidDatabase.js +265 -0
- package/dist/commonjs/InstantSolidDatabase.js.map +1 -0
- package/dist/commonjs/InstantSolidRoom.d.ts +97 -0
- package/dist/commonjs/InstantSolidRoom.d.ts.map +1 -0
- package/dist/commonjs/InstantSolidRoom.js +200 -0
- package/dist/commonjs/InstantSolidRoom.js.map +1 -0
- package/dist/commonjs/index.d.ts +6 -0
- package/dist/commonjs/index.d.ts.map +1 -0
- package/dist/commonjs/index.js +24 -0
- package/dist/commonjs/index.js.map +1 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/commonjs/version.d.ts +3 -0
- package/dist/commonjs/version.d.ts.map +1 -0
- package/dist/commonjs/version.js +5 -0
- package/dist/commonjs/version.js.map +1 -0
- package/dist/esm/InstantSolidDatabase.d.ts +156 -0
- package/dist/esm/InstantSolidDatabase.d.ts.map +1 -0
- package/dist/esm/InstantSolidDatabase.js +257 -0
- package/dist/esm/InstantSolidDatabase.js.map +1 -0
- package/dist/esm/InstantSolidRoom.d.ts +97 -0
- package/dist/esm/InstantSolidRoom.d.ts.map +1 -0
- package/dist/esm/InstantSolidRoom.js +191 -0
- package/dist/esm/InstantSolidRoom.js.map +1 -0
- package/dist/esm/index.d.ts +6 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +18 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/version.d.ts +3 -0
- package/dist/esm/version.d.ts.map +1 -0
- package/dist/esm/version.js +3 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/standalone/index.js +7010 -0
- package/dist/standalone/index.umd.cjs +7 -0
- package/package.json +63 -0
- package/src/InstantSolidDatabase.ts +363 -0
- package/src/InstantSolidRoom.ts +319 -0
- package/src/index.ts +191 -0
- package/src/version.ts +2 -0
- package/tsconfig.dev.json +14 -0
- package/tsconfig.json +45 -0
- package/vite.config.ts +20 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
(function(A,v){typeof exports=="object"&&typeof module<"u"?v(exports):typeof define=="function"&&define.amd?define(["exports"],v):(A=typeof globalThis<"u"?globalThis:A||self,v(A.instantSolidjs={}))})(this,function(A){"use strict";var Ma=Object.defineProperty;var ja=(A,v,k)=>v in A?Ma(A,v,{enumerable:!0,configurable:!0,writable:!0,value:k}):A[v]=k;var d=(A,v,k)=>ja(A,typeof v!="symbol"?v+"":v,k);function v(t){if(typeof t=="number")return(Math.abs(t*2654435761)>>>0).toString(16);if(typeof t=="boolean")return t?"1":"0";if(t===null)return"null";if(t===void 0)return"undefined";if(typeof t=="string"){let e=2166136261;for(let n=0;n<t.length;n++)e^=t.charCodeAt(n),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(t)){let e=2166136261;for(let n=0;n<t.length;n++){e^=(n+1)*2654435761;const r=v(t[n]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof t=="object"){let e=2166136261;const n=Object.keys(t).sort();for(let r=0;r<n.length;r++){const s=n[r],i=v(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=v(t[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return v(String(t))}const k={Remove:"remove",Replace:"replace",Add:"add"},Ft=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),Ar=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Ee=Symbol.iterator,K={mutable:"mutable",immutable:"immutable"},Xe={};function pe(t,e){return t instanceof Map?t.has(e):Object.prototype.hasOwnProperty.call(t,e)}function Nt(t,e){if(e in t){let n=Reflect.getPrototypeOf(t);for(;n;){const r=Reflect.getOwnPropertyDescriptor(n,e);if(r)return r;n=Reflect.getPrototypeOf(n)}}}function et(t){return Object.getPrototypeOf(t)===Set.prototype}function tt(t){return Object.getPrototypeOf(t)===Map.prototype}function q(t){var e;return(e=t.copy)!==null&&e!==void 0?e:t.original}function te(t){return!!S(t)}function S(t){return typeof t!="object"?null:t==null?void 0:t[Ft]}function nt(t){var e;const n=S(t);return n?(e=n.copy)!==null&&e!==void 0?e:n.original:t}function W(t,e){if(!t||typeof t!="object")return!1;let n;return Object.getPrototypeOf(t)===Object.prototype||Array.isArray(t)||t instanceof Map||t instanceof Set||!!(e!=null&&e.mark)&&((n=e.mark(t,K))===K.immutable||typeof n=="function")}function Kt(t,e=[]){if(Object.hasOwnProperty.call(t,"key")){const n=t.parent.copy,r=S(H(n,t.key));if(r!==null&&(r==null?void 0:r.original)!==t.original)return null;const s=t.parent.type===3,i=s?Array.from(t.parent.setMap.keys()).indexOf(t.key):t.key;if(!(s&&n.size>i||pe(n,i)))return null;e.push(i)}if(t.parent)return Kt(t.parent,e);e.reverse();try{vr(t.copy,e)}catch{return null}return e}function ne(t){return Array.isArray(t)?1:t instanceof Map?2:t instanceof Set?3:0}function H(t,e){return ne(t)===2?t.get(e):t[e]}function ye(t,e,n){ne(t)===2?t.set(e,n):t[e]=n}function rt(t,e){const n=S(t);return(n?q(n):t)[e]}function J(t,e){return t===e?t!==0||1/t===1/e:t!==t&&e!==e}function st(t){if(t)for(;t.finalities.revoke.length>0;)t.finalities.revoke.pop()()}function re(t,e){return e?t:[""].concat(t).map(n=>{const r=`${n}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function vr(t,e){for(let n=0;n<e.length-1;n+=1){const r=e[n];if(t=H(ne(t)===3?Array.from(t):t,r),typeof t!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return t}function Or(t){const e=Object.create(Object.getPrototypeOf(t));return Reflect.ownKeys(t).forEach(n=>{let r=Reflect.getOwnPropertyDescriptor(t,n);if(r.enumerable&&r.configurable&&r.writable){e[n]=t[n];return}r.writable||(r.writable=!0,r.configurable=!0),(r.get||r.set)&&(r={configurable:!0,writable:!0,enumerable:r.enumerable,value:t[n]}),Reflect.defineProperty(e,n,r)}),e}const kr=Object.prototype.propertyIsEnumerable;function qt(t,e){let n;if(Array.isArray(t))return Array.prototype.concat.call(t);if(t instanceof Set){if(!et(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t.values())}return Set.prototype.difference?Set.prototype.difference.call(t,new Set):new Set(t.values())}else if(t instanceof Map){if(!tt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t)}return new Map(t)}else if(e!=null&&e.mark&&(n=e.mark(t,K),n!==void 0)&&n!==K.mutable){if(n===K.immutable)return Or(t);if(typeof n=="function"){if(e.enablePatches||e.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return n()}throw new Error(`Unsupported mark result: ${n}`)}else if(typeof t=="object"&&Object.getPrototypeOf(t)===Object.prototype){const r={};return Object.keys(t).forEach(s=>{r[s]=t[s]}),Object.getOwnPropertySymbols(t).forEach(s=>{kr.call(t,s)&&(r[s]=t[s])}),r}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function R(t){t.copy||(t.copy=qt(t.original,t.options))}function be(t){if(!W(t))return nt(t);if(Array.isArray(t))return t.map(be);if(t instanceof Map){const n=Array.from(t.entries()).map(([r,s])=>[r,be(s)]);if(!tt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Map(n)}if(t instanceof Set){const n=Array.from(t).map(be);if(!et(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Set(n)}const e=Object.create(Object.getPrototypeOf(t));for(const n in t)e[n]=be(t[n]);return e}function Ie(t){return te(t)?be(t):t}function B(t){var e;t.assignedMap=(e=t.assignedMap)!==null&&e!==void 0?e:new Map,t.operated||(t.operated=!0,t.parent&&B(t.parent))}function zt(){throw new Error("Cannot modify frozen object")}function ae(t,e,n,r,s){{n=n??new WeakMap,r=r??[],s=s??[];const o=n.has(t)?n.get(t):t;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(t)||te(t)){r.pop(),s.pop();return}switch(ne(t)){case 2:for(const[a,c]of t)ae(a,a,n,r,s),ae(c,a,n,r,s);t.set=t.clear=t.delete=zt;break;case 3:for(const a of t)ae(a,a,n,r,s);t.add=t.clear=t.delete=zt;break;case 1:Object.freeze(t);let o=0;for(const a of t)ae(a,o,n,r,s),o+=1;break;default:Object.freeze(t),Object.keys(t).forEach(a=>{const c=t[a];ae(c,a,n,r,s)})}r.pop(),s.pop()}function it(t,e){const n=ne(t);if(n===0)Reflect.ownKeys(t).forEach(r=>{e(r,t[r],t)});else if(n===1){let r=0;for(const s of t)e(r,s,t),r+=1}else t.forEach((r,s)=>e(s,r,t))}function Vt(t,e,n){if(te(t)||!W(t,n)||e.has(t)||Object.isFrozen(t))return;const r=t instanceof Set,s=r?new Map:void 0;if(e.add(t),it(t,(i,o)=>{var a;if(te(o)){const c=S(o);R(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;ye(r?s:t,i,u)}else Vt(o,e,n)}),s){const i=t,o=Array.from(i);i.clear(),o.forEach(a=>{i.add(s.has(a)?s.get(a):a)})}}function Er(t,e){const n=t.type===3?t.setMap:t.copy;t.finalities.revoke.length>1&&t.assignedMap.get(e)&&n&&Vt(H(n,e),t.finalities.handledSet,t.options)}function ot(t){t.type===3&&t.copy&&(t.copy.clear(),t.setMap.forEach(e=>{t.copy.add(nt(e))}))}function at(t,e,n,r){if(t.operated&&t.assignedMap&&t.assignedMap.size>0&&!t.finalized){if(n&&r){const i=Kt(t);i&&e(t,i,n,r)}t.finalized=!0}}function ct(t,e,n,r){const s=S(n);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=t.type===3?t.setMap:t.copy;if(J(H(c,e),n)){let u=s.original;s.copy&&(u=s.copy),ot(t),at(t,r,i,o),t.options.enableAutoFreeze&&(t.options.updatedValues=(a=t.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,t.options.updatedValues.set(u,s.original)),ye(c,e,u)}}),t.options.enableAutoFreeze&&s.finalities!==t.finalities&&(t.options.enableAutoFreeze=!1)),W(n,t.options)&&t.finalities.draft.push(()=>{const i=t.type===3?t.setMap:t.copy;J(H(i,e),n)&&Er(t,e)})}function Ir(t,e,n,r,s){let{original:i,assignedMap:o,options:a}=t,c=t.copy;c.length<i.length&&([i,c]=[c,i],[n,r]=[r,n]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),f=re(l,s);n.push({op:k.Replace,path:f,value:Ie(c[u])}),r.push({op:k.Replace,path:f,value:Ie(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),f=re(l,s);n.push({op:k.Add,path:f,value:Ie(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),f=re(l,s);r.push({op:k.Replace,path:f,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const f=e.concat([l-1]),h=re(f,s);r.push({op:k.Remove,path:h})}}}function Cr({original:t,copy:e,assignedMap:n},r,s,i,o){n.forEach((a,c)=>{const u=H(t,c),l=Ie(H(e,c)),f=a?pe(t,c)?k.Replace:k.Add:k.Remove;if(J(u,l)&&f===k.Replace)return;const h=r.concat(c),p=re(h,o);s.push(f===k.Remove?{op:f,path:p}:{op:f,path:p,value:l}),i.push(f===k.Add?{op:k.Remove,path:p}:f===k.Remove?{op:k.Add,path:p,value:u}:{op:k.Replace,path:p,value:u})})}function Pr({original:t,copy:e},n,r,s,i){let o=0;t.forEach(a=>{if(!e.has(a)){const c=n.concat([o]),u=re(c,i);r.push({op:k.Remove,path:u,value:a}),s.unshift({op:k.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!t.has(a)){const c=n.concat([o]),u=re(c,i);r.push({op:k.Add,path:u,value:a}),s.unshift({op:k.Remove,path:u,value:a})}o+=1})}function ge(t,e,n,r){const{pathAsArray:s=!0}=t.options.enablePatches;switch(t.type){case 0:case 2:return Cr(t,e,n,r,s);case 1:return Ir(t,e,n,r,s);case 3:return Pr(t,e,n,r,s)}}const Ce=(t,e,n=!1)=>{if(typeof t=="object"&&t!==null&&(!W(t,e)||n))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},ut={get size(){return q(S(this)).size},has(t){return q(S(this)).has(t)},set(t,e){const n=S(this),r=q(n);return(!r.has(t)||!J(r.get(t),e))&&(R(n),B(n),n.assignedMap.set(t,!0),n.copy.set(t,e),ct(n,t,e,ge)),this},delete(t){if(!this.has(t))return!1;const e=S(this);return R(e),B(e),e.original.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.copy.delete(t),!0},clear(){const t=S(this);if(this.size){R(t),B(t),t.assignedMap=new Map;for(const[e]of t.original)t.assignedMap.set(e,!1);t.copy.clear()}},forEach(t,e){const n=S(this);q(n).forEach((r,s)=>{t.call(e,this.get(s),s,this)})},get(t){var e,n;const r=S(this),s=q(r).get(t),i=((n=(e=r.options).mark)===null||n===void 0?void 0:n.call(e,s,K))===K.mutable;if(r.options.strict&&Ce(s,r.options,i),i||r.finalized||!W(s,r.options)||s!==r.original.get(t))return s;const o=Xe.createDraft({original:s,parentDraft:r,key:t,finalities:r.finalities,options:r.options});return R(r),r.copy.set(t,o),o},keys(){return q(S(this)).keys()},values(){const t=this.keys();return{[Ee]:()=>this.values(),next:()=>{const e=t.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const t=this.keys();return{[Ee]:()=>this.entries(),next:()=>{const e=t.next();if(e.done)return e;const n=this.get(e.value);return{done:!1,value:[e.value,n]}}}},[Ee](){return this.entries()}},Mr=Reflect.ownKeys(ut),Wt=(t,e,{isValuesIterator:n})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=t.setMap.get(o);const c=S(a),u=((s=(r=t.options).mark)===null||s===void 0?void 0:s.call(r,a,K))===K.mutable;if(t.options.strict&&Ce(o,t.options,u),!u&&!c&&W(o,t.options)&&!t.finalized&&t.original.has(o)){const l=Xe.createDraft({original:o,parentDraft:t,key:o,finalities:t.finalities,options:t.options});t.setMap.set(o,l),a=l}else c&&(a=c.proxy);return{done:!1,value:n?a:[a,a]}},Pe={get size(){return S(this).setMap.size},has(t){const e=S(this);if(e.setMap.has(t))return!0;R(e);const n=S(t);return!!(n&&e.setMap.has(n.original))},add(t){const e=S(this);return this.has(t)||(R(e),B(e),e.assignedMap.set(t,!0),e.setMap.set(t,t),ct(e,t,t,ge)),this},delete(t){if(!this.has(t))return!1;const e=S(this);R(e),B(e);const n=S(t);return n&&e.setMap.has(n.original)?(e.assignedMap.set(n.original,!1),e.setMap.delete(n.original)):(!n&&e.setMap.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.setMap.delete(t))},clear(){if(!this.size)return;const t=S(this);R(t),B(t);for(const e of t.original)t.assignedMap.set(e,!1);t.setMap.clear()},values(){const t=S(this);R(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:Wt(t,e,{isValuesIterator:!0})}},entries(){const t=S(this);R(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:Wt(t,e,{isValuesIterator:!1})}},keys(){return this.values()},[Ee](){return this.values()},forEach(t,e){const n=this.values();let r=n.next();for(;!r.done;)t.call(e,r.value,r.value,this),r=n.next()}};Set.prototype.difference&&Object.assign(Pe,{intersection(t){return Set.prototype.intersection.call(new Set(this.values()),t)},union(t){return Set.prototype.union.call(new Set(this.values()),t)},difference(t){return Set.prototype.difference.call(new Set(this.values()),t)},symmetricDifference(t){return Set.prototype.symmetricDifference.call(new Set(this.values()),t)},isSubsetOf(t){return Set.prototype.isSubsetOf.call(new Set(this.values()),t)},isSupersetOf(t){return Set.prototype.isSupersetOf.call(new Set(this.values()),t)},isDisjointFrom(t){return Set.prototype.isDisjointFrom.call(new Set(this.values()),t)}});const jr=Reflect.ownKeys(Pe),Qt=new WeakSet,Gt={get(t,e,n){var r,s;const i=(r=t.copy)===null||r===void 0?void 0:r[e];if(i&&Qt.has(i))return i;if(e===Ft)return t;let o;if(t.options.mark){const u=e==="size"&&(t.original instanceof Map||t.original instanceof Set)?Reflect.get(t.original,e):Reflect.get(t.original,e,n);if(o=t.options.mark(u,K),o===K.mutable)return t.options.strict&&Ce(u,t.options,!0),u}const a=q(t);if(a instanceof Map&&Mr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(ut,"size").get.call(t.proxy);const u=ut[e];if(u)return u.bind(t.proxy)}if(a instanceof Set&&jr.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(Pe,"size").get.call(t.proxy);const u=Pe[e];if(u)return u.bind(t.proxy)}if(!pe(a,e)){const u=Nt(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(t.proxy):void 0}const c=a[e];if(t.options.strict&&Ce(c,t.options),t.finalized||!W(c,t.options))return c;if(c===rt(t.original,e)){if(R(t),t.copy[e]=lt({original:t.original[e],parentDraft:t,key:t.type===1?Number(e):e,finalities:t.finalities,options:t.options}),typeof o=="function"){const u=S(t.copy[e]);return R(u),B(u),u.copy}return t.copy[e]}return c},set(t,e,n){var r;if(t.type===3||t.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(t.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=Nt(q(t),e);if(i!=null&&i.set)return i.set.call(t.proxy,n),!0;const o=rt(q(t),e),a=S(o);return a&&J(a.original,n)?(t.copy[e]=n,t.assignedMap=(r=t.assignedMap)!==null&&r!==void 0?r:new Map,t.assignedMap.set(e,!1),!0):(J(n,o)&&(n!==void 0||pe(t.original,e))||(R(t),B(t),pe(t.original,e)&&J(n,t.original[e])?t.assignedMap.delete(e):t.assignedMap.set(e,!0),t.copy[e]=n,ct(t,e,n,ge)),!0)},has(t,e){return e in q(t)},ownKeys(t){return Reflect.ownKeys(q(t))},getOwnPropertyDescriptor(t,e){const n=q(t),r=Reflect.getOwnPropertyDescriptor(n,e);return r&&{writable:!0,configurable:t.type!==1||e!=="length",enumerable:r.enumerable,value:n[e]}},getPrototypeOf(t){return Reflect.getPrototypeOf(t.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(t,e){var n;return t.type===1?Gt.set.call(this,t,e,void 0,t.proxy):(rt(t.original,e)!==void 0||e in t.original?(R(t),B(t),t.assignedMap.set(e,!1)):(t.assignedMap=(n=t.assignedMap)!==null&&n!==void 0?n:new Map,t.assignedMap.delete(e)),t.copy&&delete t.copy[e],!0)}};function lt(t){const{original:e,parentDraft:n,key:r,finalities:s,options:i}=t,o=ne(e),a={type:o,finalized:!1,parent:n,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in t)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,Gt);if(s.revoke.push(u),Qt.add(c),a.proxy=c,n){const l=n;l.finalities.draft.push((f,h)=>{var p,y;const b=S(c);let g=l.type===3?l.setMap:l.copy;const w=H(g,r),_=S(w);if(_){let T=_.original;_.operated&&(T=nt(w)),ot(_),at(_,ge,f,h),l.options.enableAutoFreeze&&(l.options.updatedValues=(p=l.options.updatedValues)!==null&&p!==void 0?p:new WeakMap,l.options.updatedValues.set(T,_.original)),ye(g,r,T)}(y=b.callbacks)===null||y===void 0||y.forEach(T=>{T(f,h)})})}else{const l=S(c);l.finalities.draft.push((f,h)=>{ot(l),at(l,ge,f,h)})}return c}Xe.createDraft=lt;function $r(t,e,n,r,s){var i;const o=S(t),a=(i=o==null?void 0:o.original)!==null&&i!==void 0?i:t,c=!!e.length;if(o!=null&&o.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(n,r);const u=c?e[0]:o?o.operated?o.copy:o.original:t;return o&&st(o),s&&ae(u,u,o==null?void 0:o.options.updatedValues),[u,n&&c?[{op:k.Replace,path:[],value:e[0]}]:n,r&&c?[{op:k.Replace,path:[],value:a}]:r]}function Dr(t,e){var n;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((n=e.mark)===null||n===void 0?void 0:n.call(e,t,K))===K.mutable||!W(t,e)?t:lt({original:t,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,f]=$r(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,f]:u}]}function ft(t){const{rootDraft:e,value:n,useRawReturn:r=!1,isRoot:s=!0}=t;it(n,(i,o,a)=>{const c=S(o);if(c&&e&&c.finalities===e.finalities){t.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 ye(a,i,u)}else typeof o=="object"&&o!==null&&(t.value=o,t.isRoot=!1,ft(t))}),s&&(t.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 Bt(t){var e;const n=S(t);if(!W(t,n==null?void 0:n.options))return t;const r=ne(t);if(n&&!n.operated)return n.original;let s;function i(){s=r===2?tt(t)?new Map(t):new(Object.getPrototypeOf(t)).constructor(t):r===3?Array.from(n.setMap.values()):qt(t,n==null?void 0:n.options)}if(n){n.finalized=!0;try{i()}finally{n.finalized=!1}}else s=t;if(it(s,(o,a)=>{if(n&&J(H(n.original,o),a))return;const c=Bt(a);c!==a&&(s===t&&i(),ye(s,o,c))}),r===3){const o=(e=n==null?void 0:n.original)!==null&&e!==void 0?e:s;return et(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function Ht(t){if(!te(t))throw new Error(`current() is only used for Draft, parameter: ${t}`);return Bt(t)}const Me=(t=>function e(n,r,s){var i,o,a;if(typeof n=="function"&&typeof r!="function")return function(m,...I){return e(m,U=>n.call(this,U,...I),r)};const c=n,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({},t),l);const f=te(c)?Ht(c):c,h=Array.isArray(l.mark)?(m,I)=>{for(const U of l.mark){if(typeof U!="function")throw new Error(`Invalid mark: ${U}, 'mark' should be a function.`);const z=U(m,I);if(z)return z}}:l.mark,p=(i=l.enablePatches)!==null&&i!==void 0?i:!1,y=(o=l.strict)!==null&&o!==void 0?o:!1,g={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:h,strict:y,enablePatches:p};if(!W(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[w,_]=Dr(f,g);if(typeof r!="function"){if(!W(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[w,_]}let T;try{T=u(w)}catch(m){throw st(S(w)),m}const O=m=>{const I=S(w);if(!te(m)){if(m!==void 0&&!J(m,w)&&(I!=null&&I.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 z=m==null?void 0:m[Ar];if(z){const he=z[0];return g.strict&&typeof m=="object"&&m!==null&&ft({rootDraft:I,value:m,useRawReturn:!0}),_([he])}if(m!==void 0)return typeof m=="object"&&m!==null&&ft({rootDraft:I,value:m}),_([m])}if(m===w||m===void 0)return _([]);const U=S(m);if(g===U.options){if(U.operated)throw new Error("Cannot return a modified child draft.");return _([Ht(m)])}return _([m])};return T instanceof Promise?T.then(O,m=>{throw st(S(w)),m}):O(T)})();Object.prototype.constructor.toString();function Jt(t,e){const n=Object.keys(t),r=Object.keys(e);return n.length===r.length&&Object.keys(t).every(s=>e.hasOwnProperty(s))}function Yt(t,e){return Object.keys(t).length===Object.keys(e).length&&Object.keys(t).every(n=>e.hasOwnProperty(n)&&t[n]===e[n])}function je(t,e){return typeof t!="object"||typeof e!="object"||t===null||e===null?t===e:Jt(t,e)?Object.keys(t).every(n=>je(t[n],e[n])):!1}function dt(t){if(!_e(t))return t;const e={};for(const[n,r]of Object.entries(t))r!==void 0&&(e[n]=r);return e}function Zt(t,e){if(!_e(t)||!_e(e))return e;const n={...t};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete n[r];continue}const s=_e(t[r])&&_e(e[r]);n[r]=s?Zt(t[r],e[r]):e[r]}return n}function _e(t){return typeof t=="object"&&t!==null&&!Array.isArray(t)}function Rr(t,e,n){if(!t||e.length===0)return;let r=t||{};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,n):r[s]=n}function Xt(t,e,n){if(!t||e.length===0)return;let r=t||{};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]]=n}function en(t,e){if(!t||e.length===0)return;const[n,...r]=e;if(n in t){if(r.length===0){Array.isArray(t)?t.splice(n,1):delete t[n];return}en(t[n],r),xr(t[n])&&delete t[n]}}function xr(t){return t&&Object.keys(t).length===0}const tn=/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$/,Ur={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 Lr(t){return new Date(t)}function Fr(t){return new Date(t+"Z")}const Nr=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function Kr(t){const e=t.match(Nr);if(!e)return null;const[n,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(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function zr(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function Vr(t){return new Date(t)}function Wr(t){const e=/^(\w{3}) (\w{3}) (\d{2}) (\d{4})$/;if(!t.match(e))throw new Error(`Unable to parse \`${t}\` as a date.`);const r=new Date(t+" UTC");return new Date(Date.UTC(r.getUTCFullYear(),r.getUTCMonth(),r.getUTCDate(),0,0,0,0))}function Qr(t){const e=/^(.+T.+)([+-])(\d{2})$/,n=t.match(e);if(n){const[,r,s,i]=n,o=`${r}${s}${i}:00`;return new Date(o)}return null}function Gr(t){const e=/^(\d+)-(\d{1,2})-(\d{1,2})([ T])(.+)$/,n=t.match(e);if(n){const[,r,s,i,o,a]=n,c=s.padStart(2,"0"),u=i.padStart(2,"0"),l=`${r}-${c}-${u}T${a}`;return new Date(l)}return null}function Br(t){const[e,n]=t.split(", "),[r,s,i]=e.split("/").map(Number),o=n.match(/(\d{1,2}):(\d{2}):(\d{2}) (AM|PM)/);if(!o)throw new Error(`Unable to parse time from: ${t}`);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 Hr(t){switch(t){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Jr(t){const e=t.match(tn);if(!e)return null;const[n]=e,r=Ur[n],s=new Date(t.replace(tn,"Z"));return new Date(s.getTime()-r*1e3)}const Yr=[Kr,zr,Wr,Br,Vr,Fr,Qr,qr,Lr,Hr,Jr,Gr];function Zr(t,e){try{const n=t(e);return n instanceof Date&&!isNaN(n.getTime())?n:null}catch{return null}}function ht(t){for(const e of Yr){const n=Zr(e,t);if(n)return n}return null}function Xr(t){try{const e=JSON.parse(t);return typeof e=="string"?ht(e):null}catch{return null}}function $e(t){if(t!==void 0){if(t===null)return null;if(t instanceof Date)return t;if(typeof t=="string"){const e=ht(t)||Xr(t)||ht(t.trim());if(!e)throw new Error(`Unable to parse \`${t}\` as a date.`);return e}else if(typeof t=="number")return new Date(t);throw new Error(`Invalid date value \`${t}\`. Expected a date, number, or string, got type ${typeof t}.`)}}class se{constructor(e,n){d(this,"attrs");d(this,"linkIndex");d(this,"_blobAttrs",null);d(this,"_primaryKeys",null);d(this,"_forwardIdents",null);d(this,"_revIdents",null);this.attrs=e,this.linkIndex=n}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 n=this.attrs[e.id];n&&(this.attrs[e.id]={...n,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(yt(e)){const[n,r,s]=e["forward-identity"];L(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[n,r]=e["forward-identity"];L(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 n=e["forward-identity"],[r,s,i]=n;L(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 n=e["reverse-identity"];if(n){const[r,s,i]=n;L(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function es(t){return t.cardinality==="one"}function pt(t){return t["value-type"]==="ref"}function yt(t){return t["value-type"]==="blob"}function ce(t,e){return e.reduce((n,r)=>n&&n.get(r),t)}function Q(t,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){t.delete(e[0]);return}const[n,...r]=e;t.has(n)&&Q(t.get(n),r)}function L(t,e,n){let r=t;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],n)}function nn(t,e,n){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=t.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&n&&(u=$e(u),o[2]=u),pt(l)&&L(i,[u,c,a],o),L(r,[a,c,u],o),L(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function rn(t){return{triples:F(t.eav,3),cardinalityInference:t.cardinalityInference,useDateObjects:t.useDateObjects,version:1}}function sn(t,e){return we(t,e.triples,e.cardinalityInference,e.useDateObjects)}function on(t,e){if(t)return new se(t.attrs,t.linkIndex);if(e&&"__type"in e)return new se(e.attrs,e.linkIndex)}function ts(t,e){return ce(t.eav,[e])!==void 0}function we(t,e,n,r){const s=nn(t,e,r);return s.cardinalityInference=n,s.useDateObjects=r,s}function Te(t,e){var s,i;let n;if(Array.isArray(e[0])){const[o,a]=e[0],c=t.aev.get(o);if(!c)return null;n=(s=F(c,2).find(l=>l[2]===a))==null?void 0:s[0]}else n=e[0];if(!n)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&t.aev.get(r[0])){const[o,a]=r,c=t.aev.get(o);if(!c)return null;const l=(i=F(c,2).find(b=>b[2]===a))==null?void 0:i[0];if(!l)return null;const[f,h,p,...y]=e;return[n,h,l,...y]}else{const[o,...a]=e;return[n,...a]}}function an(t,e,n){const r=Te(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(Q(t.eav,[s,i,o]),Q(t.aev,[i,s,o]),pt(a)&&Q(t.vae,[o,i,s]))}let ns=0;function cn(t,e,n){const[r,s,i]=n;let o;const a=ce(t.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+ns++}function un(t,e,n){const r=Te(t,n);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&t.useDateObjects&&(o=$e(o));const c=ce(t.eav,[s,i,o]),u=(c==null?void 0:c[3])??cn(t,a,r),l=[s,i,o,u];es(a)?(L(t.eav,[s,i],new Map([[o,l]])),L(t.aev,[i,s],new Map([[o,l]]))):(L(t.eav,[s,i,o],l),L(t.aev,[i,s,o],l)),pt(a)&&L(t.vae,[o,i,s],l)}function rs(t,e,n){var p;const r=Te(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!yt(a))throw new Error("merge operation is not supported for links");const c=ce(t.eav,[s,i]);if(!c)return;const u=(p=c.values().next())==null?void 0:p.value;if(!u)return;const l=u[2],f=Zt(l,o),h=[s,i,f,cn(t,a,u)];L(t.eav,[s,i],new Map([[f,h]])),L(t.aev,[i,s],new Map([[f,h]]))}function bt(t,e,n){var u,l;const[r,s]=n,i=Te(t,[r]);if(!i)return;const[o]=i,a=t.eav.get(o);if(a){for(const f of a.keys()){const h=e.getAttr(f);h&&h["on-delete-reverse"]==="cascade"&&F(a.get(f),1).forEach(([p,y,b])=>{var g;return bt(t,e,[b,(g=h["reverse-identity"])==null?void 0:g[1]])}),(!s||!h||((u=h["forward-identity"])==null?void 0:u[1])===s)&&(Q(t.aev,[f,o]),Q(t.eav,[o,f]))}a.size===0&&Q(t.eav,[o])}const c=t.vae.get(o)&&F(t.vae.get(o),2);c&&c.forEach(f=>{var g,w,_;const[h,p,y]=f,b=e.getAttr(p);(!s||!b||((g=b["reverse-identity"])==null?void 0:g[1])===s)&&(Q(t.eav,[h,p,y]),Q(t.aev,[p,h,y]),Q(t.vae,[y,p,h])),b&&b["on-delete"]==="cascade"&&((w=b["reverse-identity"])==null?void 0:w[1])===s&&bt(t,e,[h,(_=b["forward-identity"])==null?void 0:_[1]])}),((l=t.vae.get(o))==null?void 0:l.size)===0&&Q(t.vae,[o])}function ln(t,e,n){const r=nn(e,n,t.useDateObjects);Object.keys(r).forEach(s=>{t[s]=r[s]})}function ss(t,[e]){t.addAttr(e)}function fn(t){return F(t.eav,3)}function is(t,e,[n]){if(!e.getAttr(n))return;const r=fn(t).filter(([s,i])=>i!==n);e.deleteAttr(n),ln(t,e,r)}function os(t,e,[n]){e.getAttr(n.id)&&(e.updateAttr(n),ln(t,e,fn(t)))}function as(t,e,n){const[r,...s]=n;switch(r){case"add-triple":un(t,e,s);break;case"deep-merge-triple":rs(t,e,s);break;case"retract-triple":an(t,e,s);break;case"delete-entity":bt(t,e,s);break;case"add-attr":ss(e,s);break;case"delete-attr":is(t,e,s);break;case"update-attr":os(t,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function F(t,e,n=[]){if(!t||e===0)return n;if(e===1){for(const r of t.values())n.push(r);return n}for(const r of t.values())F(r,e-1,n);return n}function De(t,e,n){var i;const r=[];if(n!=null&&n.hasOwnProperty("$not")){for(const o of e.keys())n.$not!==o&&r.push(e.get(o));return r}if(n!=null&&n.hasOwnProperty("$isNull")){const{attrId:o,isNull:a,reverse:c}=n.$isNull;if(c)for(const u of e.keys()){const l=t.vae.get(u),f=!l||!l.get(o);(a?f:!f)&&r.push(e.get(u))}else{const u=t.aev.get(o);for(const l of e.keys()){const f=!u||((i=u.get(l))==null?void 0:i.get(null))||!u.get(l);(a?f:!f)&&r.push(e.get(l))}}return r}if(n!=null&&n.$comparator)return F(e,1).filter(n.$op);const s=n.in||n.$in||[n];for(const o of s){const a=e.get(o);a&&r.push(a)}return r}function cs(t,e,n){let r="";return t!==void 0&&(r+="e"),e!==void 0&&(r+="a"),n!==void 0&&(r+="v"),r}function us(t,[e,n,r]){var i,o;switch(cs(e,n,r)){case"e":{const a=t.eav.get(e);return F(a,2)}case"ea":{const a=(i=t.eav.get(e))==null?void 0:i.get(n);return F(a,1)}case"eav":{const a=(o=t.eav.get(e))==null?void 0:o.get(n);return a?De(t,a,r):[]}case"ev":{const a=t.eav.get(e);if(!a)return[];const c=[];for(const u of a.values())c.push(...De(t,u,r));return c}case"a":{const a=t.aev.get(n);return F(a,2)}case"av":{const a=t.aev.get(n);if(!a)return[];const c=[];for(const u of a.values())c.push(...De(t,u,r));return c}case"v":{const a=[];for(const c of t.eav.values())for(const u of c.values())a.push(...De(t,u,r));return a}default:return F(t.eav,3)}}function ls(t,e,n){var s;const r={};if(!e)return r;for(const[i,o]of e.entries()){const a=(s=t.eav.get(n))==null?void 0:s.get(o.id),c=F(a,1);for(const u of c)r[i]=u[2]}return r}function C(t,e,n){var r;return(r=t.forwardIdents.get(e))==null?void 0:r.get(n)}function ie(t,e,n){var r;return(r=t.revIdents.get(e))==null?void 0:r.get(n)}function fs(t,e){return t.blobAttrs.get(e)}function dn(t,e){var r;const n=t.primaryKeys.get(e);return n||((r=t.forwardIdents.get(e))==null?void 0:r.get("id"))}function ds(t,e,n){const r=Te(t,n);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return ce(t.eav,[s,i])}function hs(t,e,n){const r=n.filter(([s,i,o,a,c])=>{if(s!=="add-triple"&&s!=="deep-merge-triple")return!0;const u=c==null?void 0:c.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const f=e.getAttr(o);if(f){const h=dn(e,f["forward-identity"][1]);l=!!ds(t,e,[i,h==null?void 0:h.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Me({store:t,attrsStore:e},s=>{r.forEach(i=>{as(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof se)return"immutable"}})}function ps(t){return typeof t=="string"&&t.startsWith("?")}function ys(t,e,n){if(n.hasOwnProperty(t)){const r=n[t];return pn(r,e,n)}return{...n,[t]:e}}function hn(t,e,n){return t===e?n:null}function bs(t){switch(typeof t){case"string":return t.startsWith("?")?ys:hn;default:return hn}}const gs=["in","$in","$not","$isNull","$comparator"];function _s(t){for(const e of gs)if(t.hasOwnProperty(e))return!0;return!1}function pn(t,e,n){return n?typeof t=="object"?_s(t)?n:null:bs(t)(t,e,n):null}function ws(t,e,n){return t.reduce((r,s,i)=>{const o=e[i];return pn(s,o,r)},n)}function Ts(t,e,n){return As(t,e,n).map(r=>ws(e,r,n)).filter(r=>r)}function ms(t,e,n){return e.or?e.or.patterns.flatMap(r=>gt(t,r,n)):e.and?e.and.patterns.reduce((r,s)=>gt(t,s,r),n):n.flatMap(r=>Ts(t,e,r))}function gt(t,e,n=[{}]){return e.reduce((r,s)=>ms(t,s,r),n)}function _t(t,e){return Array.isArray(e)?e.map(n=>_t(t,n)):ps(e)?t[e]:e}function Ss(t,{find:e,where:n}){return gt(t,n).map(s=>_t(s,e))}function As(t,e,n){return us(t,_t(n,e))}const vs=/^(?:[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 ue(t){return typeof t=="string"&&vs.test(t)}const M=[];for(let t=0;t<256;++t)M.push((t+256).toString(16).slice(1));function Os(t,e=0){return(M[t[e+0]]+M[t[e+1]]+M[t[e+2]]+M[t[e+3]]+"-"+M[t[e+4]]+M[t[e+5]]+"-"+M[t[e+6]]+M[t[e+7]]+"-"+M[t[e+8]]+M[t[e+9]]+"-"+M[t[e+10]]+M[t[e+11]]+M[t[e+12]]+M[t[e+13]]+M[t[e+14]]+M[t[e+15]]).toLowerCase()}let wt;const ks=new Uint8Array(16);function Es(){if(!wt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");wt=crypto.getRandomValues.bind(crypto)}return wt(ks)}const yn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Is(t,e,n){var s;if(yn.randomUUID&&!t)return yn.randomUUID();t=t||{};const r=t.random??((s=t.rng)==null?void 0:s.call(t))??Es();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,Os(r)}function bn(t){const e=t.replace(/-/g,""),n=[];for(let r=0;r<e.length;r+=2)n.push(parseInt(e.substring(r,r+2),16));return n}function Cs(t,e){for(let n=0;n<t.length;n++){if(t[n]<e[n])return-1;if(t[n]>e[n])return 1}return 0}function Ps(t,e){return Cs(bn(t),bn(e))}function P(){return Is()}function Ms(t,e){return t.localeCompare(e)}function js(){let t=Ms;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{t=Intl.Collator("en-US").compare}catch{}return t}const $s=js();let Ds=0;function me(t){return Re(`_${t}`,Ds++)}function Re(t,e){return`?${t}-${e}`}class le extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function Rs(t,e){const n=dn(t,e);if(!n)throw new le(`Could not find id attr for ${e}`);return n}function gn(t,e,n,r){return[xs(t,e,n,r)]}function xs(t,e,n,r){return[t(n,r),Rs(e,n).id,t(n,r),t("time",r)]}function Us(t,e,n){return t.map(r=>r===e?n:r)}function _n(t,e,n,r,s){const i=C(e,n,s),o=ie(e,n,s),a=i||o;if(!a)throw new le(`Could not find attr for ${[n,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"],h=r+1,p=i?[t(u,r),a.id,t(f,h),me("time")]:[t(u,h),a.id,t(f,r),me("time")];return[i?f:u,h,p,a,!!i]}function wn(t,e){if(typeof e!="string")return function(o){return!1};const r=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/%/g,".*").replace(/_/g,"."),s=new RegExp(`^${r}$`,t?void 0:"i");return function(o){return typeof o!="string"?!1:s.test(o)}}function Ls(t,e){if(typeof e!="object"||e.hasOwnProperty("$in")||e.hasOwnProperty("in"))return e;const n=t["checked-data-type"]==="date";if(e.hasOwnProperty("$gt"))return{$comparator:!0,$op:n?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:n?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:n?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:n?function(s){return new Date(s[2])<=new Date(e.$lte)}:function(s){return s[2]<=e.$lte}};if(e.hasOwnProperty("$like")){const r=wn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=wn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function Fs(t,e,n,r,s,i){const o=C(e,n,s),a=ie(e,n,s),c=o||a;if(!c)throw new le(`No attr for etype = ${n} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=C(e,n,"id");if(!u)throw new le(`No attr for etype = ${n} label = id`);return[t(n,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},me("time")]}return o?[t(n,r),c.id,Ls(c,i),me("time")]:[i,c.id,t(n,r),me("time")]}function Ns(t,e,n,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,f,h]=c,[p,y,b]=_n(t,e,l,f,u);return[p,y,[...h,b]]},[n,r,[]]);return[i,o,a]}function Tt(t,e,n,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Ns(t,e,n,r,o),f=Fs(t,e,c,u,a,i);return l.concat([f])}function Ks(t,e){return e?[e].concat(t):t}function qs([t,e]){return t==="or"&&Array.isArray(e)}function zs([t,e]){return t==="and"&&Array.isArray(e)}function Vs(t,e,n){return(r,s)=>{const i=t(r,s);return e==i?i:`${i}-${n}`}}function Tn(t,e,n,r,s,i){const o=t(r,s),a=i.map((c,u)=>{const l=Vs(t,o,u);return Sn(l,n,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ws(t){const e=[];for(let n=1;n<=t.length;n++)e.push(t.slice(0,n));return e}function mn(t,e,n,r,s){return Ws(s).map(i=>Tt(t,e,n,r,i,{$isNull:!0}))}function Sn(t,e,n,r,s){return Object.entries(s).flatMap(([i,o])=>{if(qs([i,o]))return Tn(t,"or",e,n,r,o);if(zs([i,o]))return Tn(t,"and",e,n,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o!=null&&o.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o!=null&&o.hasOwnProperty("$not")){const c=Tt(t,e,n,r,a,o),u=mn(t,e,n,r,a);return[{or:{patterns:[c,...u],joinSym:t(n,r)}}]}return o!=null&&o.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:mn(t,e,n,r,a),joinSym:t(n,r)}}]:Tt(t,e,n,r,a,o)})}function Qs(t,e,n,r){const s=Re;return r?Sn(s,t,e,n,r).concat(gn(s,t,e,n)):gn(s,t,e,n)}function Gs(t,e,n){return[t(e,n),t("time",n)]}function Bs(t,e,n,r,s,i){const[o,a,c,u,l]=_n(t,e,n,r,s),f=Us(c,t(n,r),i);return[o,a,f,u,l]}function Hs(t,e,n,{etype:r,level:s,form:i},o){const a=Object.keys(i).filter(c=>c!=="$");return a.length?Object.entries(o).map(function([u,l]){return a.map(function(p){var b,g,w;const y=!!(e.cardinalityInference&&((w=(g=(b=n.linkIndex)==null?void 0:b[r])==null?void 0:g[p])!=null&&w.isSingular));try{const[_,T,O]=Bs(t,n,r,s,p,u),m=vn(e,n,{etype:_,level:T,form:i[p],join:O}),I=y?m[0]:m;return{[p]:I}}catch(_){if(_ instanceof le)return{[p]:y?void 0:[]};throw _}}).reduce(function(p,y){return{...p,...y}},l)}):Object.values(o)}function Js(t,e,n){return n==="string"?$s(t,e):t>e?1:-1}function Se(t,e,n,r,s){return e===r||e==null&&r==null?Ps(t,n):r==null?1:e==null?-1:Js(e,r,s)}function xe([t,e],[n,r],s){return Se(t,e,n,r,s)}function mt(t){return t==null?t:new Date(t).getTime()}function Ys(t,e,n,r){var y;const[s,i,o,a]=t,c=n==="desc"?1:-1;if(((y=e["forward-identity"])==null?void 0:y[2])==="id")return xe(r,[s,a],null)===c;const[u,l]=r,f=e["checked-data-type"],h=f==="date"?mt(l):l,p=f==="date"?mt(o):o;return xe([u,h],[s,p],f)===c}function Zs(t,e){const n=e[1];return t.getAttr(n)}function Xs(t,e,n){const r=Object.keys(n)[0];return C(t,e,r)}function ei(t,e,n,r){if(n)return Zs(t,n);if(r)return Xs(t,e,r)}function ti(t,e,n){var s,i;if(!Array.isArray(n.fields))return fs(t,e);const r=new Map;for(const o of n.fields){const a=C(t,e,o),c=(s=a==null?void 0:a["forward-identity"])==null?void 0:s[2];c&&yt(a)&&r.set(c,a)}if(!r.has("id")){const o=C(t,e,"id"),a=(i=o==null?void 0:o["forward-identity"])==null?void 0:i[2];a&&r.set(a,o)}return r}function ni(t,e,{etype:n,pageInfo:r,dq:s,form:i}){var y,b;const o=(y=i==null?void 0:i.$)==null?void 0:y.order,a=An(i),c=ri(i);let u=Ss(t,s);const l=r==null?void 0:r["start-cursor"],f=ei(e,n,l,o);if(f&&((b=f==null?void 0:f["forward-identity"])==null?void 0:b[2])!=="id"){const g=f["checked-data-type"]==="date",w=f.id;u=u.map(([_])=>{var O,m,I,U,z;let T=(z=(U=(I=(m=(O=t.eav.get(_))==null?void 0:O.get(w))==null?void 0:m.values())==null?void 0:I.next())==null?void 0:U.value)==null?void 0:z[2];return g&&(T=mt(T)),[_,T]})}u.sort(c==="asc"?function(w,_){return xe(w,_,f==null?void 0:f["checked-data-type"])}:function(w,_){return xe(_,w,f==null?void 0:f["checked-data-type"])});let h={};const p=ti(e,n,s);for(const g of u){const[w]=g;if(h[w]||!a&&l&&f&&Ys(l,f,c,g))continue;const _=ls(t,p,w);_&&(h[w]=_)}return h}function ri(t){var n;const e=(n=t.$)==null?void 0:n.order;return e&&e[Object.keys(e)[0]]||"asc"}function An(t){var s,i,o;const e=(s=t.$)==null?void 0:s.offset,n=(i=t.$)==null?void 0:i.before,r=(o=t.$)==null?void 0:o.after;return!e&&!n&&!r}function si(t,e,{etype:n,level:r,form:s,join:i,pageInfo:o}){var h,p,y,b,g;if(!An(s)&&(!o||!o["start-cursor"]))return[];const a=Ks(Qs(e,n,r,(h=s.$)==null?void 0:h.where),i),c=Gs(Re,n,r),u=(p=s.$)==null?void 0:p.fields,l=ni(t,e,{etype:n,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),f=((y=s.$)==null?void 0:y.limit)||((b=s.$)==null?void 0:b.first)||((g=s.$)==null?void 0:g.last);if(f!=null){r>0&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const w=Object.entries(l);return w.length<=f?l:Object.fromEntries(w.slice(0,f))}return l}function ii(t,e,n){try{return si(t,e,n)}catch(r){if(r instanceof le)return{};throw r}}function vn(t,e,n){const r=ii(t,e,n);return Hs(Re,t,e,n,r)}function oi(t){const e={};for(const[n,r]of Object.entries(t))e[n]={startCursor:r["start-cursor"],endCursor:r["end-cursor"],hasNextPage:r["has-next-page?"],hasPreviousPage:r["has-previous-page?"]};return e}function On({store:t,attrsStore:e,pageInfo:n,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r!=null&&r[u]||u==="$$ruleParams"||(c[u]=vn(t,e,{etype:u,form:s[u],level:0,pageInfo:n==null?void 0:n[u]})),c},{})};return n&&(o.pageInfo=oi(n)),r&&(o.aggregate=r),o}function ai(){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 ci=ai();function Ue(t,e,n){const r={__etype:t,__ops:n};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return n;if(i==="__etype")return t;if(ci.has(i))return(o,a)=>Ue(t,e,[...n,a?[i,t,e,o,a]:[i,t,e,o]])}})}function kn(t,e){return`lookup__${t}__${JSON.stringify(e)}`}function Le(t){return t.startsWith("lookup__")}function St(t){const[e,n,...r]=t.split("__");return[n,JSON.parse(r.join("__"))]}function ui(t){return new Proxy({__etype:t},{get(e,n){if(n==="lookup")return(s,i)=>Ue(t,St(kn(s,i)),[]);if(n==="__etype")return t;const r=n;return Le(r)?Ue(t,St(r),[]):Ue(t,r,[])}})}function At(){return new Proxy({},{get(t,e){return ui(e)}})}const li=At();function fi(t){return t.__ops}function di(t,e){const{attrIdMap:n,refSwapAttrIds:r}=t,s=[];for(const o of e){const a=n[o];if(a)s.push(a);else if(Array.isArray(o)&&o.length==2&&n[o[0]]){const[c,u]=o;s.push([n[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 hi(t){if(Array.isArray(t))return t;const e=Object.entries(t);if(e.length!==1)throw new Error("lookup must be an object with a single unique attr and value.");return e[0]}function pi(t,e,n){return n.indexOf(".")!==-1&&!C(t,e,n)}function vt(t){const[e,n,...r]=t.split(".");if(r.length>0||n!=="id")throw new Error(`${t} is not a valid lookup attribute.`);return e}function yi(t,e,n){if(!pi(t,e,n))return C(t,e,n);const r=vt(n),s=C(t,e,r)||ie(t,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${n} does not reference a valid link attribute.`);return s}function Ot(t){return typeof t=="string"&&!Le(t)?null:typeof t=="string"&&Le(t)?St(t):hi(t)}function N(t,e,n){const r=Ot(n);if(r===null)return n;const[s,i]=r,o=yi(t,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function En(t,e,n,r){var o;const s=N(t,e,n);return Array.isArray(s)?[["add-triple",s,(o=C(t,e,"id"))==null?void 0:o.id,s]].concat(r):r}function bi({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=C(t,e,i),u=ie(t,e,i);return a.map(l=>c?["add-triple",N(t,e,n),c.id,N(t,c["reverse-identity"][1],l)]:["add-triple",N(t,u["forward-identity"][1],l),u==null?void 0:u.id,N(t,e,n)])});return En(t,e,n,s)}function gi({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=C(t,e,i),u=ie(t,e,i);return a.map(l=>c?["retract-triple",N(t,e,n),c.id,N(t,c["reverse-identity"][1],l)]:["retract-triple",N(t,u["forward-identity"][1],l),u.id,N(t,e,n)])});return En(t,e,n,s)}function _i(t,e,n,r){var s;if(Array.isArray(r)){const[i,o]=r;for(const a of t||[]){const c=a==null?void 0:a.aev.get(i);if(c){for(const[u,l,f]of F(c,2))if(f===o)return!0}}}else for(const i of t||[]){const o=i==null?void 0:i.eav.get(r);if(o){for(const a of o.keys())if(((s=e.getAttr(a))==null?void 0:s["forward-identity"][1])==n)return!0}}return!1}function In({stores:t,attrsStore:e},[n,r,s,i]){return(i==null?void 0:i.upsert)===!1?{mode:"update"}:(i==null?void 0:i.upsert)===!0?null:_i(t,e,n,r)?{mode:"update"}:null}function wi(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=dt(i),c=N(n,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,f])=>{const h=C(n,r,l);return h["checked-data-type"]==="date"&&t.useDateObjects&&(f=$e(f)),["add-triple",c,h.id,f,{mode:"create"}]})}function Ti(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=dt(i),c=N(n,r,s),u=In(t,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([f,h])=>{const p=C(n,r,f);return p["checked-data-type"]==="date"&&t.useDateObjects&&(h=$e(h)),["add-triple",c,p.id,h,...u?[u]:[]]})}function mi({attrsStore:t},[e,n]){return[["delete-entity",N(t,e,n),e]]}function Si(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=dt(i),c=N(n,r,s),u=In(t,[r,c,i,o]),l=Object.entries(a).map(([h,p])=>{const y=C(n,r,h);return["deep-merge-triple",c,y.id,p,...u?[u]:[]]});return[["add-triple",c,C(n,r,"id").id,c,...u?[u]:[]]].concat(l)}function Ai({attrsStore:t},[e,n,r]){return[["rule-params",N(t,e,n),e,r]]}function vi(t){const[e,n,r,s,i]=t;if(!s)return t;const o={...s};return delete o.id,[e,n,r,o,...i?[i]:[]]}function Oi(t,e){const[n,...r]=vi(e);switch(n){case"merge":return Si(t,r);case"create":return wi(t,r);case"update":return Ti(t,r);case"link":return bi(t,r);case"unlink":return gi(t,r);case"delete":return mi(t,r);case"ruleParams":return Ai(t,r);default:throw new Error(`unsupported action ${n}`)}}function ki(t){switch(t){case"string":case"date":case"boolean":case"number":return t;default:return}}function Ei(t,e,n){var a,c;const r=(c=(a=t.entities[e])==null?void 0:a.attrs)==null?void 0:c[n];if(n==="id")return null;if(!r)throw new Error(`${e}.${n} does not exist in your schema`);const{unique:s,indexed:i}=r==null?void 0:r.config,o=ki(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function Fe(t,e,n,r){const s=t?Ei(t,e,n):null,i=P(),a=[P(),e,n];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function Ii(t,e,n){return Object.values(t.links).find(i=>i.forward.on===e&&i.forward.label===n||i.reverse.on===e&&i.reverse.label===n)}function Ci(t,e,n){const r=Ii(t,e,n);if(!r)throw new Error(`Couldn't find the link ${e}.${n} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[P(),s.on,s.label],"reverse-identity":[P(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Cn(t,e,n,r){const s=t?Ci(t,e,n):null,i=P(),o=[P(),e,n],a=[P(),n,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const Pi=new Set(["create","update","merge","link","unlink"]),Mi=new Set(["link","unlink"]),ji=new Set(["create","update","merge"]),$i=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),kt={"unique?":!0,"index?":!0},Di={...kt,cardinality:"one"};function Ri(t){const e=[],[n,r,s,i]=t;if(!$i.has(n))return e;const o=Ot(s);if(o&&e.push({etype:r,lookupPair:o}),n==="link")for(const[a,c]of Object.entries(i)){const u=Array.isArray(c)?c:[c];for(const l of u){const f=Ot(l);f&&e.push({etype:r,lookupPair:f,linkLabel:a})}}return e}function xi({attrsStore:t,schema:e},n){var h,p;const r=new Set,s=[],i=[];function o(y,b){return C(t,y,b)||s.find(g=>g["forward-identity"][1]===y&&g["forward-identity"][2]===b)}function a(y,b){return ie(t,y,b)||s.find(g=>{var w,_;return((w=g["reverse-identity"])==null?void 0:w[1])===y&&((_=g["reverse-identity"])==null?void 0:_[2])===b})}function c(y){s.push(y),i.push(["add-attr",y]),r.add(y.id)}function u(y){y&&"isUnsynced"in y&&y.isUnsynced&&!r.has(y.id)&&(s.push(y),i.push(["add-attr",y]),r.add(y.id))}function l(y,b){return b.indexOf(".")!==-1&&!o(y,b)}function f(y,b){const g=o(y,b),w=a(y,b);u(g),u(w),!g&&!w&&c(Cn(e,y,b,Di))}for(const y of n)for(const{etype:b,lookupPair:g,linkLabel:w}of Ri(y)){const _=g[0];if(w){f(b,w);const T=o(b,w),O=a(b,w);u(T),u(O);const m=((h=T==null?void 0:T["reverse-identity"])==null?void 0:h[1])||((p=O==null?void 0:O["forward-identity"])==null?void 0:p[1])||w;if(l(m,_))f(m,vt(_));else{const I=o(m,_);I||c(Fe(e,m,_,kt)),u(I)}}else if(l(b,_))f(b,vt(_));else{const T=o(b,_);T||c(Fe(e,b,_,kt)),u(T)}}for(const y of n){const[b,g,w,_]=y;if(Pi.has(b)){const T=o(g,"id");u(T),T||c(Fe(e,g,"id",{"unique?":!0}));for(const O of Object.keys(_)){const m=o(g,O);if(u(m),ji.has(b)&&(m||c(Fe(e,g,O,O==="id"?{"unique?":!0}:null))),Mi.has(b)){const I=a(g,O);!m&&!I&&c(Cn(e,g,O)),u(I)}}}}if(s.length){const y={...t.attrs};for(const b of s)y[b.id]=b;return[new se(y,t.linkIndex),i]}return[t,i]}function Ui(t,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>fi(c)),[s,i]=xi(t,r),o={...t,attrsStore:s},a=r.flatMap(c=>Oi(o,c));return[...i,...a]}function Pn(t,e){typeof requestIdleCallback>"u"?t():requestIdleCallback(t,{timeout:e})}const Ae="__meta";class Mn{constructor(e,n){}}class Et{constructor(e){d(this,"currentValue");d(this,"_subs",[]);d(this,"_persister");d(this,"_merge");d(this,"serialize");d(this,"parse");d(this,"_saveThrottleMs");d(this,"_idleCallbackMaxWaitMs");d(this,"_nextSave",null);d(this,"_nextGc",null);d(this,"_pendingSaveKeys",new Set);d(this,"_loadedKeys",new Set);d(this,"_loadingKeys");d(this,"_objectSize");d(this,"_log");d(this,"onKeyLoaded");d(this,"_version",0);d(this,"_meta",{isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0});d(this,"_gcOpts");this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){var e;this._meta.loadingPromise&&await this._meta.loadingPromise;try{const n=this._persister.getItem(Ae);this._meta.loadingPromise=n;const r=await n;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const s=((e=this._meta.value)==null?void 0:e.objects)??{},i=r??{},o=i.objects??{};this._meta.value={...i,objects:{...s,...o}}}catch(n){this._meta.error=n,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 n=await this.waitForMetaToLoad();if(!n)return;const r=Object.entries(n.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 n=await this._persister.getItem(e);return n&&this.parse(e,n)}catch(n){return console.error(`Unable to read from storage for key=${e}`,n),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 n=this._getFromStorage(e);this._loadingKeys[e]=n;const r=await n;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 n=[],r=e==null?void 0:e.skipGc;if(this._meta.isLoading){const f=new Promise((h,p)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(h).catch(p),10+((e==null?void 0:e.attempts)??0)*1e3)});return n.push(f),Promise.all(n).then(h=>h.reduce((p,y)=>p+y,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 h=this._persister.removeItem(f);n.push(h.then(()=>1)),this._loadedKeys.delete(f),this._pendingSaveKeys.delete(f)}const a=[],c=[[Ae,s]],u=s.objects??{};s.objects=u;for(const f of o)if(this._loadedKeys.has(f)){const h=this.serialize(f,this.currentValue[f]);c.push([f,h]);const p=this._objectSize(h),y=u[f]??{createdAt:Date.now(),updatedAt:Date.now(),size:p};y.updatedAt=Date.now(),y.size=p,u[f]=y,this._pendingSaveKeys.delete(f)}else a.push(f);const l=this._persister.multiSet(c);n.push(l.then(()=>1));for(const f of a){const h=this._loadKey(f).then(()=>this._enqueuePersist(e));n.push(h)}return r||this.gc(),Promise.all(n).then(f=>f.reduce((h,p)=>h+p,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Ae);const n=new Set(Object.keys(this.currentValue));for(const h of Object.keys(this._loadingKeys))n.add(h);for(const h of this._loadedKeys)n.add(h);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:n,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const h of e)n.has(h)||h in r.objects||(this._log.info("Lost track of key in meta",h),s.push(this._persister.removeItem(h)),i.removed.push(h),i.removedMissingCount++);const o=Date.now();for(const[h,p]of Object.entries(r.objects))!n.has(h)&&p.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([h,p],[y,b])=>p.updatedAt-b.updatedAt);const c=a.filter(([h])=>!n.has(h));if(a.length>this._gcOpts.maxEntries)for(const[h]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([h,p],[y,b])=>p.updatedAt-b.updatedAt);const l=u.filter(([h])=>!n.has(h));let f=u.reduce((h,[p,y])=>h+y.size,0);for(;f>0&&f>this._gcOpts.maxSize&&l.length;){const[[h,p]]=l.splice(0,1);f-=p.size,s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedSizeCount++}for(const h of Object.keys(r.objects))!e.has(h)&&!n.has(h)&&delete r.objects[h];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(()=>{Pn(()=>{this._nextGc=null,this._gc()},30*1e3)},1e3*60+Math.random()*500))}_enqueuePersist(e){return new Promise((n,r)=>{if(this._nextSave){n(0);return}this._nextSave=setTimeout(()=>{Pn(()=>{this._nextSave=null,this._writeToStorage(e).then(n).catch(r)},this._idleCallbackMaxWaitMs)},this._saveThrottleMs)})}version(){return this._version}updateInPlace(e){this._version++;const[n,r]=Me(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=n,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return n}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(n=>n!==e)}}}const Li=6,Fi=["kv","querySubs","syncSubs"];function Ni(t){return function(n){console.error("Error in IndexedDB event",{source:t,event:n})}}async function Ki(t){return new Promise(e=>{const n=indexedDB.open(t);n.onerror=r=>{e(null)},n.onsuccess=r=>{const i=r.target.result;e(i)},n.onupgradeneeded=r=>{var i;(i=r.target.transaction)==null||i.abort(),e(null)}})}async function qi(t,e,n){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{var l,f,h;const a={};for(const[p,y]of Object.entries(r)){const b=typeof y=="string"?JSON.parse(y):y;if(b.lastAccessed){const w={createdAt:b.lastAccessed,updatedAt:b.lastAccessed,size:((h=(f=(l=b.result)==null?void 0:l.store)==null?void 0:f.triples)==null?void 0:h.length)??0};a[p]=w}const g=n.put(b,p);s.add(g)}const c={objects:a},u=n.put(c,Ae);s.add(u);for(const p of s)p.onsuccess=()=>{s.delete(p),s.size===0&&i()},p.onerror=y=>{o(y)}})}async function jn(t,e,n){const r=n.put(e,t);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function zi(t,e){const n=await Ki(`instant_${t}_5`);if(!n)return;const r=await new Promise((l,f)=>{const y=n.transaction(["kv"],"readonly").objectStore("kv").openCursor();y.onerror=g=>{f(g)};const b=[];y.onsuccess=()=>{const g=y.result;if(g){const w=g.key,_=g.value;b.push([w,_]),g.continue()}else l(b)},y.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)switch(l){case"querySubs":{const h=qi(l,f,o);a.push(h);break}default:{const h=jn(l,f,i);a.push(h);const p={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=p;break}}const u=jn(Ae,c,i);a.push(u),await Promise.all(a),await new Promise((l,f)=>{s.oncomplete=h=>l(h),s.onerror=h=>f(h),s.onabort=h=>f(h)})}const $n=new Map;class Dn extends Mn{constructor(n,r){super(n,r);d(this,"dbName");d(this,"_storeName");d(this,"_appId");d(this,"_prefix");d(this,"_dbPromise");this.dbName=`instant_${n}_${Li}`,this._storeName=r,this._appId=n,this._dbPromise=this._init()}_init(){return new Promise((n,r)=>{let s=!1;const i=indexedDB.open(this.dbName,1);i.onerror=o=>{r(o)},i.onsuccess=o=>{const c=o.target.result;if(s){const u=zi(this._appId,c).catch(l=>{Ni("Error upgrading store from version 5 to 6.")(l)});$n.set(this.dbName,u),u.then(()=>n(c)).catch(()=>n(c))}else{const u=$n.get(this.dbName);u?u.then(()=>n(c)).catch(()=>n(c)):n(c)}},i.onupgradeneeded=o=>{s=!0,this._upgradeStore(o)}})}_upgradeStore(n){const s=n.target.result;for(const i of Fi)s.objectStoreNames.contains(i)||s.createObjectStore(i)}async getItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readonly").objectStore(this._storeName).get(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{c.result?s(c.result):s(null)}})}async setItem(n,r){const s=await this._dbPromise;return new Promise((i,o)=>{const u=s.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(r,n);u.onerror=l=>{o(l)},u.onsuccess=l=>{i()}})}async multiSet(n){const r=await this._dbPromise;return new Promise((s,i)=>{const o=r.transaction([this._storeName],"readwrite"),a=o.objectStore(this._storeName),c=new Set;for(const[u,l]of n){const f=a.put(l,u);c.add(f)}for(const u of c)u.onerror=l=>{o.abort(),i(l)},u.onsuccess=l=>{c.delete(u),c.size===0&&s()}})}async removeItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async getAllKeys(){const n=await this._dbPromise;return new Promise((r,s)=>{const a=n.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();a.onerror=c=>{s(c)},a.onsuccess=c=>{r(a.result.filter(u=>typeof u=="string"))}})}}class Rn{static async getIsOnline(){return navigator.onLine}static listen(e){const n=()=>{e(!0)},r=()=>{e(!1)};return addEventListener("online",n),addEventListener("offline",r),()=>{removeEventListener("online",n),removeEventListener("offline",r)}}}class fe extends Error{constructor(n,r){super(n);d(this,"hint");this.hint=r;const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,fe),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class ve extends fe{constructor(n){var i;const r=((i=n.body)==null?void 0:i.message)||`API Error (${n.status})`;super(r,n.body.hint);d(this,"body");d(this,"status");const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,ve),this.name="InstantAPIError",this.status=n.status,this.body=n.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function G(t,e){const n=await fetch(t,e),r=await n.json();return n.status===200?Promise.resolve(r):Promise.reject(new ve({status:n.status,body:r}))}function Vi({apiURI:t,appId:e,email:n}){return G(`${t}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n})})}async function Wi({apiURI:t,appId:e,email:n,code:r,refreshToken:s}){return await G(`${t}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n,code:r,...s?{"refresh-token":s}:{}})})}async function Qi({apiURI:t,appId:e,refreshToken:n}){return await G(`${t}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":n})})}async function Gi({apiURI:t,appId:e}){return await G(`${t}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function xn({apiURI:t,appId:e,code:n,codeVerifier:r,refreshToken:s}){return await G(`${t}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:n,code_verifier:r,refresh_token:s})})}async function Bi({apiURI:t,appId:e,nonce:n,idToken:r,clientName:s,refreshToken:i}){return await G(`${t}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:n,id_token:r,client_name:s,refresh_token:i})})}async function Hi({apiURI:t,appId:e,refreshToken:n}){return await G(`${t}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:n})})}async function Ji({apiURI:t,appId:e,path:n,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:n,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await G(`${t}/storage/upload`,{method:"PUT",headers:a,body:r})}async function Yi({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await G(`${t}/storage/files?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function Zi({apiURI:t,appId:e,fileName:n,refreshToken:r,metadata:s={}}){const{data:i}=await G(`${t}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:n})});return i}async function Xi(t,e){return(await fetch(t,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function eo({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await G(`${t}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let It=!1,Un=!1,Ln=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(It=!!window.localStorage.getItem("devBackend"),Un=!!window.localStorage.getItem("__instantLogging"),Ln=!!window.localStorage.getItem("__devtoolLocalDash"));function Fn(t,e){if(!e)return t;const n={};return e.forEach(r=>{n[r]=t[r]}),n}function to(t,e,n){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=Fn(t.user??{},e==null?void 0:e.keys);r.user={...i,peerId:n}}for(const i of Object.keys(t.peers??{})){const o=(e==null?void 0:e.peers)===void 0,a=Array.isArray(e==null?void 0:e.peers)&&(e==null?void 0:e.peers.includes(i));if(o||a){const c=Fn(t.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function no(t,e){if(t.isLoading!==e.isLoading||t.error!==e.error||(t.user||e.user)&&(!t.user||!e.user||!Yt(t.user,e.user))||!Jt(t.peers,e.peers))return!0;for(const r of Object.keys(t.peers))if(!Yt(t.peers[r],e.peers[r]))return!0;return!1}class Nn{constructor(){d(this,"promise");d(this,"_resolve");d(this,"_reject");this.promise=new Promise((e,n)=>{this._resolve=e,this._reject=n})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function Kn(t,e=[]){t.forEach(n=>{const{data:r}=n,{"datalog-result":s}=r,{"join-rows":i}=s;for(const o of i)for(const a of o)e.push(a);Kn(n["child-nodes"],e)})}function qn(t){const e=[];return Kn(t,e),e}function zn(t){return Object.values(t.links).reduce((e,n)=>{var r,s;return e[r=n.forward.on]??(e[r]={}),e[n.forward.on][n.forward.label]={isForward:!0,isSingular:n.forward.has==="one",link:n},e[s=n.reverse.on]??(e[s]={}),e[n.reverse.on][n.reverse.label]={isForward:!1,isSingular:n.reverse.has==="one",link:n},e},{})}const Ct="v0.22.133";function ro(t,e){return{info:t?(...n)=>console.info(...n,e()):()=>{},debug:t?(...n)=>console.debug(...n,e()):()=>{},error:t?(...n)=>console.error(...n,e()):()=>{}}}class x{constructor(e,n,r,s={indexed:!1,unique:!1}){d(this,"valueType");d(this,"required");d(this,"isIndexed");d(this,"config");d(this,"metadata",{});this.valueType=e,this.required=n,this.isIndexed=r,this.config=s}clientRequired(){return new x(this.valueType,!1,this.isIndexed,this.config)}optional(){return new x(this.valueType,!1,this.isIndexed,this.config)}unique(){return new x(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new x(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class Ne{constructor(e,n){d(this,"attrs");d(this,"links");this.attrs=e,this.links=n}asType(){return new Ne(this.attrs,this.links)}}class Ke{constructor(e,n,r){d(this,"entities");d(this,"links");d(this,"rooms");this.entities=e,this.links=n,this.rooms=r}withRoomSchema(){return new Ke(this.entities,this.links,{})}}class E extends Error{constructor(e,n){const r=n?`At path '${n}': ${e}`:e;super(r),this.name="QueryValidationError"}}const Vn=["where","order","limit","last","first","offset","after","before","fields","aggregate"],so=t=>t.valueType||"unknown",Wn=(t,e,n=!1)=>{if(n||t==null)return!0;switch(e){case"string":return typeof t=="string";case"number":return typeof t=="number"&&!isNaN(t);case"boolean":return typeof t=="boolean";case"date":return t instanceof Date||typeof t=="string"||typeof t=="number";default:return!0}},io=(t,e,n,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,f)=>{if(!Wn(f,l,a))throw new E(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof f}`,o)};switch(t){case"in":case"$in":if(!Array.isArray(e))throw new E(`Operator '${t}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(t,n,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(t,n,e);break;case"$like":case"$ilike":if(c(t,"string",e),t==="$ilike"&&!i.isIndexed)throw new E(`Operator '${t}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(t,"boolean",e);break;default:throw new E(`Unknown operator '${t}' for attribute '${r}' in entity '${s}'`,o)}},de=(t,e,n,r,s)=>{const i=so(n),o=n.valueType==="json";if(typeof t=="object"&&t!==null&&!Array.isArray(t)){if(o)return;const c=t;for(const[u,l]of Object.entries(c))io(u,l,i,e,r,n,`${s}.${u}`)}else if(!Wn(t,i,o))throw new E(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof t}`,s)},oo=(t,e,n,r,s)=>{const i=t.split(".");if(i.length<2)throw new E(`Invalid dot notation path '${t}'. Must contain at least one dot.`,s);let o=n;for(let l=0;l<i.length-1;l++){const f=i[l],h=r.entities[o];if(!h)throw new E(`Entity '${o}' does not exist in schema while traversing dot notation path '${t}'.`,s);const p=h.links[f];if(!p){const y=Object.keys(h.links);throw new E(`Link '${f}' does not exist on entity '${o}' in dot notation path '${t}'. Available links: ${y.length>0?y.join(", "):"none"}`,s)}o=p.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new E(`Target entity '${o}' does not exist in schema for dot notation path '${t}'.`,s);if(a==="id"){if(typeof e=="string"&&!ue(e))throw new E(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);de(e,t,new x("string",!1,!0),n,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!ue(e))throw new E(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);de(e,t,new x("string",!1,!0),n,s);return}if(!u){const l=Object.keys(c.attrs);throw new E(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${t}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}de(e,t,u,n,s)},Qn=(t,e,n,r)=>{for(const[s,i]of Object.entries(t)){if(s==="or"||s==="and"){if(Array.isArray(i))for(const u of i)typeof u=="object"&&u!==null&&Qn(u,e,n,`${r}.${s}[${u}]`);continue}if(s==="id"){de(i,"id",new x("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){oo(s,i,e,n,`${r}.${s}`);continue}const o=n.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 E(`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)de(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!ue(i))throw new E(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new x("string",!1,!0);de(i,s,u,e,`${r}.${s}`)}}},ao=(t,e,n,r,s=0)=>{for(const o of Object.keys(t))if(!Vn.includes(o))throw new E(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${Vn.join(", ")}. Found: ${o}`,r);const i=["offset","before","after","first","last"];for(const o of i)if(t[o]!==void 0&&s>0)throw new E(`'${o}' can only be used on top-level namespaces. It cannot be used in nested queries.`,r);if(t.where&&n){if(typeof t.where!="object"||t.where===null)throw new E(`'where' clause must be an object in entity '${e}', but received: ${typeof t.where}`,r?`${r}.where`:void 0);Qn(t.where,e,n,r?`${r}.where`:"where")}},Gn=(t,e,n,r,s=0)=>{var i;if(!t||typeof t!="object")throw new E(`Query part for entity '${e}' must be an object, but received: ${typeof t}`,r);for(const o of Object.keys(t))if(o!=="$"){if(n&&!(o in n.entities[e].links)){const c=Object.keys(n.entities[e].links);throw new E(`Link '${o}' does not exist on entity '${e}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${r}.${o}`)}const a=t[o];if(typeof a=="object"&&a!==null){const c=(i=n==null?void 0:n.entities[e].links[o])==null?void 0:i.entityName;c&&Gn(a,c,n,`${r}.${o}`,s+1)}}else{const a=t[o];if(typeof a!="object"||a===null)throw new E(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof a}`,`${r}.$`);ao(a,e,n,`${r}.$`,s)}},Bn=(t,e)=>{if(typeof t!="object"||t===null)throw new E(`Query must be an object, but received: ${typeof t}${t===null?" (null)":""}`);if(Array.isArray(t))throw new E(`Query must be an object, but received: ${typeof t}`);const n=t;for(const r of Object.keys(n)){if(Array.isArray(t[r]))throw new E(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new E(`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 E(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}Gn(n[r],r,e,r,0)}}},Hn=t=>typeof t!="string"?!1:Le(t)?!0:ue(t);class V extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Jn=t=>t.length>0?t.join(", "):"none",co=(t,e)=>new V(`Entity '${t}' does not exist in schema. Available entities: ${Jn(e)}`),Pt={string:t=>typeof t=="string",number:t=>typeof t=="number"&&!isNaN(t),boolean:t=>typeof t=="boolean",date:t=>t instanceof Date||typeof t=="string"||typeof t=="number",json:()=>!0},uo=(t,e)=>{var n;return t==null?!0:((n=Pt[e.valueType])==null?void 0:n.call(Pt,t))??!1},Yn=(t,e)=>{const n=e.entities[t];if(!n)throw co(t,Object.keys(e.entities));return n},Mt=(t,e,n)=>{const r=Yn(t,n);if(typeof e!="object"||e===null)throw new V(`Arguments for data operation on entity '${t}' 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&&!uo(i,o))throw new V(`Invalid value for attribute '${s}' in entity '${t}'. Expected ${o.valueType}, but received: ${typeof i}`)}},Zn=(t,e,n)=>{const r=Yn(t,n);if(typeof e!="object"||e===null)throw new V(`Arguments for link operation on entity '${t}' 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 V(`Link '${s}' does not exist on entity '${t}'. Available links: ${Jn(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!Hn(a))throw new V(`Invalid entity ID in link '${s}' for entity '${t}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!Hn(i))throw new V(`Invalid UUID in link '${s}' for entity '${t}'. Expected a UUID, but received: ${i}`)}}},lo={create:Mt,update:Mt,merge:Mt,link:Zn,unlink:Zn,delete:()=>{}},fo=(t,e)=>{if(!e)return;const[n,r,s,i]=t;if(!Array.isArray(s)&&!ue(s))throw new V(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new V(`Entity name must be a string, but received: ${typeof r}`);const o=lo[n];o&&i!==void 0&&o(r,i,e)},ho=(t,e)=>{const n=Array.isArray(t)?t:[t];for(const r of n){if(!r||typeof r!="object")throw new V(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new V(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new V(`Transaction operation must be an array, but received: ${typeof s}`);fo(s,e)}}};let Xn=0;class er{constructor(e){d(this,"type","ws");d(this,"conn");d(this,"id");d(this,"onopen");d(this,"onmessage");d(this,"onclose");d(this,"onerror");this.id=`${this.type}_${Xn++}`,this.conn=new WebSocket(e),this.conn.onopen=n=>{this.onopen&&this.onopen({target:this})},this.conn.onmessage=n=>{this.onmessage&&this.onmessage({target:this,message:JSON.parse(n.data.toString())})},this.conn.onclose=n=>{this.onclose&&this.onclose({target:this})},this.conn.onerror=n=>{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 po{constructor(e,n){d(this,"type","sse");d(this,"initParams",null);d(this,"sendQueue",[]);d(this,"sendPromise");d(this,"closeFired",!1);d(this,"sseInitTimeout");d(this,"ES");d(this,"conn");d(this,"url");d(this,"id");d(this,"onopen");d(this,"onmessage");d(this,"onclose");d(this,"onerror");this.id=`${this.type}_${Xn++}`,this.url=n,this.ES=e,this.conn=new e(n),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=r=>{const s=JSON.parse(r.data);if(Array.isArray(s))for(const i of s)this.handleMessage(i);else this.handleMessage(s)},this.conn.onerror=r=>{this.handleError()}}handleMessage(e){if(e.op==="sse-init"){this.initParams={machineId:e["machine-id"],sessionId:e["session-id"],sseToken:e["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:e})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(e){var n,r,s;try{(await fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(n=this.initParams)==null?void 0:n.machineId,session_id:(r=this.initParams)==null?void 0:r.sessionId,sse_token:(s=this.initParams)==null?void 0:s.sseToken,messages:e})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const e=this.sendQueue;this.sendQueue=[];const n=this.postMessages(e);this.sendPromise=n,n.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 yo(t,e){const n=t.values;if(n){const r=on(n.attrsStore,null);if(r){for(const s of n.entities||[])s.store.useDateObjects=e,s.store=sn(r,s.store);n.attrsStore=r}}return t}function bo(t,e){var n;if(e.values){const r=[];for(const s of(n=e.values)==null?void 0:n.entities){const i=rn(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function go(t,e,n){var i,o;const r=(i=e==null?void 0:e.state)==null?void 0:i.txId,s=(o=n==null?void 0:n.state)==null?void 0:o.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?n:e||n}function jt(t,e,n){return On({store:e,attrsStore:n,pageInfo:null,aggregate:null},t.query).data[t.table][0]}function tr(t,e,n,r){var o;const s=(o=C(n,t.table,"id"))==null?void 0:o.id;if(!s)return-1;const i=ce(e.eav,[r,s,r]);return i?i[3]:-1}function nr(t,e,n){for(const{action:r,triple:s}of n)switch(r){case"added":un(t,e,s);break;case"removed":an(t,e,s);break}}function _o(t,e,n){var s,i;const r={};for(const{action:o,triple:a}of n){const[c,u,l]=a,f=(i=(s=e.getAttr(u))==null?void 0:s["forward-identity"])==null?void 0:i[2];if(!f)continue;const h=r[c]??{};r[c]=h;const p=h[f]??{};switch(o){case"added":p.newValue=l;break;case"removed":p.oldValue===void 0&&(p.oldValue=l);break}h[f]=p}for(const[o,a]of Object.entries(r))for(const[c,{oldValue:u,newValue:l}]of Object.entries(a))u===l&&delete a[c];return r}function qe(t,e){return{[t.table]:e.map(n=>n.entity)}}function wo(t,e){var r;if(t.orderFieldType)return t.orderFieldType;const n=t.orderField==="serverCreatedAt"?"number":(r=C(e(),t.table,t.orderField))==null?void 0:r["checked-data-type"];return t.orderFieldType=n,n}function To(t,e,n){const r=e;if(t.orderField==="serverCreatedAt"){n.sort(t.orderDirection==="asc"?function(o,a){return Se(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Se(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=t.orderField;n.sort(t.orderDirection==="asc"?function(o,a){return Se(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Se(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}A.SyncTableCallbackEventType=void 0,function(t){t.InitialSyncBatch="InitialSyncBatch",t.InitialSyncComplete="InitialSyncComplete",t.LoadFromStorage="LoadFromStorage",t.SyncTransaction="SyncTransaction",t.Error="Error"}(A.SyncTableCallbackEventType||(A.SyncTableCallbackEventType={}));class mo{constructor(e,n,r,s,i,o){d(this,"trySend");d(this,"subs");d(this,"callbacks",{});d(this,"config");d(this,"idToHash",{});d(this,"log");d(this,"createStore");d(this,"getAttrs");this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new Et({persister:n,merge:go,serialize:bo,parse:(a,c)=>yo(c,this.config.useDateObjects),objectSize:a=>{var c;return((c=a.values)==null?void 0:c.entities.length)||0},logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,n){const r=v(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(n),this.initSubscription(e,r,n),s=>{this.unsubscribe(r,n,s==null?void 0:s.keepSubscription)}}unsubscribe(e,n,r){const s=(this.callbacks[e]||[]).filter(i=>i!==n);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i!=null&&i.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend(P(),{op:"start-sync",q:e})}sendResync(e,n,r){this.idToHash[n.subscriptionId]=e.hash,this.trySend(n.subscriptionId,{op:"resync-table","subscription-id":n.subscriptionId,"tx-id":r,token:n.token})}sendRemove(e,n){this.trySend(P(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":n})}async initSubscription(e,n,r){var u,l,f,h;await this.subs.waitForKeyToLoad(n);const s=this.subs.currentValue[n];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),(u=s.values)!=null&&u.entities&&r&&r({type:A.SyncTableCallbackEventType.LoadFromStorage,data:qe(s,(l=s.values)==null?void 0:l.entities)});return}const i=Object.keys(e)[0],o=((h=(f=e[i])==null?void 0:f.$)==null?void 0:h.order)||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(p=>{p[n]={query:e,hash:n,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 n=this.subs.currentValue[e];n?await this.initSubscription(n.query,n.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const n=e["subscription-id"],r=e.q,s=v(r);this.idToHash[n]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",n,"query",r),i;o.state={subscriptionId:n,token:e.token}})}notifyCbs(e,n){for(const r of this.callbacks[e]||[])r(n)}onSyncLoadBatch(e){const n=e["subscription-id"],r=e["join-rows"],s=this.idToHash[n];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=jt(o,l,a.attrsStore);c.push({store:l,entity:f,serverCreatedAt:tr(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:A.SyncTableCallbackEventType.InitialSyncBatch,data:qe(o,o.values.entities),batch:i})}onSyncInitFinish(e){var i;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(o=>{const a=o[r];if(!a){this.log.error("Missing sub for hash",r,e);return}const c=a.state;if(!c)return this.log.error("Sub never set init, missing result",a,e),o;c.txId=e["tx-id"],a.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:A.SyncTableCallbackEventType.InitialSyncComplete,data:qe(s,((i=s.values)==null?void 0:i.entities)||[])})}onSyncUpdateTriples(e){var o;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const a of e.txes){if(i.txId&&i.txId>=a["tx-id"])continue;i.txId=a["tx-id"];const c=[],u={};for(const g of a.changes){const w=u[g.triple[0]]??[];u[g.triple[0]]=w,w.push(g)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},f=l.entities;s.values=l;const h=[];e:for(const[g,w]of Object.entries(u))for(let _=0;_<f.length;_++){const T=f[_];if(ts(T.store,g)){nr(T.store,l.attrsStore,w);const O=jt(s,T.store,l.attrsStore),m=_o(T.store,l.attrsStore,w)[g];O?(h.push({oldEntity:T.entity,newEntity:O,changedFields:m||{}}),T.entity=O):c.push(_),delete u[g];continue e}}const p=[];for(const[g,w]of Object.entries(u)){const _=this.createStore([]);nr(_,l.attrsStore,w);const T=jt(s,_,l.attrsStore);if(!T){this.log.error("No entity found after applying change",{sub:s,changes:w,store:_});continue}f.push({store:_,entity:T,serverCreatedAt:tr(s,_,l.attrsStore,T.id)}),p.push(T)}const y=[];for(const g of c.sort().reverse())y.push(f[g].entity),f.splice(g,1);const b=wo(s,this.getAttrs);To(s,b,f),this.notifyCbs(r,{type:A.SyncTableCallbackEventType.SyncTransaction,data:qe(s,(o=s.values)==null?void 0:o.entities),added:p,removed:y,updated:h})}this.subs.updateInPlace(a=>{a[r]=s,a[r].updatedAt=Date.now()})}clearSubscriptionData(e,n){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,n),n?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const n=v(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(n,{type:A.SyncTableCallbackEventType.Error,data:{[s]:[]},error:r})}onResyncError(e){const n=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(n,!1);r&&this.initSubscription(r.query,r.hash)}}const Y={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},So=3e4,Ao=3e4,vo=200,Oo=1e3*60,ko={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},$t="_instant_oauth_redirect",Oe="currentUser";function Eo({transportType:t,appId:e,apiURI:n,wsURI:r,EventSourceImpl:s}){if(!s)return new er(`${r}?app_id=${e}`);switch(t){case"ws":return new er(`${r}?app_id=${e}`);case"sse":return new po(s,`${n}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+t)}}function Io(){return typeof window<"u"||typeof chrome<"u"}const rr={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function Co(t,e){var r;const n=typeof t=="string"?JSON.parse(t):t;if((r=n==null?void 0:n.result)!=null&&r.store){const s=on(n.result.attrsStore,n.result.store);if(s){const i=n.result.store;n.result.store=sn(s,{...i,useDateObjects:e}),n.result.attrsStore=s}}return n}function Po(t,e){const{result:n,...r}=e,s=r;if(n){const i={...n,store:rn(n.store),attrsStore:n.attrsStore.toJSON()};s.result=i}return s}function Mo(t,e){switch(t){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function jo(t,e){switch(t){case"pendingMutations":return[...e.entries()];default:return e}}function $o(t,e,n){const r=e==null?void 0:e.result,s=n==null?void 0:n.result;return r&&!s&&n&&(n.result=r),n||e}function Dt(t){return[...t].sort((e,n)=>{const[r,s]=e,[i,o]=n,a=s.order||0,c=o.order||0;return a==c?r<i?-1:r>i?1:0:a-c})}class Do{constructor(e,n=Dn,r=Rn,s,i){d(this,"attrs");d(this,"_isOnline",!0);d(this,"_isShutdown",!1);d(this,"status",Y.CONNECTING);d(this,"querySubs");d(this,"kv");d(this,"_syncTable");d(this,"queryCbs",{});d(this,"queryOnceDfds",{});d(this,"authCbs",[]);d(this,"attrsCbs",[]);d(this,"mutationErrorCbs",[]);d(this,"connectionStatusCbs",[]);d(this,"config");d(this,"mutationDeferredStore",new Map);d(this,"_reconnectTimeoutId",null);d(this,"_reconnectTimeoutMs",0);d(this,"_transport");d(this,"_transportType","ws");d(this,"_EventSource");d(this,"_wsOk",null);d(this,"_localIdPromises",{});d(this,"_errorMessage",null);d(this,"_oauthCallbackResponse",null);d(this,"_linkIndex",null);d(this,"_broadcastChannel");d(this,"_rooms",{});d(this,"_roomsPendingLeave",{});d(this,"_presence",{});d(this,"_broadcastQueue",[]);d(this,"_broadcastSubs",{});d(this,"_currentUserCached",{isLoading:!0,error:void 0,user:void 0});d(this,"_beforeUnloadCbs",[]);d(this,"_dataForQueryCache",{});d(this,"_log");d(this,"_pendingTxCleanupTimeout");d(this,"_pendingMutationCleanupThreshold");d(this,"_inFlightMutationEventIds",new Set);d(this,"_onMergeKv",(e,n,r)=>{switch(e){case"pendingMutations":{const s=(n==null?void 0:n.entries())??[],i=(r==null?void 0:r.entries())??[],o=new Map([...s,...i]);return(n?this._rewriteMutationsSorted(this.attrs,n):[]).forEach(([c,u])=>{var l;!((l=r==null?void 0:r.pendingMutations)!=null&&l.has(c))&&!u["tx-id"]&&this._sendMutation(c,u)}),o}default:return r||n}});d(this,"getPreviousResult",e=>{var r;const n=v(e);return(r=this.dataForQuery(n))==null?void 0:r.data});d(this,"notifyOne",e=>{var i;const n=this.queryCbs[e]??[],r=(i=this._dataForQueryCache[e])==null?void 0:i.data,s=this.dataForQuery(e);s!=null&&s.data&&(this._dataForQueryCache[e]=s,!je(s.data,r)&&n.forEach(o=>o.cb(s.data)))});d(this,"notifyOneQueryOnce",e=>{var s;const n=this.queryOnceDfds[e]??[],r=(s=this.dataForQuery(e))==null?void 0:s.data;n.forEach(i=>{this._completeQueryOnce(i.q,e,i.dfd),i.dfd.resolve(r)})});d(this,"notifyQueryError",(e,n)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:n}))});d(this,"pushTx",e=>{this.config.disableValidation||ho(e,this.config.schema);try{const n=Ui({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>{var s;return(s=r==null?void 0:r.result)==null?void 0:s.store}),useDateObjects:this.config.useDateObjects},e);return this.pushOps(n)}catch(n){return this.pushOps([],n)}});d(this,"pushOps",(e,n)=>{const r=P(),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:n,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new Nn;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise});d(this,"_transportOnOpen",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][open]",n.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(Y.OPENED),this.getCurrentUser().then(r=>{var s;this._trySend(P(),{op:"init","app-id":this.config.appId,"refresh-token":(s=r.user)==null?void 0:s.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",n.id,r)})});d(this,"_transportOnMessage",e=>{const n=e.target,r=e.message;if(this._transport!==n){this._log.info("[socket][message]",n.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&n.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(n.id,s);else this._handleReceive(n.id,e.message)});d(this,"_transportOnError",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][error]",n.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",n.id,e)});d(this,"_scheduleReconnect",()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)});d(this,"_transportOnClose",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][close]",n.id,"skip; this is no longer the current transport");return}this._setStatus(Y.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",n.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",n.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()});if(this._EventSource=i,this.config={...ko,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??Ao,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??vo,this._log=ro(e.verbose||It||Un,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":Ct},this.config.schema&&(this._linkIndex=zn(this.config.schema)),!!Io()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!ue(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{var a;try{if(((a=o.data)==null?void 0:a.type)==="auth"){const c=await this.getCurrentUser();await this.updateUser(c.user).catch(u=>{this._log.error("[error] update user",u)})}}catch(c){this._log.error("[error] handle broadcast channel",c)}})),this._initStorage(n),this._syncTable=new mo(this._trySendAuthed.bind(this),new n(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>we(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._oauthCallbackResponse=this._oauthLoginInit(),this.getCurrentUser().then(o=>{this.syncUserToEndpoint(o.user)}),setInterval(async()=>{const o=await this.getCurrentUser();this.syncUserToEndpoint(o.user)},Oo),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",Y.CLOSED),this._setStatus(Y.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?zn(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new Et({persister:new e(this.config.appId,"querySubs"),merge:$o,serialize:Po,parse:(n,r)=>Co(r,this.config.useDateObjects),objectSize:n=>{var r,s,i;return((i=(s=(r=n==null?void 0:n.result)==null?void 0:r.store)==null?void 0:s.triples)==null?void 0:i.length)??0},logger:this._log,preloadEntryCount:10,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}}),this.querySubs.onKeyLoaded=n=>this._onQuerySubLoaded(n),this.kv=new Et({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:jo,parse:Mo,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=n=>{n==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(Oe),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,n,r){const s=this.mutationDeferredStore.get(n);this.mutationDeferredStore.delete(n);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:n,...r}),!!s)if(i)s.resolve({status:e,eventId:n});else if(r!=null&&r.type){const{status:o,...a}=r;s.reject(new ve({body:a,status:o??0}))}else s.reject(new fe((r==null?void 0:r.message)||"Unknown error",r==null?void 0:r.hint))}_setStatus(e,n){this.status=e,this._errorMessage=n,this.notifyConnectionStatusSubs(e)}_flushEnqueuedRoomData(e){var s,i;const n=(i=(s=this._presence[e])==null?void 0:s.result)==null?void 0:i.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],n&&this._trySetPresence(e,n),r)for(const o of r){const{topic:a,roomType:c,data:u}=o;this._tryBroadcast(e,c,a,u)}}_addQueryData(e,n,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=v(e),i=this.ensureAttrs(),o=we(this.attrs,n.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:n.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,n){var s,i,o,a,c,u,l;const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(rr[n.op]||this._log.info("[receive]",e,n.op,n),n.op){case"init-ok":{this._setStatus(Y.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(n.attrs),this._flushPendingMessages(),this._sessionId=n["session-id"];for(const p of Object.keys(this._rooms)){const y=(i=(s=this._presence[p])==null?void 0:s.result)==null?void 0:i.user,b=(o=this._rooms[p])==null?void 0:o.roomType;this._tryJoinRoom(b,p,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(v(n.q));break}case"add-query-ok":{const{q:p,result:y}=n,b=v(p);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[b])break;const g=(c=(a=y==null?void 0:y[0])==null?void 0:a.data)==null?void 0:c["page-info"],w=(l=(u=y==null?void 0:y[0])==null?void 0:u.data)==null?void 0:l.aggregate,_=qn(y),T=this.ensureAttrs(),O=we(T,_,r,this.config.useDateObjects);this.querySubs.updateInPlace(m=>{if(!m[b]){this._log.info("Missing value in querySubs",{hash:b,q:p});return}m[b].result={store:O,attrsStore:T,pageInfo:g,aggregate:w,processedTxId:n["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(b),this.notifyOneQueryOnce(b),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(n);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(n);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(n);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(n);break}case"refresh-ok":{const{computations:p,attrs:y}=n,b=n["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),b);g!==this._pendingMutations()&&this.kv.updateInPlace(T=>{T.pendingMutations=g});const w=Dt(g.entries()),_=p.map(T=>{var wr,Tr,mr,Sr;const O=T["instaql-query"],m=T["instaql-result"],I=v(O),U=qn(m),z=this.ensureAttrs(),he=we(z,U,r,this.config.useDateObjects),{store:Ea,attrsStore:Ia}=this._applyOptimisticUpdates(he,z,w,b),Ca=(Tr=(wr=m==null?void 0:m[0])==null?void 0:wr.data)==null?void 0:Tr["page-info"],Pa=(Sr=(mr=m==null?void 0:m[0])==null?void 0:mr.data)==null?void 0:Sr.aggregate;return{q:O,hash:I,store:Ea,attrsStore:Ia,pageInfo:Ca,aggregate:Pa}});_.forEach(({hash:T,q:O,store:m,attrsStore:I,pageInfo:U,aggregate:z})=>{this.querySubs.updateInPlace(he=>{if(!he[T]){this._log.error("Missing value in querySubs",{hash:T,q:O});return}he[T].result={store:m,attrsStore:I,pageInfo:U,aggregate:z,processedTxId:b}})}),this._cleanupPendingMutationsQueries(),_.forEach(({hash:T})=>{this.notifyOne(T)});break}case"transact-ok":{const{"client-event-id":p,"tx-id":y}=n;this._inFlightMutationEventIds.delete(p);const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(p);if(!g)break;this._updatePendingMutations(_=>{_.set(p,{..._.get(p),"tx-id":y,confirmed:Date.now()})});const w=[];for(const _ of g["tx-steps"])if(_[0]==="add-attr"){const T=_[1];w.push(T)}if(w.length){const _=Object.values(this.ensureAttrs().attrs);this._setAttrs([..._,...w])}this._finishTransaction("synced",p),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const p=n["room-id"];this._trySetRoomConnected(p,!0),this._patchPresencePeers(p,n.edits),this._notifyPresenceSubs(p);break}case"refresh-presence":{const p=n["room-id"];this._trySetRoomConnected(p,!0),this._setPresencePeers(p,n.data),this._notifyPresenceSubs(p);break}case"server-broadcast":{const p=n["room-id"],y=n.topic;this._trySetRoomConnected(p,!0),this._notifyBroadcastSubs(p,y,n);break}case"join-room-ok":{const p=n["room-id"];if(!this._rooms[p]){this._roomsPendingLeave[p]&&(this._tryLeaveRoom(p),delete this._roomsPendingLeave[p]);break}this._trySetRoomConnected(p,!0),this._flushEnqueuedRoomData(p);break}case"leave-room-ok":{const p=n["room-id"];this._trySetRoomConnected(p,!1);break}case"join-room-error":const f=n["room-id"],h=this._rooms[f];h&&(h.error=n.error),this._notifyPresenceSubs(f);break;case"error":this._handleReceiveError(n);break;default:this._log.info("Uknown op",n.op,n);break}}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(n=>{const r=n.pendingMutations??new Map;n.pendingMutations=r,e(r)})}_handleMutationError(e,n,r){const s=this._pendingMutations().get(n);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(n),o)),this._inFlightMutationEventIds.delete(n);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,n,r)}}_handleReceiveError(e){var a,c,u,l,f,h,p;console.log("error",e);const n=e["client-event-id"];this._inFlightMutationEventIds.delete(n);const r=this._pendingMutations().get(n),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",n,e);return}if((a=e["original-event"])!=null&&a.hasOwnProperty("q")&&((c=e["original-event"])==null?void 0:c.op)==="add-query"){const y=(u=e["original-event"])==null?void 0:u.q,b=v(y);this.notifyQueryError(v(y),s),this.notifyQueryOnceError(y,b,n,s);return}if(((l=e["original-event"])==null?void 0:l.op)==="init"){if(e.type==="record-not-found"&&((f=e.hint)==null?void 0:f["record-type"])==="app-user"){this.changeCurrentUser(null);return}this._setStatus(Y.ERRORED,s),this.notifyAll();return}if(((h=e["original-event"])==null?void 0:h.op)==="resync-table"){this._syncTable.onResyncError(e);return}if(((p=e["original-event"])==null?void 0:p.op)==="start-sync"){this._syncTable.onStartSyncError(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
|
+
`,e.hint)}notifyQueryOnceError(e,n,r,s){var o;const i=(o=this.queryOnceDfds[n])==null?void 0:o.find(a=>a.eventId===r);i&&(i.dfd.reject(s),this._completeQueryOnce(e,n,i.dfd))}_setAttrs(e){this.attrs=new se(e.reduce((n,r)=>(n[r.id]=r,n),{}),this._linkIndex),this.notifyAttrsSubs()}_startQuerySub(e,n){const r=P();return this.querySubs.updateInPlace(s=>{s[n]=s[n]||{q:e,result:null,eventId:r},s[n].lastAccessed=Date.now()}),this._trySendAuthed(r,{op:"add-query",q:e}),r}subscribeTable(e,n){return this._syncTable.subscribe(e,n)}subscribeQuery(e,n,r){this.config.disableValidation||Bn(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=v(e),i=this.getPreviousResult(e);return i&&n(i),this.queryCbs[s]=this.queryCbs[s]??[],this.queryCbs[s].push({q:e,cb:n}),this._startQuerySub(e,s),()=>{this._unsubQuery(e,s,n)}}queryOnce(e,n){this.config.disableValidation||Bn(e,this.config.schema),n&&"ruleParams"in n&&(e={$$ruleParams:n.ruleParams,...e});const r=new Nn;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=v(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")),So),r.promise}_completeQueryOnce(e,n,r){this.queryOnceDfds[n]&&(this.queryOnceDfds[n]=this.queryOnceDfds[n].filter(s=>s.dfd!==r),this._cleanupQuery(e,n))}_unsubQuery(e,n,r){this.queryCbs[n]&&(this.queryCbs[n]=this.queryCbs[n].filter(s=>s.cb!==r),this._cleanupQuery(e,n))}_hasQueryListeners(e){var n,r;return!!((n=this.queryCbs[e])!=null&&n.length||(r=this.queryOnceDfds[e])!=null&&r.length)}_cleanupQuery(e,n){this._hasQueryListeners(n)||(delete this.queryCbs[n],delete this.queryOnceDfds[n],delete this._dataForQueryCache[n],this.querySubs.unloadKey(n),this._trySendAuthed(P(),{op:"remove-query",q:e}))}_rewriteMutations(e,n,r){if(!e)return n;if(!n)return new Map;const s=l=>{const[f,h,p]=l["forward-identity"];return C(e,h,p)},i=l=>{const[f,h,p]=l["forward-identity"];return ie(e,h,p)},o={attrIdMap:{},refSwapAttrIds:new Set};let a=!1;const c=(l,f)=>{const h=[];for(const p of l){const[y]=p;if(y==="add-attr"){const[g,w]=p,_=s(w);if(_&&w.id!==_.id){o.attrIdMap[w.id]=_.id,a=!0;continue}if(w["value-type"]==="ref"){const T=i(w);if(T){o.attrIdMap[w.id]=T.id,o.refSwapAttrIds.add(w.id),a=!0;continue}}}if(r&&f&&r>=f&&y==="add-attr"||y==="update-attr"||y==="delete-attr"){a=!0;continue}const b=a?di(o,p):p;h.push(b)}return a?h:l},u=new Map;for(const[l,f]of n.entries())u.set(l,{...f,"tx-steps":c(f["tx-steps"],f["tx-id"])});return a?u:n}_rewriteMutationsSorted(e,n){return Dt(this._rewriteMutations(e,n).entries())}optimisticAttrs(){var i,o;const e=[...this._pendingMutations().values()].flatMap(a=>a["tx-steps"]),n=new Set(e.filter(([a,c])=>a==="delete-attr").map(([a,c])=>c)),r=[];for(const[a,c]of e)if(a==="add-attr")r.push(c);else if(a==="update-attr"&&c.id&&((i=this.attrs)!=null&&i.getAttr(c.id))){const u={...this.attrs.getAttr(c.id),...c};r.push(u)}if(!n.size&&!r.length)return this.attrs||new se({},this._linkIndex);const s={...((o=this.attrs)==null?void 0:o.attrs)||{}};for(const a of r)s[a.id]=a;for(const a of n)delete s[a];return new se(s,this._linkIndex)}dataForQuery(e,n=!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,h=u.attrsStore;const{pageInfo:p,aggregate:y,processedTxId:b}=u,g=this._rewriteMutationsSorted(h,a);if(n){const _=this._applyOptimisticUpdates(f,h,g,b);f=_.store,h=_.attrsStore}return{data:On({store:f,attrsStore:h,pageInfo:p,aggregate:y},c),querySubVersion:s,pendingMutationsVersion:o}}_applyOptimisticUpdates(e,n,r,s){for(const[i,o]of r)if(!o["tx-id"]||s&&o["tx-id"]>s){const a=hs(e,n,o["tx-steps"]);e=a.store,n=a.attrsStore}return{store:e,attrsStore:n}}notifyAll(){Object.keys(this.queryCbs).forEach(e=>{this.querySubs.waitForKeyToLoad(e).then(()=>this.notifyOne(e)).catch(()=>this.notifyOne(e))})}loadedNotifyAll(){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyAll()).catch(()=>this.notifyAll())}shutdown(){var e;this._log.info("[shutdown]",this.config.appId),this._isShutdown=!0,(e=this._transport)==null||e.close()}_sendMutation(e,n){if(n.error){this._handleMutationError("error",e,{message:n.error.message});return}if(this.status!==Y.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,n),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}),Dt(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:n}of Object.values(this.querySubs.currentValue))n!=null&&n.processedTxId&&(e=Math.min(e,n==null?void 0:n.processedTxId));this._updatePendingMutations(n=>{for(const[r,s]of Array.from(n.entries()))s["tx-id"]&&s["tx-id"]<=e&&n.delete(r)})}_cleanupPendingMutationsTimeout(){if(this._pendingMutations().size<this._pendingMutationCleanupThreshold)return;const e=Date.now();this._updatePendingMutations(n=>{for(const[r,s]of Array.from(n.entries()))s.confirmed&&s.confirmed+this._pendingTxCleanupTimeout<e&&n.delete(r)})}_trySendAuthed(...e){this.status===Y.AUTHENTICATED&&this._trySend(...e)}_trySend(e,n,r){if(this._transport.isOpen()){switch(rr[n.op]||this._log.info("[send]",this._transport.id,n.op,n),n.op){case"transact":{this._inFlightMutationEventIds.add(e);break}case"init":this._inFlightMutationEventIds.clear()}this._transport.send({"client-event-id":e,...n})}}_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=Eo({transportType:this._transportType,appId:this.config.appId,apiURI:this.config.apiURI,wsURI:this.config.websocketURI,EventSourceImpl:this._EventSource}),this._transport.onopen=this._transportOnOpen,this._transport.onmessage=this._transportOnMessage,this._transport.onclose=this._transportOnClose,this._transport.onerror=this._transportOnError,this._log.info("[socket][start]",this._transport.id),e!=null&&e.isOpen()&&(this._log.info("[socket][start]",this._transport.id,"close previous transport id = ",e.id),e.close())}async getLocalId(e){const n=`localToken_${e}`;if(this.kv.currentValue[n])return this.kv.currentValue[n];const r=await this.kv.waitForKeyToLoad(n);if(r)return r;const s=P();return this.kv.updateInPlace(i=>{i[n]||(i[n]=s)}),await this.kv.waitForKeyToLoad(n)}_replaceUrlAfterOAuth(){if(typeof URL>"u")return;const e=new URL(window.location.href);if(e.searchParams.get($t)){const n=e.toString();e.searchParams.delete($t),e.searchParams.delete("code"),e.searchParams.delete("error");const r=e.pathname+(e.searchParams.size?"?"+e.searchParams:"")+e.hash;if(history.replaceState(history.state,"",r),typeof navigation=="object"&&typeof navigation.addEventListener=="function"&&typeof navigation.removeEventListener=="function"){let s=!1;const i=o=>{var a;s||(s=!0,navigation.removeEventListener("navigate",i),!o.userInitiated&&o.navigationType==="replace"&&((a=o.destination)==null?void 0:a.url)===n&&history.replaceState(history.state,"",r))};navigation.addEventListener("navigate",i)}}}async _oauthLoginInit(){var s,i,o,a;if(typeof window>"u"||typeof window.location>"u"||typeof URLSearchParams>"u")return null;const e=new URLSearchParams(window.location.search);if(!e.get($t))return null;const n=e.get("error");if(n)return this._replaceUrlAfterOAuth(),{error:{message:n}};const r=e.get("code");if(!r)return null;this._replaceUrlAfterOAuth();try{const c=await this._getCurrentUser(),u=(c==null?void 0:c.type)==="guest",{user:l}=await xn({apiURI:this.config.apiURI,appId:this.config.appId,code:r,refreshToken:u?c.refresh_token:void 0});return this.setCurrentUser(l),null}catch(c){return((s=c==null?void 0:c.body)==null?void 0:s.type)==="record-not-found"&&((o=(i=c==null?void 0:c.body)==null?void 0:i.hint)==null?void 0:o["record-type"])==="app-oauth-code"&&await this._hasCurrentUser()?null:{error:{message:((a=c==null?void 0:c.body)==null?void 0:a.message)||"Error logging in."}}}}async _waitForOAuthCallbackResponse(){return await this._oauthCallbackResponse}__subscribeMutationErrors(e){return this.mutationErrorCbs.push(e),()=>{this.mutationErrorCbs=this.mutationErrorCbs.filter(n=>n!==e)}}subscribeAuth(e){this.authCbs.push(e);const n=this._currentUserCached;n.isLoading||e(this._currentUserCached);let r=!1;return this.getCurrentUser().then(s=>{r||je(s,n)||e(s)}),()=>{r=!0,this.authCbs=this.authCbs.filter(s=>s!==e)}}async getAuth(){const{user:e,error:n}=await this.getCurrentUser();if(n)throw new fe("Could not get current user: "+n.message);return e}subscribeConnectionStatus(e){return this.connectionStatusCbs.push(e),()=>{this.connectionStatusCbs=this.connectionStatusCbs.filter(n=>n!==e)}}subscribeAttrs(e){return this.attrsCbs.push(e),this.attrs&&e(this.attrs.attrs),()=>{this.attrsCbs=this.attrsCbs.filter(n=>n!==e)}}notifyAuthSubs(e){this.authCbs.forEach(n=>n(e))}notifyMutationErrorSubs(e){this.mutationErrorCbs.forEach(n=>n(e))}notifyAttrsSubs(){if(!this.attrs)return;const e=this.optimisticAttrs();this.attrsCbs.forEach(n=>n(e.attrs))}notifyConnectionStatusSubs(e){this.connectionStatusCbs.forEach(n=>n(e))}async setCurrentUser(e){this.kv.updateInPlace(n=>{n[Oe]=e}),await this.kv.waitForKeyToLoad(Oe)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(){const e=await this.kv.waitForKeyToLoad(Oe);return typeof e=="string"?JSON.parse(e):e}async getCurrentUser(){const e=await this._waitForOAuthCallbackResponse();if(e!=null&&e.error){const n={error:e.error,user:void 0};return this._currentUserCached={isLoading:!1,...n},n}try{const r={user:await this._getCurrentUser(),error:void 0};return this._currentUserCached={isLoading:!1,...r},r}catch(n){return{user:void 0,isLoading:!1,error:{message:(n==null?void 0:n.message)||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(Oe);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){var r;const{user:n}=await this.getCurrentUser();if(!je(n,e)){await this.setCurrentUser(e),await this.updateUser(e);try{(r=this._broadcastChannel)==null||r.postMessage({type:"auth"})}catch(s){console.error("Error posting message to broadcast channel",s)}}}async syncUserToEndpoint(e){if(this.config.firstPartyPath)try{await fetch(this.config.firstPartyPath+"/",{method:"POST",body:JSON.stringify({type:"sync-user",appId:this.config.appId,user:e}),headers:{"Content-Type":"application/json"}})}catch(n){this._log.error("Error syncing user with external endpoint",n)}}async updateUser(e){try{await this.syncUserToEndpoint(e)}catch(r){this._log.error("Error syncing user with external endpoint",r)}const n={error:void 0,user:e};this._currentUserCached={isLoading:!1,...n},this._dataForQueryCache={},this.querySubs.updateInPlace(r=>{Object.keys(r).forEach(s=>{delete r[s].result})}),this._reconnectTimeoutMs=0,this._transport.close(),this._oauthCallbackResponse=null,this.notifyAuthSubs(n)}sendMagicCode({email:e}){return Vi({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode({email:e,code:n}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await Wi({apiURI:this.config.apiURI,appId:this.config.appId,email:e,code:n,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}async signInWithCustomToken(e){const n=await Qi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(n.user),n}async signInAsGuest(){const e=await Gi({apiURI:this.config.apiURI,appId:this.config.appId});return await this.changeCurrentUser(e.user),e}potentiallyInvalidateToken(e,n){var i;const r=(i=e==null?void 0:e.user)==null?void 0:i.refresh_token;if(!r)return;if(n.invalidateToken===!1){this._log.info("[auth-invalidate] skipped invalidateToken");return}Hi({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:r}).then(()=>{this._log.info("[auth-invalidate] completed invalidateToken")}).catch(o=>{})}async signOut(e){const n=await this.getCurrentUser();this.potentiallyInvalidateToken(n,e),await this.changeCurrentUser(null)}createAuthorizationURL({clientName:e,redirectURL:n}){const{apiURI:r,appId:s}=this.config;return`${r}/runtime/oauth/start?app_id=${s}&client_name=${e}&redirect_uri=${n}`}async exchangeCodeForToken({code:e,codeVerifier:n}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await xn({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:n,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}issuerURI(){const{apiURI:e,appId:n}=this.config;return`${e}/runtime/${n}`}async signInWithIdToken({idToken:e,clientName:n,nonce:r}){var a;const s=await this.getCurrentUser(),i=(a=s==null?void 0:s.user)==null?void 0:a.refresh_token,o=await Bi({apiURI:this.config.apiURI,appId:this.config.appId,idToken:e,clientName:n,nonce:r,refreshToken:i});return await this.changeCurrentUser(o.user),o}joinRoom(e,n,r){let s=!1;this._rooms[n]||(s=!0,this._rooms[n]={roomType:e,isConnected:!1,error:void 0}),this._presence[n]=this._presence[n]||{};const i=this._presence[n].result;return r&&!i&&(this._presence[n].result=this._presence[n].result||{},this._presence[n].result.user=r,this._notifyPresenceSubs(n)),s&&this._tryJoinRoom(e,n,r),()=>{this._cleanupRoom(n)}}_cleanupRoom(e){var n,r,s;if(!((r=(n=this._presence[e])==null?void 0:n.handlers)!=null&&r.length)&&!Object.keys(this._broadcastSubs[e]??{}).length){const i=(s=this._rooms[e])==null?void 0:s.isConnected;delete this._rooms[e],delete this._presence[e],delete this._broadcastSubs[e],i?this._tryLeaveRoom(e):this._roomsPendingLeave[e]=!0}}getPresence(e,n,r={}){const s=this._rooms[n],i=this._presence[n];return!s||!i||!i.result?null:{...to(i.result,r,this._sessionId),isLoading:!s.isConnected,error:s.error}}publishPresence(e,n,r){const s=this._rooms[n],i=this._presence[n];if(!s||!i)return;i.result=i.result||{};const o={...i.result.user,...r};i.result.user=o,s.isConnected&&(this._trySetPresence(n,o),this._notifyPresenceSubs(n))}_trySetPresence(e,n){this._trySendAuthed(P(),{op:"set-presence","room-id":e,data:n})}_tryJoinRoom(e,n,r){this._trySendAuthed(P(),{op:"join-room","room-type":e,"room-id":n,data:r}),delete this._roomsPendingLeave[n]}_tryLeaveRoom(e){this._trySendAuthed(P(),{op:"leave-room","room-id":e})}_trySetRoomConnected(e,n){const r=this._rooms[e];r&&(r.isConnected=n)}subscribePresence(e,n,r,s){const i=this.joinRoom(e,n,r.initialPresence||r.initialData),o={...r,roomId:n,cb:s,prev:null};return this._presence[n]=this._presence[n]||{},this._presence[n].handlers=this._presence[n].handlers||[],this._presence[n].handlers.push(o),this._notifyPresenceSub(n,o),()=>{var a,c;this._presence[n].handlers=((c=(a=this._presence[n])==null?void 0:a.handlers)==null?void 0:c.filter(u=>u!==o))??[],i()}}_notifyPresenceSubs(e){var n,r;(r=(n=this._presence[e])==null?void 0:n.handlers)==null||r.forEach(s=>{this._notifyPresenceSub(e,s)})}_notifyPresenceSub(e,n){const r=this.getPresence("",e,n);r&&(n.prev&&!no(r,n.prev)||(n.prev=r,n.cb(r)))}_patchPresencePeers(e,n){var o,a,c;const r=((a=(o=this._presence[e])==null?void 0:o.result)==null?void 0:a.peers)||{};let s=Object.fromEntries(Object.entries(r).map(([u,l])=>[u,{data:l}]));(c=this._presence[e])==null||c.result;const i=Me(s,u=>{for(let[l,f,h]of n)switch(f){case"+":Rr(u,l,h);break;case"r":Xt(u,l,h);break;case"-":en(u,l);break}delete u[this._sessionId]});this._setPresencePeers(e,i)}_setPresencePeers(e,n){const r={...n};delete r[this._sessionId];const s=Object.fromEntries(Object.entries(r).map(([i,o])=>[i,o.data]));this._presence=Me(this._presence,i=>{Xt(i,[e,"result","peers"],s)})}publishTopic({roomType:e,roomId:n,topic:r,data:s}){const i=this._rooms[n];if(i){if(!i.isConnected){this._broadcastQueue[n]=this._broadcastQueue[n]??[],this._broadcastQueue[n].push({topic:r,roomType:e,data:s});return}this._tryBroadcast(n,e,r,s)}}_tryBroadcast(e,n,r,s){this._trySendAuthed(P(),{op:"client-broadcast","room-id":e,roomType:n,topic:r,data:s})}subscribeTopic(e,n,r,s){const i=this.joinRoom(e,n);return this._broadcastSubs[n]=this._broadcastSubs[n]||{},this._broadcastSubs[n][r]=this._broadcastSubs[n][r]||[],this._broadcastSubs[n][r].push(s),this._presence[n]=this._presence[n]||{},()=>{this._broadcastSubs[n][r]=this._broadcastSubs[n][r].filter(o=>o!==s),this._broadcastSubs[n][r].length||delete this._broadcastSubs[n][r],i()}}_notifyBroadcastSubs(e,n,r){var s,i,o;(o=(i=(s=this._broadcastSubs)==null?void 0:s[e])==null?void 0:i[n])==null||o.forEach(a=>{var l,f,h,p,y,b;const c=(l=r.data)==null?void 0:l.data,u=r.data["peer-id"]===this._sessionId?(h=(f=this._presence[e])==null?void 0:f.result)==null?void 0:h.user:(b=(y=(p=this._presence[e])==null?void 0:p.result)==null?void 0:y.peers)==null?void 0:b[r.data["peer-id"]];return a(c,u)})}async uploadFile(e,n,r){var o;const s=await this.getCurrentUser(),i=(o=s==null?void 0:s.user)==null?void 0:o.refresh_token;return Ji({...r,apiURI:this.config.apiURI,appId:this.config.appId,path:e,file:n,refreshToken:i})}async deleteFile(e){var i;const n=await this.getCurrentUser(),r=(i=n==null?void 0:n.user)==null?void 0:i.refresh_token;return await Yi({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}async upload(e,n){var c;const r=await this.getCurrentUser(),s=(c=r==null?void 0:r.user)==null?void 0:c.refresh_token,i=e||n.name,o=await Zi({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await Xi(o,n)}async getDownloadUrl(e){var i;const n=await this.getCurrentUser(),r=(i=n==null?void 0:n.user)==null?void 0:i.refresh_token;return await eo({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}function Ro(t,e){return new Ke(sr(t,e),e,void 0)}function xo(t){return new Ne(t,{})}function Uo(){return new x("string",!0,!1)}function Lo(){return new x("number",!0,!1)}function Fo(){return new x("boolean",!0,!1)}function No(){return new x("date",!0,!1)}function Ko(){return new x("json",!0,!1)}function qo(){return new x("json",!0,!1)}function sr(t,e){var s,i,o,a;const n={fwd:{},rev:{}};for(const c of Object.values(e))(s=n.fwd)[i=c.forward.on]||(s[i]={}),(o=n.rev)[a=c.reverse.on]||(o[a]={}),n.fwd[c.forward.on][c.forward.label]={entityName:c.reverse.on,cardinality:c.forward.has},n.rev[c.reverse.on][c.reverse.label]={entityName:c.forward.on,cardinality:c.reverse.has};return Object.fromEntries(Object.entries(t).map(([c,u])=>[c,new Ne(u.attrs,{...n.fwd[c],...n.rev[c]})]))}function zo({entities:t,links:e,rooms:n}){const r=e??{},s=n??{};return new Ke(sr(t,r),r,s)}const Vo={graph:Ro,schema:zo,entity:xo,string:Uo,number:Lo,boolean:Fo,date:No,json:Ko,any:qo};let ze;function Wo(t,e){ze==null||ze.dispose();const n=Yo(e),r=Bo(e,a),s=Go(Qo(t));function i(l){var f;l.source===s.element.contentWindow&&((f=l.data)==null?void 0:f.type)==="close"&&n.isVisible()&&a()}function o(l){const f=l.shiftKey&&l.ctrlKey&&l.key==="0",h=l.key==="Escape"||l.key==="Esc";(f||h&&n.isVisible())&&a()}function a(){n.isVisible()?n.element.style.display="none":(n.element.style.display="block",n.element.contains(s.element)||n.element.appendChild(s.element))}function c(){n.element.remove(),r.element.remove(),removeEventListener("keydown",o),removeEventListener("message",i)}function u(){document.body.appendChild(n.element),document.body.appendChild(r.element),addEventListener("keydown",o),addEventListener("message",i),ze={dispose:c}}return u()}function Qo(t){return`${It||Ln?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${t}`}function Go(t){const e=document.createElement("iframe");return e.src=t,e.className="instant-devtool-iframe",Object.assign(e.style,{width:"100%",height:"100%",backgroundColor:"white",border:"none"}),{element:e}}function Bo(t,e){const n=`
|
|
3
|
+
<svg width="32" height="32" viewBox="0 0 512 512" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
4
|
+
<rect width="512" height="512" fill="black"/>
|
|
5
|
+
<rect x="97.0973" y="91.3297" width="140" height="330" fill="white"/>
|
|
6
|
+
</svg>
|
|
7
|
+
`,r=document.createElement("button");return r.innerHTML=n,r.className="instant-devtool-toggler",Object.assign(r.style,{position:"fixed",...Ho(t.position),height:"32px",width:"32px",display:"flex",alignItems:"center",justifyContent:"center",zIndex:"9010",padding:"0",margin:"0",border:"none",cursor:"pointer"}),r.addEventListener("click",e),{element:r}}function Ho(t){switch(t){case"bottom-left":return{bottom:"24px",left:"24px"};case"bottom-right":return{bottom:"24px",right:"24px"};case"top-right":return{top:"24px",right:"24px"};case"top-left":return{top:"24px",left:"24px"}}}function Jo(t){switch(t){case"bottom-left":return{bottom:"24px",right:"24px",left:"60px",top:"72px"};case"bottom-right":return{bottom:"24px",left:"24px",right:"60px",top:"72px"};case"top-right":return{top:"24px",left:"24px",right:"60px",bottom:"72px"};case"top-left":return{top:"24px",right:"24px",left:"60px",bottom:"72px"}}}function Yo(t){const e=document.createElement("div");Object.assign(e.style,{position:"fixed",...Jo(t.position),display:"block",borderRadius:"4px",border:"1px #ccc solid",boxShadow:"0px 0px 8px #00000044",backgroundColor:"#eee",zIndex:"999990"}),e.style.display="none",e.className="instant-devtool-container";function n(){return e.style.display!=="none"}return{element:e,isVisible:n}}function Zo(t,e){return e&&e.refresh_token?new Response(JSON.stringify({ok:!0}),{headers:{"Content-Type":"application/json","Set-Cookie":`instant_user_${t.appId}=${encodeURIComponent(JSON.stringify(e))}; Path=/; HttpOnly; Secure; SameSite=Strict; Max-Age=604800`}}):new Response(JSON.stringify({ok:!0}),{headers:{"Content-Type":"application/json","Set-Cookie":`instant_user_${t.appId}=; Path=/; HttpOnly; Secure; SameSite=Strict; Max-Age=-1`}})}function Ve(t,e){return new Response(JSON.stringify({ok:!1,error:e}),{status:t,headers:{"Content-Type":"application/json"}})}const Xo=t=>({POST:async e=>{let n;try{n=await e.json()}catch{return Ve(400,"Invalid JSON body")}if(!n.type)return Ve(400,'Missing "type" field');if(n.appId!==t.appId)return Ve(403,"App ID mismatch");switch(n.type){case"sync-user":return Zo(t,n.user??null);default:return Ve(400,`Unknown type: ${n.type}`)}}}),ea={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"};function ta(){return globalThis.__instantDbSchemaHashStore=globalThis.__instantDbSchemaHashStore??new WeakMap,globalThis.__instantDbSchemaHashStore}function na(){return globalThis.__instantDbStore=globalThis.__instantDbStore??{},globalThis.__instantDbStore}function Rt(t){const e=t.__adminToken;return t.appId+"_"+(t.websocketURI||"default_ws_uri")+"_"+(t.apiURI||"default_api_uri")+"_"+(e||"client_only")+"_"+t.useDateObjects}const xt=na(),ir=ta();class ra{constructor(e){d(this,"db");d(this,"sendMagicCode",e=>this.db.sendMagicCode(e));d(this,"signInWithMagicCode",e=>this.db.signInWithMagicCode(e));d(this,"signInWithToken",e=>this.db.signInWithCustomToken(e));d(this,"signInAsGuest",()=>this.db.signInAsGuest());d(this,"createAuthorizationURL",e=>this.db.createAuthorizationURL(e));d(this,"signInWithIdToken",e=>this.db.signInWithIdToken(e));d(this,"exchangeOAuthCode",e=>this.db.exchangeCodeForToken(e));d(this,"issuerURI",()=>this.db.issuerURI());d(this,"signOut",(e={invalidateToken:!0})=>this.db.signOut(e));this.db=e}}class sa{constructor(e){d(this,"db");d(this,"uploadFile",(e,n,r={})=>this.db.uploadFile(e,n,r));d(this,"delete",e=>this.db.deleteFile(e));d(this,"upload",(e,n)=>this.db.upload(e,n));d(this,"put",this.upload);d(this,"getDownloadUrl",e=>this.db.getDownloadUrl(e));this.db=e}}function ia(t){return JSON.parse(JSON.stringify(t))}class oa{constructor(e){d(this,"_reactor");d(this,"auth");d(this,"storage");d(this,"tx",At());this._reactor=e,this.auth=new ra(this._reactor),this.storage=new sa(this._reactor)}transact(e){return this._reactor.pushTx(e)}getLocalId(e){return this._reactor.getLocalId(e)}subscribeQuery(e,n,r){return this._reactor.subscribeQuery(e,n,r)}subscribeAuth(e){return this._reactor.subscribeAuth(e)}getAuth(){return this._reactor.getAuth()}subscribeConnectionStatus(e){return this._reactor.subscribeConnectionStatus(e)}joinRoom(e="_defaultRoomType",n="_defaultRoomId",r){return{leaveRoom:this._reactor.joinRoom(e,n,r==null?void 0:r.initialPresence),subscribeTopic:(i,o)=>this._reactor.subscribeTopic(e,n,i,o),subscribePresence:(i,o)=>this._reactor.subscribePresence(e,n,i,o),publishTopic:(i,o)=>this._reactor.publishTopic({roomType:e,roomId:n,topic:i,data:o}),publishPresence:i=>this._reactor.publishPresence(e,n,i),getPresence:i=>this._reactor.getPresence(e,n,i)}}shutdown(){delete xt[Rt(this._reactor.config)],this._reactor.shutdown()}queryOnce(e,n){return this._reactor.queryOnce(e,n)}_syncTableExperimental(e,n){return this._reactor.subscribeTable(e,n)}}function or(t){if(!t)return"0";const e=ir.get(t);if(e)return e;const n=v(t);return ir.set(t,n),n}function aa(t,e){return or(t._reactor.config.schema)!==or(e)}function ca(t,e,n,r,s){var u;const i={...t,appId:(u=t.appId)==null?void 0:u.trim(),useDateObjects:t.useDateObjects??!1},o=xt[Rt(i)];if(o)return aa(o,i.schema)&&o._reactor.updateSchema(i.schema),o;const a=new Do({...ea,...i,cardinalityInference:!!i.schema},e||Dn,n||Rn,{...r||{},"@instantdb/core":Ct},s),c=new oa(a);return xt[Rt(i)]=c,ua(i.appId,i.devtool),c}function ua(t,e){if(typeof window>"u"||typeof window.location>"u"||typeof document>"u"||typeof e=="boolean"&&!e)return;const n={position:"bottom-right",allowedHosts:["localhost"],...typeof e=="object"?e:{}};n.allowedHosts.includes(window.location.hostname)&&Wo(t,n)}const la=!1,We={equals:(t,e)=>t===e};let ar=fr;const oe=1,Qe=2,fa={};var $=null;let Ut=null,da=null,j=null,D=null,Z=null,Ge=0;function ke(t,e){e=e?Object.assign({},We,e):We;const n={value:t,observers:null,observerSlots:null,comparator:e.equals||void 0},r=s=>(typeof s=="function"&&(s=s(n.value)),ur(n,s));return[cr.bind(n),r]}function X(t,e,n){ar=ba;const r=lr(t,e,!1,oe);r.user=!0,Z?Z.push(r):Be(r)}function Lt(t,e,n){n=n?Object.assign({},We,n):We;const r=lr(t,e,!0,0);return r.observers=null,r.observerSlots=null,r.comparator=n.equals||void 0,Be(r),cr.bind(r)}function ha(t){if(j===null)return t();const e=j;j=null;try{return t()}finally{j=e}}function ee(t){return $===null||($.cleanups===null?$.cleanups=[t]:$.cleanups.push(t)),t}function cr(){if(this.sources&&this.state)if(this.state===oe)Be(this);else{const t=D;D=null,Je(()=>Ye(this)),D=t}if(j){const t=this.observers?this.observers.length:0;j.sources?(j.sources.push(this),j.sourceSlots.push(t)):(j.sources=[this],j.sourceSlots=[t]),this.observers?(this.observers.push(j),this.observerSlots.push(j.sources.length-1)):(this.observers=[j],this.observerSlots=[j.sources.length-1])}return this.value}function ur(t,e,n){let r=t.value;return(!t.comparator||!t.comparator(r,e))&&(t.value=e,t.observers&&t.observers.length&&Je(()=>{for(let s=0;s<t.observers.length;s+=1){const i=t.observers[s],o=Ut&&Ut.running;o&&Ut.disposed.has(i),(o?!i.tState:!i.state)&&(i.pure?D.push(i):Z.push(i),i.observers&&dr(i)),o||(i.state=oe)}if(D.length>1e6)throw D=[],new Error})),e}function Be(t){if(!t.fn)return;Ze(t);const e=Ge;pa(t,t.value,e)}function pa(t,e,n){let r;const s=$,i=j;j=$=t;try{r=t.fn(e)}catch(o){return t.pure&&(t.state=oe,t.owned&&t.owned.forEach(Ze),t.owned=null),t.updatedAt=n+1,hr(o)}finally{j=i,$=s}(!t.updatedAt||t.updatedAt<=n)&&(t.updatedAt!=null&&"observers"in t?ur(t,r):t.value=r,t.updatedAt=n)}function lr(t,e,n,r=oe,s){const i={fn:t,state:r,updatedAt:null,owned:null,sources:null,sourceSlots:null,cleanups:null,value:e,owner:$,context:$?$.context:null,pure:n};return $===null||$!==fa&&($.owned?$.owned.push(i):$.owned=[i]),i}function He(t){if(t.state===0)return;if(t.state===Qe)return Ye(t);if(t.suspense&&ha(t.suspense.inFallback))return t.suspense.effects.push(t);const e=[t];for(;(t=t.owner)&&(!t.updatedAt||t.updatedAt<Ge);)t.state&&e.push(t);for(let n=e.length-1;n>=0;n--)if(t=e[n],t.state===oe)Be(t);else if(t.state===Qe){const r=D;D=null,Je(()=>Ye(t,e[0])),D=r}}function Je(t,e){if(D)return t();let n=!1;D=[],Z?n=!0:Z=[],Ge++;try{const r=t();return ya(n),r}catch(r){n||(Z=null),D=null,hr(r)}}function ya(t){if(D&&(fr(D),D=null),t)return;const e=Z;Z=null,e.length&&Je(()=>ar(e))}function fr(t){for(let e=0;e<t.length;e++)He(t[e])}function ba(t){let e,n=0;for(e=0;e<t.length;e++){const r=t[e];r.user?t[n++]=r:He(r)}for(e=0;e<n;e++)He(t[e])}function Ye(t,e){t.state=0;for(let n=0;n<t.sources.length;n+=1){const r=t.sources[n];if(r.sources){const s=r.state;s===oe?r!==e&&(!r.updatedAt||r.updatedAt<Ge)&&He(r):s===Qe&&Ye(r,e)}}}function dr(t){for(let e=0;e<t.observers.length;e+=1){const n=t.observers[e];n.state||(n.state=Qe,n.pure?D.push(n):Z.push(n),n.observers&&dr(n))}}function Ze(t){let e;if(t.sources)for(;t.sources.length;){const n=t.sources.pop(),r=t.sourceSlots.pop(),s=n.observers;if(s&&s.length){const i=s.pop(),o=n.observerSlots.pop();r<s.length&&(i.sourceSlots[o]=r,s[r]=i,n.observerSlots[r]=o)}}if(t.tOwned){for(e=t.tOwned.length-1;e>=0;e--)Ze(t.tOwned[e]);delete t.tOwned}if(t.owned){for(e=t.owned.length-1;e>=0;e--)Ze(t.owned[e]);t.owned=null}if(t.cleanups){for(e=t.cleanups.length-1;e>=0;e--)t.cleanups[e]();t.cleanups=null}t.state=0}function ga(t){return t instanceof Error?t:new Error(typeof t=="string"?t:"Unknown error",{cause:t})}function hr(t,e=$){throw ga(t)}const _a=1e3;function wa(t,e,n){X(()=>{const r=t.core._reactor.subscribeTopic(t.type,t.id,e,(s,i)=>{n(s,i)});ee(r)})}function Ta(t,e){return X(()=>{const n=t.core._reactor.joinRoom(t.type,t.id);ee(n)}),n=>{t.core._reactor.publishTopic({roomType:t.type,roomId:t.id,topic:e,data:n})}}function ma(t,e={}){const[n,r]=ke(t.core._reactor.getPresence(t.type,t.id,e)??{peers:{},isLoading:!0});X(()=>{const i=t.core._reactor.subscribePresence(t.type,t.id,e,o=>{r(o)});ee(i)});const s=i=>{t.core._reactor.publishPresence(t.type,t.id,i)};return Lt(()=>({...n(),publishPresence:s}))}function Sa(t,e,n){X(()=>{const r=t.core._reactor.joinRoom(t.type,t.id,e);ee(r)}),X(()=>{n?n.forEach(r=>r):JSON.stringify(e),t.core._reactor.publishPresence(t.type,t.id,e)})}function Aa(t,e,n={}){let r=null;const s=pr.usePresence(t,{keys:[e]}),i=Lt(()=>{if(n!=null&&n.writeOnly)return[];s();const u=t.core._reactor.getPresence(t.type,t.id);return Object.values((u==null?void 0:u.peers)??{}).filter(l=>l[e]===!0)}),o=u=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:u}),r&&(clearTimeout(r),r=null),u&&((n==null?void 0:n.timeout)===null||(n==null?void 0:n.timeout)===0||(r=setTimeout(()=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:null})},(n==null?void 0:n.timeout)??_a)))};return{active:i,setActive:o,inputProps:{onKeyDown:u=>{const f=!((n==null?void 0:n.stopOnEnter)&&u.key==="Enter");o(f)},onBlur:()=>{o(!1)}}}}const pr={useTopicEffect:wa,usePublishTopic:Ta,usePresence:ma,useSyncPresence:Sa,useTypingIndicator:Aa};class yr{constructor(e,n,r){d(this,"core");d(this,"type");d(this,"id");this.core=e,this.type=n,this.id=r}}const br={isLoading:!0,data:void 0,pageInfo:void 0,error:void 0},va={isLoading:!0,user:void 0,error:void 0};function Oa(t){return{isLoading:!t,data:void 0,pageInfo:void 0,error:void 0,...t||{}}}class gr{constructor(e){d(this,"tx",At());d(this,"auth");d(this,"storage");d(this,"core");d(this,"getLocalId",e=>this.core.getLocalId(e));d(this,"transact",e=>this.core.transact(e));d(this,"queryOnce",(e,n)=>this.core.queryOnce(e,n));d(this,"useQuery",(e,n)=>{const[r,s]=ke(br);return X(()=>{if(!e){s(()=>br);return}let i=e;n&&"ruleParams"in n&&(i={$$ruleParams:n.ruleParams,...i});const o=ia(i),a=this.core._reactor.getPreviousResult(o);a&&s(()=>Oa(a));const c=this.core.subscribeQuery(o,u=>{s(()=>Object.assign({isLoading:!1,data:void 0,pageInfo:void 0,error:void 0},u))});ee(c)}),r});d(this,"useAuth",()=>{const[e,n]=ke(this.core._reactor._currentUserCached??va);return X(()=>{const r=this.core.subscribeAuth(s=>{n({isLoading:!1,...s})});ee(r)}),e});d(this,"useUser",()=>{const e=this.useAuth();return Lt(()=>{const{user:n}=e();if(!n)throw new fe("useUser must be used within an auth-protected route");return n})});d(this,"useConnectionStatus",()=>{const[e,n]=ke(this.core._reactor.status);return X(()=>{const r=this.core.subscribeConnectionStatus(s=>{n(()=>s)});ee(r)}),e});d(this,"useLocalId",e=>{const[n,r]=ke(null);return X(()=>{let s=!0;this.getLocalId(e).then(i=>{s&&r(()=>i)}),ee(()=>{s=!1})}),n});d(this,"rooms",pr);this.core=e,this.auth=this.core.auth,this.storage=this.core.storage}getAuth(){return this.core.getAuth()}room(e="_defaultRoomType",n="_defaultRoomId"){return new yr(this.core,e,n)}}function _r(t){const e=ca(t,void 0,void 0,{"@instantdb/solidjs":Ct});return new gr(e)}const ka=_r;A.InstantAPIError=ve,A.InstantSolidDatabase=gr,A.InstantSolidRoom=yr,A.StoreInterface=Mn,A.createInstantRouteHandler=Xo,A.i=Vo,A.id=P,A.init=_r,A.init_experimental=ka,A.lookup=kn,A.tx=li,Object.defineProperty(A,Symbol.toStringTag,{value:"Module"})});
|
package/package.json
ADDED
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@instantdb/solidjs",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"version": "0.0.1",
|
|
5
|
+
"description": "SolidJS client for InstantDB",
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "git+https://github.com/instantdb/instant.git",
|
|
9
|
+
"directory": "client/packages/solidjs"
|
|
10
|
+
},
|
|
11
|
+
"scripts": {
|
|
12
|
+
"test": "echo \"Error: no test specified\" && exit 1",
|
|
13
|
+
"check": "tsc --noEmit",
|
|
14
|
+
"check-exports": "attw --pack .",
|
|
15
|
+
"build:tshy": "tshy",
|
|
16
|
+
"build:standalone": "vite build",
|
|
17
|
+
"build": "rm -rf dist; npm run build:tshy && npm run build:standalone && npm run check-exports",
|
|
18
|
+
"dev:module": "tsc --watch --preserveWatchOutput -p tsconfig.dev.json",
|
|
19
|
+
"dev:main": "tsc --watch --preserveWatchOutput -p tsconfig.cjs.dev.json",
|
|
20
|
+
"dev": "run-p dev:module dev:main",
|
|
21
|
+
"publish-package": "pnpm pack && npm publish *.tgz --access public"
|
|
22
|
+
},
|
|
23
|
+
"exports": {
|
|
24
|
+
"./package.json": "./package.json",
|
|
25
|
+
".": {
|
|
26
|
+
"import": {
|
|
27
|
+
"types": "./dist/esm/index.d.ts",
|
|
28
|
+
"default": "./dist/esm/index.js"
|
|
29
|
+
},
|
|
30
|
+
"require": {
|
|
31
|
+
"types": "./dist/commonjs/index.d.ts",
|
|
32
|
+
"default": "./dist/commonjs/index.js"
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
"tshy": {
|
|
37
|
+
"selfLink": false,
|
|
38
|
+
"main": true,
|
|
39
|
+
"module": true,
|
|
40
|
+
"project": "./tsconfig.json",
|
|
41
|
+
"exports": {
|
|
42
|
+
"./package.json": "./package.json",
|
|
43
|
+
".": "./src/index.ts"
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
"main": "./dist/commonjs/index.js",
|
|
47
|
+
"types": "./dist/commonjs/index.d.ts",
|
|
48
|
+
"module": "./dist/esm/index.js",
|
|
49
|
+
"devDependencies": {
|
|
50
|
+
"tshy": "^3.0.2",
|
|
51
|
+
"@arethetypeswrong/cli": "^0.17.4",
|
|
52
|
+
"npm-run-all": "^4.1.5",
|
|
53
|
+
"typescript": "^5.0.0",
|
|
54
|
+
"vite": "^5.2.0"
|
|
55
|
+
},
|
|
56
|
+
"peerDependencies": {
|
|
57
|
+
"solid-js": ">=1.0.0"
|
|
58
|
+
},
|
|
59
|
+
"dependencies": {
|
|
60
|
+
"@instantdb/core": "workspace:*",
|
|
61
|
+
"@instantdb/version": "workspace:*"
|
|
62
|
+
}
|
|
63
|
+
}
|