@inixiative/json-rules 2.5.1 → 2.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,10 +1,10 @@
1
- import W from'dayjs';import zl from'dayjs/plugin/isSameOrAfter.js';import Hl from'dayjs/plugin/isSameOrBefore.js';import Jl from'dayjs/plugin/timezone.js';import Ql from'dayjs/plugin/utc.js';var kn=typeof global=="object"&&global&&global.Object===Object&&global,Ie=kn;var Tn=typeof self=="object"&&self&&self.Object===Object&&self,Mn=Ie||Tn||Function("return this")(),P=Mn;var _n=P.Symbol,D=_n;var Wt=Object.prototype,Pn=Wt.hasOwnProperty,Fn=Wt.toString,Pe=D?D.toStringTag:void 0;function Cn(e){var t=Pn.call(e,Pe),r=e[Pe];try{e[Pe]=void 0;var o=!0;}catch{}var n=Fn.call(e);return o&&(t?e[Pe]=r:delete e[Pe]),n}var Ut=Cn;var Dn=Object.prototype,Bn=Dn.toString;function Nn(e){return Bn.call(e)}var Gt=Nn;var qn="[object Null]",Ln="[object Undefined]",Kt=D?D.toStringTag:void 0;function In(e){return e==null?e===void 0?Ln:qn:Kt&&Kt in Object(e)?Ut(e):Gt(e)}var B=In;function jn(e){return e!=null&&typeof e=="object"}var N=jn;var Vn="[object Symbol]";function Wn(e){return typeof e=="symbol"||N(e)&&B(e)==Vn}var pe=Wn;function Un(e,t){for(var r=-1,o=e==null?0:e.length,n=Array(o);++r<o;)n[r]=t(e[r],r,e);return n}var zt=Un;var Gn=Array.isArray,_=Gn;var Ht=D?D.prototype:void 0,Jt=Ht?Ht.toString:void 0;function Qt(e){if(typeof e=="string")return e;if(_(e))return zt(e,Qt)+"";if(pe(e))return Jt?Jt.call(e):"";var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var Yt=Qt;function zn(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var q=zn;function Hn(e){return e}var Xt=Hn;var Jn="[object AsyncFunction]",Qn="[object Function]",Yn="[object GeneratorFunction]",Xn="[object Proxy]";function Zn(e){if(!q(e))return false;var t=B(e);return t==Qn||t==Yn||t==Jn||t==Xn}var je=Zn;var ea=P["__core-js_shared__"],Ve=ea;var Zt=(function(){var e=/[^.]+$/.exec(Ve&&Ve.keys&&Ve.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function ta(e){return !!Zt&&Zt in e}var er=ta;var ra=Function.prototype,oa=ra.toString;function na(e){if(e!=null){try{return oa.call(e)}catch{}try{return e+""}catch{}}return ""}var j=na;var aa=/[\\^$.*+?()[\]{}|]/g,ia=/^\[object .+?Constructor\]$/,sa=Function.prototype,la=Object.prototype,fa=sa.toString,ua=la.hasOwnProperty,pa=RegExp("^"+fa.call(ua).replace(aa,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function da(e){if(!q(e)||er(e))return false;var t=je(e)?pa:ia;return t.test(j(e))}var tr=da;function ma(e,t){return e?.[t]}var rr=ma;function ca(e,t){var r=rr(e,t);return tr(r)?r:void 0}var C=ca;var ga=C(P,"WeakMap"),We=ga;var ya=(function(){try{var e=C(Object,"defineProperty");return e({},"",{}),e}catch{}})(),yt=ya;var ha=9007199254740991,wa=/^(?:0|[1-9]\d*)$/;function xa(e,t){var r=typeof e;return t=t??ha,!!t&&(r=="number"||r!="symbol"&&wa.test(e))&&e>-1&&e%1==0&&e<t}var de=xa;function ba(e,t,r){t=="__proto__"&&yt?yt(e,t,{configurable:true,enumerable:true,value:r,writable:true}):e[t]=r;}var or=ba;function Oa(e,t){return e===t||e!==e&&t!==t}var me=Oa;var $a=9007199254740991;function Aa(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=$a}var ce=Aa;function va(e){return e!=null&&ce(e.length)&&!je(e)}var z=va;function Ea(e,t,r){if(!q(r))return false;var o=typeof t;return (o=="number"?z(r)&&de(t,r.length):o=="string"&&t in r)?me(r[t],e):false}var nr=Ea;var Ra=Object.prototype;function Sa(e){var t=e&&e.constructor,r=typeof t=="function"&&t.prototype||Ra;return e===r}var Ue=Sa;function ka(e,t){for(var r=-1,o=Array(e);++r<e;)o[r]=t(r);return o}var ar=ka;var Ta="[object Arguments]";function Ma(e){return N(e)&&B(e)==Ta}var ht=Ma;var ir=Object.prototype,_a=ir.hasOwnProperty,Pa=ir.propertyIsEnumerable,Fa=ht((function(){return arguments})())?ht:function(e){return N(e)&&_a.call(e,"callee")&&!Pa.call(e,"callee")},ge=Fa;function Ca(){return false}var sr=Ca;var ur=typeof exports=="object"&&exports&&!exports.nodeType&&exports,lr=ur&&typeof module=="object"&&module&&!module.nodeType&&module,Da=lr&&lr.exports===ur,fr=Da?P.Buffer:void 0,Ba=fr?fr.isBuffer:void 0,Na=Ba||sr,ae=Na;var qa="[object Arguments]",La="[object Array]",Ia="[object Boolean]",ja="[object Date]",Va="[object Error]",Wa="[object Function]",Ua="[object Map]",Ga="[object Number]",Ka="[object Object]",za="[object RegExp]",Ha="[object Set]",Ja="[object String]",Qa="[object WeakMap]",Ya="[object ArrayBuffer]",Xa="[object DataView]",Za="[object Float32Array]",ei="[object Float64Array]",ti="[object Int8Array]",ri="[object Int16Array]",oi="[object Int32Array]",ni="[object Uint8Array]",ai="[object Uint8ClampedArray]",ii="[object Uint16Array]",si="[object Uint32Array]",T={};T[Za]=T[ei]=T[ti]=T[ri]=T[oi]=T[ni]=T[ai]=T[ii]=T[si]=true;T[qa]=T[La]=T[Ya]=T[Ia]=T[Xa]=T[ja]=T[Va]=T[Wa]=T[Ua]=T[Ga]=T[Ka]=T[za]=T[Ha]=T[Ja]=T[Qa]=false;function li(e){return N(e)&&ce(e.length)&&!!T[B(e)]}var pr=li;function fi(e){return function(t){return e(t)}}var dr=fi;var mr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Fe=mr&&typeof module=="object"&&module&&!module.nodeType&&module,ui=Fe&&Fe.exports===mr,wt=ui&&Ie.process,pi=(function(){try{var e=Fe&&Fe.require&&Fe.require("util").types;return e||wt&&wt.binding&&wt.binding("util")}catch{}})(),xt=pi;var cr=xt&&xt.isTypedArray,di=cr?dr(cr):pr,ye=di;var mi=Object.prototype,ci=mi.hasOwnProperty;function gi(e,t){var r=_(e),o=!r&&ge(e),n=!r&&!o&&ae(e),a=!r&&!o&&!n&&ye(e),i=r||o||n||a,s=i?ar(e.length,String):[],l=s.length;for(var p in e)(t||ci.call(e,p))&&!(i&&(p=="length"||n&&(p=="offset"||p=="parent")||a&&(p=="buffer"||p=="byteLength"||p=="byteOffset")||de(p,l)))&&s.push(p);return s}var gr=gi;function yi(e,t){return function(r){return e(t(r))}}var yr=yi;var hi=yr(Object.keys,Object),hr=hi;var wi=Object.prototype,xi=wi.hasOwnProperty;function bi(e){if(!Ue(e))return hr(e);var t=[];for(var r in Object(e))xi.call(e,r)&&r!="constructor"&&t.push(r);return t}var Ge=bi;function Oi(e){return z(e)?gr(e):Ge(e)}var he=Oi;var $i=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Ai=/^\w*$/;function vi(e,t){if(_(e))return false;var r=typeof e;return r=="number"||r=="symbol"||r=="boolean"||e==null||pe(e)?true:Ai.test(e)||!$i.test(e)||t!=null&&e in Object(t)}var we=vi;var Ei=C(Object,"create"),V=Ei;function Ri(){this.__data__=V?V(null):{},this.size=0;}var wr=Ri;function Si(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var xr=Si;var ki="__lodash_hash_undefined__",Ti=Object.prototype,Mi=Ti.hasOwnProperty;function _i(e){var t=this.__data__;if(V){var r=t[e];return r===ki?void 0:r}return Mi.call(t,e)?t[e]:void 0}var br=_i;var Pi=Object.prototype,Fi=Pi.hasOwnProperty;function Ci(e){var t=this.__data__;return V?t[e]!==void 0:Fi.call(t,e)}var Or=Ci;var Di="__lodash_hash_undefined__";function Bi(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=V&&t===void 0?Di:t,this}var $r=Bi;function xe(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var o=e[t];this.set(o[0],o[1]);}}xe.prototype.clear=wr;xe.prototype.delete=xr;xe.prototype.get=br;xe.prototype.has=Or;xe.prototype.set=$r;var bt=xe;function Ni(){this.__data__=[],this.size=0;}var Ar=Ni;function qi(e,t){for(var r=e.length;r--;)if(me(e[r][0],t))return r;return -1}var H=qi;var Li=Array.prototype,Ii=Li.splice;function ji(e){var t=this.__data__,r=H(t,e);if(r<0)return false;var o=t.length-1;return r==o?t.pop():Ii.call(t,r,1),--this.size,true}var vr=ji;function Vi(e){var t=this.__data__,r=H(t,e);return r<0?void 0:t[r][1]}var Er=Vi;function Wi(e){return H(this.__data__,e)>-1}var Rr=Wi;function Ui(e,t){var r=this.__data__,o=H(r,e);return o<0?(++this.size,r.push([e,t])):r[o][1]=t,this}var Sr=Ui;function be(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var o=e[t];this.set(o[0],o[1]);}}be.prototype.clear=Ar;be.prototype.delete=vr;be.prototype.get=Er;be.prototype.has=Rr;be.prototype.set=Sr;var J=be;var Gi=C(P,"Map"),Q=Gi;function Ki(){this.size=0,this.__data__={hash:new bt,map:new(Q||J),string:new bt};}var kr=Ki;function zi(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}var Tr=zi;function Hi(e,t){var r=e.__data__;return Tr(t)?r[typeof t=="string"?"string":"hash"]:r.map}var Y=Hi;function Ji(e){var t=Y(this,e).delete(e);return this.size-=t?1:0,t}var Mr=Ji;function Qi(e){return Y(this,e).get(e)}var _r=Qi;function Yi(e){return Y(this,e).has(e)}var Pr=Yi;function Xi(e,t){var r=Y(this,e),o=r.size;return r.set(e,t),this.size+=r.size==o?0:1,this}var Fr=Xi;function Oe(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var o=e[t];this.set(o[0],o[1]);}}Oe.prototype.clear=kr;Oe.prototype.delete=Mr;Oe.prototype.get=_r;Oe.prototype.has=Pr;Oe.prototype.set=Fr;var ie=Oe;var Zi="Expected a function";function Ot(e,t){if(typeof e!="function"||t!=null&&typeof t!="function")throw new TypeError(Zi);var r=function(){var o=arguments,n=t?t.apply(this,o):o[0],a=r.cache;if(a.has(n))return a.get(n);var i=e.apply(this,o);return r.cache=a.set(n,i)||a,i};return r.cache=new(Ot.Cache||ie),r}Ot.Cache=ie;var Cr=Ot;var es=500;function ts(e){var t=Cr(e,function(o){return r.size===es&&r.clear(),o}),r=t.cache;return t}var Dr=ts;var rs=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,os=/\\(\\)?/g,ns=Dr(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(rs,function(r,o,n,a){t.push(n?a.replace(os,"$1"):o||r);}),t}),Br=ns;function as(e){return e==null?"":Yt(e)}var Nr=as;function is(e,t){return _(e)?e:we(e,t)?[e]:Br(Nr(e))}var Ke=is;function ls(e){if(typeof e=="string"||pe(e))return e;var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var X=ls;function fs(e,t){t=Ke(t,e);for(var r=0,o=t.length;e!=null&&r<o;)e=e[X(t[r++])];return r&&r==o?e:void 0}var ze=fs;function us(e,t,r){var o=e==null?void 0:ze(e,t);return o===void 0?r:o}var R=us;function ps(e,t){for(var r=-1,o=t.length,n=e.length;++r<o;)e[n+r]=t[r];return e}var qr=ps;function ds(){this.__data__=new J,this.size=0;}var Lr=ds;function ms(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}var Ir=ms;function cs(e){return this.__data__.get(e)}var jr=cs;function gs(e){return this.__data__.has(e)}var Vr=gs;var ys=200;function hs(e,t){var r=this.__data__;if(r instanceof J){var o=r.__data__;if(!Q||o.length<ys-1)return o.push([e,t]),this.size=++r.size,this;r=this.__data__=new ie(o);}return r.set(e,t),this.size=r.size,this}var Wr=hs;function $e(e){var t=this.__data__=new J(e);this.size=t.size;}$e.prototype.clear=Lr;$e.prototype.delete=Ir;$e.prototype.get=jr;$e.prototype.has=Vr;$e.prototype.set=Wr;var Ae=$e;function ws(e,t){for(var r=-1,o=e==null?0:e.length,n=0,a=[];++r<o;){var i=e[r];t(i,r,e)&&(a[n++]=i);}return a}var Ur=ws;function xs(){return []}var Gr=xs;var bs=Object.prototype,Os=bs.propertyIsEnumerable,Kr=Object.getOwnPropertySymbols,$s=Kr?function(e){return e==null?[]:(e=Object(e),Ur(Kr(e),function(t){return Os.call(e,t)}))}:Gr,zr=$s;function As(e,t,r){var o=t(e);return _(e)?o:qr(o,r(e))}var Hr=As;function vs(e){return Hr(e,he,zr)}var $t=vs;var Es=C(P,"DataView"),He=Es;var Rs=C(P,"Promise"),Je=Rs;var Ss=C(P,"Set"),Qe=Ss;var Jr="[object Map]",ks="[object Object]",Qr="[object Promise]",Yr="[object Set]",Xr="[object WeakMap]",Zr="[object DataView]",Ts=j(He),Ms=j(Q),_s=j(Je),Ps=j(Qe),Fs=j(We),se=B;(He&&se(new He(new ArrayBuffer(1)))!=Zr||Q&&se(new Q)!=Jr||Je&&se(Je.resolve())!=Qr||Qe&&se(new Qe)!=Yr||We&&se(new We)!=Xr)&&(se=function(e){var t=B(e),r=t==ks?e.constructor:void 0,o=r?j(r):"";if(o)switch(o){case Ts:return Zr;case Ms:return Jr;case _s:return Qr;case Ps:return Yr;case Fs:return Xr}return t});var Ce=se;var Cs=P.Uint8Array,At=Cs;var Ds="__lodash_hash_undefined__";function Bs(e){return this.__data__.set(e,Ds),this}var eo=Bs;function Ns(e){return this.__data__.has(e)}var to=Ns;function Ye(e){var t=-1,r=e==null?0:e.length;for(this.__data__=new ie;++t<r;)this.add(e[t]);}Ye.prototype.add=Ye.prototype.push=eo;Ye.prototype.has=to;var ro=Ye;function qs(e,t){for(var r=-1,o=e==null?0:e.length;++r<o;)if(t(e[r],r,e))return true;return false}var Xe=qs;function Ls(e,t){return e.has(t)}var oo=Ls;var Is=1,js=2;function Vs(e,t,r,o,n,a){var i=r&Is,s=e.length,l=t.length;if(s!=l&&!(i&&l>s))return false;var p=a.get(e),u=a.get(t);if(p&&u)return p==t&&u==e;var d=-1,m=true,c=r&js?new ro:void 0;for(a.set(e,t),a.set(t,e);++d<s;){var h=e[d],w=t[d];if(o)var g=i?o(w,h,d,t,e,a):o(h,w,d,e,t,a);if(g!==void 0){if(g)continue;m=false;break}if(c){if(!Xe(t,function(v,M){if(!oo(c,M)&&(h===v||n(h,v,r,o,a)))return c.push(M)})){m=false;break}}else if(!(h===w||n(h,w,r,o,a))){m=false;break}}return a.delete(e),a.delete(t),m}var Ze=Vs;function Ws(e){var t=-1,r=Array(e.size);return e.forEach(function(o,n){r[++t]=[n,o];}),r}var no=Ws;function Us(e){var t=-1,r=Array(e.size);return e.forEach(function(o){r[++t]=o;}),r}var ao=Us;var Gs=1,Ks=2,zs="[object Boolean]",Hs="[object Date]",Js="[object Error]",Qs="[object Map]",Ys="[object Number]",Xs="[object RegExp]",Zs="[object Set]",el="[object String]",tl="[object Symbol]",rl="[object ArrayBuffer]",ol="[object DataView]",io=D?D.prototype:void 0,vt=io?io.valueOf:void 0;function nl(e,t,r,o,n,a,i){switch(r){case ol:if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return false;e=e.buffer,t=t.buffer;case rl:return !(e.byteLength!=t.byteLength||!a(new At(e),new At(t)));case zs:case Hs:case Ys:return me(+e,+t);case Js:return e.name==t.name&&e.message==t.message;case Xs:case el:return e==t+"";case Qs:var s=no;case Zs:var l=o&Gs;if(s||(s=ao),e.size!=t.size&&!l)return false;var p=i.get(e);if(p)return p==t;o|=Ks,i.set(e,t);var u=Ze(s(e),s(t),o,n,a,i);return i.delete(e),u;case tl:if(vt)return vt.call(e)==vt.call(t)}return false}var so=nl;var al=1,il=Object.prototype,sl=il.hasOwnProperty;function ll(e,t,r,o,n,a){var i=r&al,s=$t(e),l=s.length,p=$t(t),u=p.length;if(l!=u&&!i)return false;for(var d=l;d--;){var m=s[d];if(!(i?m in t:sl.call(t,m)))return false}var c=a.get(e),h=a.get(t);if(c&&h)return c==t&&h==e;var w=true;a.set(e,t),a.set(t,e);for(var g=i;++d<l;){m=s[d];var v=e[m],M=t[m];if(o)var S=i?o(M,v,m,t,e,a):o(v,M,m,e,t,a);if(!(S===void 0?v===M||n(v,M,r,o,a):S)){w=false;break}g||(g=m=="constructor");}if(w&&!g){var E=e.constructor,$=t.constructor;E!=$&&"constructor"in e&&"constructor"in t&&!(typeof E=="function"&&E instanceof E&&typeof $=="function"&&$ instanceof $)&&(w=false);}return a.delete(e),a.delete(t),w}var lo=ll;var fl=1,fo="[object Arguments]",uo="[object Array]",et="[object Object]",ul=Object.prototype,po=ul.hasOwnProperty;function pl(e,t,r,o,n,a){var i=_(e),s=_(t),l=i?uo:Ce(e),p=s?uo:Ce(t);l=l==fo?et:l,p=p==fo?et:p;var u=l==et,d=p==et,m=l==p;if(m&&ae(e)){if(!ae(t))return false;i=true,u=false;}if(m&&!u)return a||(a=new Ae),i||ye(e)?Ze(e,t,r,o,n,a):so(e,t,l,r,o,n,a);if(!(r&fl)){var c=u&&po.call(e,"__wrapped__"),h=d&&po.call(t,"__wrapped__");if(c||h){var w=c?e.value():e,g=h?t.value():t;return a||(a=new Ae),n(w,g,r,o,a)}}return m?(a||(a=new Ae),lo(e,t,r,o,n,a)):false}var mo=pl;function co(e,t,r,o,n){return e===t?true:e==null||t==null||!N(e)&&!N(t)?e!==e&&t!==t:mo(e,t,r,o,co,n)}var tt=co;var dl=1,ml=2;function cl(e,t,r,o){var n=r.length,a=n,i=!o;if(e==null)return !a;for(e=Object(e);n--;){var s=r[n];if(i&&s[2]?s[1]!==e[s[0]]:!(s[0]in e))return false}for(;++n<a;){s=r[n];var l=s[0],p=e[l],u=s[1];if(i&&s[2]){if(p===void 0&&!(l in e))return false}else {var d=new Ae;if(o)var m=o(p,u,l,e,t,d);if(!(m===void 0?tt(u,p,dl|ml,o,d):m))return false}}return true}var go=cl;function gl(e){return e===e&&!q(e)}var rt=gl;function yl(e){for(var t=he(e),r=t.length;r--;){var o=t[r],n=e[o];t[r]=[o,n,rt(n)];}return t}var yo=yl;function hl(e,t){return function(r){return r==null?false:r[e]===t&&(t!==void 0||e in Object(r))}}var ot=hl;function wl(e){var t=yo(e);return t.length==1&&t[0][2]?ot(t[0][0],t[0][1]):function(r){return r===e||go(r,e,t)}}var ho=wl;function xl(e,t){return e!=null&&t in Object(e)}var wo=xl;function bl(e,t,r){t=Ke(t,e);for(var o=-1,n=t.length,a=false;++o<n;){var i=X(t[o]);if(!(a=e!=null&&r(e,i)))break;e=e[i];}return a||++o!=n?a:(n=e==null?0:e.length,!!n&&ce(n)&&de(i,n)&&(_(e)||ge(e)))}var xo=bl;function Ol(e,t){return e!=null&&xo(e,t,wo)}var bo=Ol;var $l=1,Al=2;function vl(e,t){return we(e)&&rt(t)?ot(X(e),t):function(r){var o=R(r,e);return o===void 0&&o===t?bo(r,e):tt(t,o,$l|Al)}}var Oo=vl;function El(e){return function(t){return t?.[e]}}var $o=El;function Rl(e){return function(t){return ze(t,e)}}var Ao=Rl;function Sl(e){return we(e)?$o(X(e)):Ao(e)}var vo=Sl;function kl(e){return typeof e=="function"?e:e==null?Xt:typeof e=="object"?_(e)?Oo(e[0],e[1]):ho(e):vo(e)}var nt=kl;function Tl(e,t,r,o){for(var n=-1,a=e==null?0:e.length;++n<a;){var i=e[n];t(o,i,r(i),e);}return o}var Eo=Tl;function Ml(e){return function(t,r,o){for(var n=-1,a=Object(t),i=o(t),s=i.length;s--;){var l=i[e?s:++n];if(r(a[l],l,a)===false)break}return t}}var Ro=Ml;var _l=Ro(),So=_l;function Pl(e,t){return e&&So(e,t,he)}var ko=Pl;function Fl(e,t){return function(r,o){if(r==null)return r;if(!z(r))return e(r,o);for(var n=r.length,a=t?n:-1,i=Object(r);(t?a--:++a<n)&&o(i[a],a,i)!==false;);return r}}var To=Fl;var Cl=To(ko),at=Cl;function Dl(e,t,r,o){return at(e,function(n,a,i){t(o,n,r(n),i);}),o}var Mo=Dl;function Bl(e,t){return function(r,o){var n=_(r)?Eo:Mo,a=t?t():{};return n(r,e,nt(o),a)}}var _o=Bl;var Nl=Object.prototype,ql=Nl.hasOwnProperty,Ll=_o(function(e,t,r){ql.call(e,r)?e[r].push(t):or(e,r,[t]);}),Et=Ll;var Il="[object Map]",jl="[object Set]",Vl=Object.prototype,Wl=Vl.hasOwnProperty;function Ul(e){if(e==null)return true;if(z(e)&&(_(e)||typeof e=="string"||typeof e.splice=="function"||ae(e)||ye(e)||ge(e)))return !e.length;var t=Ce(e);if(t==Il||t==jl)return !e.size;if(Ue(e))return !Ge(e).length;for(var r in e)if(Wl.call(e,r))return false;return true}var it=Ul;function Gl(e,t){var r;return at(e,function(o,n,a){return r=t(o,n,a),!r}),!!r}var Po=Gl;function Kl(e,t,r){var o=_(e)?Xe:Po;return r&&nr(e,t,r)&&(t=void 0),o(e,nt(t))}var Rt=Kl;var f={equals:"equals",notEquals:"notEquals",lessThan:"lessThan",lessThanEquals:"lessThanEquals",greaterThan:"greaterThan",greaterThanEquals:"greaterThanEquals",contains:"contains",notContains:"notContains",in:"in",notIn:"notIn",matches:"matches",notMatches:"notMatches",between:"between",notBetween:"notBetween",isEmpty:"isEmpty",notEmpty:"notEmpty",exists:"exists",notExists:"notExists",startsWith:"startsWith",endsWith:"endsWith"},y={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},x={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};W.extend(Ql);W.extend(Jl);W.extend(Hl);W.extend(zl);var Fo=(e,t,r)=>{let o=R(t,e.field);if(!o)throw new Error(`${e.field} is null or undefined`);if(!kt(o))throw new Error(`${e.field} is not a valid date: ${String(o)}`);let n=W(o);if(!n.isValid())throw new Error(`${e.field} is not a valid date: ${o}`);let a=p=>e.error||`${e.field} ${p}`,i=Yl(e,t,r,n,o),s=i[0],l=i[1];switch(e.dateOperator){case x.before:return n.isBefore(s)||a(`must be before ${s.format()}`);case x.after:return n.isAfter(s)||a(`must be after ${s.format()}`);case x.onOrBefore:return n.isSameOrBefore(s)||a(`must be on or before ${s.format()}`);case x.onOrAfter:return n.isSameOrAfter(s)||a(`must be on or after ${s.format()}`);case x.between:{if(!l)throw new Error("between operator requires an end date");return n.isSameOrAfter(s)&&n.isSameOrBefore(l)||a(`must be between ${s.format()} and ${l?.format()}`)}case x.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return n.isBefore(s)||n.isAfter(l)||a(`must not be between ${s.format()} and ${l?.format()}`)}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let p=n.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return u.includes(p)||a(`must be on ${u.join(" or ")}`)}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let p=n.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return !u.includes(p)||a(`must not be on ${u.join(" or ")}`)}default:throw new Error("Unknown date operator")}},Yl=(e,t,r,o,n)=>{if([x.between,x.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[s,l]=e.value,p=St(s,n),u=St(l,n);if(!p.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!u.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[d,m]=p.isBefore(u)||p.isSame(u)?[p,u]:[u,p];return [d,m]}if([x.before,x.after,x.onOrBefore,x.onOrAfter].includes(e.dateOperator)){let s;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);s=e.value;}else if(e.path)if(e.path.startsWith("$.")){let p=R(t,e.path.substring(2));s=kt(p)?p:void 0;}else {let p=R(r,e.path);s=kt(p)?p:void 0;}else throw new Error("No value or path specified for date comparison");let l=St(s,n);if(!l.isValid())throw new Error(`Invalid comparison date: ${s}`);return [l,void 0]}return [W(),void 0]},St=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return W(e);let n=String(t),a=0;if(n.includes("+")||n.includes("T")&&n.match(/T.*-\d{2}:/)){let s=n.match(/([+-])(\d{2}):(\d{2})/);s&&(a=(s[1]==="+"?1:-1)*(parseInt(s[2],10)*60+parseInt(s[3],10)));}else n.includes("Z")||(a=0);return r.match(/^\d{4}-\d{2}-\d{2}$/)?W(`${e}T00:00:00`).subtract(a,"minute"):W(e).subtract(a,"minute")},kt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var No=(e,t,r)=>{let o=R(t,e.field),a=![f.isEmpty,f.notEmpty,f.exists,f.notExists].includes(e.operator),i=a?Xl(e,t,r):void 0,s=l=>e.error||`${e.field} ${l}${a?` ${JSON.stringify(i)}`:""}`;switch(e.operator){case f.equals:return o===i||s("must equal");case f.notEquals:return o!==i||s("must not equal");case f.lessThan:return st(o,i,"lt")||s("must be less than");case f.lessThanEquals:return st(o,i,"lte")||s("must be less than or equal to");case f.greaterThan:return st(o,i,"gt")||s("must be greater than");case f.greaterThanEquals:return st(o,i,"gte")||s("must be greater than or equal to");case f.in:return Array.isArray(i)&&i.includes(o)||s("must be one of");case f.notIn:return !Array.isArray(i)||!i.includes(o)||s("must not be one of");case f.contains:return Bo(o,i)||s("must contain");case f.notContains:return !Bo(o,i)||s("must not contain");case f.matches:return Co(o)&&(i instanceof RegExp||typeof i=="string")&&!!o.match(i)||s("must match pattern");case f.notMatches:return !Co(o)||!(i instanceof RegExp||typeof i=="string")||!o.match(i)||s("must not match pattern");case f.between:{let l=Do(i);if(!l)throw new Error("between operator requires an array of two values");if(!ve(o))return s("must be between");let p=Ee(o),[u,d]=l;return p>=u&&p<=d||s("must be between")}case f.notBetween:{let l=Do(i);if(!l)throw new Error("notBetween operator requires an array of two values");if(!ve(o))return true;let p=Ee(o),[u,d]=l;return p<u||p>d||s("must not be between")}case f.isEmpty:return it(o)||s("must be empty");case f.notEmpty:return !it(o)||s("must not be empty");case f.exists:return o!==void 0||s("must exist");case f.notExists:return o===void 0||s("must not exist");case f.startsWith:return typeof o=="string"&&typeof i=="string"&&o.startsWith(i)||s("must start with");case f.endsWith:return typeof o=="string"&&typeof i=="string"&&o.endsWith(i)||s("must end with");default:throw new Error("Unknown operator")}},Xl=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?R(t,e.path.substring(2)):R(r,e.path);throw new Error("No value or path specified")},ve=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ee=e=>e instanceof Date?e.getTime():e,st=(e,t,r)=>{if(!ve(e)||!ve(t))return false;let o=Ee(e),n=Ee(t);switch(r){case "lt":return o<n;case "lte":return o<=n;case "gt":return o>n;case "gte":return o>=n}},Co=e=>typeof e=="string",Do=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!ve(t)||!ve(r))return null;let o=Ee(t),n=Ee(r);return o<=n?[o,n]:[n,o]},Bo=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var Tt=e=>{if(typeof e!="boolean"){if("all"in e){for(let t of e.all)Tt(t);return}if("any"in e){for(let t of e.any)Tt(t);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},le=(e,t,r)=>{if(Array.isArray(t)&&Tt(e),typeof e=="boolean")return e;let o={...r,context:r?.context??t};return "all"in e?Zl(e.all,t,o,e.error):"any"in e?ef(e.any,t,o,e.error):"arrayOperator"in e?of(e,t,o):"dateOperator"in e?Fo(e,t,o.context):"aggregate"in e?rf(e,t,o):"field"in e?No(e,t,o.context):"if"in e?tf(e,t,o):false},Zl=(e,t,r,o)=>{let n=[];for(let a of e){let i=le(a,t,r);i!==true&&(typeof i=="string"?n.push(i):n.push("false"));}return n.length?o||(n.length===1?n[0]:`All conditions must pass: ${n.join(" AND ")}`):true},ef=(e,t,r,o)=>{let n=[];for(let a of e){let i=le(a,t,r);if(i===true)return true;typeof i=="string"&&n.push(i);}return o||(n.length===1?n[0]:`At least one condition must pass: ${n.join(" OR ")}`)},tf=(e,t,r)=>le(e.if,t,r)===true?le(e.then,t,r):e.else!==void 0?le(e.else,t,r):true,rf=(e,t,r)=>{let o=R(t,e.field);if(!Array.isArray(o))throw new Error(`${e.field} must be an array`);let{mode:n,field:a}=e.aggregate;if(n!=="sum"&&n!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let i=e.condition,l=(i?o.filter(h=>le(i,h,r)===true):o).map((h,w)=>{let g=a?R(h,a):h;if(typeof g!="number"||!Number.isFinite(g)){let v=`${e.field}[${w}]${a?`.${a}`:""}`;throw new Error(`${v} must be a finite number`)}return g}),p=l.reduce((h,w)=>h+w,0),u=n==="sum"?p:l.length===0?0:p/l.length,d=r.context,m;if(e.value!==void 0)m=e.value;else if(e.path)m=e.path.startsWith("$.")?R(t,e.path.substring(2)):R(d,e.path);else throw new Error("Aggregate rule requires value or path");let c=h=>e.error||`${e.field} ${n} ${h} ${JSON.stringify(m)}`;switch(e.operator){case f.equals:return u===m||c("must equal");case f.notEquals:return u!==m||c("must not equal");case f.lessThan:return typeof m=="number"&&u<m||c("must be less than");case f.lessThanEquals:return typeof m=="number"&&u<=m||c("must be less than or equal to");case f.greaterThan:return typeof m=="number"&&u>m||c("must be greater than");case f.greaterThanEquals:return typeof m=="number"&&u>=m||c("must be greater than or equal to");case f.between:{if(!Array.isArray(m)||m.length!==2)throw new Error("between requires a two-element array");let[h,w]=m,[g,v]=h<=w?[h,w]:[w,h];return u>=g&&u<=v||c("must be between")}case f.notBetween:{if(!Array.isArray(m)||m.length!==2)throw new Error("notBetween requires a two-element array");let[h,w]=m,[g,v]=h<=w?[h,w]:[w,h];return u<g||u>v||c("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},of=(e,t,r)=>{let o=e.field?R(t,e.field):t;if(!Array.isArray(o))throw new Error(`${e.field||"(root)"} must be an array`);let n=d=>e.error||`${e.field} ${d}`,a=[y.all,y.any,y.none,y.atLeast,y.atMost,y.exactly],i=[y.atLeast,y.atMost,y.exactly],s=e.condition;if(a.includes(e.arrayOperator)&&!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(i.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let p=0,u=0;if(a.includes(e.arrayOperator)){if(!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!Rt(o,q))return n("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let d=o.map(m=>le(s,m,r));p=d.filter(m=>m===true).length,u=d.filter(m=>typeof m=="string").length;}switch(e.arrayOperator){case y.empty:return !o.length||n("must be empty");case y.notEmpty:return !!o.length||n("must not be empty");case y.all:return p===o.length||n(`all elements must match (${u} failed)`);case y.any:return !!p||n("at least one element must match");case y.none:return !p||n(`no elements should match (${p} matched)`);case y.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p>=l||n(`at least ${l} elements must match (${p} matched)`);case y.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p<=l||n(`at most ${l} elements must match (${p} matched)`);case y.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p===l||n(`exactly ${l} elements must match (${p} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var qo=(e,t,r,o)=>{let n={};for(let a of e){let i=a[t];if(i==null)continue;let s=String(i);if(n[s]!==void 0){let l=o==="one"?`endpoint[0] must be the "one" side of a oneToMany bridge \u2014 swap endpoints if '${r}' is the "many" side`:`oneToOne bridges require unique '${t}' on both endpoints`;throw new Error(`buildBridgeDictionary: duplicate '${t}' value '${s}' on '${r}' \u2014 ${l}.`)}n[s]=a;}return n},nf=(e,t)=>{let r={};for(let o of e.bridges??[]){let[n,a]=o.endpoints,i=`${n.fieldMap}:${n.model}`,s=`${a.fieldMap}:${a.model}`,l=o.cardinality==="oneToMany"?"one":"oneToOne";if(t[i]&&(r[n.fieldMap]??={},r[n.fieldMap][n.model]??={},r[n.fieldMap][n.model][n.on]=qo(t[i],n.on,i,l)),t[s])if(r[a.fieldMap]??={},r[a.fieldMap][a.model]??={},o.cardinality==="oneToMany"){let p=t[s].filter(u=>u[a.on]!==null&&u[a.on]!==void 0);r[a.fieldMap][a.model][a.on]=Et(p,a.on);}else r[a.fieldMap][a.model][a.on]=qo(t[s],a.on,s,"oneToOne");}return r};var Mt=e=>{let t={maps:structuredClone(e.maps),bridges:e.bridges?structuredClone(e.bridges):void 0};for(let r of e.bridges??[]){let[o,n]=r.endpoints,a=t.maps[o.fieldMap]?.models[o.model],i=t.maps[n.fieldMap]?.models[n.model];if(!a)throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' not found`);if(!i)throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' not found`);if(o.fieldMap===n.fieldMap&&o.model===n.model)throw new Error(`stitchFieldMaps: self-bridge '${o.fieldMap}:${o.model}' to itself is not supported`);if(!a.fields[o.on])throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' has no field '${o.on}' for join`);if(!i.fields[n.on])throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' has no field '${n.on}' for join`);let s=`${o.fieldMap}:${o.model}`,l=`${n.fieldMap}:${n.model}`;if(a.fields[l])throw new Error(`stitchFieldMaps: bridge '${l}' already injected on '${s}'`);if(i.fields[s])throw new Error(`stitchFieldMaps: bridge '${s}' already injected on '${l}'`);let p=r.cardinality==="oneToMany";a.fields[l]={kind:"bridge",type:l,isList:p},i.fields[s]={kind:"bridge",type:s,isList:false};}return t};var af=/[.:]/,Lo=e=>{let t=[];for(let[r,o]of Object.entries(e.maps))for(let[n,a]of Object.entries(o.models))for(let[i,s]of Object.entries(a.fields))s.kind!=="bridge"&&af.test(i)&&t.push(`'${r}:${n}.${i}' contains forbidden character . or :`);if(t.length)throw new Error(`validateFieldMapSet:
1
+ import z from'dayjs';import _f from'dayjs/plugin/isSameOrAfter.js';import Pf from'dayjs/plugin/isSameOrBefore.js';import kf from'dayjs/plugin/timezone.js';import Sf from'dayjs/plugin/utc.js';import Af from'dayjs/plugin/isoWeek.js';import Rf from'dayjs/plugin/quarterOfYear.js';var Xo=typeof global=="object"&&global&&global.Object===Object&&global,Ze=Xo;var ea=typeof self=="object"&&self&&self.Object===Object&&self,ta=Ze||ea||Function("return this")(),_=ta;var ra=_.Symbol,B=ra;var ur=Object.prototype,na=ur.hasOwnProperty,oa=ur.toString,We=B?B.toStringTag:void 0;function aa(e){var t=na.call(e,We),r=e[We];try{e[We]=void 0;var n=!0;}catch{}var o=oa.call(e);return n&&(t?e[We]=r:delete e[We]),o}var pr=aa;var ia=Object.prototype,sa=ia.toString;function la(e){return sa.call(e)}var dr=la;var fa="[object Null]",ua="[object Undefined]",mr=B?B.toStringTag:void 0;function pa(e){return e==null?e===void 0?ua:fa:mr&&mr in Object(e)?pr(e):dr(e)}var q=pa;function da(e){return e!=null&&typeof e=="object"}var N=da;var ma="[object Symbol]";function ca(e){return typeof e=="symbol"||N(e)&&q(e)==ma}var V=ca;function ga(e,t){for(var r=-1,n=e==null?0:e.length,o=Array(n);++r<n;)o[r]=t(e[r],r,e);return o}var ye=ga;var ya=Array.isArray,k=ya;var cr=B?B.prototype:void 0,gr=cr?cr.toString:void 0;function yr(e){if(typeof e=="string")return e;if(k(e))return ye(e,yr)+"";if(V(e))return gr?gr.call(e):"";var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var hr=yr;function wa(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var L=wa;function xa(e){return e}var Xe=xa;var ba="[object AsyncFunction]",Oa="[object Function]",Ea="[object GeneratorFunction]",va="[object Proxy]";function $a(e){if(!L(e))return false;var t=q(e);return t==Oa||t==Ea||t==ba||t==va}var et=$a;var Aa=_["__core-js_shared__"],tt=Aa;var wr=(function(){var e=/[^.]+$/.exec(tt&&tt.keys&&tt.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function Ra(e){return !!wr&&wr in e}var xr=Ra;var ka=Function.prototype,Sa=ka.toString;function Ta(e){if(e!=null){try{return Sa.call(e)}catch{}try{return e+""}catch{}}return ""}var U=Ta;var Da=/[\\^$.*+?()[\]{}|]/g,Ma=/^\[object .+?Constructor\]$/,_a=Function.prototype,Pa=Object.prototype,Ca=_a.toString,Fa=Pa.hasOwnProperty,Ba=RegExp("^"+Ca.call(Fa).replace(Da,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function qa(e){if(!L(e)||xr(e))return false;var t=et(e)?Ba:Ma;return t.test(U(e))}var br=qa;function Na(e,t){return e?.[t]}var Or=Na;function La(e,t){var r=Or(e,t);return br(r)?r:void 0}var F=La;var Ia=F(_,"WeakMap"),rt=Ia;var ja=(function(){try{var e=F(Object,"defineProperty");return e({},"",{}),e}catch{}})(),_t=ja;var Wa=9007199254740991,Va=/^(?:0|[1-9]\d*)$/;function Ua(e,t){var r=typeof e;return t=t??Wa,!!t&&(r=="number"||r!="symbol"&&Va.test(e))&&e>-1&&e%1==0&&e<t}var he=Ua;function Ga(e,t,r){t=="__proto__"&&_t?_t(e,t,{configurable:true,enumerable:true,value:r,writable:true}):e[t]=r;}var Er=Ga;function Ka(e,t){return e===t||e!==e&&t!==t}var we=Ka;var za=9007199254740991;function Ha(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=za}var xe=Ha;function Ja(e){return e!=null&&xe(e.length)&&!et(e)}var I=Ja;function Qa(e,t,r){if(!L(r))return false;var n=typeof t;return (n=="number"?I(r)&&he(t,r.length):n=="string"&&t in r)?we(r[t],e):false}var vr=Qa;var Ya=Object.prototype;function Za(e){var t=e&&e.constructor,r=typeof t=="function"&&t.prototype||Ya;return e===r}var nt=Za;function Xa(e,t){for(var r=-1,n=Array(e);++r<e;)n[r]=t(r);return n}var $r=Xa;var ei="[object Arguments]";function ti(e){return N(e)&&q(e)==ei}var Pt=ti;var Ar=Object.prototype,ri=Ar.hasOwnProperty,ni=Ar.propertyIsEnumerable,oi=Pt((function(){return arguments})())?Pt:function(e){return N(e)&&ri.call(e,"callee")&&!ni.call(e,"callee")},be=oi;function ai(){return false}var Rr=ai;var Tr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,kr=Tr&&typeof module=="object"&&module&&!module.nodeType&&module,ii=kr&&kr.exports===Tr,Sr=ii?_.Buffer:void 0,si=Sr?Sr.isBuffer:void 0,li=si||Rr,fe=li;var fi="[object Arguments]",ui="[object Array]",pi="[object Boolean]",di="[object Date]",mi="[object Error]",ci="[object Function]",gi="[object Map]",yi="[object Number]",hi="[object Object]",wi="[object RegExp]",xi="[object Set]",bi="[object String]",Oi="[object WeakMap]",Ei="[object ArrayBuffer]",vi="[object DataView]",$i="[object Float32Array]",Ai="[object Float64Array]",Ri="[object Int8Array]",ki="[object Int16Array]",Si="[object Int32Array]",Ti="[object Uint8Array]",Di="[object Uint8ClampedArray]",Mi="[object Uint16Array]",_i="[object Uint32Array]",M={};M[$i]=M[Ai]=M[Ri]=M[ki]=M[Si]=M[Ti]=M[Di]=M[Mi]=M[_i]=true;M[fi]=M[ui]=M[Ei]=M[pi]=M[vi]=M[di]=M[mi]=M[ci]=M[gi]=M[yi]=M[hi]=M[wi]=M[xi]=M[bi]=M[Oi]=false;function Pi(e){return N(e)&&xe(e.length)&&!!M[q(e)]}var Dr=Pi;function Ci(e){return function(t){return e(t)}}var ot=Ci;var Mr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Ve=Mr&&typeof module=="object"&&module&&!module.nodeType&&module,Fi=Ve&&Ve.exports===Mr,Ct=Fi&&Ze.process,Bi=(function(){try{var e=Ve&&Ve.require&&Ve.require("util").types;return e||Ct&&Ct.binding&&Ct.binding("util")}catch{}})(),Ft=Bi;var _r=Ft&&Ft.isTypedArray,qi=_r?ot(_r):Dr,Oe=qi;var Ni=Object.prototype,Li=Ni.hasOwnProperty;function Ii(e,t){var r=k(e),n=!r&&be(e),o=!r&&!n&&fe(e),a=!r&&!n&&!o&&Oe(e),i=r||n||o||a,s=i?$r(e.length,String):[],l=s.length;for(var p in e)(t||Li.call(e,p))&&!(i&&(p=="length"||o&&(p=="offset"||p=="parent")||a&&(p=="buffer"||p=="byteLength"||p=="byteOffset")||he(p,l)))&&s.push(p);return s}var Pr=Ii;function ji(e,t){return function(r){return e(t(r))}}var Cr=ji;var Wi=Cr(Object.keys,Object),Fr=Wi;var Vi=Object.prototype,Ui=Vi.hasOwnProperty;function Gi(e){if(!nt(e))return Fr(e);var t=[];for(var r in Object(e))Ui.call(e,r)&&r!="constructor"&&t.push(r);return t}var at=Gi;function Ki(e){return I(e)?Pr(e):at(e)}var Ee=Ki;var zi=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Hi=/^\w*$/;function Ji(e,t){if(k(e))return false;var r=typeof e;return r=="number"||r=="symbol"||r=="boolean"||e==null||V(e)?true:Hi.test(e)||!zi.test(e)||t!=null&&e in Object(t)}var ve=Ji;var Qi=F(Object,"create"),G=Qi;function Yi(){this.__data__=G?G(null):{},this.size=0;}var Br=Yi;function Zi(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var qr=Zi;var Xi="__lodash_hash_undefined__",es=Object.prototype,ts=es.hasOwnProperty;function rs(e){var t=this.__data__;if(G){var r=t[e];return r===Xi?void 0:r}return ts.call(t,e)?t[e]:void 0}var Nr=rs;var ns=Object.prototype,os=ns.hasOwnProperty;function as(e){var t=this.__data__;return G?t[e]!==void 0:os.call(t,e)}var Lr=as;var is="__lodash_hash_undefined__";function ss(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=G&&t===void 0?is:t,this}var Ir=ss;function $e(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}$e.prototype.clear=Br;$e.prototype.delete=qr;$e.prototype.get=Nr;$e.prototype.has=Lr;$e.prototype.set=Ir;var Bt=$e;function ls(){this.__data__=[],this.size=0;}var jr=ls;function fs(e,t){for(var r=e.length;r--;)if(we(e[r][0],t))return r;return -1}var Y=fs;var us=Array.prototype,ps=us.splice;function ds(e){var t=this.__data__,r=Y(t,e);if(r<0)return false;var n=t.length-1;return r==n?t.pop():ps.call(t,r,1),--this.size,true}var Wr=ds;function ms(e){var t=this.__data__,r=Y(t,e);return r<0?void 0:t[r][1]}var Vr=ms;function cs(e){return Y(this.__data__,e)>-1}var Ur=cs;function gs(e,t){var r=this.__data__,n=Y(r,e);return n<0?(++this.size,r.push([e,t])):r[n][1]=t,this}var Gr=gs;function Ae(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}Ae.prototype.clear=jr;Ae.prototype.delete=Wr;Ae.prototype.get=Vr;Ae.prototype.has=Ur;Ae.prototype.set=Gr;var Z=Ae;var ys=F(_,"Map"),X=ys;function hs(){this.size=0,this.__data__={hash:new Bt,map:new(X||Z),string:new Bt};}var Kr=hs;function ws(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}var zr=ws;function xs(e,t){var r=e.__data__;return zr(t)?r[typeof t=="string"?"string":"hash"]:r.map}var ee=xs;function bs(e){var t=ee(this,e).delete(e);return this.size-=t?1:0,t}var Hr=bs;function Os(e){return ee(this,e).get(e)}var Jr=Os;function Es(e){return ee(this,e).has(e)}var Qr=Es;function vs(e,t){var r=ee(this,e),n=r.size;return r.set(e,t),this.size+=r.size==n?0:1,this}var Yr=vs;function Re(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}Re.prototype.clear=Kr;Re.prototype.delete=Hr;Re.prototype.get=Jr;Re.prototype.has=Qr;Re.prototype.set=Yr;var ue=Re;var $s="Expected a function";function qt(e,t){if(typeof e!="function"||t!=null&&typeof t!="function")throw new TypeError($s);var r=function(){var n=arguments,o=t?t.apply(this,n):n[0],a=r.cache;if(a.has(o))return a.get(o);var i=e.apply(this,n);return r.cache=a.set(o,i)||a,i};return r.cache=new(qt.Cache||ue),r}qt.Cache=ue;var Zr=qt;var As=500;function Rs(e){var t=Zr(e,function(n){return r.size===As&&r.clear(),n}),r=t.cache;return t}var Xr=Rs;var ks=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,Ss=/\\(\\)?/g,Ts=Xr(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(ks,function(r,n,o,a){t.push(o?a.replace(Ss,"$1"):n||r);}),t}),en=Ts;function Ds(e){return e==null?"":hr(e)}var tn=Ds;function Ms(e,t){return k(e)?e:ve(e,t)?[e]:en(tn(e))}var it=Ms;function Ps(e){if(typeof e=="string"||V(e))return e;var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var te=Ps;function Cs(e,t){t=it(t,e);for(var r=0,n=t.length;e!=null&&r<n;)e=e[te(t[r++])];return r&&r==n?e:void 0}var ke=Cs;function Fs(e,t,r){var n=e==null?void 0:ke(e,t);return n===void 0?r:n}var S=Fs;function Bs(e,t){for(var r=-1,n=t.length,o=e.length;++r<n;)e[o+r]=t[r];return e}var rn=Bs;function qs(){this.__data__=new Z,this.size=0;}var nn=qs;function Ns(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}var on=Ns;function Ls(e){return this.__data__.get(e)}var an=Ls;function Is(e){return this.__data__.has(e)}var sn=Is;var js=200;function Ws(e,t){var r=this.__data__;if(r instanceof Z){var n=r.__data__;if(!X||n.length<js-1)return n.push([e,t]),this.size=++r.size,this;r=this.__data__=new ue(n);}return r.set(e,t),this.size=r.size,this}var ln=Ws;function Se(e){var t=this.__data__=new Z(e);this.size=t.size;}Se.prototype.clear=nn;Se.prototype.delete=on;Se.prototype.get=an;Se.prototype.has=sn;Se.prototype.set=ln;var Te=Se;function Vs(e,t){for(var r=-1,n=e==null?0:e.length,o=0,a=[];++r<n;){var i=e[r];t(i,r,e)&&(a[o++]=i);}return a}var fn=Vs;function Us(){return []}var un=Us;var Gs=Object.prototype,Ks=Gs.propertyIsEnumerable,pn=Object.getOwnPropertySymbols,zs=pn?function(e){return e==null?[]:(e=Object(e),fn(pn(e),function(t){return Ks.call(e,t)}))}:un,dn=zs;function Hs(e,t,r){var n=t(e);return k(e)?n:rn(n,r(e))}var mn=Hs;function Js(e){return mn(e,Ee,dn)}var Nt=Js;var Qs=F(_,"DataView"),st=Qs;var Ys=F(_,"Promise"),lt=Ys;var Zs=F(_,"Set"),ft=Zs;var cn="[object Map]",Xs="[object Object]",gn="[object Promise]",yn="[object Set]",hn="[object WeakMap]",wn="[object DataView]",el=U(st),tl=U(X),rl=U(lt),nl=U(ft),ol=U(rt),pe=q;(st&&pe(new st(new ArrayBuffer(1)))!=wn||X&&pe(new X)!=cn||lt&&pe(lt.resolve())!=gn||ft&&pe(new ft)!=yn||rt&&pe(new rt)!=hn)&&(pe=function(e){var t=q(e),r=t==Xs?e.constructor:void 0,n=r?U(r):"";if(n)switch(n){case el:return wn;case tl:return cn;case rl:return gn;case nl:return yn;case ol:return hn}return t});var Ue=pe;var al=_.Uint8Array,Lt=al;var il="__lodash_hash_undefined__";function sl(e){return this.__data__.set(e,il),this}var xn=sl;function ll(e){return this.__data__.has(e)}var bn=ll;function ut(e){var t=-1,r=e==null?0:e.length;for(this.__data__=new ue;++t<r;)this.add(e[t]);}ut.prototype.add=ut.prototype.push=xn;ut.prototype.has=bn;var On=ut;function fl(e,t){for(var r=-1,n=e==null?0:e.length;++r<n;)if(t(e[r],r,e))return true;return false}var pt=fl;function ul(e,t){return e.has(t)}var En=ul;var pl=1,dl=2;function ml(e,t,r,n,o,a){var i=r&pl,s=e.length,l=t.length;if(s!=l&&!(i&&l>s))return false;var p=a.get(e),u=a.get(t);if(p&&u)return p==t&&u==e;var d=-1,c=true,m=r&dl?new On:void 0;for(a.set(e,t),a.set(t,e);++d<s;){var w=e[d],h=t[d];if(n)var g=i?n(h,w,d,t,e,a):n(w,h,d,e,t,a);if(g!==void 0){if(g)continue;c=false;break}if(m){if(!pt(t,function(E,A){if(!En(m,A)&&(w===E||o(w,E,r,n,a)))return m.push(A)})){c=false;break}}else if(!(w===h||o(w,h,r,n,a))){c=false;break}}return a.delete(e),a.delete(t),c}var dt=ml;function cl(e){var t=-1,r=Array(e.size);return e.forEach(function(n,o){r[++t]=[o,n];}),r}var vn=cl;function gl(e){var t=-1,r=Array(e.size);return e.forEach(function(n){r[++t]=n;}),r}var $n=gl;var yl=1,hl=2,wl="[object Boolean]",xl="[object Date]",bl="[object Error]",Ol="[object Map]",El="[object Number]",vl="[object RegExp]",$l="[object Set]",Al="[object String]",Rl="[object Symbol]",kl="[object ArrayBuffer]",Sl="[object DataView]",An=B?B.prototype:void 0,It=An?An.valueOf:void 0;function Tl(e,t,r,n,o,a,i){switch(r){case Sl:if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return false;e=e.buffer,t=t.buffer;case kl:return !(e.byteLength!=t.byteLength||!a(new Lt(e),new Lt(t)));case wl:case xl:case El:return we(+e,+t);case bl:return e.name==t.name&&e.message==t.message;case vl:case Al:return e==t+"";case Ol:var s=vn;case $l:var l=n&yl;if(s||(s=$n),e.size!=t.size&&!l)return false;var p=i.get(e);if(p)return p==t;n|=hl,i.set(e,t);var u=dt(s(e),s(t),n,o,a,i);return i.delete(e),u;case Rl:if(It)return It.call(e)==It.call(t)}return false}var Rn=Tl;var Dl=1,Ml=Object.prototype,_l=Ml.hasOwnProperty;function Pl(e,t,r,n,o,a){var i=r&Dl,s=Nt(e),l=s.length,p=Nt(t),u=p.length;if(l!=u&&!i)return false;for(var d=l;d--;){var c=s[d];if(!(i?c in t:_l.call(t,c)))return false}var m=a.get(e),w=a.get(t);if(m&&w)return m==t&&w==e;var h=true;a.set(e,t),a.set(t,e);for(var g=i;++d<l;){c=s[d];var E=e[c],A=t[c];if(n)var D=i?n(A,E,c,t,e,a):n(E,A,c,e,t,a);if(!(D===void 0?E===A||o(E,A,r,n,a):D)){h=false;break}g||(g=c=="constructor");}if(h&&!g){var R=e.constructor,v=t.constructor;R!=v&&"constructor"in e&&"constructor"in t&&!(typeof R=="function"&&R instanceof R&&typeof v=="function"&&v instanceof v)&&(h=false);}return a.delete(e),a.delete(t),h}var kn=Pl;var Cl=1,Sn="[object Arguments]",Tn="[object Array]",mt="[object Object]",Fl=Object.prototype,Dn=Fl.hasOwnProperty;function Bl(e,t,r,n,o,a){var i=k(e),s=k(t),l=i?Tn:Ue(e),p=s?Tn:Ue(t);l=l==Sn?mt:l,p=p==Sn?mt:p;var u=l==mt,d=p==mt,c=l==p;if(c&&fe(e)){if(!fe(t))return false;i=true,u=false;}if(c&&!u)return a||(a=new Te),i||Oe(e)?dt(e,t,r,n,o,a):Rn(e,t,l,r,n,o,a);if(!(r&Cl)){var m=u&&Dn.call(e,"__wrapped__"),w=d&&Dn.call(t,"__wrapped__");if(m||w){var h=m?e.value():e,g=w?t.value():t;return a||(a=new Te),o(h,g,r,n,a)}}return c?(a||(a=new Te),kn(e,t,r,n,o,a)):false}var Mn=Bl;function _n(e,t,r,n,o){return e===t?true:e==null||t==null||!N(e)&&!N(t)?e!==e&&t!==t:Mn(e,t,r,n,_n,o)}var ct=_n;var ql=1,Nl=2;function Ll(e,t,r,n){var o=r.length,a=o,i=!n;if(e==null)return !a;for(e=Object(e);o--;){var s=r[o];if(i&&s[2]?s[1]!==e[s[0]]:!(s[0]in e))return false}for(;++o<a;){s=r[o];var l=s[0],p=e[l],u=s[1];if(i&&s[2]){if(p===void 0&&!(l in e))return false}else {var d=new Te;if(n)var c=n(p,u,l,e,t,d);if(!(c===void 0?ct(u,p,ql|Nl,n,d):c))return false}}return true}var Pn=Ll;function Il(e){return e===e&&!L(e)}var gt=Il;function jl(e){for(var t=Ee(e),r=t.length;r--;){var n=t[r],o=e[n];t[r]=[n,o,gt(o)];}return t}var Cn=jl;function Wl(e,t){return function(r){return r==null?false:r[e]===t&&(t!==void 0||e in Object(r))}}var yt=Wl;function Vl(e){var t=Cn(e);return t.length==1&&t[0][2]?yt(t[0][0],t[0][1]):function(r){return r===e||Pn(r,e,t)}}var Fn=Vl;function Ul(e,t){return e!=null&&t in Object(e)}var Bn=Ul;function Gl(e,t,r){t=it(t,e);for(var n=-1,o=t.length,a=false;++n<o;){var i=te(t[n]);if(!(a=e!=null&&r(e,i)))break;e=e[i];}return a||++n!=o?a:(o=e==null?0:e.length,!!o&&xe(o)&&he(i,o)&&(k(e)||be(e)))}var qn=Gl;function Kl(e,t){return e!=null&&qn(e,t,Bn)}var Nn=Kl;var zl=1,Hl=2;function Jl(e,t){return ve(e)&&gt(t)?yt(te(e),t):function(r){var n=S(r,e);return n===void 0&&n===t?Nn(r,e):ct(t,n,zl|Hl)}}var Ln=Jl;function Ql(e){return function(t){return t?.[e]}}var In=Ql;function Yl(e){return function(t){return ke(t,e)}}var jn=Yl;function Zl(e){return ve(e)?In(te(e)):jn(e)}var Wn=Zl;function Xl(e){return typeof e=="function"?e:e==null?Xe:typeof e=="object"?k(e)?Ln(e[0],e[1]):Fn(e):Wn(e)}var De=Xl;function ef(e,t,r,n){for(var o=-1,a=e==null?0:e.length;++o<a;){var i=e[o];t(n,i,r(i),e);}return n}var Vn=ef;function tf(e){return function(t,r,n){for(var o=-1,a=Object(t),i=n(t),s=i.length;s--;){var l=i[e?s:++o];if(r(a[l],l,a)===false)break}return t}}var Un=tf;var rf=Un(),Gn=rf;function nf(e,t){return e&&Gn(e,t,Ee)}var Kn=nf;function of(e,t){return function(r,n){if(r==null)return r;if(!I(r))return e(r,n);for(var o=r.length,a=t?o:-1,i=Object(r);(t?a--:++a<o)&&n(i[a],a,i)!==false;);return r}}var zn=of;var af=zn(Kn),Me=af;function sf(e,t,r,n){return Me(e,function(o,a,i){t(n,o,r(o),i);}),n}var Hn=sf;function lf(e,t){return function(r,n){var o=k(r)?Vn:Hn,a=t?t():{};return o(r,e,De(n),a)}}var Jn=lf;function ff(e,t){var r=-1,n=I(e)?Array(e.length):[];return Me(e,function(o,a,i){n[++r]=t(o,a,i);}),n}var Qn=ff;var uf=Object.prototype,pf=uf.hasOwnProperty,df=Jn(function(e,t,r){pf.call(e,r)?e[r].push(t):Er(e,r,[t]);}),jt=df;var mf="[object Map]",cf="[object Set]",gf=Object.prototype,yf=gf.hasOwnProperty;function hf(e){if(e==null)return true;if(I(e)&&(k(e)||typeof e=="string"||typeof e.splice=="function"||fe(e)||Oe(e)||be(e)))return !e.length;var t=Ue(e);if(t==mf||t==cf)return !e.size;if(nt(e))return !at(e).length;for(var r in e)if(yf.call(e,r))return false;return true}var ht=hf;function wf(e,t){var r=e.length;for(e.sort(t);r--;)e[r]=e[r].value;return e}var Yn=wf;function xf(e,t){if(e!==t){var r=e!==void 0,n=e===null,o=e===e,a=V(e),i=t!==void 0,s=t===null,l=t===t,p=V(t);if(!s&&!p&&!a&&e>t||a&&i&&l&&!s&&!p||n&&i&&l||!r&&l||!o)return 1;if(!n&&!a&&!p&&e<t||p&&r&&o&&!n&&!a||s&&r&&o||!i&&o||!l)return -1}return 0}var Zn=xf;function bf(e,t,r){for(var n=-1,o=e.criteria,a=t.criteria,i=o.length,s=r.length;++n<i;){var l=Zn(o[n],a[n]);if(l){if(n>=s)return l;var p=r[n];return l*(p=="desc"?-1:1)}}return e.index-t.index}var Xn=bf;function Of(e,t,r){t.length?t=ye(t,function(a){return k(a)?function(i){return ke(i,a.length===1?a[0]:a)}:a}):t=[Xe];var n=-1;t=ye(t,ot(De));var o=Qn(e,function(a,i,s){var l=ye(t,function(p){return p(a)});return {criteria:l,index:++n,value:a}});return Yn(o,function(a,i){return Xn(a,i,r)})}var eo=Of;function Ef(e,t,r,n){return e==null?[]:(k(t)||(t=t==null?[]:[t]),r=n?void 0:r,k(r)||(r=r==null?[]:[r]),eo(e,t,r))}var Wt=Ef;function vf(e,t){var r;return Me(e,function(n,o,a){return r=t(n,o,a),!r}),!!r}var to=vf;function $f(e,t,r){var n=k(e)?pt:to;return r&&vr(e,t,r)&&(t=void 0),n(e,De(t))}var Vt=$f;z.extend(Sf);z.extend(kf);z.extend(Rf);z.extend(Af);var Tf={years:"year",quarters:"quarter",months:"month",weeks:"week",days:"day",hours:"hour",minutes:"minute",seconds:"second"},Df=e=>typeof e=="object"&&e!==null&&!Array.isArray(e)&&!(e instanceof Date),P=e=>Df(e)?"ago"in e||"ahead"in e||"this"in e||"last"in e||"next"in e||"start"in e||"end"in e:false,Ut=e=>{if(e.now===void 0)throw new Error("date expressions require `now` to be supplied to the evaluator");let t=e.timeZone?z(e.now).tz(e.timeZone):z(e.now);if(!t.isValid())throw new Error(`invalid \`now\`: ${String(e.now)}`);return t},wt=(e,t,r)=>{let n=e;for(let o of Object.keys(t)){let a=t[o];if(a!==void 0){if(a<0)throw new Error(`relative magnitudes must be positive: ${o}=${a}`);n=n.add(r*a,Tf[o]);}}return n},xt=e=>"ago"in e||"ahead"in e,de=e=>"this"in e||"last"in e||"next"in e,Gt=e=>"start"in e||"end"in e,Mf=(e,t)=>e==="week"?t.weekStart==="sunday"?"week":"isoWeek":e,Ge=(e,t)=>{let r=Ut(t),n="this"in e?e.this:"last"in e?e.last:e.next,o=n==="isoWeek"?"week":n,a=r;"last"in e?a=r.subtract(1,o):"next"in e&&(a=r.add(1,o));let i=Mf(n,t);return [a.startOf(i),a.endOf(i)]},K=(e,t)=>{if(xt(e)){let r=Ut(t);return "ago"in e?wt(r,e.ago,-1):wt(r,e.ahead,1)}if(Gt(e)){let r="start"in e?e.start:e.end,[n,o]=Ge(r,t);return "start"in e?n:o}throw new Error("a point operator requires a rolling or start/end edge expression, not a bare period")},bt=(e,t,r)=>{if(de(e)){let[n,o]=Ge(e,r);return t==="before"||t==="onOrBefore"?n:o}return K(e,r)},Pe=(e,t)=>{if(de(e))return Ge(e,t);if(xt(e)){let r=Ut(t);return "ago"in e?[wt(r,e.ago,-1),r]:[r,wt(r,e.ahead,1)]}throw new Error("`within` requires a range expression (period or rolling), not an edge point")};var f={equals:"equals",notEquals:"notEquals",lessThan:"lessThan",lessThanEquals:"lessThanEquals",greaterThan:"greaterThan",greaterThanEquals:"greaterThanEquals",contains:"contains",notContains:"notContains",in:"in",notIn:"notIn",matches:"matches",notMatches:"notMatches",between:"between",notBetween:"notBetween",isEmpty:"isEmpty",notEmpty:"notEmpty",exists:"exists",notExists:"notExists",startsWith:"startsWith",endsWith:"endsWith"},y={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},x={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",within:"within",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};z.extend(Sf);z.extend(kf);z.extend(Pf);z.extend(_f);var ro=(e,t,r,n={})=>{let o=S(t,e.field);if(!o)throw new Error(`${e.field} is null or undefined`);if(!zt(o))throw new Error(`${e.field} is not a valid date: ${String(o)}`);let a=z(o);if(!a.isValid())throw new Error(`${e.field} is not a valid date: ${o}`);let i=u=>e.error||`${e.field} ${u}`,s=Bf(e,t,r,a,o,n),l=s[0],p=s[1];switch(e.dateOperator){case x.before:return a.isBefore(l)||i(`must be before ${l.format()}`);case x.after:return a.isAfter(l)||i(`must be after ${l.format()}`);case x.onOrBefore:return a.isSameOrBefore(l)||i(`must be on or before ${l.format()}`);case x.onOrAfter:return a.isSameOrAfter(l)||i(`must be on or after ${l.format()}`);case x.within:{if(!p)throw new Error("within operator requires a range");return a.isSameOrAfter(l)&&a.isSameOrBefore(p)||i(`must be within ${l.format()} and ${p.format()}`)}case x.between:{if(!p)throw new Error("between operator requires an end date");return a.isSameOrAfter(l)&&a.isSameOrBefore(p)||i(`must be between ${l.format()} and ${p?.format()}`)}case x.notBetween:{if(!p)throw new Error("notBetween operator requires an end date");return a.isBefore(l)||a.isAfter(p)||i(`must not be between ${l.format()} and ${p?.format()}`)}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let u=a.format("dddd").toLowerCase(),d=e.value.map(c=>String(c).toLowerCase());return d.includes(u)||i(`must be on ${d.join(" or ")}`)}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let u=a.format("dddd").toLowerCase(),d=e.value.map(c=>String(c).toLowerCase());return !d.includes(u)||i(`must not be on ${d.join(" or ")}`)}default:throw new Error("Unknown date operator")}},Bf=(e,t,r,n,o,a)=>{if(e.dateOperator===x.within){if(!P(e.value))throw new Error("within operator requires a range date expression");return Pe(e.value,a)}if([x.between,x.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[l,p]=e.value,u=P(l)?K(l,a):Kt(l,o),d=P(p)?K(p,a):Kt(p,o);if(!u.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!d.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[c,m]=u.isBefore(d)||u.isSame(d)?[u,d]:[d,u];return [c,m]}if([x.before,x.after,x.onOrBefore,x.onOrAfter].includes(e.dateOperator)){let l;if(e.value!==void 0){if(P(e.value)){if(de(e.value)){let[u,d]=Ge(e.value,a);return [e.dateOperator===x.before||e.dateOperator===x.onOrBefore?u:d,void 0]}return [K(e.value,a),void 0]}if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);l=e.value;}else if(e.path)if(e.path.startsWith("$.")){let u=S(t,e.path.substring(2));l=zt(u)?u:void 0;}else {let u=S(r,e.path);l=zt(u)?u:void 0;}else throw new Error("No value or path specified for date comparison");let p=Kt(l,o);if(!p.isValid())throw new Error(`Invalid comparison date: ${l}`);return [p,void 0]}return [z(),void 0]},Kt=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return z(e);let o=String(t),a=0;if(o.includes("+")||o.includes("T")&&o.match(/T.*-\d{2}:/)){let s=o.match(/([+-])(\d{2}):(\d{2})/);s&&(a=(s[1]==="+"?1:-1)*(parseInt(s[2],10)*60+parseInt(s[3],10)));}else o.includes("Z")||(a=0);return r.match(/^\d{4}-\d{2}-\d{2}$/)?z(`${e}T00:00:00`).subtract(a,"minute"):z(e).subtract(a,"minute")},zt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var io=(e,t,r)=>{let n=S(t,e.field),a=![f.isEmpty,f.notEmpty,f.exists,f.notExists].includes(e.operator),i=a?qf(e,t,r):void 0,s=l=>e.error||`${e.field} ${l}${a?` ${JSON.stringify(i)}`:""}`;switch(e.operator){case f.equals:return n===i||s("must equal");case f.notEquals:return n!==i||s("must not equal");case f.lessThan:return Ot(n,i,"lt")||s("must be less than");case f.lessThanEquals:return Ot(n,i,"lte")||s("must be less than or equal to");case f.greaterThan:return Ot(n,i,"gt")||s("must be greater than");case f.greaterThanEquals:return Ot(n,i,"gte")||s("must be greater than or equal to");case f.in:return Array.isArray(i)&&i.includes(n)||s("must be one of");case f.notIn:return !Array.isArray(i)||!i.includes(n)||s("must not be one of");case f.contains:return ao(n,i)||s("must contain");case f.notContains:return !ao(n,i)||s("must not contain");case f.matches:return no(n)&&(i instanceof RegExp||typeof i=="string")&&!!n.match(i)||s("must match pattern");case f.notMatches:return !no(n)||!(i instanceof RegExp||typeof i=="string")||!n.match(i)||s("must not match pattern");case f.between:{let l=oo(i);if(!l)throw new Error("between operator requires an array of two values");if(!Ce(n))return s("must be between");let p=Fe(n),[u,d]=l;return p>=u&&p<=d||s("must be between")}case f.notBetween:{let l=oo(i);if(!l)throw new Error("notBetween operator requires an array of two values");if(!Ce(n))return true;let p=Fe(n),[u,d]=l;return p<u||p>d||s("must not be between")}case f.isEmpty:return ht(n)||s("must be empty");case f.notEmpty:return !ht(n)||s("must not be empty");case f.exists:return n!==void 0||s("must exist");case f.notExists:return n===void 0||s("must not exist");case f.startsWith:return typeof n=="string"&&typeof i=="string"&&n.startsWith(i)||s("must start with");case f.endsWith:return typeof n=="string"&&typeof i=="string"&&n.endsWith(i)||s("must end with");default:throw new Error("Unknown operator")}},qf=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?S(t,e.path.substring(2)):S(r,e.path);throw new Error("No value or path specified")},Ce=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Fe=e=>e instanceof Date?e.getTime():e,Ot=(e,t,r)=>{if(!Ce(e)||!Ce(t))return false;let n=Fe(e),o=Fe(t);switch(r){case "lt":return n<o;case "lte":return n<=o;case "gt":return n>o;case "gte":return n>=o}},no=e=>typeof e=="string",oo=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!Ce(t)||!Ce(r))return null;let n=Fe(t),o=Fe(r);return n<=o?[n,o]:[o,n]},ao=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var re=e=>!!e.orderBy?.length||e.take!==void 0||e.skip!==void 0,Nf=new Set(["before","onOrBefore","lessThan","lessThanEquals"]),Lf=new Set(["after","onOrAfter","greaterThan","greaterThanEquals"]),If=e=>{if(typeof e!="object"||e===null)return null;let t=e;return "aggregate"in t||typeof t.field!="string"?null:typeof t.dateOperator=="string"?{op:t.dateOperator,field:t.field}:typeof t.operator=="string"?{op:t.operator,field:t.field}:null},Et=e=>{if(e.skip!==void 0&&e.skip!==0||e.take!==1||!e.orderBy||e.orderBy.length!==1)return null;let{field:t,dir:r}=e.orderBy[0];if(r!=="asc"&&r!=="desc")return null;let n=null;if(e.arrayOperator==="all"?n="all":(e.arrayOperator==="any"||e.arrayOperator==="atLeast"&&e.count===1)&&(n="any"),!n)return null;let o=If(e.condition);if(!o||o.field!==t)return null;let a=Nf.has(o.op),i=Lf.has(o.op);if(!a&&!i)return null;let s=r==="desc";if(!(n==="all"?s&&a||!s&&i:s&&i||!s&&a))return null;let{orderBy:p,take:u,skip:d,count:c,...m}=e;return {...m,arrayOperator:n}},Ht=(e,t)=>{let r=e;return t.orderBy?.length&&(r=Wt(r,t.orderBy.map(n=>n.field),t.orderBy.map(n=>n.dir))),t.skip!==void 0&&(r=r.slice(t.skip)),t.take!==void 0&&(r=r.slice(0,t.take)),r};var Jt=e=>{if(typeof e!="boolean"){if("all"in e){for(let t of e.all)Jt(t);return}if("any"in e){for(let t of e.any)Jt(t);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},me=(e,t,r)=>{if(Array.isArray(t)&&Jt(e),typeof e=="boolean")return e;let n={...r,context:r?.context??t};return "all"in e?jf(e.all,t,n,e.error):"any"in e?Wf(e.any,t,n,e.error):"arrayOperator"in e?Gf(e,t,n):"dateOperator"in e?ro(e,t,n.context,n):"aggregate"in e?Uf(e,t,n):"field"in e?io(e,t,n.context):"if"in e?Vf(e,t,n):false},jf=(e,t,r,n)=>{let o=[];for(let a of e){let i=me(a,t,r);i!==true&&(typeof i=="string"?o.push(i):o.push("false"));}return o.length?n||(o.length===1?o[0]:`All conditions must pass: ${o.join(" AND ")}`):true},Wf=(e,t,r,n)=>{let o=[];for(let a of e){let i=me(a,t,r);if(i===true)return true;typeof i=="string"&&o.push(i);}return n||(o.length===1?o[0]:`At least one condition must pass: ${o.join(" OR ")}`)},Vf=(e,t,r)=>me(e.if,t,r)===true?me(e.then,t,r):e.else!==void 0?me(e.else,t,r):true,Uf=(e,t,r)=>{let n=S(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let o=Ht(n,e),{mode:a,field:i}=e.aggregate;if(a!=="sum"&&a!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let s=e.condition,p=(s?o.filter(h=>me(s,h,r)===true):o).map((h,g)=>{let E=i?S(h,i):h;if(typeof E!="number"||!Number.isFinite(E)){let A=`${e.field}[${g}]${i?`.${i}`:""}`;throw new Error(`${A} must be a finite number`)}return E}),u=p.reduce((h,g)=>h+g,0),d=a==="sum"?u:p.length===0?0:u/p.length,c=r.context,m;if(e.value!==void 0)m=e.value;else if(e.path)m=e.path.startsWith("$.")?S(t,e.path.substring(2)):S(c,e.path);else throw new Error("Aggregate rule requires value or path");let w=h=>e.error||`${e.field} ${a} ${h} ${JSON.stringify(m)}`;switch(e.operator){case f.equals:return d===m||w("must equal");case f.notEquals:return d!==m||w("must not equal");case f.lessThan:return typeof m=="number"&&d<m||w("must be less than");case f.lessThanEquals:return typeof m=="number"&&d<=m||w("must be less than or equal to");case f.greaterThan:return typeof m=="number"&&d>m||w("must be greater than");case f.greaterThanEquals:return typeof m=="number"&&d>=m||w("must be greater than or equal to");case f.between:{if(!Array.isArray(m)||m.length!==2)throw new Error("between requires a two-element array");let[h,g]=m,[E,A]=h<=g?[h,g]:[g,h];return d>=E&&d<=A||w("must be between")}case f.notBetween:{if(!Array.isArray(m)||m.length!==2)throw new Error("notBetween requires a two-element array");let[h,g]=m,[E,A]=h<=g?[h,g]:[g,h];return d<E||d>A||w("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},Gf=(e,t,r)=>{let n=e.field?S(t,e.field):t;if(!Array.isArray(n))throw new Error(`${e.field||"(root)"} must be an array`);let o=Ht(n,e),a=c=>e.error||`${e.field} ${c}`,i=[y.all,y.any,y.none,y.atLeast,y.atMost,y.exactly],s=[y.atLeast,y.atMost,y.exactly],l=e.condition;if(i.includes(e.arrayOperator)&&!l)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let p=e.count;if(s.includes(e.arrayOperator)&&p===void 0)throw new Error(`${e.arrayOperator} requires a count`);let u=0,d=0;if(i.includes(e.arrayOperator)){if(!l)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(o.length>0&&!Vt(o,L))return a("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let c=o.map(m=>me(l,m,r));u=c.filter(m=>m===true).length,d=c.filter(m=>typeof m=="string").length;}switch(e.arrayOperator){case y.empty:return !o.length||a("must be empty");case y.notEmpty:return !!o.length||a("must not be empty");case y.all:return u===o.length||a(`all elements must match (${d} failed)`);case y.any:return !!u||a("at least one element must match");case y.none:return !u||a(`no elements should match (${u} matched)`);case y.atLeast:if(p===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u>=p||a(`at least ${p} elements must match (${u} matched)`);case y.atMost:if(p===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u<=p||a(`at most ${p} elements must match (${u} matched)`);case y.exactly:if(p===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u===p||a(`exactly ${p} elements must match (${u} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var so=(e,t,r,n)=>{let o={};for(let a of e){let i=a[t];if(i==null)continue;let s=String(i);if(o[s]!==void 0){let l=n==="one"?`endpoint[0] must be the "one" side of a oneToMany bridge \u2014 swap endpoints if '${r}' is the "many" side`:`oneToOne bridges require unique '${t}' on both endpoints`;throw new Error(`buildBridgeDictionary: duplicate '${t}' value '${s}' on '${r}' \u2014 ${l}.`)}o[s]=a;}return o},Kf=(e,t)=>{let r={};for(let n of e.bridges??[]){let[o,a]=n.endpoints,i=`${o.fieldMap}:${o.model}`,s=`${a.fieldMap}:${a.model}`,l=n.cardinality==="oneToMany"?"one":"oneToOne";if(t[i]&&(r[o.fieldMap]??={},r[o.fieldMap][o.model]??={},r[o.fieldMap][o.model][o.on]=so(t[i],o.on,i,l)),t[s])if(r[a.fieldMap]??={},r[a.fieldMap][a.model]??={},n.cardinality==="oneToMany"){let p=t[s].filter(u=>u[a.on]!==null&&u[a.on]!==void 0);r[a.fieldMap][a.model][a.on]=jt(p,a.on);}else r[a.fieldMap][a.model][a.on]=so(t[s],a.on,s,"oneToOne");}return r};var Qt=e=>{let t={maps:structuredClone(e.maps),bridges:e.bridges?structuredClone(e.bridges):void 0};for(let r of e.bridges??[]){let[n,o]=r.endpoints,a=t.maps[n.fieldMap]?.models[n.model],i=t.maps[o.fieldMap]?.models[o.model];if(!a)throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' not found`);if(!i)throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' not found`);if(n.fieldMap===o.fieldMap&&n.model===o.model)throw new Error(`stitchFieldMaps: self-bridge '${n.fieldMap}:${n.model}' to itself is not supported`);if(!a.fields[n.on])throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' has no field '${n.on}' for join`);if(!i.fields[o.on])throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' has no field '${o.on}' for join`);let s=`${n.fieldMap}:${n.model}`,l=`${o.fieldMap}:${o.model}`;if(a.fields[l])throw new Error(`stitchFieldMaps: bridge '${l}' already injected on '${s}'`);if(i.fields[s])throw new Error(`stitchFieldMaps: bridge '${s}' already injected on '${l}'`);let p=r.cardinality==="oneToMany";a.fields[l]={kind:"bridge",type:l,isList:p},i.fields[s]={kind:"bridge",type:s,isList:false};}return t};var zf=/[.:]/,lo=e=>{let t=[];for(let[r,n]of Object.entries(e.maps))for(let[o,a]of Object.entries(n.models))for(let[i,s]of Object.entries(a.fields))s.kind!=="bridge"&&zf.test(i)&&t.push(`'${r}:${o}.${i}' contains forbidden character . or :`);if(t.length)throw new Error(`validateFieldMapSet:
2
2
  ${t.join(`
3
- `)}`)},sf=(e,t="fieldMap")=>{Lo({maps:{[t]:e}});};var Io={[f.equals]:f.notEquals,[f.notEquals]:f.equals,[f.lessThan]:f.greaterThanEquals,[f.lessThanEquals]:f.greaterThan,[f.greaterThan]:f.lessThanEquals,[f.greaterThanEquals]:f.lessThan,[f.in]:f.notIn,[f.notIn]:f.in,[f.contains]:f.notContains,[f.notContains]:f.contains,[f.matches]:f.notMatches,[f.notMatches]:f.matches,[f.between]:f.notBetween,[f.notBetween]:f.between,[f.isEmpty]:f.notEmpty,[f.notEmpty]:f.isEmpty,[f.exists]:f.notExists,[f.notExists]:f.exists},lf={[x.before]:x.onOrAfter,[x.after]:x.onOrBefore,[x.onOrBefore]:x.after,[x.onOrAfter]:x.before,[x.between]:x.notBetween,[x.notBetween]:x.between,[x.dayIn]:x.dayNotIn,[x.dayNotIn]:x.dayIn},ff=e=>{let t=Io[e.operator];if(!t)throw new Error(`negate: operator '${e.operator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'. Rewrite the where clause using an invertible operator, or add the inverse operator to the DSL.`);return {...e,operator:t}},uf=e=>{let t=lf[e.dateOperator];return {...e,dateOperator:t}},pf=e=>{let t=Io[e.operator];if(!t)throw new Error(`negate: aggregate operator '${e.operator}' has no inverse in the DSL.`);return {...e,operator:t}},df=e=>{switch(e.arrayOperator){case y.any:return {...e,arrayOperator:y.none};case y.none:return {...e,arrayOperator:y.any};case y.all:if(!e.condition)throw new Error("negate: arrayRule 'all' missing condition");return {...e,arrayOperator:y.any,condition:Z(e.condition)};case y.empty:return {...e,arrayOperator:y.notEmpty};case y.notEmpty:return {...e,arrayOperator:y.empty};case y.atLeast:if(e.count===void 0)throw new Error("negate: 'atLeast' missing count");return {...e,arrayOperator:y.atMost,count:e.count-1};case y.atMost:if(e.count===void 0)throw new Error("negate: 'atMost' missing count");return {...e,arrayOperator:y.atLeast,count:e.count+1};case y.exactly:throw new Error("negate: arrayRule 'exactly' has no single-operator inverse. Rewrite as { any: [atMost n-1, atLeast n+1] } if needed.");default:throw new Error(`negate: unknown arrayOperator '${e.arrayOperator}'`)}},Z=e=>{if(typeof e=="boolean")return !e;if("all"in e)return {any:e.all.map(Z)};if("any"in e)return {all:e.any.map(Z)};if("if"in e)return e.else!==void 0?{if:e.if,then:Z(e.then),else:Z(e.else)}:{all:[e.if,Z(e.then)]};if("arrayOperator"in e)return df(e);if("dateOperator"in e)return uf(e);if("aggregate"in e)return pf(e);if("field"in e&&"operator"in e)return ff(e);throw new Error("negate: unknown condition shape")};var jo=e=>"model"in e,lt=e=>{let t=new Set,r=e;for(;!jo(r);){if(t.has(r))throw new Error("cycle detected in narrowing parent chain");t.add(r),r=r.parent;}return r},ft=e=>{let t=[],r=new Set,o=e;for(;!jo(o);){if(r.has(o))throw new Error("cycle detected in narrowing parent chain");r.add(o),t.unshift(o),o=o.parent;}return t},U=(e,t)=>{if(e.kind==="object")return {mapName:t,modelName:e.type};if(e.kind==="bridge"){let[r,o]=e.type.includes(":")?e.type.split(":"):[t,e.type];return {mapName:r,modelName:o}}return null};var Re=e=>{let t=lt(e),r=e.maps===t.maps?[]:ft(e);return {lens:t,chain:r}},De=(e,t)=>e===null?new Set(t):new Set(t.filter(r=>e.has(r))),mf=e=>{if(!e.picks)return;if(!("relations"in e)||!e.relations)return e.picks;let t=[...e.picks];for(let r of Object.keys(e.relations))t.includes(r)||t.push(r);return t},cf=(e,t)=>{let r=mf(t);if(r&&(e.picks=De(e.picks,r)),t.omits)for(let o of t.omits)e.omits.add(o);},Vo=(e,t,r)=>{e.set(t,De(e.get(t)??null,r));},Wo=(e,t,r)=>{let o=e.get(t)??new Set;for(let n of r)o.add(n);e.set(t,o);},gf=(e,t,r)=>{if(r.enumPicks)for(let[o,n]of Object.entries(r.enumPicks))Vo(e,o,n);if(r.enumOmits)for(let[o,n]of Object.entries(r.enumOmits))Wo(t,o,n);},yf=(e,t)=>{cf(e,t),t.where!==void 0&&e.whereClauses.push(t.where);},ee=(e,t,r,o)=>{let n={picks:null,omits:new Set,enumValuesByField:new Map,whereClauses:[],relations:new Map},a=e.lens.maps[t],i=a?.models[r];if(!i)return n;let s=new Map,l=new Map,p=new Map,u=new Map,d=m=>{yf(n,m),gf(s,l,m);};for(let m of e.chain){let c=m.mapDefaults?.[t];if(c){let w=c.models?.[r];w&&d(w);for(let[g,v]of Object.entries(c.enums??{}))v.picks&&Vo(p,g,v.picks),v.omits&&Wo(u,g,v.omits);}let h=m.root;if(o.length===0){if(t===e.lens.mapName&&r===e.lens.model&&h){d(h);for(let[w,g]of Object.entries(h.relations??{}))n.relations.set(w,g);}}else {for(let w of o)if(h=h?.relations?.[w],!h)break;if(h){d(h);for(let[w,g]of Object.entries(h.relations??{}))n.relations.set(w,g);}}}for(let[m,c]of Object.entries(i.fields)){if(c.kind!=="enum")continue;let h=c.type,w=c.values??a?.enums?.[h];if(!w)continue;let g=w,v=p.get(h),M=u.get(h);v&&(g=g.filter($=>v.has($))),M&&(g=g.filter($=>!M.has($)));let S=s.get(m),E=l.get(m);S&&(g=g.filter($=>S.has($))),E&&(g=g.filter($=>!E.has($))),n.enumValuesByField.set(m,g);}return n},_t=(e,t)=>!(e.omits.has(t)||e.picks!==null&&!e.picks.has(t)),Uo=(e,t)=>e.enumValuesByField.get(t)??null,Pt=(e,t,r,o,n)=>{let a=n.split("."),i=t,s=r,l=[...o],p=[];for(let u=0;u<a.length;u++){let m=e.lens.maps[i]?.models[s];if(!m)return null;let c=ee(e,i,s,l),h=a[u];if(!_t(c,h))return null;let w=m.fields[h];if(!w)return null;if(u===a.length-1)return {mapName:i,modelName:s,relPath:l,entry:w,hopEffects:p,terminalEffect:c,terminalFieldName:h};p.push(c);let g=U(w,i);if(!g)return null;l=[...l,h],i=g.mapName,s=g.modelName;}return null};var hf=(e,t)=>t.length===0?e:{all:[...t,e]},wf=(e,t,r)=>r===y.all?{any:[Z(t),e]}:{all:[t,e]},fe=(e,t,r,o,n)=>{if(typeof e=="boolean")return e;if("all"in e)return {...e,all:e.all.map(a=>fe(a,t,r,o,n))};if("any"in e)return {...e,any:e.any.map(a=>fe(a,t,r,o,n))};if("if"in e)return {...e,if:fe(e.if,t,r,o,n),then:fe(e.then,t,r,o,n),else:e.else!==void 0?fe(e.else,t,r,o,n):e.else};if("field"in e&&typeof e.field=="string"&&e.field!==""){if(!t.lens.maps[r]?.models[o])return e;let s=e.field.split("."),l=r,p=o,u=[...n],m=false;for(let c=0;c<s.length;c++){let h=t.lens.maps[l]?.models[p];if(!h)break;let w=h.fields[s[c]];if(!w)break;if(c===s.length-1){if(w.kind==="object"||w.kind==="bridge"){let g=U(w,l);g&&(u=[...u,s[c]],l=g.mapName,p=g.modelName,m=true);}break}if(w.kind==="object"||w.kind==="bridge"){let g=U(w,l);if(g)u=[...u,s[c]],l=g.mapName,p=g.modelName;else break}else break}if("condition"in e&&e.condition!==void 0&&m){let c=ee(t,l,p,u),h=fe(e.condition,t,l,p,u),w="arrayOperator"in e?e.arrayOperator:void 0;for(let g of c.whereClauses)w?h=wf(h,g,w):h={all:[g,h]};return {...e,condition:h}}return e}return e},xf=(e,t)=>{let r=Re(t),o=ee(r,r.lens.mapName,r.lens.model,[]),n=fe(e,r,r.lens.mapName,r.lens.model,[]);return hf(n,o.whereClauses)};var bf=e=>{if(e.path!==void 0)return null;let t=e.value;return t===void 0?null:Array.isArray(t)?t:[t]},ue=(e,t,r,o,n,a)=>{if(typeof e=="boolean")return;if("all"in e){for(let c of e.all)ue(c,t,r,o,n,a);return}if("any"in e){for(let c of e.any)ue(c,t,r,o,n,a);return}if("if"in e){ue(e.if,t,r,o,n,a),ue(e.then,t,r,o,n,a),e.else!==void 0&&ue(e.else,t,r,o,n,a);return}let i=r,s=o,l=n,p=null,u=false,d=null,m=null;if("field"in e&&typeof e.field=="string"&&e.field!==""){let c=Pt(t,r,o,n,e.field);if(!c){a.push({path:e.field,reason:"path does not resolve through the narrowed lens"});return}if(p=c.terminalFieldName,u=c.entry.kind==="enum",d=c.entry.type,m=Uo(c.terminalEffect,p),c.entry.kind==="object"||c.entry.kind==="bridge"){let h=c.entry.kind==="object"?{mapName:c.mapName,modelName:c.entry.type}:{mapName:c.entry.type.split(":")[0]??c.mapName,modelName:c.entry.type.split(":")[1]??c.entry.type};i=h.mapName,s=h.modelName,l=[...c.relPath,p];}}if(u&&"operator"in e&&p){let c=bf(e);if(c&&m){let h=new Set(m);for(let w of c)typeof w=="string"&&!h.has(w)&&a.push({path:p,reason:`value '${w}' is not in the allowed set for enum '${d}' (allowed: ${[...h].join(", ")})`});}}if("aggregate"in e&&typeof e.aggregate=="object"&&e.aggregate!==null&&typeof e.aggregate.field=="string"&&e.aggregate.field!==""){let c=e.aggregate.field;Pt(t,i,s,l,c)||a.push({path:c,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ue(e.condition,t,i,s,l,a);},Ft=(e,t)=>{let r=Re(t),o=[];return ue(e,r,r.lens.mapName,r.lens.model,[],o),ee(r,r.lens.mapName,r.lens.model,[]),{ok:o.length===0,violations:o}};var Of=e=>({...Mt({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var Go=(e,t,r,o,n,a,i,s,l=false)=>{e.picks&&e.omits&&s.push(`${i}: cannot specify both picks and omits`),l&&"relations"in e&&e.relations&&s.push(`${i}: defaults cannot declare 'relations' \u2014 relations are path-specific only`);for(let u of e.picks??[]){if(!o[u]){s.push(`${i}.picks: field '${u}' not on model`);continue}let d=false;for(let m of t){if(m.picks&&!m.picks.includes(u)){s.push(`${i}.picks: '${u}' not in ancestor's picks`),d=true;break}if(m.omits?.includes(u)){s.push(`${i}.picks: '${u}' was omitted by ancestor`),d=true;break}}d||!l&&r&&(r.picks&&!r.picks.includes(u)?s.push(`${i}.picks: '${u}' not visible from defaults.picks`):r.omits?.includes(u)&&s.push(`${i}.picks: '${u}' not visible (already excluded by defaults.omits)`));}for(let u of e.omits??[]){if(!o[u]){s.push(`${i}.omits: field '${u}' not on model`);continue}let d=false;for(let m of t){if(m.picks&&!m.picks.includes(u)){s.push(`${i}.omits: '${u}' not in ancestor's picks (already invisible)`),d=true;break}if(m.omits?.includes(u)){s.push(`${i}.omits: '${u}' already excluded by ancestor`),d=true;break}}d||!l&&r&&(r.picks&&!r.picks.includes(u)?s.push(`${i}.omits: '${u}' not visible from defaults.picks`):r.omits?.includes(u)&&s.push(`${i}.omits: '${u}' already excluded by defaults`));}let p=(u,d,m)=>{let c=o[d];if(!c){s.push(`${i}.${u}: field '${d}' not on model`);return}if(c.kind!=="enum"){s.push(`${i}.${u}: field '${d}' is not an enum field`);return}let h=c.values??a?.[c.type];for(let w of m)h&&!h.includes(w)&&s.push(`${i}.${u}.${d}: '${w}' is not a known value of enum '${c.type}'`);};for(let[u,d]of Object.entries(e.enumPicks??{}))p("enumPicks",u,d);for(let[u,d]of Object.entries(e.enumOmits??{}))p("enumOmits",u,d);if(e.where!==void 0&&e.where!==true&&e.where!==false){let u=$f(e.where,o,n);for(let d of u)s.push(`${i}.where: ${d}`);}},$f=(e,t,r)=>{let o=[],n=a=>{if(a===null||typeof a!="object")return;if(Array.isArray(a)){for(let s of a)n(s);return}let i=a;if("all"in i&&Array.isArray(i.all)){for(let s of i.all)n(s);return}if("any"in i&&Array.isArray(i.any)){for(let s of i.any)n(s);return}if("if"in i){n(i.if),n(i.then),i.else!==void 0&&n(i.else);return}if("field"in i&&typeof i.field=="string"&&i.field!==""){let s=i.field.split(".")[0];t[s]||o.push(`'${i.field}' not on model ${r}`);}"condition"in i&&i.condition!==void 0&&n(i.condition);};return n(e),o},Af=(e,t,r,o,n)=>{for(let[a,i]of Object.entries(t)){let s=r?.[a];if(!s){n.push(`mapDefaults.${e}.enums.${a}: enum not in registry`);continue}let l=null,p=new Set;for(let d of o){let m=d[a];if(m&&(m.picks&&(l=De(l,m.picks)),m.omits))for(let c of m.omits)p.add(c);}let u=d=>!(p.has(d)||l&&!l.has(d));for(let d of i.picks??[])s.includes(d)?u(d)||n.push(`mapDefaults.${e}.enums.${a}.picks: '${d}' not visible from ancestors`):n.push(`mapDefaults.${e}.enums.${a}.picks: '${d}' not a known value`);for(let d of i.omits??[])s.includes(d)?u(d)||n.push(`mapDefaults.${e}.enums.${a}.omits: '${d}' already excluded by ancestors`):n.push(`mapDefaults.${e}.enums.${a}.omits: '${d}' not a known value`);}},Ko=(e,t,r,o,n,a,i,s,l)=>{let p=(u,d,m)=>{let c=e[d];if(!c||c.kind!=="enum")return;let h=c.type,w={picks:null,omits:new Set},g=E=>{w.picks=De(w.picks,E);},v=E=>{for(let $ of E)w.omits.add($);},M=[...o];r&&M.push(r);for(let E of M){let $=E[h];$&&($.picks&&g($.picks),$.omits&&v($.omits));}let S=[...a];n&&S.push(n);for(let E of S){let $=E.enumPicks?.[d],_e=E.enumOmits?.[d];$&&g($),_e&&v(_e);}for(let E of i){let $=E.enumPicks?.[d],_e=E.enumOmits?.[d];$&&g($),_e&&v(_e);}for(let E of m)w.omits.has(E)?l.push(`${s}.${u}.${d}: '${E}' already excluded by inherited enum narrowing`):w.picks&&!w.picks.has(E)&&l.push(`${s}.${u}.${d}: '${E}' not allowed by inherited enum narrowing`);};for(let[u,d]of Object.entries(t.enumPicks??{}))p("enumPicks",u,d);for(let[u,d]of Object.entries(t.enumOmits??{}))p("enumOmits",u,d);},zo=(e,t,r,o,n,a,i,s,l)=>{let p=n[a],u=p?.models[i];if(!u)return;let d=r.mapDefaults?.[a]?.models?.[i],m=o.map(g=>g.mapDefaults?.[a]?.models?.[i]).filter(g=>g!==void 0),c=r.mapDefaults?.[a]?.enums,h=o.map(g=>g.mapDefaults?.[a]?.enums).filter(g=>g!==void 0),w=[...m.map(g=>g),...t];Go(e,w,d,u.fields,i,p?.enums,s,l,false),Ko(u.fields,e,c,h,d,m,t,s,l);for(let[g,v]of Object.entries(e.relations??{})){let M=u.fields[g];if(!M){l.push(`${s}.relations: '${g}' not on model`);continue}if(M.kind!=="object"&&M.kind!=="bridge"){l.push(`${s}.relations: '${g}' is not a relation (kind=${M.kind})`);continue}let S=U(M,a);if(!S)continue;if(!n[S.mapName]?.models[S.modelName]){l.push(`${s}.relations.${g}: target model not found in lens`);continue}let E=t.map($=>$.relations?.[g]).filter($=>$!==void 0);zo(v,E,r,o,n,S.mapName,S.modelName,`${s}.relations.${g}`,l);}},vf=e=>{let t=[],r=lt(e),o=ft(e.parent);for(let[n,a]of Object.entries(e.mapDefaults??{})){let i=r.maps[n];if(!i){t.push(`mapDefaults.${n}: not in lens`);continue}let s=o.map(l=>l.mapDefaults?.[n]?.enums).filter(l=>l!==void 0);for(let[l,p]of Object.entries(a.models??{})){let u=i.models[l];if(!u){t.push(`mapDefaults.${n}.models.${l}: not in fieldMap`);continue}let d=o.map(m=>m.mapDefaults?.[n]?.models?.[l]).filter(m=>m!==void 0);Go(p,d,void 0,u.fields,l,i.enums,`mapDefaults.${n}.models.${l}`,t,true),Ko(u.fields,p,void 0,s,void 0,d,[],`mapDefaults.${n}.models.${l}`,t);}a.enums&&Af(n,a.enums,i.enums,s,t);}if(e.root){let n=r.mapName,a=r.model,i=r.maps[n];if(!i)t.push(`root: lens map '${n}' not in lens`);else if(!i.models[a])t.push(`root: lens model '${a}' not in fieldMap`);else {let s=o.map(l=>l.root).filter(l=>l!==void 0);zo(e.root,s,e,o,r.maps,n,a,"root",t);}}if(e.root?.where!==void 0){let n=Ft(e.root.where,e.parent);for(let a of n.violations)t.push(`root.where: '${a.path}' ${a.reason}`);}if(t.length)throw new Error(`validateNarrowing:
3
+ `)}`)},Hf=(e,t="fieldMap")=>{lo({maps:{[t]:e}});};var fo={[f.equals]:f.notEquals,[f.notEquals]:f.equals,[f.lessThan]:f.greaterThanEquals,[f.lessThanEquals]:f.greaterThan,[f.greaterThan]:f.lessThanEquals,[f.greaterThanEquals]:f.lessThan,[f.in]:f.notIn,[f.notIn]:f.in,[f.contains]:f.notContains,[f.notContains]:f.contains,[f.matches]:f.notMatches,[f.notMatches]:f.matches,[f.between]:f.notBetween,[f.notBetween]:f.between,[f.isEmpty]:f.notEmpty,[f.notEmpty]:f.isEmpty,[f.exists]:f.notExists,[f.notExists]:f.exists},Jf={[x.before]:x.onOrAfter,[x.after]:x.onOrBefore,[x.onOrBefore]:x.after,[x.onOrAfter]:x.before,[x.between]:x.notBetween,[x.notBetween]:x.between,[x.dayIn]:x.dayNotIn,[x.dayNotIn]:x.dayIn},Qf=e=>{let t=fo[e.operator];if(!t)throw new Error(`negate: operator '${e.operator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'. Rewrite the where clause using an invertible operator, or add the inverse operator to the DSL.`);return {...e,operator:t}},Yf=e=>{let t=Jf[e.dateOperator];if(!t)throw new Error(`negate: date operator '${e.dateOperator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'.`);return {...e,dateOperator:t}},Zf=e=>{let t=fo[e.operator];if(!t)throw new Error(`negate: aggregate operator '${e.operator}' has no inverse in the DSL.`);return {...e,operator:t}},Xf=e=>{switch(e.arrayOperator){case y.any:return {...e,arrayOperator:y.none};case y.none:return {...e,arrayOperator:y.any};case y.all:if(!e.condition)throw new Error("negate: arrayRule 'all' missing condition");return {...e,arrayOperator:y.any,condition:ne(e.condition)};case y.empty:return {...e,arrayOperator:y.notEmpty};case y.notEmpty:return {...e,arrayOperator:y.empty};case y.atLeast:if(e.count===void 0)throw new Error("negate: 'atLeast' missing count");return {...e,arrayOperator:y.atMost,count:e.count-1};case y.atMost:if(e.count===void 0)throw new Error("negate: 'atMost' missing count");return {...e,arrayOperator:y.atLeast,count:e.count+1};case y.exactly:throw new Error("negate: arrayRule 'exactly' has no single-operator inverse. Rewrite as { any: [atMost n-1, atLeast n+1] } if needed.");default:throw new Error(`negate: unknown arrayOperator '${e.arrayOperator}'`)}},ne=e=>{if(typeof e=="boolean")return !e;if("all"in e)return {any:e.all.map(ne)};if("any"in e)return {all:e.any.map(ne)};if("if"in e)return e.else!==void 0?{if:e.if,then:ne(e.then),else:ne(e.else)}:{all:[e.if,ne(e.then)]};if("arrayOperator"in e)return Xf(e);if("dateOperator"in e)return Yf(e);if("aggregate"in e)return Zf(e);if("field"in e&&"operator"in e)return Qf(e);throw new Error("negate: unknown condition shape")};var uo=e=>"model"in e,vt=e=>{let t=new Set,r=e;for(;!uo(r);){if(t.has(r))throw new Error("cycle detected in narrowing parent chain");t.add(r),r=r.parent;}return r},$t=e=>{let t=[],r=new Set,n=e;for(;!uo(n);){if(r.has(n))throw new Error("cycle detected in narrowing parent chain");r.add(n),t.unshift(n),n=n.parent;}return t},H=(e,t)=>{if(e.kind==="object")return {mapName:t,modelName:e.type};if(e.kind==="bridge"){let[r,n]=e.type.includes(":")?e.type.split(":"):[t,e.type];return {mapName:r,modelName:n}}return null};var Be=e=>{let t=vt(e),r=e.maps===t.maps?[]:$t(e);return {lens:t,chain:r}},Ke=(e,t)=>e===null?new Set(t):new Set(t.filter(r=>e.has(r))),eu=e=>{if(!e.picks)return;if(!("relations"in e)||!e.relations)return e.picks;let t=[...e.picks];for(let r of Object.keys(e.relations))t.includes(r)||t.push(r);return t},tu=(e,t)=>{let r=eu(t);if(r&&(e.picks=Ke(e.picks,r)),t.omits)for(let n of t.omits)e.omits.add(n);},po=(e,t,r)=>{e.set(t,Ke(e.get(t)??null,r));},mo=(e,t,r)=>{let n=e.get(t)??new Set;for(let o of r)n.add(o);e.set(t,n);},ru=(e,t,r)=>{if(r.enumPicks)for(let[n,o]of Object.entries(r.enumPicks))po(e,n,o);if(r.enumOmits)for(let[n,o]of Object.entries(r.enumOmits))mo(t,n,o);},nu=(e,t)=>{tu(e,t),t.where!==void 0&&e.whereClauses.push(t.where);},oe=(e,t,r,n)=>{let o={picks:null,omits:new Set,enumValuesByField:new Map,whereClauses:[],relations:new Map},a=e.lens.maps[t],i=a?.models[r];if(!i)return o;let s=new Map,l=new Map,p=new Map,u=new Map,d=c=>{nu(o,c),ru(s,l,c);};for(let c of e.chain){let m=c.mapDefaults?.[t];if(m){let h=m.models?.[r];h&&d(h);for(let[g,E]of Object.entries(m.enums??{}))E.picks&&po(p,g,E.picks),E.omits&&mo(u,g,E.omits);}let w=c.root;if(n.length===0){if(t===e.lens.mapName&&r===e.lens.model&&w){d(w);for(let[h,g]of Object.entries(w.relations??{}))o.relations.set(h,g);}}else {for(let h of n)if(w=w?.relations?.[h],!w)break;if(w){d(w);for(let[h,g]of Object.entries(w.relations??{}))o.relations.set(h,g);}}}for(let[c,m]of Object.entries(i.fields)){if(m.kind!=="enum")continue;let w=m.type,h=m.values??a?.enums?.[w];if(!h)continue;let g=h,E=p.get(w),A=u.get(w);E&&(g=g.filter(v=>E.has(v))),A&&(g=g.filter(v=>!A.has(v)));let D=s.get(c),R=l.get(c);D&&(g=g.filter(v=>D.has(v))),R&&(g=g.filter(v=>!R.has(v))),o.enumValuesByField.set(c,g);}return o},Yt=(e,t)=>!(e.omits.has(t)||e.picks!==null&&!e.picks.has(t)),co=(e,t)=>e.enumValuesByField.get(t)??null,Zt=(e,t,r,n,o)=>{let a=o.split("."),i=t,s=r,l=[...n],p=[];for(let u=0;u<a.length;u++){let c=e.lens.maps[i]?.models[s];if(!c)return null;let m=oe(e,i,s,l),w=a[u];if(!Yt(m,w))return null;let h=c.fields[w];if(!h)return null;if(u===a.length-1)return {mapName:i,modelName:s,relPath:l,entry:h,hopEffects:p,terminalEffect:m,terminalFieldName:w};p.push(m);let g=H(h,i);if(!g)return null;l=[...l,w],i=g.mapName,s=g.modelName;}return null};var ou=(e,t)=>t.length===0?e:{all:[...t,e]},au=(e,t,r)=>r===y.all?{any:[ne(t),e]}:{all:[t,e]},ce=(e,t,r,n,o)=>{if(typeof e=="boolean")return e;if("all"in e)return {...e,all:e.all.map(a=>ce(a,t,r,n,o))};if("any"in e)return {...e,any:e.any.map(a=>ce(a,t,r,n,o))};if("if"in e)return {...e,if:ce(e.if,t,r,n,o),then:ce(e.then,t,r,n,o),else:e.else!==void 0?ce(e.else,t,r,n,o):e.else};if("field"in e&&typeof e.field=="string"&&e.field!==""){if(!t.lens.maps[r]?.models[n])return e;let s=e.field.split("."),l=r,p=n,u=[...o],c=false;for(let m=0;m<s.length;m++){let w=t.lens.maps[l]?.models[p];if(!w)break;let h=w.fields[s[m]];if(!h)break;if(m===s.length-1){if(h.kind==="object"||h.kind==="bridge"){let g=H(h,l);g&&(u=[...u,s[m]],l=g.mapName,p=g.modelName,c=true);}break}if(h.kind==="object"||h.kind==="bridge"){let g=H(h,l);if(g)u=[...u,s[m]],l=g.mapName,p=g.modelName;else break}else break}if("condition"in e&&e.condition!==void 0&&c){let m=oe(t,l,p,u),w=ce(e.condition,t,l,p,u),h="arrayOperator"in e?e.arrayOperator:void 0;for(let g of m.whereClauses)h?w=au(w,g,h):w={all:[g,w]};return {...e,condition:w}}return e}return e},iu=(e,t)=>{let r=Be(t),n=oe(r,r.lens.mapName,r.lens.model,[]),o=ce(e,r,r.lens.mapName,r.lens.model,[]);return ou(o,n.whereClauses)};var su=e=>{if(e.path!==void 0)return null;let t=e.value;return t===void 0?null:Array.isArray(t)?t:[t]},ge=(e,t,r,n,o,a)=>{if(typeof e=="boolean")return;if("all"in e){for(let m of e.all)ge(m,t,r,n,o,a);return}if("any"in e){for(let m of e.any)ge(m,t,r,n,o,a);return}if("if"in e){ge(e.if,t,r,n,o,a),ge(e.then,t,r,n,o,a),e.else!==void 0&&ge(e.else,t,r,n,o,a);return}let i=r,s=n,l=o,p=null,u=false,d=null,c=null;if("field"in e&&typeof e.field=="string"&&e.field!==""){let m=Zt(t,r,n,o,e.field);if(!m){a.push({path:e.field,reason:"path does not resolve through the narrowed lens"});return}if(p=m.terminalFieldName,u=m.entry.kind==="enum",d=m.entry.type,c=co(m.terminalEffect,p),m.entry.kind==="object"||m.entry.kind==="bridge"){let w=m.entry.kind==="object"?{mapName:m.mapName,modelName:m.entry.type}:{mapName:m.entry.type.split(":")[0]??m.mapName,modelName:m.entry.type.split(":")[1]??m.entry.type};i=w.mapName,s=w.modelName,l=[...m.relPath,p];}}if(u&&"operator"in e&&p){let m=su(e);if(m&&c){let w=new Set(c);for(let h of m)typeof h=="string"&&!w.has(h)&&a.push({path:p,reason:`value '${h}' is not in the allowed set for enum '${d}' (allowed: ${[...w].join(", ")})`});}}if("aggregate"in e&&typeof e.aggregate=="object"&&e.aggregate!==null&&typeof e.aggregate.field=="string"&&e.aggregate.field!==""){let m=e.aggregate.field;Zt(t,i,s,l,m)||a.push({path:m,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ge(e.condition,t,i,s,l,a);},Xt=(e,t)=>{let r=Be(t),n=[];return ge(e,r,r.lens.mapName,r.lens.model,[],n),oe(r,r.lens.mapName,r.lens.model,[]),{ok:n.length===0,violations:n}};var lu=e=>({...Qt({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var go=(e,t,r,n,o,a,i,s,l=false)=>{e.picks&&e.omits&&s.push(`${i}: cannot specify both picks and omits`),l&&"relations"in e&&e.relations&&s.push(`${i}: defaults cannot declare 'relations' \u2014 relations are path-specific only`);for(let u of e.picks??[]){if(!n[u]){s.push(`${i}.picks: field '${u}' not on model`);continue}let d=false;for(let c of t){if(c.picks&&!c.picks.includes(u)){s.push(`${i}.picks: '${u}' not in ancestor's picks`),d=true;break}if(c.omits?.includes(u)){s.push(`${i}.picks: '${u}' was omitted by ancestor`),d=true;break}}d||!l&&r&&(r.picks&&!r.picks.includes(u)?s.push(`${i}.picks: '${u}' not visible from defaults.picks`):r.omits?.includes(u)&&s.push(`${i}.picks: '${u}' not visible (already excluded by defaults.omits)`));}for(let u of e.omits??[]){if(!n[u]){s.push(`${i}.omits: field '${u}' not on model`);continue}let d=false;for(let c of t){if(c.picks&&!c.picks.includes(u)){s.push(`${i}.omits: '${u}' not in ancestor's picks (already invisible)`),d=true;break}if(c.omits?.includes(u)){s.push(`${i}.omits: '${u}' already excluded by ancestor`),d=true;break}}d||!l&&r&&(r.picks&&!r.picks.includes(u)?s.push(`${i}.omits: '${u}' not visible from defaults.picks`):r.omits?.includes(u)&&s.push(`${i}.omits: '${u}' already excluded by defaults`));}let p=(u,d,c)=>{let m=n[d];if(!m){s.push(`${i}.${u}: field '${d}' not on model`);return}if(m.kind!=="enum"){s.push(`${i}.${u}: field '${d}' is not an enum field`);return}let w=m.values??a?.[m.type];for(let h of c)w&&!w.includes(h)&&s.push(`${i}.${u}.${d}: '${h}' is not a known value of enum '${m.type}'`);};for(let[u,d]of Object.entries(e.enumPicks??{}))p("enumPicks",u,d);for(let[u,d]of Object.entries(e.enumOmits??{}))p("enumOmits",u,d);if(e.where!==void 0&&e.where!==true&&e.where!==false){let u=fu(e.where,n,o);for(let d of u)s.push(`${i}.where: ${d}`);}},fu=(e,t,r)=>{let n=[],o=a=>{if(a===null||typeof a!="object")return;if(Array.isArray(a)){for(let s of a)o(s);return}let i=a;if("all"in i&&Array.isArray(i.all)){for(let s of i.all)o(s);return}if("any"in i&&Array.isArray(i.any)){for(let s of i.any)o(s);return}if("if"in i){o(i.if),o(i.then),i.else!==void 0&&o(i.else);return}if("field"in i&&typeof i.field=="string"&&i.field!==""){let s=i.field.split(".")[0];t[s]||n.push(`'${i.field}' not on model ${r}`);}"condition"in i&&i.condition!==void 0&&o(i.condition);};return o(e),n},uu=(e,t,r,n,o)=>{for(let[a,i]of Object.entries(t)){let s=r?.[a];if(!s){o.push(`mapDefaults.${e}.enums.${a}: enum not in registry`);continue}let l=null,p=new Set;for(let d of n){let c=d[a];if(c&&(c.picks&&(l=Ke(l,c.picks)),c.omits))for(let m of c.omits)p.add(m);}let u=d=>!(p.has(d)||l&&!l.has(d));for(let d of i.picks??[])s.includes(d)?u(d)||o.push(`mapDefaults.${e}.enums.${a}.picks: '${d}' not visible from ancestors`):o.push(`mapDefaults.${e}.enums.${a}.picks: '${d}' not a known value`);for(let d of i.omits??[])s.includes(d)?u(d)||o.push(`mapDefaults.${e}.enums.${a}.omits: '${d}' already excluded by ancestors`):o.push(`mapDefaults.${e}.enums.${a}.omits: '${d}' not a known value`);}},yo=(e,t,r,n,o,a,i,s,l)=>{let p=(u,d,c)=>{let m=e[d];if(!m||m.kind!=="enum")return;let w=m.type,h={picks:null,omits:new Set},g=R=>{h.picks=Ke(h.picks,R);},E=R=>{for(let v of R)h.omits.add(v);},A=[...n];r&&A.push(r);for(let R of A){let v=R[w];v&&(v.picks&&g(v.picks),v.omits&&E(v.omits));}let D=[...a];o&&D.push(o);for(let R of D){let v=R.enumPicks?.[d],je=R.enumOmits?.[d];v&&g(v),je&&E(je);}for(let R of i){let v=R.enumPicks?.[d],je=R.enumOmits?.[d];v&&g(v),je&&E(je);}for(let R of c)h.omits.has(R)?l.push(`${s}.${u}.${d}: '${R}' already excluded by inherited enum narrowing`):h.picks&&!h.picks.has(R)&&l.push(`${s}.${u}.${d}: '${R}' not allowed by inherited enum narrowing`);};for(let[u,d]of Object.entries(t.enumPicks??{}))p("enumPicks",u,d);for(let[u,d]of Object.entries(t.enumOmits??{}))p("enumOmits",u,d);},ho=(e,t,r,n,o,a,i,s,l)=>{let p=o[a],u=p?.models[i];if(!u)return;let d=r.mapDefaults?.[a]?.models?.[i],c=n.map(g=>g.mapDefaults?.[a]?.models?.[i]).filter(g=>g!==void 0),m=r.mapDefaults?.[a]?.enums,w=n.map(g=>g.mapDefaults?.[a]?.enums).filter(g=>g!==void 0),h=[...c.map(g=>g),...t];go(e,h,d,u.fields,i,p?.enums,s,l,false),yo(u.fields,e,m,w,d,c,t,s,l);for(let[g,E]of Object.entries(e.relations??{})){let A=u.fields[g];if(!A){l.push(`${s}.relations: '${g}' not on model`);continue}if(A.kind!=="object"&&A.kind!=="bridge"){l.push(`${s}.relations: '${g}' is not a relation (kind=${A.kind})`);continue}let D=H(A,a);if(!D)continue;if(!o[D.mapName]?.models[D.modelName]){l.push(`${s}.relations.${g}: target model not found in lens`);continue}let R=t.map(v=>v.relations?.[g]).filter(v=>v!==void 0);ho(E,R,r,n,o,D.mapName,D.modelName,`${s}.relations.${g}`,l);}},pu=e=>{let t=[],r=vt(e),n=$t(e.parent);for(let[o,a]of Object.entries(e.mapDefaults??{})){let i=r.maps[o];if(!i){t.push(`mapDefaults.${o}: not in lens`);continue}let s=n.map(l=>l.mapDefaults?.[o]?.enums).filter(l=>l!==void 0);for(let[l,p]of Object.entries(a.models??{})){let u=i.models[l];if(!u){t.push(`mapDefaults.${o}.models.${l}: not in fieldMap`);continue}let d=n.map(c=>c.mapDefaults?.[o]?.models?.[l]).filter(c=>c!==void 0);go(p,d,void 0,u.fields,l,i.enums,`mapDefaults.${o}.models.${l}`,t,true),yo(u.fields,p,void 0,s,void 0,d,[],`mapDefaults.${o}.models.${l}`,t);}a.enums&&uu(o,a.enums,i.enums,s,t);}if(e.root){let o=r.mapName,a=r.model,i=r.maps[o];if(!i)t.push(`root: lens map '${o}' not in lens`);else if(!i.models[a])t.push(`root: lens model '${a}' not in fieldMap`);else {let s=n.map(l=>l.root).filter(l=>l!==void 0);ho(e.root,s,e,n,r.maps,o,a,"root",t);}}if(e.root?.where!==void 0){let o=Xt(e.root.where,e.parent);for(let a of o.violations)t.push(`root.where: '${a.path}' ${a.reason}`);}if(t.length)throw new Error(`validateNarrowing:
4
4
  ${t.join(`
5
- `)}`)};var Ef=e=>{let t=Re(e),r=new Map,o=(n,a,i,s)=>{if(r.has(s))return;let l=t.lens.maps[n]?.models[a];if(!l)return;let p=ee(t,n,a,i),u={};for(let[d,m]of Object.entries(l.fields)){if(!_t(p,d))continue;let c=p.enumValuesByField.get(d);u[d]=c!==void 0?{...m,values:c}:m;}r.set(s,{mapName:n,modelName:a,fields:u,whereClauses:p.whereClauses});for(let d of p.relations.keys()){let m=l.fields[d];if(!m)continue;let c=U(m,n);c&&o(c.mapName,c.modelName,[...i,d],`${s}.${d}`);}};return o(t.lens.mapName,t.lens.model,[],t.lens.model),r};var Rf={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},Sf=["Int","Float","Decimal","BigInt"],Se=["String",...Sf,"DateTime"],te=["String"],ut=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],Ho=Object.values(Rf),zh={check:"check",toPrisma:"toPrisma",toSql:"toSql"},k=["check","toPrisma","toSql"],ke=["check","toPrisma"],pt=["check","toSql"],Hh={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},L={[f.equals]:{kinds:ut,targets:k,valueShape:"scalar"},[f.notEquals]:{kinds:ut,targets:k,valueShape:"scalar"},[f.lessThan]:{kinds:Se,targets:k,valueShape:"ordered"},[f.lessThanEquals]:{kinds:Se,targets:k,valueShape:"ordered"},[f.greaterThan]:{kinds:Se,targets:k,valueShape:"ordered"},[f.greaterThanEquals]:{kinds:Se,targets:k,valueShape:"ordered"},[f.in]:{kinds:ut,targets:k,valueShape:"array"},[f.notIn]:{kinds:ut,targets:k,valueShape:"array"},[f.contains]:{kinds:te,targets:k,valueShape:"string"},[f.notContains]:{kinds:te,targets:k,valueShape:"string"},[f.startsWith]:{kinds:te,targets:k,valueShape:"string"},[f.endsWith]:{kinds:te,targets:k,valueShape:"string"},[f.matches]:{kinds:te,targets:pt,valueShape:"pattern"},[f.notMatches]:{kinds:te,targets:pt,valueShape:"pattern"},[f.between]:{kinds:Se,targets:k,valueShape:"range"},[f.notBetween]:{kinds:Se,targets:k,valueShape:"range"},[f.isEmpty]:{kinds:te,targets:k,valueShape:"none"},[f.notEmpty]:{kinds:te,targets:k,valueShape:"none"},[f.exists]:{kinds:Ho,targets:k,valueShape:"none"},[f.notExists]:{kinds:Ho,targets:k,valueShape:"none"}},re={[x.before]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.after]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.onOrBefore]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.onOrAfter]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.between]:{kinds:["DateTime"],targets:k,valueShape:"dateRange"},[x.notBetween]:{kinds:["DateTime"],targets:k,valueShape:"dateRange"},[x.dayIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"},[x.dayNotIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"}},oe={[y.all]:{targets:ke,valueShape:"predicate"},[y.any]:{targets:ke,valueShape:"predicate"},[y.none]:{targets:ke,valueShape:"predicate"},[y.atLeast]:{targets:ke,valueShape:"count"},[y.atMost]:{targets:ke,valueShape:"count"},[y.exactly]:{targets:ke,valueShape:"count"},[y.empty]:{targets:k,valueShape:"none"},[y.notEmpty]:{targets:k,valueShape:"none"}},kf=new Set(["scalar","ordered"]),Tf=new Set(["range"]),Jh=[f.equals,f.notEquals,f.lessThan,f.lessThanEquals,f.greaterThan,f.greaterThanEquals,f.between,f.notBetween],Jo=e=>{let t=L[e];return t?kf.has(t.valueShape):false},Qo=e=>{let t=L[e];return t?Tf.has(t.valueShape):false},Ct=e=>{if(Object.hasOwn(L,e))return L[e].valueShape;if(Object.hasOwn(re,e))return re[e].valueShape;if(Object.hasOwn(oe,e))return oe[e].valueShape;throw new Error(`Unknown operator: ${e}`)},dt=(e,t)=>Object.hasOwn(L,e)?L[e].targets.includes(t):Object.hasOwn(re,e)?re[e].targets.includes(t):Object.hasOwn(oe,e)?oe[e].targets.includes(t):false,Qh=(e,t)=>{let r=Object.keys(L).filter(n=>{let a=L[n];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))}),o=Object.keys(re).filter(n=>{let a=re[n];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))});return {field:r,date:o}},Yh=e=>Object.keys(oe).filter(t=>e?oe[t].targets.includes(e):true);var mt=(e,t,r,o)=>{let n=e.models[t];if(!n)return null;for(let a of Object.values(n.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(o===void 0||a.relationName===o))return a;return null};var I=(e,t)=>{let r=e.split("."),o=t;for(let n=r.length-1;n>=0;n--)o={[r[n]]:o};return o};var Yo,Xo=e=>{Yo=e;},Zo=(e,t,r)=>{if(!t?.map||!t?.model||!r)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return _f(e,t,r)},Mf=(e,t,r)=>{let o=e.split("."),n=[],a=r;for(let i=0;i<o.length;i++){let s=o[i],l=t.models[a]?.fields[s];if(!l||l.kind!=="object")throw new Error(`Field '${s}' is not a relation in model '${a}'. Prisma aggregate rules only support relation fields.`);if(i===o.length-1){if(!l.isList)throw new Error(`Field '${s}' is not a list relation in model '${a}'.`);return {segments:o,intermediateRelations:n,terminalModel:a,terminalEntry:l}}if(l.isList)throw new Error(`Intermediate field '${s}' in path '${e}' is a list relation. Only the final segment can be a list relation for aggregate rules.`);n.push({fieldName:s,entry:l,onModel:a}),a=l.type;}throw new Error(`Field path '${e}' did not terminate at a list relation.`)},_f=(e,t,r)=>{let{map:o,model:n}=t,{intermediateRelations:a,terminalModel:i,terminalEntry:s}=Mf(e.field,o,n),l=s.type,p=e.aggregate.field??"",u=o.models[l]?.fields[p];if(!u)throw new Error(`aggregate.field '${p}' does not exist on model '${l}'.`);if(u.kind!=="scalar")throw new Error(`aggregate.field '${p}' on model '${l}' must be a scalar field, got '${u.kind}'.`);if(u.type==="Json")throw new Error(`aggregate.field '${p}' on model '${l}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let d,m;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");d=s.toFields?.[0]??"id",m=s.fromFields[0];}else {let S=mt(o,l,i,s.relationName);if(!S)throw new Error(`Cannot determine FK relationship between '${i}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((S.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");d=S.fromFields?.[0]??"",m=S.toFields?.[0]??"";}let c=e.condition?Yo(e.condition,{...t,model:l},r):{},h=e.aggregate.mode==="sum"?"_sum":"_avg",w={[p]:{[h]:Pf(e)}},g={operation:"groupBy",model:l,args:{by:[d],where:c,having:w},extract:d},v=r.steps.length;r.steps.push(g);let M={__step:v};if(a.length>0){let S={[m]:{in:M}},E=a.map($=>$.fieldName).join(".");return I(E,S)}return {[m]:{in:M}}},Pf=e=>{let t=e.value;switch(e.operator){case f.equals:return {equals:t};case f.notEquals:return {not:t};case f.lessThan:return {lt:t};case f.lessThanEquals:return {lte:t};case f.greaterThan:return {gt:t};case f.greaterThanEquals:return {gte:t};case f.between:{if(!Array.isArray(t)||t.length!==2)throw new Error("between requires two values");let[r,o]=t,[n,a]=r<=o?[r,o]:[o,r];return {gte:n,lte:a}}case f.notBetween:throw new Error("Operator 'notBetween' is not supported for Prisma aggregate rules.");default:throw new Error(`Operator '${e.operator}' is not supported for Prisma aggregate rules.`)}};var en=(e,t,r,o)=>{let{map:n,model:a}=t;if(!e.field)throw new Error("toPrisma: count-based ArrayRule requires a field path");let i=n.models[a]?.fields[e.field];if(!i||i.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${a}'. Count operators require a relation field.`);if(!i.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${a}'. Count operators only apply to one-to-many or many-to-many relations.`);let s=i.type,l,p;if(i.fromFields&&i.fromFields.length>0){if(i.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=i.toFields?.[0]??"id",p=i.fromFields[0];}else {let g=mt(n,s,a,i.relationName);if(!g){let M=Object.values(n.models[s]?.fields??{}).some(S=>S.kind==="object"&&S.type===a&&S.isList&&!S.fromFields?.length);throw new Error(M?`'${a}.${e.field}' is an implicit many-to-many relation. Count operators require an explicit join model with a FK \u2014 convert to an explicit @relation or use prisma.$queryRaw.`:`Cannot determine FK relationship between '${a}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`)}if((g.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=g.fromFields?.[0]??"",p=g.toFields?.[0]??"";}let u=e.condition?o(e.condition,{...t,model:s},r):{},d=e.count??1,m=Ff(e.arrayOperator,d,l),c={operation:"groupBy",model:s,args:{by:[l],where:u,having:m},extract:l},h=r.steps.length;r.steps.push(c);let w={__step:h};return {[p]:{in:w}}},Ff=(e,t,r)=>{switch(e){case y.atLeast:return {[r]:{_count:{gte:t}}};case y.atMost:return {[r]:{_count:{lte:t}}};case y.exactly:return {[r]:{_count:{equals:t}}};default:throw new Error("unreachable")}};var Be,tn=e=>{Be=e;},rn=(e,t,r)=>{if(e.arrayOperator===y.atLeast||e.arrayOperator===y.atMost||e.arrayOperator===y.exactly){if(t?.map&&t?.model&&r)return en(e,t,r,Be);throw new Error(`ArrayOperator '${e.arrayOperator}' requires a FieldMap and model to generate a multi-step plan. Pass { map, model } options to toPrisma(). Without them, use prisma.$queryRaw for count-based relation filtering.`)}if(!e.field)throw new Error("toPrisma: ArrayRule.field is required (fieldless arrayOps are check-only)");let o=Bf(e,t,r);return I(e.field,o)},Cf=(e,t,r)=>{let o=e.split("."),n=r;for(let a of o){let i=t.models[n]?.fields[a];if(!i||i.kind!=="object")return null;n=i.type;}return n},Df=(e,t)=>{if(!t?.map||!t?.model||!e.field)return t;let r=Cf(e.field,t.map,t.model);return r?{...t,model:r}:t},Bf=(e,t,r)=>{let o=Df(e,t);switch(e.arrayOperator){case y.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:Be(e.condition,o,r)};case y.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:Be(e.condition,o,r)};case y.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:Be(e.condition,o,r)};case y.empty:return {none:{}};case y.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var an=(e,t)=>{let r=qf(e,t);return I(e.field,r)},Nf=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column date comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve date path '${e.path}'. Pass context when calling toPrisma().`);return R(t.context,e.path)}},qf=(e,t)=>{let r=()=>Nf(e,t);switch(e.dateOperator){case x.before:return {lt:r()};case x.after:return {gt:r()};case x.onOrBefore:return {lte:r()};case x.onOrAfter:return {gte:r()};case x.between:{let o=r();if(!Array.isArray(o)||o.length!==2)throw new Error("between date operator requires an array of two values");let[n,a]=on(o);return {gte:n,lte:a}}case x.notBetween:{let o=r();if(!Array.isArray(o)||o.length!==2)throw new Error("notBetween date operator requires an array of two values");let[n,a]=on(o);return {NOT:{gte:n,lte:a}}}case x.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case x.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},on=e=>{let[t,r]=e;return Lf(t,r)<=0?[t,r]:[r,t]},Lf=(e,t)=>{let r=nn(e),o=nn(t);return r<o?-1:r>o?1:0},nn=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var ct=(e,t,r)=>{let o=e.split("."),n=r;for(let a=0;a<o.length;a++){let i=t.models[n];if(!i)return {kind:"fallback"};let s=i.fields[o[a]];if(!s)return {kind:"fallback"};if(s.kind==="bridge")return {kind:"bridge"};if(s.kind==="scalar"&&s.type==="Json"&&a<o.length-1)return {kind:"json-path",stopIndex:a+1,jsonPath:o.slice(a+1)};if(s.kind==="object"){if(!t.models[s.type])return {kind:"fallback"};n=s.type;continue}return {kind:"direct"}}return {kind:"direct"}};var sn=(e,t)=>{if(e.operator===f.isEmpty)return {OR:[Ne(e.field,{equals:null},t),Ne(e.field,{equals:""},t)]};if(e.operator===f.notEmpty)return {AND:[Ne(e.field,{not:null},t),Ne(e.field,{not:""},t)]};let r=jf(e,t);return Ne(e.field,r,t)},If=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve path '${e.path}'. Pass context when calling toPrisma().`);return R(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},jf=(e,t)=>{let r=()=>If(e,t);switch(e.operator){case f.equals:return {equals:r()??null};case f.notEquals:return {not:r()??null};case f.lessThan:return {lt:r()};case f.lessThanEquals:return {lte:r()};case f.greaterThan:return {gt:r()};case f.greaterThanEquals:return {gte:r()};case f.in:return {in:r()};case f.notIn:return {notIn:r()};case f.contains:return {contains:r()};case f.notContains:return {not:{contains:r()}};case f.startsWith:return {startsWith:r()};case f.endsWith:return {endsWith:r()};case f.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.between:{let o=r();if(!Array.isArray(o)||o.length!==2)throw new Error("between operator requires an array of two values");let[n,a]=o[0]<=o[1]?o:[o[1],o[0]];return {gte:n,lte:a}}case f.notBetween:{let o=r();if(!Array.isArray(o)||o.length!==2)throw new Error("notBetween operator requires an array of two values");let[n,a]=o[0]<=o[1]?o:[o[1],o[0]];return {NOT:{gte:n,lte:a}}}case f.isEmpty:case f.notEmpty:throw new Error("isEmpty/notEmpty handled at buildFieldRule level");case f.exists:return {not:null};case f.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},Ne=(e,t,r)=>{if(!r?.map||!r?.model)return I(e,t);let o=ct(e,r.map,r.model),n=e.split(".");switch(o.kind){case "fallback":case "direct":return I(e,t);case "bridge":return {};case "json-path":{let a={path:o.jsonPath,...t},i=n.slice(0,o.stopIndex).join(".");return I(i,a)}}};var Te,fn=e=>{Te=e;},Vf=(e,t,r)=>{let o=e.split("."),n=r;for(let a of o){let i=t.models[n]?.fields[a];if(!i||i.kind!=="object")return null;n=i.type;}return n},G=(e,t)=>{if(typeof e=="boolean"||!t?.map||!t?.model)return false;if("all"in e)return e.all.some(r=>G(r,t));if("any"in e)return e.any.some(r=>G(r,t));if("if"in e)return G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(ct(e.field,t.map,t.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let o=Vf(e.field,t.map,t.model);if(o&&G(e.condition,{...t,model:o}))return true}}return false},un=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(o=>Te(o,t,r))},pn=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(o=>Te(o,t,r))},dn=(e,t,r)=>{if(G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t))return {};let o=Te(e.if,t,r),n={NOT:o},a=e.then===false?ln:Te(e.then,t,r);if(e.else!==void 0){let i=e.else===false?ln:Te(e.else,t,r);return {AND:[{OR:[n,a]},{OR:[o,i]}]}}return {OR:[n,a]}},ln={AND:[{id:null},{id:{not:null}}]};var qe=(e,t,r)=>{if(typeof e=="boolean"){if(e)return {};throw new Error("Boolean 'false' has no direct Prisma WHERE equivalent. toPrisma is designed for structured Rule conditions.")}if("all"in e)return un(e,t,r);if("any"in e)return pn(e,t,r);if("if"in e)return dn(e,t,r);if("arrayOperator"in e)return rn(e,t,r);if("dateOperator"in e)return an(e,t);if("aggregate"in e)return Zo(e,t,r);if("field"in e)return sn(e,t);throw new Error("Unknown condition type")};fn(qe);tn(qe);Xo(qe);var Wf=async(e,t)=>{let r=e.steps.filter(a=>a.operation==="groupBy"),o=e.steps.find(a=>a.operation==="where");if(!o)throw new Error("executePrismaQueryPlan: result has no where step");let n=[];for(let a of r){let i=a.model.charAt(0).toLowerCase()+a.model.slice(1),s=t[i];if(!s)throw new Error(`executePrismaQueryPlan: no delegate for model '${a.model}'. Ensure prismaDelegate has a key '${i}'.`);let l=await s[a.operation](a.args);n.push(l.map(p=>p[a.extract]));}return Dt(o.where,n)},Dt=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>Dt(r,t));if(typeof e=="object"){let r=e;if("__step"in r&&typeof r.__step=="number"){let n=r.__step;if(n>=t.length)throw new Error(`Step ref __step: ${n} out of range (${t.length} steps executed)`);return t[n]}let o={};for(let[n,a]of Object.entries(r))o[n]=Dt(a,t);return o}return e};var Uf=e=>{if(!e?.map)return e;let t="maps"in e.map;if(t&&!e.mapName)throw new Error("toPrisma: 'map' is a FieldMapSet \u2014 'mapName' is required to resolve which map to use.");if(!t||!e.mapName)return e;let r=e.map.maps[e.mapName];if(!r)throw new Error(`toPrisma: fieldMap set has no entry for '${e.mapName}'`);return {...e,map:r}},Pw=(e,t)=>{let r={steps:[]},o=qe(e,Uf(t),r);return {steps:[...r.steps,{operation:"where",where:o}]}};var A=e=>`"${e.replace(/"/g,'""')}"`;var O=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var Le=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),F=e=>{let t=e.split(".");if(t.length===1)return A(e);let[r,...o]=t;return o.length===0?A(r):cn(A(r),o)},mn=(e,t)=>{let r=e.split(".");if(r.length===1)return `${A(t)}.${A(e)}`;let[o,...n]=r;return cn(`${A(t)}.${A(o)}`,n)},Bt=e=>`'${e.replace(/'/g,"''")}'`,cn=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(Bt).join("->"),o=Bt(t[t.length-1]);return r?`${e}->${r}->>${o}`:`${e}->>${o}`},gn=e=>{let t=e.split(".");if(t.length===1)return A(e);let[r,...o]=t;return o.length===0?A(r):Gf(A(r),o)},Gf=(e,t)=>{let r=t.map(Bt).join("->");return `${e}->${r}`};var yn=(e,t)=>{if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let r=Kf(e,t);return Hf(r,e,t)},Kf=(e,t)=>{let r=gn(e.field),{mode:o,field:n}=e.aggregate,a=o==="sum"?"SUM":"AVG",i=t.map?.models[t.currentModel??""]?.fields[e.field];if(i?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(n?.includes("."))throw new Error(`aggregate.field '${n}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(i?.kind==="scalar"&&i?.isList===true){if(n)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${a==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${r}) AS elem)`}if(n){let u=`(elem->>'${n}')::numeric`;return `(SELECT ${a==="SUM"?`COALESCE(SUM(${u}), 0)`:`AVG(${u})`} FROM jsonb_array_elements(${r}) AS elem)`}let l="elem::numeric";return `(SELECT ${a==="SUM"?`COALESCE(SUM(${l}), 0)`:`AVG(${l})`} FROM jsonb_array_elements_text(${r}) AS elem)`},zf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:R(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},Hf=(e,t,r)=>{let o=zf(t,r),n=o.type==="value"?o.value:void 0,a=o.type==="column"?o.sql:void 0;switch(t.operator){case f.equals:return a?`${e} = ${a}`:n===null?`${e} IS NULL`:`${e} = ${O(r,n)}`;case f.notEquals:return a?`${e} <> ${a}`:n===null?`${e} IS NOT NULL`:`${e} <> ${O(r,n)}`;case f.lessThan:return a?`${e} < ${a}`:`${e} < ${O(r,n)}`;case f.lessThanEquals:return a?`${e} <= ${a}`:`${e} <= ${O(r,n)}`;case f.greaterThan:return a?`${e} > ${a}`:`${e} > ${O(r,n)}`;case f.greaterThanEquals:return a?`${e} >= ${a}`:`${e} >= ${O(r,n)}`;case f.between:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("between requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} BETWEEN ${O(r,s)} AND ${O(r,l)}`}case f.notBetween:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} NOT BETWEEN ${O(r,s)} AND ${O(r,l)}`}default:throw new Error(`Operator '${t.operator}' is not supported for aggregate rules`)}};var hn=(e,t)=>{if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let r=F(e.field),o=t.map?.models[t.currentModel??""]?.fields[e.field],n=o?.kind==="scalar"&&o?.isList===true,a=n?`array_length(${r}, 1)`:`jsonb_array_length(${r})`;switch(e.arrayOperator){case y.empty:return n?`(${r} IS NULL OR ${a} IS NULL)`:`(${r} IS NULL OR ${a} = 0)`;case y.notEmpty:return n?`(${r} IS NOT NULL AND ${a} IS NOT NULL)`:`(${r} IS NOT NULL AND ${a} > 0)`;case y.all:case y.any:case y.none:case y.atLeast:case y.atMost:case y.exactly:throw new Error(`Array operator '${e.arrayOperator}' with conditions is not supported in SQL. Use application-level filtering for complex array operations.`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Nt=e=>{let t={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};return e.map(r=>{let o=t[r.toLowerCase()];if(o===void 0)throw new Error(`Unknown day name: ${r}`);return o})};var gt=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return F(e);let r=e.split("."),o=t.currentModel,n=t.currentAlias;for(let a=0;a<r.length;a++){let i=t.map.models[o];if(!i)return F(e);let s=i.fields[r[a]];if(!s)return F(e);if(s.kind==="object"){let p=`${n}.${r[a]}`,u=t.joinRegistry?.get(p),d;if(u)d=u;else {let m=t.joinCounter;if(!m)return F(e);d=`t${++m.n}`;let c=Jf(t.map,o,n,s,d);if(!c)return F(e);t.joins?.push(c),t.joinRegistry?.set(p,d);}o=s.type,n=d;continue}let l=r.slice(a);return mn(l.join("."),n)}return F(e)},Jf=(e,t,r,o,n)=>{let a=o.type,i=e.models[a]?.dbName??a,s;if(o.fromFields&&o.fromFields.length>0&&o.toFields&&o.toFields.length>0)s=o.fromFields.map((l,p)=>`${A(n)}.${A(o.toFields?.[p]??"")} = ${A(r)}.${A(l)}`).join(" AND ");else {let l=Qf(e,a,t,o.relationName);if(!l)return null;s=(l.fromFields??[]).map((p,u)=>`${A(n)}.${A(p)} = ${A(r)}.${A(l.toFields?.[u]??"")}`).join(" AND ");}return `LEFT JOIN ${A(i)} AS ${A(n)} ON ${s}`},Qf=(e,t,r,o)=>{let n=e.models[t];if(!n)return null;for(let a of Object.values(n.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(o===void 0||a.relationName===o))return a;return null};var bn=(e,t)=>{let r=gt(e.field,t),o=Xf(e,t),n=o.type==="value"?o.value:void 0,a=o.type==="column"?o.sql:void 0;switch(e.dateOperator){case x.before:return a!==void 0?`${r} < ${a}`:`${r} < ${O(t,n)}`;case x.after:return a!==void 0?`${r} > ${a}`:`${r} > ${O(t,n)}`;case x.onOrBefore:return a!==void 0?`${r} <= ${a}`:`${r} <= ${O(t,n)}`;case x.onOrAfter:return a!==void 0?`${r} >= ${a}`:`${r} >= ${O(t,n)}`;case x.between:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("between date operator requires an array of two values");let[s,l]=wn(i);return `${r} BETWEEN ${O(t,s)} AND ${O(t,l)}`}case x.notBetween:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween date operator requires an array of two values");let[s,l]=wn(i);return `${r} NOT BETWEEN ${O(t,s)} AND ${O(t,l)}`}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=Nt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) = ANY(${O(t,i)})`}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let i=Nt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) <> ALL(${O(t,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},wn=e=>{let[t,r]=e;return Yf(t,r)<=0?[t,r]:[r,t]},Yf=(e,t)=>{let r=xn(e),o=xn(t);return r<o?-1:r>o?1:0},xn=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),Xf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve date path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:R(t.context,e.path)}}return {type:"value",value:void 0}};var On=(e,t)=>{let r=gt(e.field,t),o=Zf(e,t),n=o.type==="value"?o.value:void 0,a=o.type==="column"?o.sql:void 0;switch(e.operator){case f.equals:return a!==void 0?`${r} = ${a}`:n===null?`${r} IS NULL`:`${r} = ${O(t,n)}`;case f.notEquals:return a!==void 0?`${r} <> ${a}`:n===null?`${r} IS NOT NULL`:`${r} <> ${O(t,n)}`;case f.lessThan:return a!==void 0?`${r} < ${a}`:`${r} < ${O(t,n)}`;case f.lessThanEquals:return a!==void 0?`${r} <= ${a}`:`${r} <= ${O(t,n)}`;case f.greaterThan:return a!==void 0?`${r} > ${a}`:`${r} > ${O(t,n)}`;case f.greaterThanEquals:return a!==void 0?`${r} >= ${a}`:`${r} >= ${O(t,n)}`;case f.in:return !Array.isArray(n)||n.length===0?"FALSE":`${r} = ANY(${O(t,n)})`;case f.notIn:return !Array.isArray(n)||n.length===0?"TRUE":`${r} <> ALL(${O(t,n)})`;case f.contains:return `${r} LIKE ${O(t,`%${Le(String(n))}%`)}`;case f.notContains:return `${r} NOT LIKE ${O(t,`%${Le(String(n))}%`)}`;case f.startsWith:return `${r} LIKE ${O(t,`${Le(String(n))}%`)}`;case f.endsWith:return `${r} LIKE ${O(t,`%${Le(String(n))}`)}`;case f.matches:return `${r} ~ ${O(t,n)}`;case f.notMatches:return `${r} !~ ${O(t,n)}`;case f.between:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("between operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} BETWEEN ${O(t,s)} AND ${O(t,l)}`}case f.notBetween:{let i=n;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} NOT BETWEEN ${O(t,s)} AND ${O(t,l)}`}case f.isEmpty:return `(${r} IS NULL OR ${r} = '')`;case f.notEmpty:return `(${r} IS NOT NULL AND ${r} <> '')`;case f.exists:return `${r} IS NOT NULL`;case f.notExists:return `${r} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},Zf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:R(t.context,e.path)}}return {type:"value",value:void 0}};var Me,$n=e=>{Me=e;},eu=(e,t,r)=>{let o=e.split("."),n=r;for(let a=0;a<o.length;a++){let i=t.models[n];if(!i)return false;let s=i.fields[o[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){n=s.type;continue}return false}return false},tu=(e,t,r)=>{let o=e.split("."),n=r;for(let a of o){let i=t.models[n]?.fields[a];if(!i||i.kind!=="object")return null;n=i.type;}return n},K=(e,t)=>{if(typeof e=="boolean"||!t.map||!t.currentModel)return false;if("all"in e)return e.all.some(r=>K(r,t));if("any"in e)return e.any.some(r=>K(r,t));if("if"in e)return K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(eu(e.field,t.map,t.currentModel))return true;if("condition"in e&&e.condition!==void 0){let r=tu(e.field,t.map,t.currentModel);if(r&&K(e.condition,{...t,currentModel:r}))return true}}return false},An=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(o=>Me(o,t)).join(" AND ")})`,vn=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(o=>Me(o,t)).join(" OR ")})`,En=(e,t)=>{if(K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t))return "TRUE";let r=Me(e.if,t),o=Me(e.then,t);if(e.else!==void 0){let n=Me(e.else,t);return `((NOT(${r}) OR ${o}) AND (${r} OR ${n}))`}return `(NOT(${r}) OR ${o})`};var ru=(e,t,r)=>{let o=e.split("."),n=r;for(let a=0;a<o.length;a++){let i=t.models[n];if(!i)return false;let s=i.fields[o[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){n=s.type;continue}return false}return false},qt=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&t.map&&t.currentModel&&ru(e.field,t.map,t.currentModel))return "TRUE";if("all"in e)return An(e,t);if("any"in e)return vn(e,t);if("if"in e)return En(e,t);if("arrayOperator"in e)return hn(e,t);if("dateOperator"in e)return bn(e,t);if("aggregate"in e)return yn(e,t);if("field"in e)return On(e,t);throw new Error("Unknown condition type")};$n(qt);var Ox=(e,t)=>{let r=!!(t?.map&&t?.model),o=t?.alias??(r?"t0":void 0),n={params:[],paramIndex:0,context:t?.context,map:t?.map,currentModel:t?.model,currentAlias:o,joinCounter:r?{n:0}:void 0,joins:r?[]:void 0,joinRegistry:r?new Map:void 0};return {sql:qt(e,n),params:n.params,joins:n.joins??[]}};var ou=new Set(Object.keys(L)),nu=new Set(Object.keys(oe)),au=new Set(Object.keys(re)),iu=(e,t={})=>{let r={target:t.target??"check",errors:[]};return ne(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},Ex=(e,t={})=>{let r=iu(e,t);if(r.ok)return;let o=r.errors.map(n=>`${n.path}: ${n.message}`).join(`
5
+ `)}`)};var du=e=>{let t=Be(e),r=new Map,n=(o,a,i,s)=>{if(r.has(s))return;let l=t.lens.maps[o]?.models[a];if(!l)return;let p=oe(t,o,a,i),u={};for(let[d,c]of Object.entries(l.fields)){if(!Yt(p,d))continue;let m=p.enumValuesByField.get(d);u[d]=m!==void 0?{...c,values:m}:c;}r.set(s,{mapName:o,modelName:a,fields:u,whereClauses:p.whereClauses});for(let d of p.relations.keys()){let c=l.fields[d];if(!c)continue;let m=H(c,o);m&&n(m.mapName,m.modelName,[...i,d],`${s}.${d}`);}};return n(t.lens.mapName,t.lens.model,[],t.lens.model),r};var mu={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},cu=["Int","Float","Decimal","BigInt"],qe=["String",...cu,"DateTime"],ae=["String"],At=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],wo=Object.values(mu),hx={check:"check",toPrisma:"toPrisma",toSql:"toSql"},T=["check","toPrisma","toSql"],Ne=["check","toPrisma"],Rt=["check","toSql"],wx={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},j={[f.equals]:{kinds:At,targets:T,valueShape:"scalar"},[f.notEquals]:{kinds:At,targets:T,valueShape:"scalar"},[f.lessThan]:{kinds:qe,targets:T,valueShape:"ordered"},[f.lessThanEquals]:{kinds:qe,targets:T,valueShape:"ordered"},[f.greaterThan]:{kinds:qe,targets:T,valueShape:"ordered"},[f.greaterThanEquals]:{kinds:qe,targets:T,valueShape:"ordered"},[f.in]:{kinds:At,targets:T,valueShape:"array"},[f.notIn]:{kinds:At,targets:T,valueShape:"array"},[f.contains]:{kinds:ae,targets:T,valueShape:"string"},[f.notContains]:{kinds:ae,targets:T,valueShape:"string"},[f.startsWith]:{kinds:ae,targets:T,valueShape:"string"},[f.endsWith]:{kinds:ae,targets:T,valueShape:"string"},[f.matches]:{kinds:ae,targets:Rt,valueShape:"pattern"},[f.notMatches]:{kinds:ae,targets:Rt,valueShape:"pattern"},[f.between]:{kinds:qe,targets:T,valueShape:"range"},[f.notBetween]:{kinds:qe,targets:T,valueShape:"range"},[f.isEmpty]:{kinds:ae,targets:T,valueShape:"none"},[f.notEmpty]:{kinds:ae,targets:T,valueShape:"none"},[f.exists]:{kinds:wo,targets:T,valueShape:"none"},[f.notExists]:{kinds:wo,targets:T,valueShape:"none"}},ie={[x.before]:{kinds:["DateTime"],targets:T,valueShape:"dateValue"},[x.after]:{kinds:["DateTime"],targets:T,valueShape:"dateValue"},[x.onOrBefore]:{kinds:["DateTime"],targets:T,valueShape:"dateValue"},[x.onOrAfter]:{kinds:["DateTime"],targets:T,valueShape:"dateValue"},[x.within]:{kinds:["DateTime"],targets:T,valueShape:"dateRange"},[x.between]:{kinds:["DateTime"],targets:T,valueShape:"dateRange"},[x.notBetween]:{kinds:["DateTime"],targets:T,valueShape:"dateRange"},[x.dayIn]:{kinds:["DateTime"],targets:Rt,valueShape:"dayList"},[x.dayNotIn]:{kinds:["DateTime"],targets:Rt,valueShape:"dayList"}},se={[y.all]:{targets:Ne,valueShape:"predicate"},[y.any]:{targets:Ne,valueShape:"predicate"},[y.none]:{targets:Ne,valueShape:"predicate"},[y.atLeast]:{targets:Ne,valueShape:"count"},[y.atMost]:{targets:Ne,valueShape:"count"},[y.exactly]:{targets:Ne,valueShape:"count"},[y.empty]:{targets:T,valueShape:"none"},[y.notEmpty]:{targets:T,valueShape:"none"}},gu=new Set(["scalar","ordered"]),yu=new Set(["range"]),xx=[f.equals,f.notEquals,f.lessThan,f.lessThanEquals,f.greaterThan,f.greaterThanEquals,f.between,f.notBetween],xo=e=>{let t=j[e];return t?gu.has(t.valueShape):false},bo=e=>{let t=j[e];return t?yu.has(t.valueShape):false},er=e=>{if(Object.hasOwn(j,e))return j[e].valueShape;if(Object.hasOwn(ie,e))return ie[e].valueShape;if(Object.hasOwn(se,e))return se[e].valueShape;throw new Error(`Unknown operator: ${e}`)},kt=(e,t)=>Object.hasOwn(j,e)?j[e].targets.includes(t):Object.hasOwn(ie,e)?ie[e].targets.includes(t):Object.hasOwn(se,e)?se[e].targets.includes(t):false,bx=(e,t)=>{let r=Object.keys(j).filter(o=>{let a=j[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))}),n=Object.keys(ie).filter(o=>{let a=ie[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))});return {field:r,date:n}},Ox=e=>Object.keys(se).filter(t=>e?se[t].targets.includes(e):true);var St=(e,t,r,n)=>{let o=e.models[t];if(!o)return null;for(let a of Object.values(o.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(n===void 0||a.relationName===n))return a;return null};var W=(e,t)=>{let r=e.split("."),n=t;for(let o=r.length-1;o>=0;o--)n={[r[o]]:n};return n};var Oo,Eo=e=>{Oo=e;},vo=(e,t,r)=>{if(re(e))throw new Error("Windowing (orderBy/take/skip) is not supported by toPrisma(); evaluate with check().");if(!t?.map||!t?.model||!r)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return wu(e,t,r)},hu=(e,t,r)=>{let n=e.split("."),o=[],a=r;for(let i=0;i<n.length;i++){let s=n[i],l=t.models[a]?.fields[s];if(!l||l.kind!=="object")throw new Error(`Field '${s}' is not a relation in model '${a}'. Prisma aggregate rules only support relation fields.`);if(i===n.length-1){if(!l.isList)throw new Error(`Field '${s}' is not a list relation in model '${a}'.`);return {segments:n,intermediateRelations:o,terminalModel:a,terminalEntry:l}}if(l.isList)throw new Error(`Intermediate field '${s}' in path '${e}' is a list relation. Only the final segment can be a list relation for aggregate rules.`);o.push({fieldName:s,entry:l,onModel:a}),a=l.type;}throw new Error(`Field path '${e}' did not terminate at a list relation.`)},wu=(e,t,r)=>{let{map:n,model:o}=t,{intermediateRelations:a,terminalModel:i,terminalEntry:s}=hu(e.field,n,o),l=s.type,p=e.aggregate.field??"",u=n.models[l]?.fields[p];if(!u)throw new Error(`aggregate.field '${p}' does not exist on model '${l}'.`);if(u.kind!=="scalar")throw new Error(`aggregate.field '${p}' on model '${l}' must be a scalar field, got '${u.kind}'.`);if(u.type==="Json")throw new Error(`aggregate.field '${p}' on model '${l}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let d,c;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");d=s.toFields?.[0]??"id",c=s.fromFields[0];}else {let D=St(n,l,i,s.relationName);if(!D)throw new Error(`Cannot determine FK relationship between '${i}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((D.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");d=D.fromFields?.[0]??"",c=D.toFields?.[0]??"";}let m=e.condition?Oo(e.condition,{...t,model:l},r):{},w=e.aggregate.mode==="sum"?"_sum":"_avg",h={[p]:{[w]:xu(e)}},g={operation:"groupBy",model:l,args:{by:[d],where:m,having:h},extract:d},E=r.steps.length;r.steps.push(g);let A={__step:E};if(a.length>0){let D={[c]:{in:A}},R=a.map(v=>v.fieldName).join(".");return W(R,D)}return {[c]:{in:A}}},xu=e=>{let t=e.value;switch(e.operator){case f.equals:return {equals:t};case f.notEquals:return {not:t};case f.lessThan:return {lt:t};case f.lessThanEquals:return {lte:t};case f.greaterThan:return {gt:t};case f.greaterThanEquals:return {gte:t};case f.between:{if(!Array.isArray(t)||t.length!==2)throw new Error("between requires two values");let[r,n]=t,[o,a]=r<=n?[r,n]:[n,r];return {gte:o,lte:a}}case f.notBetween:throw new Error("Operator 'notBetween' is not supported for Prisma aggregate rules.");default:throw new Error(`Operator '${e.operator}' is not supported for Prisma aggregate rules.`)}};var $o=(e,t,r,n)=>{let{map:o,model:a}=t;if(!e.field)throw new Error("toPrisma: count-based ArrayRule requires a field path");let i=o.models[a]?.fields[e.field];if(!i||i.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${a}'. Count operators require a relation field.`);if(!i.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${a}'. Count operators only apply to one-to-many or many-to-many relations.`);let s=i.type,l,p;if(i.fromFields&&i.fromFields.length>0){if(i.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=i.toFields?.[0]??"id",p=i.fromFields[0];}else {let g=St(o,s,a,i.relationName);if(!g){let A=Object.values(o.models[s]?.fields??{}).some(D=>D.kind==="object"&&D.type===a&&D.isList&&!D.fromFields?.length);throw new Error(A?`'${a}.${e.field}' is an implicit many-to-many relation. Count operators require an explicit join model with a FK \u2014 convert to an explicit @relation or use prisma.$queryRaw.`:`Cannot determine FK relationship between '${a}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`)}if((g.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=g.fromFields?.[0]??"",p=g.toFields?.[0]??"";}let u=e.condition?n(e.condition,{...t,model:s},r):{},d=e.count??1,c=bu(e.arrayOperator,d,l),m={operation:"groupBy",model:s,args:{by:[l],where:u,having:c},extract:l},w=r.steps.length;r.steps.push(m);let h={__step:w};return {[p]:{in:h}}},bu=(e,t,r)=>{switch(e){case y.atLeast:return {[r]:{_count:{gte:t}}};case y.atMost:return {[r]:{_count:{lte:t}}};case y.exactly:return {[r]:{_count:{equals:t}}};default:throw new Error("unreachable")}};var Ou="Windowing (orderBy/take/skip) is not supported by toPrisma() for this rule; only extremal (take:1, single orderBy on the compared field, aligned direction) rewrites to every/some. Evaluate other windowed rules with check().",ze,Ao=e=>{ze=e;},tr=(e,t,r)=>{if(re(e)){let o=Et(e);if(!o)throw new Error(Ou);return tr(o,t,r)}if(e.arrayOperator===y.atLeast||e.arrayOperator===y.atMost||e.arrayOperator===y.exactly){if(t?.map&&t?.model&&r)return $o(e,t,r,ze);throw new Error(`ArrayOperator '${e.arrayOperator}' requires a FieldMap and model to generate a multi-step plan. Pass { map, model } options to toPrisma(). Without them, use prisma.$queryRaw for count-based relation filtering.`)}if(!e.field)throw new Error("toPrisma: ArrayRule.field is required (fieldless arrayOps are check-only)");let n=$u(e,t,r);return W(e.field,n)},Eu=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},vu=(e,t)=>{if(!t?.map||!t?.model||!e.field)return t;let r=Eu(e.field,t.map,t.model);return r?{...t,model:r}:t},$u=(e,t,r)=>{let n=vu(e,t);switch(e.arrayOperator){case y.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:ze(e.condition,n,r)};case y.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:ze(e.condition,n,r)};case y.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:ze(e.condition,n,r)};case y.empty:return {none:{}};case y.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Au=e=>({now:e?.now,timeZone:e?.timeZone,weekStart:e?.weekStart}),So=(e,t)=>{let r=Ru(e,t);return W(e.field,r)},rr=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column date comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve date path '${e.path}'. Pass context when calling toPrisma().`);return S(t.context,e.path)}},Ru=(e,t)=>{let r=Au(t),n=()=>P(e.value)?bt(e.value,e.dateOperator,r).toDate():rr(e,t),o=a=>P(a)?K(a,r).toDate():a;switch(e.dateOperator){case x.before:return {lt:n()};case x.after:return {gt:n()};case x.onOrBefore:return {lte:n()};case x.onOrAfter:return {gte:n()};case x.within:{if(!P(e.value))throw new Error("within date operator requires a range date expression");let[a,i]=Pe(e.value,r);return {gte:a.toDate(),lte:i.toDate()}}case x.between:{let a=rr(e,t);if(!Array.isArray(a)||a.length!==2)throw new Error("between date operator requires an array of two values");let[i,s]=Ro(a.map(o));return {gte:i,lte:s}}case x.notBetween:{let a=rr(e,t);if(!Array.isArray(a)||a.length!==2)throw new Error("notBetween date operator requires an array of two values");let[i,s]=Ro(a.map(o));return {NOT:{gte:i,lte:s}}}case x.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case x.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Ro=e=>{let[t,r]=e;return ku(t,r)<=0?[t,r]:[r,t]},ku=(e,t)=>{let r=ko(e),n=ko(t);return r<n?-1:r>n?1:0},ko=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var Tt=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return {kind:"fallback"};let s=i.fields[n[a]];if(!s)return {kind:"fallback"};if(s.kind==="bridge")return {kind:"bridge"};if(s.kind==="scalar"&&s.type==="Json"&&a<n.length-1)return {kind:"json-path",stopIndex:a+1,jsonPath:n.slice(a+1)};if(s.kind==="object"){if(!t.models[s.type])return {kind:"fallback"};o=s.type;continue}return {kind:"direct"}}return {kind:"direct"}};var To=(e,t)=>{if(e.operator===f.isEmpty)return {OR:[He(e.field,{equals:null},t),He(e.field,{equals:""},t)]};if(e.operator===f.notEmpty)return {AND:[He(e.field,{not:null},t),He(e.field,{not:""},t)]};let r=Tu(e,t);return He(e.field,r,t)},Su=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve path '${e.path}'. Pass context when calling toPrisma().`);return S(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},Tu=(e,t)=>{let r=()=>Su(e,t);switch(e.operator){case f.equals:return {equals:r()??null};case f.notEquals:return {not:r()??null};case f.lessThan:return {lt:r()};case f.lessThanEquals:return {lte:r()};case f.greaterThan:return {gt:r()};case f.greaterThanEquals:return {gte:r()};case f.in:return {in:r()};case f.notIn:return {notIn:r()};case f.contains:return {contains:r()};case f.notContains:return {not:{contains:r()}};case f.startsWith:return {startsWith:r()};case f.endsWith:return {endsWith:r()};case f.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between operator requires an array of two values");let[o,a]=n[0]<=n[1]?n:[n[1],n[0]];return {gte:o,lte:a}}case f.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween operator requires an array of two values");let[o,a]=n[0]<=n[1]?n:[n[1],n[0]];return {NOT:{gte:o,lte:a}}}case f.isEmpty:case f.notEmpty:throw new Error("isEmpty/notEmpty handled at buildFieldRule level");case f.exists:return {not:null};case f.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},He=(e,t,r)=>{if(!r?.map||!r?.model)return W(e,t);let n=Tt(e,r.map,r.model),o=e.split(".");switch(n.kind){case "fallback":case "direct":return W(e,t);case "bridge":return {};case "json-path":{let a={path:n.jsonPath,...t},i=o.slice(0,n.stopIndex).join(".");return W(i,a)}}};var Le,Mo=e=>{Le=e;},Du=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},J=(e,t)=>{if(typeof e=="boolean"||!t?.map||!t?.model)return false;if("all"in e)return e.all.some(r=>J(r,t));if("any"in e)return e.any.some(r=>J(r,t));if("if"in e)return J(e.if,t)||J(e.then,t)||e.else!==void 0&&J(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(Tt(e.field,t.map,t.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let n=Du(e.field,t.map,t.model);if(n&&J(e.condition,{...t,model:n}))return true}}return false},_o=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(n=>Le(n,t,r))},Po=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>Le(n,t,r))},Co=(e,t,r)=>{if(J(e.if,t)||J(e.then,t)||e.else!==void 0&&J(e.else,t))return {};let n=Le(e.if,t,r),o={NOT:n},a=e.then===false?Do:Le(e.then,t,r);if(e.else!==void 0){let i=e.else===false?Do:Le(e.else,t,r);return {AND:[{OR:[o,a]},{OR:[n,i]}]}}return {OR:[o,a]}},Do={AND:[{id:null},{id:{not:null}}]};var Je=(e,t,r)=>{if(typeof e=="boolean"){if(e)return {};throw new Error("Boolean 'false' has no direct Prisma WHERE equivalent. toPrisma is designed for structured Rule conditions.")}if("all"in e)return _o(e,t,r);if("any"in e)return Po(e,t,r);if("if"in e)return Co(e,t,r);if("arrayOperator"in e)return tr(e,t,r);if("dateOperator"in e)return So(e,t);if("aggregate"in e)return vo(e,t,r);if("field"in e)return To(e,t);throw new Error("Unknown condition type")};Mo(Je);Ao(Je);Eo(Je);var Mu=async(e,t)=>{let r=e.steps.filter(a=>a.operation==="groupBy"),n=e.steps.find(a=>a.operation==="where");if(!n)throw new Error("executePrismaQueryPlan: result has no where step");let o=[];for(let a of r){let i=a.model.charAt(0).toLowerCase()+a.model.slice(1),s=t[i];if(!s)throw new Error(`executePrismaQueryPlan: no delegate for model '${a.model}'. Ensure prismaDelegate has a key '${i}'.`);let l=await s[a.operation](a.args);o.push(l.map(p=>p[a.extract]));}return nr(n.where,o)},nr=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>nr(r,t));if(typeof e=="object"){let r=e;if("__step"in r&&typeof r.__step=="number"){let o=r.__step;if(o>=t.length)throw new Error(`Step ref __step: ${o} out of range (${t.length} steps executed)`);return t[o]}let n={};for(let[o,a]of Object.entries(r))n[o]=nr(a,t);return n}return e};var _u=e=>{if(!e?.map)return e;let t="maps"in e.map;if(t&&!e.mapName)throw new Error("toPrisma: 'map' is a FieldMapSet \u2014 'mapName' is required to resolve which map to use.");if(!t||!e.mapName)return e;let r=e.map.maps[e.mapName];if(!r)throw new Error(`toPrisma: fieldMap set has no entry for '${e.mapName}'`);return {...e,map:r}},ab=(e,t)=>{let r={steps:[]},n=Je(e,_u(t),r);return {steps:[...r.steps,{operation:"where",where:n}]}};var $=e=>`"${e.replace(/"/g,'""')}"`;var O=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var Qe=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),C=e=>{let t=e.split(".");if(t.length===1)return $(e);let[r,...n]=t;return n.length===0?$(r):Bo($(r),n)},Fo=(e,t)=>{let r=e.split(".");if(r.length===1)return `${$(t)}.${$(e)}`;let[n,...o]=r;return Bo(`${$(t)}.${$(n)}`,o)},or=e=>`'${e.replace(/'/g,"''")}'`,Bo=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(or).join("->"),n=or(t[t.length-1]);return r?`${e}->${r}->>${n}`:`${e}->>${n}`},qo=e=>{let t=e.split(".");if(t.length===1)return $(e);let[r,...n]=t;return n.length===0?$(r):Pu($(r),n)},Pu=(e,t)=>{let r=t.map(or).join("->");return `${e}->${r}`};var No=(e,t)=>{if(re(e))throw new Error("Windowing (orderBy/take/skip) is not supported by toSql(); evaluate with check().");if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let r=Cu(e,t);return Bu(r,e,t)},Cu=(e,t)=>{let r=qo(e.field),{mode:n,field:o}=e.aggregate,a=n==="sum"?"SUM":"AVG",i=t.map?.models[t.currentModel??""]?.fields[e.field];if(i?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(o?.includes("."))throw new Error(`aggregate.field '${o}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(i?.kind==="scalar"&&i?.isList===true){if(o)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${a==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${r}) AS elem)`}if(o){let u=`(elem->>'${o}')::numeric`;return `(SELECT ${a==="SUM"?`COALESCE(SUM(${u}), 0)`:`AVG(${u})`} FROM jsonb_array_elements(${r}) AS elem)`}let l="elem::numeric";return `(SELECT ${a==="SUM"?`COALESCE(SUM(${l}), 0)`:`AVG(${l})`} FROM jsonb_array_elements_text(${r}) AS elem)`},Fu=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${$(t.currentAlias)}.${$(r)}`:C(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:S(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},Bu=(e,t,r)=>{let n=Fu(t,r),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(t.operator){case f.equals:return a?`${e} = ${a}`:o===null?`${e} IS NULL`:`${e} = ${O(r,o)}`;case f.notEquals:return a?`${e} <> ${a}`:o===null?`${e} IS NOT NULL`:`${e} <> ${O(r,o)}`;case f.lessThan:return a?`${e} < ${a}`:`${e} < ${O(r,o)}`;case f.lessThanEquals:return a?`${e} <= ${a}`:`${e} <= ${O(r,o)}`;case f.greaterThan:return a?`${e} > ${a}`:`${e} > ${O(r,o)}`;case f.greaterThanEquals:return a?`${e} >= ${a}`:`${e} >= ${O(r,o)}`;case f.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} BETWEEN ${O(r,s)} AND ${O(r,l)}`}case f.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} NOT BETWEEN ${O(r,s)} AND ${O(r,l)}`}default:throw new Error(`Operator '${t.operator}' is not supported for aggregate rules`)}};var qu="Windowing (orderBy/take/skip) is not supported by toSql(); evaluate with check().",Lo=(e,t)=>{if(re(e))throw new Error(qu);if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let r=C(e.field),n=t.map?.models[t.currentModel??""]?.fields[e.field],o=n?.kind==="scalar"&&n?.isList===true,a=o?`array_length(${r}, 1)`:`jsonb_array_length(${r})`;switch(e.arrayOperator){case y.empty:return o?`(${r} IS NULL OR ${a} IS NULL)`:`(${r} IS NULL OR ${a} = 0)`;case y.notEmpty:return o?`(${r} IS NOT NULL AND ${a} IS NOT NULL)`:`(${r} IS NOT NULL AND ${a} > 0)`;case y.all:case y.any:case y.none:case y.atLeast:case y.atMost:case y.exactly:throw new Error(`Array operator '${e.arrayOperator}' with conditions is not supported in SQL. Use application-level filtering for complex array operations.`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var ar=e=>{let t={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};return e.map(r=>{let n=t[r.toLowerCase()];if(n===void 0)throw new Error(`Unknown day name: ${r}`);return n})};var Dt=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return C(e);let r=e.split("."),n=t.currentModel,o=t.currentAlias;for(let a=0;a<r.length;a++){let i=t.map.models[n];if(!i)return C(e);let s=i.fields[r[a]];if(!s)return C(e);if(s.kind==="object"){let p=`${o}.${r[a]}`,u=t.joinRegistry?.get(p),d;if(u)d=u;else {let c=t.joinCounter;if(!c)return C(e);d=`t${++c.n}`;let m=Nu(t.map,n,o,s,d);if(!m)return C(e);t.joins?.push(m),t.joinRegistry?.set(p,d);}n=s.type,o=d;continue}let l=r.slice(a);return Fo(l.join("."),o)}return C(e)},Nu=(e,t,r,n,o)=>{let a=n.type,i=e.models[a]?.dbName??a,s;if(n.fromFields&&n.fromFields.length>0&&n.toFields&&n.toFields.length>0)s=n.fromFields.map((l,p)=>`${$(o)}.${$(n.toFields?.[p]??"")} = ${$(r)}.${$(l)}`).join(" AND ");else {let l=Lu(e,a,t,n.relationName);if(!l)return null;s=(l.fromFields??[]).map((p,u)=>`${$(o)}.${$(p)} = ${$(r)}.${$(l.toFields?.[u]??"")}`).join(" AND ");}return `LEFT JOIN ${$(i)} AS ${$(o)} ON ${s}`},Lu=(e,t,r,n)=>{let o=e.models[t];if(!o)return null;for(let a of Object.values(o.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(n===void 0||a.relationName===n))return a;return null};var Vo=(e,t)=>{let r=Dt(e.field,t),n=ju(e,t),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(e.dateOperator){case x.before:return a!==void 0?`${r} < ${a}`:`${r} < ${O(t,o)}`;case x.after:return a!==void 0?`${r} > ${a}`:`${r} > ${O(t,o)}`;case x.onOrBefore:return a!==void 0?`${r} <= ${a}`:`${r} <= ${O(t,o)}`;case x.onOrAfter:return a!==void 0?`${r} >= ${a}`:`${r} >= ${O(t,o)}`;case x.within:{if(!P(e.value))throw new Error("within date operator requires a range date expression");let[i,s]=Pe(e.value,t.dateConfig??{});return `${r} BETWEEN ${O(t,i.toDate())} AND ${O(t,s.toDate())}`}case x.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between date operator requires an array of two values");let[s,l]=Io(i.map(Wo(t)));return `${r} BETWEEN ${O(t,s)} AND ${O(t,l)}`}case x.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween date operator requires an array of two values");let[s,l]=Io(i.map(Wo(t)));return `${r} NOT BETWEEN ${O(t,s)} AND ${O(t,l)}`}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=ar(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) = ANY(${O(t,i)})`}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let i=ar(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) <> ALL(${O(t,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Io=e=>{let[t,r]=e;return Iu(t,r)<=0?[t,r]:[r,t]},Iu=(e,t)=>{let r=jo(e),n=jo(t);return r<n?-1:r>n?1:0},jo=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),Wo=e=>t=>P(t)?K(t,e.dateConfig??{}).toDate():t,ju=(e,t)=>{if(e.value!==void 0)return P(e.value)&&e.dateOperator!==x.within?{type:"value",value:bt(e.value,e.dateOperator,t.dateConfig??{}).toDate()}:{type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${$(t.currentAlias)}.${$(r)}`:C(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve date path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:S(t.context,e.path)}}return {type:"value",value:void 0}};var Uo=(e,t)=>{let r=Dt(e.field,t),n=Wu(e,t),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(e.operator){case f.equals:return a!==void 0?`${r} = ${a}`:o===null?`${r} IS NULL`:`${r} = ${O(t,o)}`;case f.notEquals:return a!==void 0?`${r} <> ${a}`:o===null?`${r} IS NOT NULL`:`${r} <> ${O(t,o)}`;case f.lessThan:return a!==void 0?`${r} < ${a}`:`${r} < ${O(t,o)}`;case f.lessThanEquals:return a!==void 0?`${r} <= ${a}`:`${r} <= ${O(t,o)}`;case f.greaterThan:return a!==void 0?`${r} > ${a}`:`${r} > ${O(t,o)}`;case f.greaterThanEquals:return a!==void 0?`${r} >= ${a}`:`${r} >= ${O(t,o)}`;case f.in:return !Array.isArray(o)||o.length===0?"FALSE":`${r} = ANY(${O(t,o)})`;case f.notIn:return !Array.isArray(o)||o.length===0?"TRUE":`${r} <> ALL(${O(t,o)})`;case f.contains:return `${r} LIKE ${O(t,`%${Qe(String(o))}%`)}`;case f.notContains:return `${r} NOT LIKE ${O(t,`%${Qe(String(o))}%`)}`;case f.startsWith:return `${r} LIKE ${O(t,`${Qe(String(o))}%`)}`;case f.endsWith:return `${r} LIKE ${O(t,`%${Qe(String(o))}`)}`;case f.matches:return `${r} ~ ${O(t,o)}`;case f.notMatches:return `${r} !~ ${O(t,o)}`;case f.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} BETWEEN ${O(t,s)} AND ${O(t,l)}`}case f.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} NOT BETWEEN ${O(t,s)} AND ${O(t,l)}`}case f.isEmpty:return `(${r} IS NULL OR ${r} = '')`;case f.notEmpty:return `(${r} IS NOT NULL AND ${r} <> '')`;case f.exists:return `${r} IS NOT NULL`;case f.notExists:return `${r} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},Wu=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${$(t.currentAlias)}.${$(r)}`:C(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:S(t.context,e.path)}}return {type:"value",value:void 0}};var Ie,Go=e=>{Ie=e;},Vu=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return false;let s=i.fields[n[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},Uu=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},Q=(e,t)=>{if(typeof e=="boolean"||!t.map||!t.currentModel)return false;if("all"in e)return e.all.some(r=>Q(r,t));if("any"in e)return e.any.some(r=>Q(r,t));if("if"in e)return Q(e.if,t)||Q(e.then,t)||e.else!==void 0&&Q(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(Vu(e.field,t.map,t.currentModel))return true;if("condition"in e&&e.condition!==void 0){let r=Uu(e.field,t.map,t.currentModel);if(r&&Q(e.condition,{...t,currentModel:r}))return true}}return false},Ko=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(n=>Ie(n,t)).join(" AND ")})`,zo=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(n=>Ie(n,t)).join(" OR ")})`,Ho=(e,t)=>{if(Q(e.if,t)||Q(e.then,t)||e.else!==void 0&&Q(e.else,t))return "TRUE";let r=Ie(e.if,t),n=Ie(e.then,t);if(e.else!==void 0){let o=Ie(e.else,t);return `((NOT(${r}) OR ${n}) AND (${r} OR ${o}))`}return `(NOT(${r}) OR ${n})`};var Gu=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return false;let s=i.fields[n[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},ir=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&t.map&&t.currentModel&&Gu(e.field,t.map,t.currentModel))return "TRUE";if("all"in e)return Ko(e,t);if("any"in e)return zo(e,t);if("if"in e)return Ho(e,t);if("arrayOperator"in e)return Lo(e,t);if("dateOperator"in e)return Vo(e,t);if("aggregate"in e)return No(e,t);if("field"in e)return Uo(e,t);throw new Error("Unknown condition type")};Go(ir);var Yb=(e,t)=>{let r=!!(t?.map&&t?.model),n=t?.alias??(r?"t0":void 0),o={params:[],paramIndex:0,context:t?.context,dateConfig:{now:t?.now,timeZone:t?.timeZone,weekStart:t?.weekStart},map:t?.map,currentModel:t?.model,currentAlias:n,joinCounter:r?{n:0}:void 0,joins:r?[]:void 0,joinRegistry:r?new Map:void 0};return {sql:ir(e,o),params:o.params,joins:o.joins??[]}};var Ku=new Set(["year","quarter","month","week","isoWeek","day","hour","minute","second"]),zu=new Set(["years","quarters","months","weeks","days","hours","minutes","seconds"]),Hu=new Set(Object.keys(j)),Ju=new Set(Object.keys(se)),Qu=new Set(Object.keys(ie)),Yu=(e,t={})=>{let r={target:t.target??"check",errors:[]};return le(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},nO=(e,t={})=>{let r=Yu(e,t);if(r.ok)return;let n=r.errors.map(o=>`${o.path}: ${o.message}`).join(`
6
6
  `);throw new Error(`Invalid rule:
7
- ${o}`)},ne=(e,t,r)=>{if(typeof e=="boolean"){r.target==="toPrisma"&&e===false&&b(r,t,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!Sn(e)){b(r,t,"invalid_condition","Condition must be a boolean or object");return}let o=su(e);if(!o){b(r,t,"ambiguous_condition","Condition must be exactly one of: field rule, array rule, date rule, all, any, or if/then[/else]");return}switch(o){case "all":Rn(e.all,`${t}.all`,r);break;case "any":Rn(e.any,`${t}.any`,r);break;case "if":ne(e.if,`${t}.if`,r),ne(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&ne(e.else,`${t}.else`,r);break;case "field":lu(e,t,r);break;case "aggregate":uu(e,t,r);break;case "array":pu(e,t,r);break;case "date":du(e,t,r);break}},su=e=>{let t=[];"all"in e&&t.push("all"),"any"in e&&t.push("any"),("if"in e||"then"in e||"else"in e)&&t.push("if"),"arrayOperator"in e&&t.push("array"),"dateOperator"in e&&t.push("date"),"aggregate"in e?t.push("aggregate"):"operator"in e&&t.push("field");let r=Array.from(new Set(t));return r.length!==1?null:r[0]},Rn=(e,t,r)=>{if(!Array.isArray(e)){b(r,t,"logical_array_required","Logical operator requires an array of conditions");return}e.forEach((o,n)=>{ne(o,`${t}[${n}]`,r);});},lu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!ou.has(e.operator)){b(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let o=e.operator;dt(o,r.target)||b(r,`${t}.operator`,`unsupported_${Vt(r.target)}_operator`,`Operator '${o}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&b(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let n=Ct(o);if(n==="none"){mu(e,t,r);return}jt(e,t,r)&&("path"in e&&typeof e.path=="string"||fu(n,e.value,o,`${t}.value`,r));},fu=(e,t,r,o,n)=>{switch(e){case "scalar":case "string":e==="string"&&typeof t!="string"&&b(n,o,"invalid_string_value",`Operator '${r}' requires a string value`);return;case "ordered":Lt(t)||b(n,o,"invalid_ordered_value",`Operator '${r}' requires a string, number, or Date value`);return;case "array":Array.isArray(t)||b(n,o,"invalid_membership_value",`Operator '${r}' requires an array value`);return;case "pattern":typeof t=="string"||t instanceof RegExp||b(n,o,"invalid_pattern_value",`Operator '${r}' requires a string or RegExp value`);return;case "range":cu(t)||b(n,o,"invalid_range_value",`Operator '${r}' requires a two-item range`);return}},uu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!Sn(e.aggregate)){b(r,`${t}.aggregate`,"invalid_aggregate","aggregate must be an object");return}let o=e.aggregate;o.mode!=="sum"&&o.mode!=="avg"&&b(r,`${t}.aggregate.mode`,"invalid_aggregate_mode","aggregate.mode must be 'sum' or 'avg'"),"field"in o&&o.field!==void 0&&typeof o.field!="string"&&b(r,`${t}.aggregate.field`,"invalid_aggregate_field","aggregate.field must be a string");let n=typeof e.operator=="string"&&Jo(e.operator),a=typeof e.operator=="string"&&Qo(e.operator);if(!n&&!a){b(r,`${t}.operator`,"invalid_aggregate_operator","Aggregate rules only support: equals, notEquals, lessThan, lessThanEquals, greaterThan, greaterThanEquals, between, notBetween");return}if(r.target==="toPrisma"&&e.operator===f.notBetween&&b(r,`${t}.operator`,"unsupported_prisma_aggregate_operator","Operator 'notBetween' is not supported by toPrisma() for aggregate rules"),r.target==="toPrisma"&&typeof e.path=="string"&&b(r,`${t}.path`,"unsupported_prisma_aggregate_path","path is not supported by toPrisma() for aggregate rules; use value instead"),"condition"in e&&e.condition!==void 0&&(r.target==="toSql"&&b(r,`${t}.condition`,"unsupported_sql_aggregate_condition","Aggregate condition filtering is not supported by toSql(); use check() or toPrisma()"),ne(e.condition,`${t}.condition`,r)),!jt(e,t,r)||"path"in e&&typeof e.path=="string")return;let i=e.value;a?gu(i)||b(r,`${t}.value`,"invalid_range_value",`Operator '${e.operator}' requires a two-item numeric range`):typeof i!="number"&&b(r,`${t}.value`,"invalid_aggregate_value","Aggregate rule value must be a number");},pu=(e,t,r)=>{if(typeof e.field!="string"&&r.target!=="check"&&b(r,`${t}.field`,"field_required","Array rule requires a string field for this target"),typeof e.arrayOperator!="string"||!nu.has(e.arrayOperator)){b(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let o=e.arrayOperator;switch(dt(o,r.target)||b(r,`${t}.arrayOperator`,`unsupported_${Vt(r.target)}_array_operator`,`Array operator '${o}' is not supported by ${r.target}()`),o){case y.empty:case y.notEmpty:"condition"in e&&e.condition!==void 0&&b(r,`${t}.condition`,"unexpected_condition",`Array operator '${o}' does not accept condition`),"count"in e&&e.count!==void 0&&b(r,`${t}.count`,"unexpected_count",`Array operator '${o}' does not accept count`);break;case y.all:case y.any:case y.none:!("condition"in e)||e.condition===void 0?b(r,`${t}.condition`,"missing_condition",`Array operator '${o}' requires condition`):ne(e.condition,`${t}.condition`,r),"count"in e&&e.count!==void 0&&b(r,`${t}.count`,"unexpected_count",`Array operator '${o}' does not accept count`);break;case y.atLeast:case y.atMost:case y.exactly:r.target!=="toPrisma"&&typeof e.count!="number"?b(r,`${t}.count`,"missing_count",`Array operator '${o}' requires count`):"count"in e&&e.count!==void 0&&typeof e.count!="number"&&b(r,`${t}.count`,"invalid_count","count must be a number"),r.target==="check"&&(!("condition"in e)||e.condition===void 0)?b(r,`${t}.condition`,"missing_condition",`Array operator '${o}' requires condition for check()`):"condition"in e&&e.condition!==void 0&&ne(e.condition,`${t}.condition`,r);break}},du=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!au.has(e.dateOperator)){b(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let o=e.dateOperator;dt(o,r.target)||b(r,`${t}.dateOperator`,`unsupported_${Vt(r.target)}_date_operator`,`Date operator '${o}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&b(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let n=Ct(o);if(n==="dayList"){(!Array.isArray(e.value)||!e.value.every(a=>typeof a=="string"))&&b(r,`${t}.value`,"invalid_day_list",`Date operator '${o}' requires an array of day names`),"path"in e&&e.path!==void 0&&b(r,`${t}.path`,"unexpected_path",`Date operator '${o}' does not accept path`);return}if(jt(e,t,r)&&!("path"in e&&typeof e.path=="string")){if(n==="dateRange"){yu(e.value)||b(r,`${t}.value`,"invalid_date_range",`Date operator '${o}' requires a two-item date range`);return}It(e.value)||b(r,`${t}.value`,"invalid_date_value",`Date operator '${o}' requires a date-like value`);}},jt=(e,t,r)=>{let o="value"in e&&e.value!==void 0,n=typeof e.path=="string";return o&&n?(b(r,t,"ambiguous_value_source","Rule cannot define both value and path"),false):!o&&!n?(b(r,t,"missing_value_source","Rule requires either value or path"),false):true},mu=(e,t,r)=>{"value"in e&&e.value!==void 0&&b(r,`${t}.value`,"unexpected_value","Rule does not accept value"),"path"in e&&e.path!==void 0&&b(r,`${t}.path`,"unexpected_path","Rule does not accept path");},Vt=e=>e==="toPrisma"?"prisma":e==="toSql"?"sql":"check",Sn=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Lt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,cu=e=>Array.isArray(e)&&e.length===2&&Lt(e[0])&&Lt(e[1]),gu=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",It=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,yu=e=>Array.isArray(e)&&e.length===2&&It(e[0])&&It(e[1]),b=(e,t,r,o)=>{e.errors.push({path:t,code:r,message:o});};/*! Bundled license information:
7
+ ${n}`)},le=(e,t,r)=>{if(typeof e=="boolean"){r.target==="toPrisma"&&e===false&&b(r,t,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!Ye(e)){b(r,t,"invalid_condition","Condition must be a boolean or object");return}let n=Zu(e);if(!n){b(r,t,"ambiguous_condition","Condition must be exactly one of: field rule, array rule, date rule, all, any, or if/then[/else]");return}switch(n){case "all":Jo(e.all,`${t}.all`,r);break;case "any":Jo(e.any,`${t}.any`,r);break;case "if":le(e.if,`${t}.if`,r),le(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&le(e.else,`${t}.else`,r);break;case "field":Xu(e,t,r);break;case "aggregate":tp(e,t,r);break;case "array":rp(e,t,r);break;case "date":np(e,t,r);break}},Zu=e=>{let t=[];"all"in e&&t.push("all"),"any"in e&&t.push("any"),("if"in e||"then"in e||"else"in e)&&t.push("if"),"arrayOperator"in e&&t.push("array"),"dateOperator"in e&&t.push("date"),"aggregate"in e?t.push("aggregate"):"operator"in e&&t.push("field");let r=Array.from(new Set(t));return r.length!==1?null:r[0]},Jo=(e,t,r)=>{if(!Array.isArray(e)){b(r,t,"logical_array_required","Logical operator requires an array of conditions");return}e.forEach((n,o)=>{le(n,`${t}[${o}]`,r);});},Xu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!Hu.has(e.operator)){b(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;kt(n,r.target)||b(r,`${t}.operator`,`unsupported_${Mt(r.target)}_operator`,`Operator '${n}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&b(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let o=er(n);if(o==="none"){ap(e,t,r);return}fr(e,t,r)&&("path"in e&&typeof e.path=="string"||ep(o,e.value,n,`${t}.value`,r));},ep=(e,t,r,n,o)=>{switch(e){case "scalar":case "string":e==="string"&&typeof t!="string"&&b(o,n,"invalid_string_value",`Operator '${r}' requires a string value`);return;case "ordered":sr(t)||b(o,n,"invalid_ordered_value",`Operator '${r}' requires a string, number, or Date value`);return;case "array":Array.isArray(t)||b(o,n,"invalid_membership_value",`Operator '${r}' requires an array value`);return;case "pattern":typeof t=="string"||t instanceof RegExp||b(o,n,"invalid_pattern_value",`Operator '${r}' requires a string or RegExp value`);return;case "range":ip(t)||b(o,n,"invalid_range_value",`Operator '${r}' requires a two-item range`);return}},tp=(e,t,r)=>{if(Zo(e,t,r),typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!Ye(e.aggregate)){b(r,`${t}.aggregate`,"invalid_aggregate","aggregate must be an object");return}let n=e.aggregate;n.mode!=="sum"&&n.mode!=="avg"&&b(r,`${t}.aggregate.mode`,"invalid_aggregate_mode","aggregate.mode must be 'sum' or 'avg'"),"field"in n&&n.field!==void 0&&typeof n.field!="string"&&b(r,`${t}.aggregate.field`,"invalid_aggregate_field","aggregate.field must be a string");let o=typeof e.operator=="string"&&xo(e.operator),a=typeof e.operator=="string"&&bo(e.operator);if(!o&&!a){b(r,`${t}.operator`,"invalid_aggregate_operator","Aggregate rules only support: equals, notEquals, lessThan, lessThanEquals, greaterThan, greaterThanEquals, between, notBetween");return}if(r.target==="toPrisma"&&e.operator===f.notBetween&&b(r,`${t}.operator`,"unsupported_prisma_aggregate_operator","Operator 'notBetween' is not supported by toPrisma() for aggregate rules"),r.target==="toPrisma"&&typeof e.path=="string"&&b(r,`${t}.path`,"unsupported_prisma_aggregate_path","path is not supported by toPrisma() for aggregate rules; use value instead"),"condition"in e&&e.condition!==void 0&&(r.target==="toSql"&&b(r,`${t}.condition`,"unsupported_sql_aggregate_condition","Aggregate condition filtering is not supported by toSql(); use check() or toPrisma()"),le(e.condition,`${t}.condition`,r)),!fr(e,t,r)||"path"in e&&typeof e.path=="string")return;let i=e.value;a?sp(i)||b(r,`${t}.value`,"invalid_range_value",`Operator '${e.operator}' requires a two-item numeric range`):typeof i!="number"&&b(r,`${t}.value`,"invalid_aggregate_value","Aggregate rule value must be a number");},rp=(e,t,r)=>{if(typeof e.field!="string"&&r.target!=="check"&&b(r,`${t}.field`,"field_required","Array rule requires a string field for this target"),Zo(e,t,r),typeof e.arrayOperator!="string"||!Ju.has(e.arrayOperator)){b(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(kt(n,r.target)||b(r,`${t}.arrayOperator`,`unsupported_${Mt(r.target)}_array_operator`,`Array operator '${n}' is not supported by ${r.target}()`),n){case y.empty:case y.notEmpty:"condition"in e&&e.condition!==void 0&&b(r,`${t}.condition`,"unexpected_condition",`Array operator '${n}' does not accept condition`),"count"in e&&e.count!==void 0&&b(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case y.all:case y.any:case y.none:!("condition"in e)||e.condition===void 0?b(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition`):le(e.condition,`${t}.condition`,r),"count"in e&&e.count!==void 0&&b(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case y.atLeast:case y.atMost:case y.exactly:r.target!=="toPrisma"&&typeof e.count!="number"?b(r,`${t}.count`,"missing_count",`Array operator '${n}' requires count`):"count"in e&&e.count!==void 0&&typeof e.count!="number"&&b(r,`${t}.count`,"invalid_count","count must be a number"),r.target==="check"&&(!("condition"in e)||e.condition===void 0)?b(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition for check()`):"condition"in e&&e.condition!==void 0&&le(e.condition,`${t}.condition`,r);break}},np=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!Qu.has(e.dateOperator)){b(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;kt(n,r.target)||b(r,`${t}.dateOperator`,`unsupported_${Mt(r.target)}_date_operator`,`Date operator '${n}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&b(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let o=er(n);if(o==="dayList"){(!Array.isArray(e.value)||!e.value.every(a=>typeof a=="string"))&&b(r,`${t}.value`,"invalid_day_list",`Date operator '${n}' requires an array of day names`),"path"in e&&e.path!==void 0&&b(r,`${t}.path`,"unexpected_path",`Date operator '${n}' does not accept path`);return}if(fr(e,t,r)&&!("path"in e&&typeof e.path=="string")){if(P(e.value)){Yo(e.value,n,`${t}.value`,r);return}if(n==="within"){b(r,`${t}.value`,"invalid_date_range","Date operator 'within' requires a range date expression (a period or rolling window)");return}if(o==="dateRange"){if(!lp(e.value)){b(r,`${t}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return}e.value.forEach((a,i)=>{P(a)&&Yo(a,n,`${t}.value[${i}]`,r);});return}lr(e.value)||b(r,`${t}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},op=(e,t,r)=>{if(!Ye(e)||Object.keys(e).length===0){b(r,t,"invalid_relative_units","Relative offset requires at least one unit");return}for(let[n,o]of Object.entries(e)){if(!zu.has(n)){b(r,`${t}.${n}`,"invalid_relative_unit",`Unknown relative unit '${n}'`);continue}(typeof o!="number"||!Number.isFinite(o)||o<0)&&b(r,`${t}.${n}`,"invalid_relative_magnitude",`Relative magnitudes must be positive numbers (got ${String(o)})`);}},Qo=(e,t,r)=>{(typeof e!="string"||!Ku.has(e))&&b(r,t,"invalid_period_unit",`Unknown period unit '${String(e)}'`);},Yo=(e,t,r,n)=>{let o=t==="within";if(xt(e)){op("ago"in e?e.ago:e.ahead,r,n);return}if(de(e)){let a="this"in e?e.this:"last"in e?e.last:e.next;Qo(a,r,n);return}if(Gt(e)){if(o){b(n,r,"invalid_date_range","'within' requires a range (period or rolling); a start/end edge is a single point");return}let a="start"in e?e.start:e.end;if(!Ye(a)||!de(a)){b(n,r,"invalid_period_unit","start/end requires a this/last/next period");return}let i="this"in a?a.this:"last"in a?a.last:a.next;Qo(i,r,n);return}b(n,r,"invalid_date_expression","Unrecognized date expression");},fr=(e,t,r)=>{let n="value"in e&&e.value!==void 0,o=typeof e.path=="string";return n&&o?(b(r,t,"ambiguous_value_source","Rule cannot define both value and path"),false):!n&&!o?(b(r,t,"missing_value_source","Rule requires either value or path"),false):true},ap=(e,t,r)=>{"value"in e&&e.value!==void 0&&b(r,`${t}.value`,"unexpected_value","Rule does not accept value"),"path"in e&&e.path!==void 0&&b(r,`${t}.path`,"unexpected_path","Rule does not accept path");},Mt=e=>e==="toPrisma"?"prisma":e==="toSql"?"sql":"check",Ye=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),sr=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,ip=e=>Array.isArray(e)&&e.length===2&&sr(e[0])&&sr(e[1]),sp=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",lr=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,lp=e=>Array.isArray(e)&&e.length===2&&(lr(e[0])||P(e[0]))&&(lr(e[1])||P(e[1])),Zo=(e,t,r)=>{if(("orderBy"in e&&e.orderBy!==void 0||"take"in e&&e.take!==void 0||"skip"in e&&e.skip!==void 0)&&r.target!=="check"&&(r.target==="toPrisma"&&Et(e)!==null||b(r,t,`unsupported_${Mt(r.target)}_window`,`Windowing (orderBy/take/skip) is not supported by ${r.target}() for this rule; evaluate with check()`)),"orderBy"in e&&e.orderBy!==void 0){let o=e.orderBy;!Array.isArray(o)||o.length===0?b(r,`${t}.orderBy`,"invalid_order_by","orderBy must be a non-empty array of { field, dir }"):o.forEach((a,i)=>{(!Ye(a)||typeof a.field!="string"||a.dir!=="asc"&&a.dir!=="desc")&&b(r,`${t}.orderBy[${i}]`,"invalid_order_by",'orderBy entries must be { field: string, dir: "asc" | "desc" }');});}for(let o of ["take","skip"])if(o in e&&e[o]!==void 0){let a=e[o];(typeof a!="number"||!Number.isInteger(a)||a<0)&&b(r,`${t}.${o}`,`invalid_window_${o}`,`${o} must be a non-negative integer`);}},b=(e,t,r,n)=>{e.errors.push({path:t,code:r,message:n});};/*! Bundled license information:
8
8
 
9
9
  lodash-es/lodash.js:
10
10
  (**
@@ -16,5 +16,5 @@ lodash-es/lodash.js:
16
16
  * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
17
17
  * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
18
18
  *)
19
- */export{Jh as AGGREGATE_OPERATORS,Ho as ALL_KINDS,oe as ARRAY_OPERATOR_CATALOG,y as ArrayOperator,re as DATE_OPERATOR_CATALOG,x as DateOperator,ut as EQUATABLE_KINDS,L as FIELD_OPERATOR_CATALOG,Rf as FieldKind,Sf as NUMERIC_KINDS,Se as ORDERABLE_KINDS,f as Operator,zh as RuleTarget,te as STRINGY_KINDS,Hh as ValueShape,xf as applyLens,Ex as assertValidRule,nf as buildBridgeDictionary,le as check,Ft as checkRuleAgainstLens,Of as createLens,Wf as executePrismaQueryPlan,Yh as getArrayOperators,Qh as getOperatorsForKind,Ct as getValueShape,Qo as isAggregateRangeOperator,Jo as isAggregateSingleOperator,dt as isOperatorSupportedForTarget,Ef as projectByPath,Mt as stitchFieldMaps,Pw as toPrisma,Ox as toSql,sf as validateFieldMap,Lo as validateFieldMapSet,vf as validateNarrowing,iu as validateRule};//# sourceMappingURL=index.js.map
19
+ */export{xx as AGGREGATE_OPERATORS,wo as ALL_KINDS,se as ARRAY_OPERATOR_CATALOG,y as ArrayOperator,ie as DATE_OPERATOR_CATALOG,x as DateOperator,At as EQUATABLE_KINDS,j as FIELD_OPERATOR_CATALOG,mu as FieldKind,cu as NUMERIC_KINDS,qe as ORDERABLE_KINDS,f as Operator,hx as RuleTarget,ae as STRINGY_KINDS,wx as ValueShape,iu as applyLens,nO as assertValidRule,Kf as buildBridgeDictionary,me as check,Xt as checkRuleAgainstLens,lu as createLens,Mu as executePrismaQueryPlan,Ox as getArrayOperators,bx as getOperatorsForKind,er as getValueShape,bo as isAggregateRangeOperator,xo as isAggregateSingleOperator,kt as isOperatorSupportedForTarget,du as projectByPath,Qt as stitchFieldMaps,ab as toPrisma,Yb as toSql,Hf as validateFieldMap,lo as validateFieldMapSet,pu as validateNarrowing,Yu as validateRule};//# sourceMappingURL=index.js.map
20
20
  //# sourceMappingURL=index.js.map