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