@inixiative/json-rules 2.3.0 → 2.4.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.d.cts CHANGED
@@ -391,6 +391,15 @@ declare const validateNarrowing: (narrowing: LensNarrowing) => void;
391
391
 
392
392
  declare const projectNarrowing: (lensOrNarrowing: Lens | LensNarrowing) => FieldMapSet;
393
393
 
394
+ type ProjectedVisit = {
395
+ mapName: string;
396
+ modelName: string;
397
+ fields: Record<string, FieldMapEntry>;
398
+ whereClauses: Condition[];
399
+ };
400
+ type PathProjection = Map<string, ProjectedVisit>;
401
+ declare const projectByPath: (lensOrNarrowing: Lens | LensNarrowing) => PathProjection;
402
+
394
403
  declare const FieldKind: {
395
404
  readonly String: "String";
396
405
  readonly Boolean: "Boolean";
@@ -538,4 +547,4 @@ declare const assertValidRule: (condition: unknown, options?: {
538
547
  target?: RuleTarget;
539
548
  }) => asserts condition is Condition;
540
549
 
541
- export { AGGREGATE_OPERATORS, ALL_KINDS, ARRAY_OPERATOR_CATALOG, type AggregateMode, type AggregateRule, type All, type Any, type ArrayCatalogEntry, ArrayOperator, type ArrayRule, type Bridge, type BridgeCardinality, type BridgeDictionary, type BridgeEndpoint, type BuildOptions, type CatalogEntry, type CheckOptions, type Condition, type CreateLensInput, DATE_OPERATOR_CATALOG, type DateInputValue, DateOperator, type DateRule, type DateRuleValue, EQUATABLE_KINDS, type EnumNarrowing, FIELD_OPERATOR_CATALOG, FieldKind, type FieldMap, type FieldMapEntry, type FieldMapSet, type GroupByStep, type IfThenElse, type Lens, type LensNarrowing, type ModelDefaultNarrowing, type ModelNarrowing, NUMERIC_KINDS, type NarrowingDefaults, ORDERABLE_KINDS, Operator, type OrderedRuleValue, type PrismaStep, type PrismaWhere, type Rule, type RuleLensCheck, type RuleLensViolation, type RuleScalar, RuleTarget, type RuleValue, STRINGY_KINDS, type SqlResult, type StepRef, type StrictAggregateRule, type StrictAll, type StrictAny, type StrictArrayCountRule, type StrictArrayPredicateRule, type StrictArrayPresenceRule, type StrictArrayRule, type StrictCondition, type StrictContainsRule, type StrictDateComparisonRule, type StrictDateDayRule, type StrictDateRangeRule, type StrictDateRule, type StrictEqualityRule, type StrictIfThenElse, type StrictMembershipRule, type StrictOrderedComparisonRule, type StrictPatternRule, type StrictPresenceRule, type StrictRangeRule, type StrictRule, type StrictStringBoundaryRule, type ToPrismaResult, type ValidationIssue, type ValidationResult, ValueShape, type WhereStep, applyLens, assertValidRule, buildBridgeDictionary, check, checkRuleAgainstLens, createLens, executePrismaQueryPlan, getArrayOperators, getOperatorsForKind, getValueShape, isAggregateRangeOperator, isAggregateSingleOperator, isOperatorSupportedForTarget, projectNarrowing, stitchFieldMaps, toPrisma, toSql, validateFieldMap, validateFieldMapSet, validateNarrowing, validateRule };
550
+ export { AGGREGATE_OPERATORS, ALL_KINDS, ARRAY_OPERATOR_CATALOG, type AggregateMode, type AggregateRule, type All, type Any, type ArrayCatalogEntry, ArrayOperator, type ArrayRule, type Bridge, type BridgeCardinality, type BridgeDictionary, type BridgeEndpoint, type BuildOptions, type CatalogEntry, type CheckOptions, type Condition, type CreateLensInput, DATE_OPERATOR_CATALOG, type DateInputValue, DateOperator, type DateRule, type DateRuleValue, EQUATABLE_KINDS, type EnumNarrowing, FIELD_OPERATOR_CATALOG, FieldKind, type FieldMap, type FieldMapEntry, type FieldMapSet, type GroupByStep, type IfThenElse, type Lens, type LensNarrowing, type ModelDefaultNarrowing, type ModelNarrowing, NUMERIC_KINDS, type NarrowingDefaults, ORDERABLE_KINDS, Operator, type OrderedRuleValue, type PathProjection, type PrismaStep, type PrismaWhere, type ProjectedVisit, type Rule, type RuleLensCheck, type RuleLensViolation, type RuleScalar, RuleTarget, type RuleValue, STRINGY_KINDS, type SqlResult, type StepRef, type StrictAggregateRule, type StrictAll, type StrictAny, type StrictArrayCountRule, type StrictArrayPredicateRule, type StrictArrayPresenceRule, type StrictArrayRule, type StrictCondition, type StrictContainsRule, type StrictDateComparisonRule, type StrictDateDayRule, type StrictDateRangeRule, type StrictDateRule, type StrictEqualityRule, type StrictIfThenElse, type StrictMembershipRule, type StrictOrderedComparisonRule, type StrictPatternRule, type StrictPresenceRule, type StrictRangeRule, type StrictRule, type StrictStringBoundaryRule, type ToPrismaResult, type ValidationIssue, type ValidationResult, ValueShape, type WhereStep, applyLens, assertValidRule, buildBridgeDictionary, check, checkRuleAgainstLens, createLens, executePrismaQueryPlan, getArrayOperators, getOperatorsForKind, getValueShape, isAggregateRangeOperator, isAggregateSingleOperator, isOperatorSupportedForTarget, projectByPath, projectNarrowing, stitchFieldMaps, toPrisma, toSql, validateFieldMap, validateFieldMapSet, validateNarrowing, validateRule };
package/dist/index.d.ts CHANGED
@@ -391,6 +391,15 @@ declare const validateNarrowing: (narrowing: LensNarrowing) => void;
391
391
 
392
392
  declare const projectNarrowing: (lensOrNarrowing: Lens | LensNarrowing) => FieldMapSet;
393
393
 
394
+ type ProjectedVisit = {
395
+ mapName: string;
396
+ modelName: string;
397
+ fields: Record<string, FieldMapEntry>;
398
+ whereClauses: Condition[];
399
+ };
400
+ type PathProjection = Map<string, ProjectedVisit>;
401
+ declare const projectByPath: (lensOrNarrowing: Lens | LensNarrowing) => PathProjection;
402
+
394
403
  declare const FieldKind: {
395
404
  readonly String: "String";
396
405
  readonly Boolean: "Boolean";
@@ -538,4 +547,4 @@ declare const assertValidRule: (condition: unknown, options?: {
538
547
  target?: RuleTarget;
539
548
  }) => asserts condition is Condition;
540
549
 
541
- export { AGGREGATE_OPERATORS, ALL_KINDS, ARRAY_OPERATOR_CATALOG, type AggregateMode, type AggregateRule, type All, type Any, type ArrayCatalogEntry, ArrayOperator, type ArrayRule, type Bridge, type BridgeCardinality, type BridgeDictionary, type BridgeEndpoint, type BuildOptions, type CatalogEntry, type CheckOptions, type Condition, type CreateLensInput, DATE_OPERATOR_CATALOG, type DateInputValue, DateOperator, type DateRule, type DateRuleValue, EQUATABLE_KINDS, type EnumNarrowing, FIELD_OPERATOR_CATALOG, FieldKind, type FieldMap, type FieldMapEntry, type FieldMapSet, type GroupByStep, type IfThenElse, type Lens, type LensNarrowing, type ModelDefaultNarrowing, type ModelNarrowing, NUMERIC_KINDS, type NarrowingDefaults, ORDERABLE_KINDS, Operator, type OrderedRuleValue, type PrismaStep, type PrismaWhere, type Rule, type RuleLensCheck, type RuleLensViolation, type RuleScalar, RuleTarget, type RuleValue, STRINGY_KINDS, type SqlResult, type StepRef, type StrictAggregateRule, type StrictAll, type StrictAny, type StrictArrayCountRule, type StrictArrayPredicateRule, type StrictArrayPresenceRule, type StrictArrayRule, type StrictCondition, type StrictContainsRule, type StrictDateComparisonRule, type StrictDateDayRule, type StrictDateRangeRule, type StrictDateRule, type StrictEqualityRule, type StrictIfThenElse, type StrictMembershipRule, type StrictOrderedComparisonRule, type StrictPatternRule, type StrictPresenceRule, type StrictRangeRule, type StrictRule, type StrictStringBoundaryRule, type ToPrismaResult, type ValidationIssue, type ValidationResult, ValueShape, type WhereStep, applyLens, assertValidRule, buildBridgeDictionary, check, checkRuleAgainstLens, createLens, executePrismaQueryPlan, getArrayOperators, getOperatorsForKind, getValueShape, isAggregateRangeOperator, isAggregateSingleOperator, isOperatorSupportedForTarget, projectNarrowing, stitchFieldMaps, toPrisma, toSql, validateFieldMap, validateFieldMapSet, validateNarrowing, validateRule };
550
+ export { AGGREGATE_OPERATORS, ALL_KINDS, ARRAY_OPERATOR_CATALOG, type AggregateMode, type AggregateRule, type All, type Any, type ArrayCatalogEntry, ArrayOperator, type ArrayRule, type Bridge, type BridgeCardinality, type BridgeDictionary, type BridgeEndpoint, type BuildOptions, type CatalogEntry, type CheckOptions, type Condition, type CreateLensInput, DATE_OPERATOR_CATALOG, type DateInputValue, DateOperator, type DateRule, type DateRuleValue, EQUATABLE_KINDS, type EnumNarrowing, FIELD_OPERATOR_CATALOG, FieldKind, type FieldMap, type FieldMapEntry, type FieldMapSet, type GroupByStep, type IfThenElse, type Lens, type LensNarrowing, type ModelDefaultNarrowing, type ModelNarrowing, NUMERIC_KINDS, type NarrowingDefaults, ORDERABLE_KINDS, Operator, type OrderedRuleValue, type PathProjection, type PrismaStep, type PrismaWhere, type ProjectedVisit, type Rule, type RuleLensCheck, type RuleLensViolation, type RuleScalar, RuleTarget, type RuleValue, STRINGY_KINDS, type SqlResult, type StepRef, type StrictAggregateRule, type StrictAll, type StrictAny, type StrictArrayCountRule, type StrictArrayPredicateRule, type StrictArrayPresenceRule, type StrictArrayRule, type StrictCondition, type StrictContainsRule, type StrictDateComparisonRule, type StrictDateDayRule, type StrictDateRangeRule, type StrictDateRule, type StrictEqualityRule, type StrictIfThenElse, type StrictMembershipRule, type StrictOrderedComparisonRule, type StrictPatternRule, type StrictPresenceRule, type StrictRangeRule, type StrictRule, type StrictStringBoundaryRule, type ToPrismaResult, type ValidationIssue, type ValidationResult, ValueShape, type WhereStep, applyLens, assertValidRule, buildBridgeDictionary, check, checkRuleAgainstLens, createLens, executePrismaQueryPlan, getArrayOperators, getOperatorsForKind, getValueShape, isAggregateRangeOperator, isAggregateSingleOperator, isOperatorSupportedForTarget, projectByPath, projectNarrowing, stitchFieldMaps, toPrisma, toSql, validateFieldMap, validateFieldMapSet, validateNarrowing, validateRule };
package/dist/index.js CHANGED
@@ -1,10 +1,10 @@
1
- import W from'dayjs';import Zl from'dayjs/plugin/isSameOrAfter.js';import ef from'dayjs/plugin/isSameOrBefore.js';import tf from'dayjs/plugin/timezone.js';import rf from'dayjs/plugin/utc.js';var Co=typeof global=="object"&&global&&global.Object===Object&&global,je=Co;var Do=typeof self=="object"&&self&&self.Object===Object&&self,Bo=je||Do||Function("return this")(),F=Bo;var No=F.Symbol,D=No;var Ut=Object.prototype,qo=Ut.hasOwnProperty,Lo=Ut.toString,Pe=D?D.toStringTag:void 0;function Io(e){var t=qo.call(e,Pe),r=e[Pe];try{e[Pe]=void 0;var n=!0;}catch{}var o=Lo.call(e);return n&&(t?e[Pe]=r:delete e[Pe]),o}var Gt=Io;var jo=Object.prototype,Vo=jo.toString;function Wo(e){return Vo.call(e)}var Kt=Wo;var Uo="[object Null]",Go="[object Undefined]",zt=D?D.toStringTag:void 0;function Ko(e){return e==null?e===void 0?Go:Uo:zt&&zt in Object(e)?Gt(e):Kt(e)}var B=Ko;function zo(e){return e!=null&&typeof e=="object"}var N=zo;var Ho="[object Symbol]";function Jo(e){return typeof e=="symbol"||N(e)&&B(e)==Ho}var pe=Jo;function Qo(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 Ht=Qo;var Yo=Array.isArray,_=Yo;var Jt=D?D.prototype:void 0,Qt=Jt?Jt.toString:void 0;function Yt(e){if(typeof e=="string")return e;if(_(e))return Ht(e,Yt)+"";if(pe(e))return Qt?Qt.call(e):"";var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var Xt=Yt;function Zo(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var q=Zo;function ea(e){return e}var Zt=ea;var ta="[object AsyncFunction]",ra="[object Function]",na="[object GeneratorFunction]",oa="[object Proxy]";function aa(e){if(!q(e))return false;var t=B(e);return t==ra||t==na||t==ta||t==oa}var Ve=aa;var ia=F["__core-js_shared__"],We=ia;var er=(function(){var e=/[^.]+$/.exec(We&&We.keys&&We.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function sa(e){return !!er&&er in e}var tr=sa;var la=Function.prototype,fa=la.toString;function ua(e){if(e!=null){try{return fa.call(e)}catch{}try{return e+""}catch{}}return ""}var j=ua;var pa=/[\\^$.*+?()[\]{}|]/g,da=/^\[object .+?Constructor\]$/,ma=Function.prototype,ca=Object.prototype,ga=ma.toString,ya=ca.hasOwnProperty,ha=RegExp("^"+ga.call(ya).replace(pa,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function wa(e){if(!q(e)||tr(e))return false;var t=Ve(e)?ha:da;return t.test(j(e))}var rr=wa;function xa(e,t){return e?.[t]}var nr=xa;function ba(e,t){var r=nr(e,t);return rr(r)?r:void 0}var C=ba;var Oa=C(F,"WeakMap"),Ue=Oa;var $a=(function(){try{var e=C(Object,"defineProperty");return e({},"",{}),e}catch{}})(),yt=$a;var Aa=9007199254740991,va=/^(?:0|[1-9]\d*)$/;function Ea(e,t){var r=typeof e;return t=t??Aa,!!t&&(r=="number"||r!="symbol"&&va.test(e))&&e>-1&&e%1==0&&e<t}var de=Ea;function Ra(e,t,r){t=="__proto__"&&yt?yt(e,t,{configurable:true,enumerable:true,value:r,writable:true}):e[t]=r;}var or=Ra;function Sa(e,t){return e===t||e!==e&&t!==t}var me=Sa;var ka=9007199254740991;function Ma(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=ka}var ce=Ma;function Ta(e){return e!=null&&ce(e.length)&&!Ve(e)}var z=Ta;function _a(e,t,r){if(!q(r))return false;var n=typeof t;return (n=="number"?z(r)&&de(t,r.length):n=="string"&&t in r)?me(r[t],e):false}var ar=_a;var Fa=Object.prototype;function Pa(e){var t=e&&e.constructor,r=typeof t=="function"&&t.prototype||Fa;return e===r}var Ge=Pa;function Ca(e,t){for(var r=-1,n=Array(e);++r<e;)n[r]=t(r);return n}var ir=Ca;var Da="[object Arguments]";function Ba(e){return N(e)&&B(e)==Da}var ht=Ba;var sr=Object.prototype,Na=sr.hasOwnProperty,qa=sr.propertyIsEnumerable,La=ht((function(){return arguments})())?ht:function(e){return N(e)&&Na.call(e,"callee")&&!qa.call(e,"callee")},ge=La;function Ia(){return false}var lr=Ia;var pr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,fr=pr&&typeof module=="object"&&module&&!module.nodeType&&module,ja=fr&&fr.exports===pr,ur=ja?F.Buffer:void 0,Va=ur?ur.isBuffer:void 0,Wa=Va||lr,ae=Wa;var Ua="[object Arguments]",Ga="[object Array]",Ka="[object Boolean]",za="[object Date]",Ha="[object Error]",Ja="[object Function]",Qa="[object Map]",Ya="[object Number]",Xa="[object Object]",Za="[object RegExp]",ei="[object Set]",ti="[object String]",ri="[object WeakMap]",ni="[object ArrayBuffer]",oi="[object DataView]",ai="[object Float32Array]",ii="[object Float64Array]",si="[object Int8Array]",li="[object Int16Array]",fi="[object Int32Array]",ui="[object Uint8Array]",pi="[object Uint8ClampedArray]",di="[object Uint16Array]",mi="[object Uint32Array]",T={};T[ai]=T[ii]=T[si]=T[li]=T[fi]=T[ui]=T[pi]=T[di]=T[mi]=true;T[Ua]=T[Ga]=T[ni]=T[Ka]=T[oi]=T[za]=T[Ha]=T[Ja]=T[Qa]=T[Ya]=T[Xa]=T[Za]=T[ei]=T[ti]=T[ri]=false;function ci(e){return N(e)&&ce(e.length)&&!!T[B(e)]}var dr=ci;function gi(e){return function(t){return e(t)}}var mr=gi;var cr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Ce=cr&&typeof module=="object"&&module&&!module.nodeType&&module,yi=Ce&&Ce.exports===cr,wt=yi&&je.process,hi=(function(){try{var e=Ce&&Ce.require&&Ce.require("util").types;return e||wt&&wt.binding&&wt.binding("util")}catch{}})(),xt=hi;var gr=xt&&xt.isTypedArray,wi=gr?mr(gr):dr,ye=wi;var xi=Object.prototype,bi=xi.hasOwnProperty;function Oi(e,t){var r=_(e),n=!r&&ge(e),o=!r&&!n&&ae(e),a=!r&&!n&&!o&&ye(e),i=r||n||o||a,s=i?ir(e.length,String):[],l=s.length;for(var p in e)(t||bi.call(e,p))&&!(i&&(p=="length"||o&&(p=="offset"||p=="parent")||a&&(p=="buffer"||p=="byteLength"||p=="byteOffset")||de(p,l)))&&s.push(p);return s}var yr=Oi;function $i(e,t){return function(r){return e(t(r))}}var hr=$i;var Ai=hr(Object.keys,Object),wr=Ai;var vi=Object.prototype,Ei=vi.hasOwnProperty;function Ri(e){if(!Ge(e))return wr(e);var t=[];for(var r in Object(e))Ei.call(e,r)&&r!="constructor"&&t.push(r);return t}var Ke=Ri;function Si(e){return z(e)?yr(e):Ke(e)}var he=Si;var ki=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Mi=/^\w*$/;function Ti(e,t){if(_(e))return false;var r=typeof e;return r=="number"||r=="symbol"||r=="boolean"||e==null||pe(e)?true:Mi.test(e)||!ki.test(e)||t!=null&&e in Object(t)}var we=Ti;var _i=C(Object,"create"),V=_i;function Fi(){this.__data__=V?V(null):{},this.size=0;}var xr=Fi;function Pi(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var br=Pi;var Ci="__lodash_hash_undefined__",Di=Object.prototype,Bi=Di.hasOwnProperty;function Ni(e){var t=this.__data__;if(V){var r=t[e];return r===Ci?void 0:r}return Bi.call(t,e)?t[e]:void 0}var Or=Ni;var qi=Object.prototype,Li=qi.hasOwnProperty;function Ii(e){var t=this.__data__;return V?t[e]!==void 0:Li.call(t,e)}var $r=Ii;var ji="__lodash_hash_undefined__";function Vi(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=V&&t===void 0?ji:t,this}var Ar=Vi;function xe(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]);}}xe.prototype.clear=xr;xe.prototype.delete=br;xe.prototype.get=Or;xe.prototype.has=$r;xe.prototype.set=Ar;var bt=xe;function Wi(){this.__data__=[],this.size=0;}var vr=Wi;function Ui(e,t){for(var r=e.length;r--;)if(me(e[r][0],t))return r;return -1}var H=Ui;var Gi=Array.prototype,Ki=Gi.splice;function zi(e){var t=this.__data__,r=H(t,e);if(r<0)return false;var n=t.length-1;return r==n?t.pop():Ki.call(t,r,1),--this.size,true}var Er=zi;function Hi(e){var t=this.__data__,r=H(t,e);return r<0?void 0:t[r][1]}var Rr=Hi;function Ji(e){return H(this.__data__,e)>-1}var Sr=Ji;function Qi(e,t){var r=this.__data__,n=H(r,e);return n<0?(++this.size,r.push([e,t])):r[n][1]=t,this}var kr=Qi;function be(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]);}}be.prototype.clear=vr;be.prototype.delete=Er;be.prototype.get=Rr;be.prototype.has=Sr;be.prototype.set=kr;var J=be;var Yi=C(F,"Map"),Q=Yi;function Xi(){this.size=0,this.__data__={hash:new bt,map:new(Q||J),string:new bt};}var Mr=Xi;function Zi(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}var Tr=Zi;function es(e,t){var r=e.__data__;return Tr(t)?r[typeof t=="string"?"string":"hash"]:r.map}var Y=es;function ts(e){var t=Y(this,e).delete(e);return this.size-=t?1:0,t}var _r=ts;function rs(e){return Y(this,e).get(e)}var Fr=rs;function ns(e){return Y(this,e).has(e)}var Pr=ns;function os(e,t){var r=Y(this,e),n=r.size;return r.set(e,t),this.size+=r.size==n?0:1,this}var Cr=os;function Oe(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]);}}Oe.prototype.clear=Mr;Oe.prototype.delete=_r;Oe.prototype.get=Fr;Oe.prototype.has=Pr;Oe.prototype.set=Cr;var ie=Oe;var as="Expected a function";function Ot(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(Ot.Cache||ie),r}Ot.Cache=ie;var Dr=Ot;var is=500;function ss(e){var t=Dr(e,function(n){return r.size===is&&r.clear(),n}),r=t.cache;return t}var Br=ss;var ls=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,fs=/\\(\\)?/g,us=Br(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(ls,function(r,n,o,a){t.push(o?a.replace(fs,"$1"):n||r);}),t}),Nr=us;function ps(e){return e==null?"":Xt(e)}var qr=ps;function ds(e,t){return _(e)?e:we(e,t)?[e]:Nr(qr(e))}var ze=ds;function cs(e){if(typeof e=="string"||pe(e))return e;var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var X=cs;function gs(e,t){t=ze(t,e);for(var r=0,n=t.length;e!=null&&r<n;)e=e[X(t[r++])];return r&&r==n?e:void 0}var He=gs;function ys(e,t,r){var n=e==null?void 0:He(e,t);return n===void 0?r:n}var k=ys;function hs(e,t){for(var r=-1,n=t.length,o=e.length;++r<n;)e[o+r]=t[r];return e}var Lr=hs;function ws(){this.__data__=new J,this.size=0;}var Ir=ws;function xs(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}var jr=xs;function bs(e){return this.__data__.get(e)}var Vr=bs;function Os(e){return this.__data__.has(e)}var Wr=Os;var $s=200;function As(e,t){var r=this.__data__;if(r instanceof J){var n=r.__data__;if(!Q||n.length<$s-1)return n.push([e,t]),this.size=++r.size,this;r=this.__data__=new ie(n);}return r.set(e,t),this.size=r.size,this}var Ur=As;function $e(e){var t=this.__data__=new J(e);this.size=t.size;}$e.prototype.clear=Ir;$e.prototype.delete=jr;$e.prototype.get=Vr;$e.prototype.has=Wr;$e.prototype.set=Ur;var Ae=$e;function vs(e,t){for(var r=-1,n=e==null?0:e.length,o=0,a=[];++r<n;){var i=e[r];t(i,r,e)&&(a[o++]=i);}return a}var Gr=vs;function Es(){return []}var Kr=Es;var Rs=Object.prototype,Ss=Rs.propertyIsEnumerable,zr=Object.getOwnPropertySymbols,ks=zr?function(e){return e==null?[]:(e=Object(e),Gr(zr(e),function(t){return Ss.call(e,t)}))}:Kr,Hr=ks;function Ms(e,t,r){var n=t(e);return _(e)?n:Lr(n,r(e))}var Jr=Ms;function Ts(e){return Jr(e,he,Hr)}var $t=Ts;var _s=C(F,"DataView"),Je=_s;var Fs=C(F,"Promise"),Qe=Fs;var Ps=C(F,"Set"),Ye=Ps;var Qr="[object Map]",Cs="[object Object]",Yr="[object Promise]",Xr="[object Set]",Zr="[object WeakMap]",en="[object DataView]",Ds=j(Je),Bs=j(Q),Ns=j(Qe),qs=j(Ye),Ls=j(Ue),se=B;(Je&&se(new Je(new ArrayBuffer(1)))!=en||Q&&se(new Q)!=Qr||Qe&&se(Qe.resolve())!=Yr||Ye&&se(new Ye)!=Xr||Ue&&se(new Ue)!=Zr)&&(se=function(e){var t=B(e),r=t==Cs?e.constructor:void 0,n=r?j(r):"";if(n)switch(n){case Ds:return en;case Bs:return Qr;case Ns:return Yr;case qs:return Xr;case Ls:return Zr}return t});var De=se;var Is=F.Uint8Array,At=Is;var js="__lodash_hash_undefined__";function Vs(e){return this.__data__.set(e,js),this}var tn=Vs;function Ws(e){return this.__data__.has(e)}var rn=Ws;function Xe(e){var t=-1,r=e==null?0:e.length;for(this.__data__=new ie;++t<r;)this.add(e[t]);}Xe.prototype.add=Xe.prototype.push=tn;Xe.prototype.has=rn;var nn=Xe;function Us(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 Ze=Us;function Gs(e,t){return e.has(t)}var on=Gs;var Ks=1,zs=2;function Hs(e,t,r,n,o,a){var i=r&Ks,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&zs?new nn: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(!Ze(t,function(O,S){if(!on(c,S)&&(y===O||o(y,O,r,n,a)))return c.push(S)})){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 et=Hs;function Js(e){var t=-1,r=Array(e.size);return e.forEach(function(n,o){r[++t]=[o,n];}),r}var an=Js;function Qs(e){var t=-1,r=Array(e.size);return e.forEach(function(n){r[++t]=n;}),r}var sn=Qs;var Ys=1,Xs=2,Zs="[object Boolean]",el="[object Date]",tl="[object Error]",rl="[object Map]",nl="[object Number]",ol="[object RegExp]",al="[object Set]",il="[object String]",sl="[object Symbol]",ll="[object ArrayBuffer]",fl="[object DataView]",ln=D?D.prototype:void 0,vt=ln?ln.valueOf:void 0;function ul(e,t,r,n,o,a,i){switch(r){case fl:if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return false;e=e.buffer,t=t.buffer;case ll:return !(e.byteLength!=t.byteLength||!a(new At(e),new At(t)));case Zs:case el:case nl:return me(+e,+t);case tl:return e.name==t.name&&e.message==t.message;case ol:case il:return e==t+"";case rl:var s=an;case al:var l=n&Ys;if(s||(s=sn),e.size!=t.size&&!l)return false;var p=i.get(e);if(p)return p==t;n|=Xs,i.set(e,t);var u=et(s(e),s(t),n,o,a,i);return i.delete(e),u;case sl:if(vt)return vt.call(e)==vt.call(t)}return false}var fn=ul;var pl=1,dl=Object.prototype,ml=dl.hasOwnProperty;function cl(e,t,r,n,o,a){var i=r&pl,s=$t(e),l=s.length,p=$t(t),u=p.length;if(l!=u&&!i)return false;for(var d=l;d--;){var m=s[d];if(!(i?m in t:ml.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],S=t[m];if(n)var v=i?n(S,O,m,t,e,a):n(O,S,m,e,t,a);if(!(v===void 0?O===S||o(O,S,r,n,a):v)){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 un=cl;var gl=1,pn="[object Arguments]",dn="[object Array]",tt="[object Object]",yl=Object.prototype,mn=yl.hasOwnProperty;function hl(e,t,r,n,o,a){var i=_(e),s=_(t),l=i?dn:De(e),p=s?dn:De(t);l=l==pn?tt:l,p=p==pn?tt:p;var u=l==tt,d=p==tt,m=l==p;if(m&&ae(e)){if(!ae(t))return false;i=true,u=false;}if(m&&!u)return a||(a=new Ae),i||ye(e)?et(e,t,r,n,o,a):fn(e,t,l,r,n,o,a);if(!(r&gl)){var c=u&&mn.call(e,"__wrapped__"),y=d&&mn.call(t,"__wrapped__");if(c||y){var h=c?e.value():e,g=y?t.value():t;return a||(a=new Ae),o(h,g,r,n,a)}}return m?(a||(a=new Ae),un(e,t,r,n,o,a)):false}var cn=hl;function gn(e,t,r,n,o){return e===t?true:e==null||t==null||!N(e)&&!N(t)?e!==e&&t!==t:cn(e,t,r,n,gn,o)}var rt=gn;var wl=1,xl=2;function bl(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 Ae;if(n)var m=n(p,u,l,e,t,d);if(!(m===void 0?rt(u,p,wl|xl,n,d):m))return false}}return true}var yn=bl;function Ol(e){return e===e&&!q(e)}var nt=Ol;function $l(e){for(var t=he(e),r=t.length;r--;){var n=t[r],o=e[n];t[r]=[n,o,nt(o)];}return t}var hn=$l;function Al(e,t){return function(r){return r==null?false:r[e]===t&&(t!==void 0||e in Object(r))}}var ot=Al;function vl(e){var t=hn(e);return t.length==1&&t[0][2]?ot(t[0][0],t[0][1]):function(r){return r===e||yn(r,e,t)}}var wn=vl;function El(e,t){return e!=null&&t in Object(e)}var xn=El;function Rl(e,t,r){t=ze(t,e);for(var n=-1,o=t.length,a=false;++n<o;){var i=X(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&&ce(o)&&de(i,o)&&(_(e)||ge(e)))}var bn=Rl;function Sl(e,t){return e!=null&&bn(e,t,xn)}var On=Sl;var kl=1,Ml=2;function Tl(e,t){return we(e)&&nt(t)?ot(X(e),t):function(r){var n=k(r,e);return n===void 0&&n===t?On(r,e):rt(t,n,kl|Ml)}}var $n=Tl;function _l(e){return function(t){return t?.[e]}}var An=_l;function Fl(e){return function(t){return He(t,e)}}var vn=Fl;function Pl(e){return we(e)?An(X(e)):vn(e)}var En=Pl;function Cl(e){return typeof e=="function"?e:e==null?Zt:typeof e=="object"?_(e)?$n(e[0],e[1]):wn(e):En(e)}var at=Cl;function Dl(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 Rn=Dl;function Bl(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 Sn=Bl;var Nl=Sn(),kn=Nl;function ql(e,t){return e&&kn(e,t,he)}var Mn=ql;function Ll(e,t){return function(r,n){if(r==null)return r;if(!z(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 Tn=Ll;var Il=Tn(Mn),it=Il;function jl(e,t,r,n){return it(e,function(o,a,i){t(n,o,r(o),i);}),n}var _n=jl;function Vl(e,t){return function(r,n){var o=_(r)?Rn:_n,a=t?t():{};return o(r,e,at(n),a)}}var Fn=Vl;var Wl=Object.prototype,Ul=Wl.hasOwnProperty,Gl=Fn(function(e,t,r){Ul.call(e,r)?e[r].push(t):or(e,r,[t]);}),Et=Gl;var Kl="[object Map]",zl="[object Set]",Hl=Object.prototype,Jl=Hl.hasOwnProperty;function Ql(e){if(e==null)return true;if(z(e)&&(_(e)||typeof e=="string"||typeof e.splice=="function"||ae(e)||ye(e)||ge(e)))return !e.length;var t=De(e);if(t==Kl||t==zl)return !e.size;if(Ge(e))return !Ke(e).length;for(var r in e)if(Jl.call(e,r))return false;return true}var st=Ql;function Yl(e,t){var r;return it(e,function(n,o,a){return r=t(n,o,a),!r}),!!r}var Pn=Yl;function Xl(e,t,r){var n=_(e)?Ze:Pn;return r&&ar(e,t,r)&&(t=void 0),n(e,at(t))}var Rt=Xl;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",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};W.extend(rf);W.extend(tf);W.extend(ef);W.extend(Zl);var Cn=(e,t,r)=>{let n=k(t,e.field);if(!n)throw new Error(`${e.field} is null or undefined`);if(!kt(n))throw new Error(`${e.field} is not a valid date: ${String(n)}`);let o=W(n);if(!o.isValid())throw new Error(`${e.field} is not a valid date: ${n}`);let a=p=>e.error||`${e.field} ${p}`,i=nf(e,t,r,o,n),s=i[0],l=i[1];switch(e.dateOperator){case x.before:return o.isBefore(s)||a(`must be before ${s.format()}`);case x.after:return o.isAfter(s)||a(`must be after ${s.format()}`);case x.onOrBefore:return o.isSameOrBefore(s)||a(`must be on or before ${s.format()}`);case x.onOrAfter:return o.isSameOrAfter(s)||a(`must be on or after ${s.format()}`);case x.between:{if(!l)throw new Error("between operator requires an end date");return o.isSameOrAfter(s)&&o.isSameOrBefore(l)||a(`must be between ${s.format()} and ${l?.format()}`)}case x.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return o.isBefore(s)||o.isAfter(l)||a(`must not be between ${s.format()} and ${l?.format()}`)}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let p=o.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return u.includes(p)||a(`must be on ${u.join(" or ")}`)}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let p=o.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return !u.includes(p)||a(`must not be on ${u.join(" or ")}`)}default:throw new Error("Unknown date operator")}},nf=(e,t,r,n,o)=>{if([x.between,x.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[s,l]=e.value,p=St(s,o),u=St(l,o);if(!p.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!u.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[d,m]=p.isBefore(u)||p.isSame(u)?[p,u]:[u,p];return [d,m]}if([x.before,x.after,x.onOrBefore,x.onOrAfter].includes(e.dateOperator)){let s;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);s=e.value;}else if(e.path)if(e.path.startsWith("$.")){let p=k(t,e.path.substring(2));s=kt(p)?p:void 0;}else {let p=k(r,e.path);s=kt(p)?p:void 0;}else throw new Error("No value or path specified for date comparison");let l=St(s,o);if(!l.isValid())throw new Error(`Invalid comparison date: ${s}`);return [l,void 0]}return [W(),void 0]},St=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return W(e);let 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}$/)?W(`${e}T00:00:00`).subtract(a,"minute"):W(e).subtract(a,"minute")},kt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var qn=(e,t,r)=>{let n=k(t,e.field),a=![f.isEmpty,f.notEmpty,f.exists,f.notExists].includes(e.operator),i=a?of(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 lt(n,i,"lt")||s("must be less than");case f.lessThanEquals:return lt(n,i,"lte")||s("must be less than or equal to");case f.greaterThan:return lt(n,i,"gt")||s("must be greater than");case f.greaterThanEquals:return lt(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 Nn(n,i)||s("must contain");case f.notContains:return !Nn(n,i)||s("must not contain");case f.matches:return Dn(n)&&(i instanceof RegExp||typeof i=="string")&&!!n.match(i)||s("must match pattern");case f.notMatches:return !Dn(n)||!(i instanceof RegExp||typeof i=="string")||!n.match(i)||s("must not match pattern");case f.between:{let l=Bn(i);if(!l)throw new Error("between operator requires an array of two values");if(!ve(n))return s("must be between");let p=Ee(n),[u,d]=l;return p>=u&&p<=d||s("must be between")}case f.notBetween:{let l=Bn(i);if(!l)throw new Error("notBetween operator requires an array of two values");if(!ve(n))return true;let p=Ee(n),[u,d]=l;return p<u||p>d||s("must not be between")}case f.isEmpty:return st(n)||s("must be empty");case f.notEmpty:return !st(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")}},of=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?k(t,e.path.substring(2)):k(r,e.path);throw new Error("No value or path specified")},ve=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ee=e=>e instanceof Date?e.getTime():e,lt=(e,t,r)=>{if(!ve(e)||!ve(t))return false;let n=Ee(e),o=Ee(t);switch(r){case "lt":return n<o;case "lte":return n<=o;case "gt":return n>o;case "gte":return n>=o}},Dn=e=>typeof e=="string",Bn=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!ve(t)||!ve(r))return null;let n=Ee(t),o=Ee(r);return n<=o?[n,o]:[o,n]},Nn=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var Mt=e=>{if(typeof e!="boolean"){if("all"in e){for(let t of e.all)Mt(t);return}if("any"in e){for(let t of e.any)Mt(t);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},le=(e,t,r)=>{if(Array.isArray(t)&&Mt(e),typeof e=="boolean")return e;let n={...r,context:r?.context??t};return "all"in e?af(e.all,t,n,e.error):"any"in e?sf(e.any,t,n,e.error):"arrayOperator"in e?uf(e,t,n):"dateOperator"in e?Cn(e,t,n.context):"aggregate"in e?ff(e,t,n):"field"in e?qn(e,t,n.context):"if"in e?lf(e,t,n):false},af=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(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},sf=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(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 ")}`)},lf=(e,t,r)=>le(e.if,t,r)===true?le(e.then,t,r):e.else!==void 0?le(e.else,t,r):true,ff=(e,t,r)=>{let n=k(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let{mode:o,field:a}=e.aggregate;if(o!=="sum"&&o!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let i=e.condition,l=(i?n.filter(y=>le(i,y,r)===true):n).map((y,h)=>{let g=a?k(y,a):y;if(typeof g!="number"||!Number.isFinite(g)){let O=`${e.field}[${h}]${a?`.${a}`:""}`;throw new Error(`${O} must be a finite number`)}return g}),p=l.reduce((y,h)=>y+h,0),u=o==="sum"?p:l.length===0?0:p/l.length,d=r.context,m;if(e.value!==void 0)m=e.value;else if(e.path)m=e.path.startsWith("$.")?k(t,e.path.substring(2)):k(d,e.path);else throw new Error("Aggregate rule requires value or path");let c=y=>e.error||`${e.field} ${o} ${y} ${JSON.stringify(m)}`;switch(e.operator){case f.equals:return u===m||c("must equal");case f.notEquals:return u!==m||c("must not equal");case f.lessThan:return typeof m=="number"&&u<m||c("must be less than");case f.lessThanEquals:return typeof m=="number"&&u<=m||c("must be less than or equal to");case f.greaterThan:return typeof m=="number"&&u>m||c("must be greater than");case f.greaterThanEquals:return typeof m=="number"&&u>=m||c("must be greater than or equal to");case f.between:{if(!Array.isArray(m)||m.length!==2)throw new Error("between requires a two-element array");let[y,h]=m,[g,O]=y<=h?[y,h]:[h,y];return u>=g&&u<=O||c("must be between")}case f.notBetween:{if(!Array.isArray(m)||m.length!==2)throw new Error("notBetween requires a two-element array");let[y,h]=m,[g,O]=y<=h?[y,h]:[h,y];return u<g||u>O||c("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},uf=(e,t,r)=>{let n=e.field?k(t,e.field):t;if(!Array.isArray(n))throw new Error(`${e.field||"(root)"} must be an array`);let o=d=>e.error||`${e.field} ${d}`,a=[w.all,w.any,w.none,w.atLeast,w.atMost,w.exactly],i=[w.atLeast,w.atMost,w.exactly],s=e.condition;if(a.includes(e.arrayOperator)&&!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(i.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let p=0,u=0;if(a.includes(e.arrayOperator)){if(!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!Rt(n,q))return o("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let d=n.map(m=>le(s,m,r));p=d.filter(m=>m===true).length,u=d.filter(m=>typeof m=="string").length;}switch(e.arrayOperator){case w.empty:return !n.length||o("must be empty");case w.notEmpty:return !!n.length||o("must not be empty");case w.all:return p===n.length||o(`all elements must match (${u} failed)`);case w.any:return !!p||o("at least one element must match");case w.none:return !p||o(`no elements should match (${p} matched)`);case w.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p>=l||o(`at least ${l} elements must match (${p} matched)`);case w.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p<=l||o(`at most ${l} elements must match (${p} matched)`);case w.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p===l||o(`exactly ${l} elements must match (${p} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Ln=(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},pf=(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]=Ln(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]=Et(p,a.on);}else r[a.fieldMap][a.model][a.on]=Ln(t[s],a.on,s,"oneToOne");}return r};var Tt=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 df=/[.:]/,In=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"&&df.test(i)&&t.push(`'${r}:${o}.${i}' contains forbidden character . or :`);if(t.length)throw new Error(`validateFieldMapSet:
1
+ import U from'dayjs';import Zl from'dayjs/plugin/isSameOrAfter.js';import ef from'dayjs/plugin/isSameOrBefore.js';import tf from'dayjs/plugin/timezone.js';import rf from'dayjs/plugin/utc.js';var Co=typeof global=="object"&&global&&global.Object===Object&&global,Ve=Co;var Do=typeof self=="object"&&self&&self.Object===Object&&self,Bo=Ve||Do||Function("return this")(),P=Bo;var No=P.Symbol,D=No;var Gt=Object.prototype,Lo=Gt.hasOwnProperty,qo=Gt.toString,Ce=D?D.toStringTag:void 0;function Io(e){var t=Lo.call(e,Ce),r=e[Ce];try{e[Ce]=void 0;var n=!0;}catch{}var o=qo.call(e);return n&&(t?e[Ce]=r:delete e[Ce]),o}var Kt=Io;var jo=Object.prototype,Vo=jo.toString;function Wo(e){return Vo.call(e)}var zt=Wo;var Uo="[object Null]",Go="[object Undefined]",Ht=D?D.toStringTag:void 0;function Ko(e){return e==null?e===void 0?Go:Uo:Ht&&Ht in Object(e)?Kt(e):zt(e)}var B=Ko;function zo(e){return e!=null&&typeof e=="object"}var N=zo;var Ho="[object Symbol]";function Jo(e){return typeof e=="symbol"||N(e)&&B(e)==Ho}var pe=Jo;function Qo(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 Jt=Qo;var Yo=Array.isArray,_=Yo;var Qt=D?D.prototype:void 0,Yt=Qt?Qt.toString:void 0;function Xt(e){if(typeof e=="string")return e;if(_(e))return Jt(e,Xt)+"";if(pe(e))return Yt?Yt.call(e):"";var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var Zt=Xt;function Zo(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var L=Zo;function ea(e){return e}var er=ea;var ta="[object AsyncFunction]",ra="[object Function]",na="[object GeneratorFunction]",oa="[object Proxy]";function aa(e){if(!L(e))return false;var t=B(e);return t==ra||t==na||t==ta||t==oa}var We=aa;var ia=P["__core-js_shared__"],Ue=ia;var tr=(function(){var e=/[^.]+$/.exec(Ue&&Ue.keys&&Ue.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function sa(e){return !!tr&&tr in e}var rr=sa;var la=Function.prototype,fa=la.toString;function ua(e){if(e!=null){try{return fa.call(e)}catch{}try{return e+""}catch{}}return ""}var V=ua;var pa=/[\\^$.*+?()[\]{}|]/g,da=/^\[object .+?Constructor\]$/,ma=Function.prototype,ca=Object.prototype,ga=ma.toString,ya=ca.hasOwnProperty,ha=RegExp("^"+ga.call(ya).replace(pa,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function wa(e){if(!L(e)||rr(e))return false;var t=We(e)?ha:da;return t.test(V(e))}var nr=wa;function xa(e,t){return e?.[t]}var or=xa;function ba(e,t){var r=or(e,t);return nr(r)?r:void 0}var C=ba;var Oa=C(P,"WeakMap"),Ge=Oa;var $a=(function(){try{var e=C(Object,"defineProperty");return e({},"",{}),e}catch{}})(),yt=$a;var Aa=9007199254740991,va=/^(?:0|[1-9]\d*)$/;function Ea(e,t){var r=typeof e;return t=t??Aa,!!t&&(r=="number"||r!="symbol"&&va.test(e))&&e>-1&&e%1==0&&e<t}var de=Ea;function Ra(e,t,r){t=="__proto__"&&yt?yt(e,t,{configurable:true,enumerable:true,value:r,writable:true}):e[t]=r;}var ar=Ra;function Sa(e,t){return e===t||e!==e&&t!==t}var me=Sa;var ka=9007199254740991;function Ma(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=ka}var ce=Ma;function Ta(e){return e!=null&&ce(e.length)&&!We(e)}var z=Ta;function _a(e,t,r){if(!L(r))return false;var n=typeof t;return (n=="number"?z(r)&&de(t,r.length):n=="string"&&t in r)?me(r[t],e):false}var ir=_a;var Pa=Object.prototype;function Fa(e){var t=e&&e.constructor,r=typeof t=="function"&&t.prototype||Pa;return e===r}var Ke=Fa;function Ca(e,t){for(var r=-1,n=Array(e);++r<e;)n[r]=t(r);return n}var sr=Ca;var Da="[object Arguments]";function Ba(e){return N(e)&&B(e)==Da}var ht=Ba;var lr=Object.prototype,Na=lr.hasOwnProperty,La=lr.propertyIsEnumerable,qa=ht((function(){return arguments})())?ht:function(e){return N(e)&&Na.call(e,"callee")&&!La.call(e,"callee")},ge=qa;function Ia(){return false}var fr=Ia;var dr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,ur=dr&&typeof module=="object"&&module&&!module.nodeType&&module,ja=ur&&ur.exports===dr,pr=ja?P.Buffer:void 0,Va=pr?pr.isBuffer:void 0,Wa=Va||fr,ae=Wa;var Ua="[object Arguments]",Ga="[object Array]",Ka="[object Boolean]",za="[object Date]",Ha="[object Error]",Ja="[object Function]",Qa="[object Map]",Ya="[object Number]",Xa="[object Object]",Za="[object RegExp]",ei="[object Set]",ti="[object String]",ri="[object WeakMap]",ni="[object ArrayBuffer]",oi="[object DataView]",ai="[object Float32Array]",ii="[object Float64Array]",si="[object Int8Array]",li="[object Int16Array]",fi="[object Int32Array]",ui="[object Uint8Array]",pi="[object Uint8ClampedArray]",di="[object Uint16Array]",mi="[object Uint32Array]",T={};T[ai]=T[ii]=T[si]=T[li]=T[fi]=T[ui]=T[pi]=T[di]=T[mi]=true;T[Ua]=T[Ga]=T[ni]=T[Ka]=T[oi]=T[za]=T[Ha]=T[Ja]=T[Qa]=T[Ya]=T[Xa]=T[Za]=T[ei]=T[ti]=T[ri]=false;function ci(e){return N(e)&&ce(e.length)&&!!T[B(e)]}var mr=ci;function gi(e){return function(t){return e(t)}}var cr=gi;var gr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,De=gr&&typeof module=="object"&&module&&!module.nodeType&&module,yi=De&&De.exports===gr,wt=yi&&Ve.process,hi=(function(){try{var e=De&&De.require&&De.require("util").types;return e||wt&&wt.binding&&wt.binding("util")}catch{}})(),xt=hi;var yr=xt&&xt.isTypedArray,wi=yr?cr(yr):mr,ye=wi;var xi=Object.prototype,bi=xi.hasOwnProperty;function Oi(e,t){var r=_(e),n=!r&&ge(e),o=!r&&!n&&ae(e),a=!r&&!n&&!o&&ye(e),i=r||n||o||a,s=i?sr(e.length,String):[],l=s.length;for(var p in e)(t||bi.call(e,p))&&!(i&&(p=="length"||o&&(p=="offset"||p=="parent")||a&&(p=="buffer"||p=="byteLength"||p=="byteOffset")||de(p,l)))&&s.push(p);return s}var hr=Oi;function $i(e,t){return function(r){return e(t(r))}}var wr=$i;var Ai=wr(Object.keys,Object),xr=Ai;var vi=Object.prototype,Ei=vi.hasOwnProperty;function Ri(e){if(!Ke(e))return xr(e);var t=[];for(var r in Object(e))Ei.call(e,r)&&r!="constructor"&&t.push(r);return t}var ze=Ri;function Si(e){return z(e)?hr(e):ze(e)}var he=Si;var ki=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Mi=/^\w*$/;function Ti(e,t){if(_(e))return false;var r=typeof e;return r=="number"||r=="symbol"||r=="boolean"||e==null||pe(e)?true:Mi.test(e)||!ki.test(e)||t!=null&&e in Object(t)}var we=Ti;var _i=C(Object,"create"),W=_i;function Pi(){this.__data__=W?W(null):{},this.size=0;}var br=Pi;function Fi(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var Or=Fi;var Ci="__lodash_hash_undefined__",Di=Object.prototype,Bi=Di.hasOwnProperty;function Ni(e){var t=this.__data__;if(W){var r=t[e];return r===Ci?void 0:r}return Bi.call(t,e)?t[e]:void 0}var $r=Ni;var Li=Object.prototype,qi=Li.hasOwnProperty;function Ii(e){var t=this.__data__;return W?t[e]!==void 0:qi.call(t,e)}var Ar=Ii;var ji="__lodash_hash_undefined__";function Vi(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=W&&t===void 0?ji:t,this}var vr=Vi;function xe(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]);}}xe.prototype.clear=br;xe.prototype.delete=Or;xe.prototype.get=$r;xe.prototype.has=Ar;xe.prototype.set=vr;var bt=xe;function Wi(){this.__data__=[],this.size=0;}var Er=Wi;function Ui(e,t){for(var r=e.length;r--;)if(me(e[r][0],t))return r;return -1}var H=Ui;var Gi=Array.prototype,Ki=Gi.splice;function zi(e){var t=this.__data__,r=H(t,e);if(r<0)return false;var n=t.length-1;return r==n?t.pop():Ki.call(t,r,1),--this.size,true}var Rr=zi;function Hi(e){var t=this.__data__,r=H(t,e);return r<0?void 0:t[r][1]}var Sr=Hi;function Ji(e){return H(this.__data__,e)>-1}var kr=Ji;function Qi(e,t){var r=this.__data__,n=H(r,e);return n<0?(++this.size,r.push([e,t])):r[n][1]=t,this}var Mr=Qi;function be(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]);}}be.prototype.clear=Er;be.prototype.delete=Rr;be.prototype.get=Sr;be.prototype.has=kr;be.prototype.set=Mr;var J=be;var Yi=C(P,"Map"),Q=Yi;function Xi(){this.size=0,this.__data__={hash:new bt,map:new(Q||J),string:new bt};}var Tr=Xi;function Zi(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}var _r=Zi;function es(e,t){var r=e.__data__;return _r(t)?r[typeof t=="string"?"string":"hash"]:r.map}var Y=es;function ts(e){var t=Y(this,e).delete(e);return this.size-=t?1:0,t}var Pr=ts;function rs(e){return Y(this,e).get(e)}var Fr=rs;function ns(e){return Y(this,e).has(e)}var Cr=ns;function os(e,t){var r=Y(this,e),n=r.size;return r.set(e,t),this.size+=r.size==n?0:1,this}var Dr=os;function Oe(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]);}}Oe.prototype.clear=Tr;Oe.prototype.delete=Pr;Oe.prototype.get=Fr;Oe.prototype.has=Cr;Oe.prototype.set=Dr;var ie=Oe;var as="Expected a function";function Ot(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(Ot.Cache||ie),r}Ot.Cache=ie;var Br=Ot;var is=500;function ss(e){var t=Br(e,function(n){return r.size===is&&r.clear(),n}),r=t.cache;return t}var Nr=ss;var ls=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,fs=/\\(\\)?/g,us=Nr(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(ls,function(r,n,o,a){t.push(o?a.replace(fs,"$1"):n||r);}),t}),Lr=us;function ps(e){return e==null?"":Zt(e)}var qr=ps;function ds(e,t){return _(e)?e:we(e,t)?[e]:Lr(qr(e))}var He=ds;function cs(e){if(typeof e=="string"||pe(e))return e;var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var X=cs;function gs(e,t){t=He(t,e);for(var r=0,n=t.length;e!=null&&r<n;)e=e[X(t[r++])];return r&&r==n?e:void 0}var Je=gs;function ys(e,t,r){var n=e==null?void 0:Je(e,t);return n===void 0?r:n}var S=ys;function hs(e,t){for(var r=-1,n=t.length,o=e.length;++r<n;)e[o+r]=t[r];return e}var Ir=hs;function ws(){this.__data__=new J,this.size=0;}var jr=ws;function xs(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}var Vr=xs;function bs(e){return this.__data__.get(e)}var Wr=bs;function Os(e){return this.__data__.has(e)}var Ur=Os;var $s=200;function As(e,t){var r=this.__data__;if(r instanceof J){var n=r.__data__;if(!Q||n.length<$s-1)return n.push([e,t]),this.size=++r.size,this;r=this.__data__=new ie(n);}return r.set(e,t),this.size=r.size,this}var Gr=As;function $e(e){var t=this.__data__=new J(e);this.size=t.size;}$e.prototype.clear=jr;$e.prototype.delete=Vr;$e.prototype.get=Wr;$e.prototype.has=Ur;$e.prototype.set=Gr;var Ae=$e;function vs(e,t){for(var r=-1,n=e==null?0:e.length,o=0,a=[];++r<n;){var i=e[r];t(i,r,e)&&(a[o++]=i);}return a}var Kr=vs;function Es(){return []}var zr=Es;var Rs=Object.prototype,Ss=Rs.propertyIsEnumerable,Hr=Object.getOwnPropertySymbols,ks=Hr?function(e){return e==null?[]:(e=Object(e),Kr(Hr(e),function(t){return Ss.call(e,t)}))}:zr,Jr=ks;function Ms(e,t,r){var n=t(e);return _(e)?n:Ir(n,r(e))}var Qr=Ms;function Ts(e){return Qr(e,he,Jr)}var $t=Ts;var _s=C(P,"DataView"),Qe=_s;var Ps=C(P,"Promise"),Ye=Ps;var Fs=C(P,"Set"),Xe=Fs;var Yr="[object Map]",Cs="[object Object]",Xr="[object Promise]",Zr="[object Set]",en="[object WeakMap]",tn="[object DataView]",Ds=V(Qe),Bs=V(Q),Ns=V(Ye),Ls=V(Xe),qs=V(Ge),se=B;(Qe&&se(new Qe(new ArrayBuffer(1)))!=tn||Q&&se(new Q)!=Yr||Ye&&se(Ye.resolve())!=Xr||Xe&&se(new Xe)!=Zr||Ge&&se(new Ge)!=en)&&(se=function(e){var t=B(e),r=t==Cs?e.constructor:void 0,n=r?V(r):"";if(n)switch(n){case Ds:return tn;case Bs:return Yr;case Ns:return Xr;case Ls:return Zr;case qs:return en}return t});var Be=se;var Is=P.Uint8Array,At=Is;var js="__lodash_hash_undefined__";function Vs(e){return this.__data__.set(e,js),this}var rn=Vs;function Ws(e){return this.__data__.has(e)}var nn=Ws;function Ze(e){var t=-1,r=e==null?0:e.length;for(this.__data__=new ie;++t<r;)this.add(e[t]);}Ze.prototype.add=Ze.prototype.push=rn;Ze.prototype.has=nn;var on=Ze;function Us(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 et=Us;function Gs(e,t){return e.has(t)}var an=Gs;var Ks=1,zs=2;function Hs(e,t,r,n,o,a){var i=r&Ks,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&zs?new on:void 0;for(a.set(e,t),a.set(t,e);++d<s;){var y=e[d],w=t[d];if(n)var g=i?n(w,y,d,t,e,a):n(y,w,d,e,t,a);if(g!==void 0){if(g)continue;m=false;break}if(c){if(!et(t,function($,M){if(!an(c,M)&&(y===$||o(y,$,r,n,a)))return c.push(M)})){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 tt=Hs;function Js(e){var t=-1,r=Array(e.size);return e.forEach(function(n,o){r[++t]=[o,n];}),r}var sn=Js;function Qs(e){var t=-1,r=Array(e.size);return e.forEach(function(n){r[++t]=n;}),r}var ln=Qs;var Ys=1,Xs=2,Zs="[object Boolean]",el="[object Date]",tl="[object Error]",rl="[object Map]",nl="[object Number]",ol="[object RegExp]",al="[object Set]",il="[object String]",sl="[object Symbol]",ll="[object ArrayBuffer]",fl="[object DataView]",fn=D?D.prototype:void 0,vt=fn?fn.valueOf:void 0;function ul(e,t,r,n,o,a,i){switch(r){case fl:if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return false;e=e.buffer,t=t.buffer;case ll:return !(e.byteLength!=t.byteLength||!a(new At(e),new At(t)));case Zs:case el:case nl:return me(+e,+t);case tl:return e.name==t.name&&e.message==t.message;case ol:case il:return e==t+"";case rl:var s=sn;case al:var l=n&Ys;if(s||(s=ln),e.size!=t.size&&!l)return false;var p=i.get(e);if(p)return p==t;n|=Xs,i.set(e,t);var u=tt(s(e),s(t),n,o,a,i);return i.delete(e),u;case sl:if(vt)return vt.call(e)==vt.call(t)}return false}var un=ul;var pl=1,dl=Object.prototype,ml=dl.hasOwnProperty;function cl(e,t,r,n,o,a){var i=r&pl,s=$t(e),l=s.length,p=$t(t),u=p.length;if(l!=u&&!i)return false;for(var d=l;d--;){var m=s[d];if(!(i?m in t:ml.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;++d<l;){m=s[d];var $=e[m],M=t[m];if(n)var E=i?n(M,$,m,t,e,a):n($,M,m,e,t,a);if(!(E===void 0?$===M||o($,M,r,n,a):E)){w=false;break}g||(g=m=="constructor");}if(w&&!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)&&(w=false);}return a.delete(e),a.delete(t),w}var pn=cl;var gl=1,dn="[object Arguments]",mn="[object Array]",rt="[object Object]",yl=Object.prototype,cn=yl.hasOwnProperty;function hl(e,t,r,n,o,a){var i=_(e),s=_(t),l=i?mn:Be(e),p=s?mn:Be(t);l=l==dn?rt:l,p=p==dn?rt:p;var u=l==rt,d=p==rt,m=l==p;if(m&&ae(e)){if(!ae(t))return false;i=true,u=false;}if(m&&!u)return a||(a=new Ae),i||ye(e)?tt(e,t,r,n,o,a):un(e,t,l,r,n,o,a);if(!(r&gl)){var c=u&&cn.call(e,"__wrapped__"),y=d&&cn.call(t,"__wrapped__");if(c||y){var w=c?e.value():e,g=y?t.value():t;return a||(a=new Ae),o(w,g,r,n,a)}}return m?(a||(a=new Ae),pn(e,t,r,n,o,a)):false}var gn=hl;function yn(e,t,r,n,o){return e===t?true:e==null||t==null||!N(e)&&!N(t)?e!==e&&t!==t:gn(e,t,r,n,yn,o)}var nt=yn;var wl=1,xl=2;function bl(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 Ae;if(n)var m=n(p,u,l,e,t,d);if(!(m===void 0?nt(u,p,wl|xl,n,d):m))return false}}return true}var hn=bl;function Ol(e){return e===e&&!L(e)}var ot=Ol;function $l(e){for(var t=he(e),r=t.length;r--;){var n=t[r],o=e[n];t[r]=[n,o,ot(o)];}return t}var wn=$l;function Al(e,t){return function(r){return r==null?false:r[e]===t&&(t!==void 0||e in Object(r))}}var at=Al;function vl(e){var t=wn(e);return t.length==1&&t[0][2]?at(t[0][0],t[0][1]):function(r){return r===e||hn(r,e,t)}}var xn=vl;function El(e,t){return e!=null&&t in Object(e)}var bn=El;function Rl(e,t,r){t=He(t,e);for(var n=-1,o=t.length,a=false;++n<o;){var i=X(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&&ce(o)&&de(i,o)&&(_(e)||ge(e)))}var On=Rl;function Sl(e,t){return e!=null&&On(e,t,bn)}var $n=Sl;var kl=1,Ml=2;function Tl(e,t){return we(e)&&ot(t)?at(X(e),t):function(r){var n=S(r,e);return n===void 0&&n===t?$n(r,e):nt(t,n,kl|Ml)}}var An=Tl;function _l(e){return function(t){return t?.[e]}}var vn=_l;function Pl(e){return function(t){return Je(t,e)}}var En=Pl;function Fl(e){return we(e)?vn(X(e)):En(e)}var Rn=Fl;function Cl(e){return typeof e=="function"?e:e==null?er:typeof e=="object"?_(e)?An(e[0],e[1]):xn(e):Rn(e)}var it=Cl;function Dl(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 Sn=Dl;function Bl(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 kn=Bl;var Nl=kn(),Mn=Nl;function Ll(e,t){return e&&Mn(e,t,he)}var Tn=Ll;function ql(e,t){return function(r,n){if(r==null)return r;if(!z(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 _n=ql;var Il=_n(Tn),st=Il;function jl(e,t,r,n){return st(e,function(o,a,i){t(n,o,r(o),i);}),n}var Pn=jl;function Vl(e,t){return function(r,n){var o=_(r)?Sn:Pn,a=t?t():{};return o(r,e,it(n),a)}}var Fn=Vl;var Wl=Object.prototype,Ul=Wl.hasOwnProperty,Gl=Fn(function(e,t,r){Ul.call(e,r)?e[r].push(t):ar(e,r,[t]);}),Et=Gl;var Kl="[object Map]",zl="[object Set]",Hl=Object.prototype,Jl=Hl.hasOwnProperty;function Ql(e){if(e==null)return true;if(z(e)&&(_(e)||typeof e=="string"||typeof e.splice=="function"||ae(e)||ye(e)||ge(e)))return !e.length;var t=Be(e);if(t==Kl||t==zl)return !e.size;if(Ke(e))return !ze(e).length;for(var r in e)if(Jl.call(e,r))return false;return true}var lt=Ql;function Yl(e,t){var r;return st(e,function(n,o,a){return r=t(n,o,a),!r}),!!r}var Cn=Yl;function Xl(e,t,r){var n=_(e)?et:Cn;return r&&ir(e,t,r)&&(t=void 0),n(e,it(t))}var Rt=Xl;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",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};U.extend(rf);U.extend(tf);U.extend(ef);U.extend(Zl);var Dn=(e,t,r)=>{let n=S(t,e.field);if(!n)throw new Error(`${e.field} is null or undefined`);if(!kt(n))throw new Error(`${e.field} is not a valid date: ${String(n)}`);let o=U(n);if(!o.isValid())throw new Error(`${e.field} is not a valid date: ${n}`);let a=p=>e.error||`${e.field} ${p}`,i=nf(e,t,r,o,n),s=i[0],l=i[1];switch(e.dateOperator){case x.before:return o.isBefore(s)||a(`must be before ${s.format()}`);case x.after:return o.isAfter(s)||a(`must be after ${s.format()}`);case x.onOrBefore:return o.isSameOrBefore(s)||a(`must be on or before ${s.format()}`);case x.onOrAfter:return o.isSameOrAfter(s)||a(`must be on or after ${s.format()}`);case x.between:{if(!l)throw new Error("between operator requires an end date");return o.isSameOrAfter(s)&&o.isSameOrBefore(l)||a(`must be between ${s.format()} and ${l?.format()}`)}case x.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return o.isBefore(s)||o.isAfter(l)||a(`must not be between ${s.format()} and ${l?.format()}`)}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let p=o.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return u.includes(p)||a(`must be on ${u.join(" or ")}`)}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let p=o.format("dddd").toLowerCase(),u=e.value.map(d=>String(d).toLowerCase());return !u.includes(p)||a(`must not be on ${u.join(" or ")}`)}default:throw new Error("Unknown date operator")}},nf=(e,t,r,n,o)=>{if([x.between,x.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[s,l]=e.value,p=St(s,o),u=St(l,o);if(!p.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!u.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[d,m]=p.isBefore(u)||p.isSame(u)?[p,u]:[u,p];return [d,m]}if([x.before,x.after,x.onOrBefore,x.onOrAfter].includes(e.dateOperator)){let s;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);s=e.value;}else if(e.path)if(e.path.startsWith("$.")){let p=S(t,e.path.substring(2));s=kt(p)?p:void 0;}else {let p=S(r,e.path);s=kt(p)?p:void 0;}else throw new Error("No value or path specified for date comparison");let l=St(s,o);if(!l.isValid())throw new Error(`Invalid comparison date: ${s}`);return [l,void 0]}return [U(),void 0]},St=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return U(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}$/)?U(`${e}T00:00:00`).subtract(a,"minute"):U(e).subtract(a,"minute")},kt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var qn=(e,t,r)=>{let n=S(t,e.field),a=![f.isEmpty,f.notEmpty,f.exists,f.notExists].includes(e.operator),i=a?of(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 ft(n,i,"lt")||s("must be less than");case f.lessThanEquals:return ft(n,i,"lte")||s("must be less than or equal to");case f.greaterThan:return ft(n,i,"gt")||s("must be greater than");case f.greaterThanEquals:return ft(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 Ln(n,i)||s("must contain");case f.notContains:return !Ln(n,i)||s("must not contain");case f.matches:return Bn(n)&&(i instanceof RegExp||typeof i=="string")&&!!n.match(i)||s("must match pattern");case f.notMatches:return !Bn(n)||!(i instanceof RegExp||typeof i=="string")||!n.match(i)||s("must not match pattern");case f.between:{let l=Nn(i);if(!l)throw new Error("between operator requires an array of two values");if(!ve(n))return s("must be between");let p=Ee(n),[u,d]=l;return p>=u&&p<=d||s("must be between")}case f.notBetween:{let l=Nn(i);if(!l)throw new Error("notBetween operator requires an array of two values");if(!ve(n))return true;let p=Ee(n),[u,d]=l;return p<u||p>d||s("must not be between")}case f.isEmpty:return lt(n)||s("must be empty");case f.notEmpty:return !lt(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")}},of=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?S(t,e.path.substring(2)):S(r,e.path);throw new Error("No value or path specified")},ve=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ee=e=>e instanceof Date?e.getTime():e,ft=(e,t,r)=>{if(!ve(e)||!ve(t))return false;let n=Ee(e),o=Ee(t);switch(r){case "lt":return n<o;case "lte":return n<=o;case "gt":return n>o;case "gte":return n>=o}},Bn=e=>typeof e=="string",Nn=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!ve(t)||!ve(r))return null;let n=Ee(t),o=Ee(r);return n<=o?[n,o]:[o,n]},Ln=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var Mt=e=>{if(typeof e!="boolean"){if("all"in e){for(let t of e.all)Mt(t);return}if("any"in e){for(let t of e.any)Mt(t);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},le=(e,t,r)=>{if(Array.isArray(t)&&Mt(e),typeof e=="boolean")return e;let n={...r,context:r?.context??t};return "all"in e?af(e.all,t,n,e.error):"any"in e?sf(e.any,t,n,e.error):"arrayOperator"in e?uf(e,t,n):"dateOperator"in e?Dn(e,t,n.context):"aggregate"in e?ff(e,t,n):"field"in e?qn(e,t,n.context):"if"in e?lf(e,t,n):false},af=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(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},sf=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(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 ")}`)},lf=(e,t,r)=>le(e.if,t,r)===true?le(e.then,t,r):e.else!==void 0?le(e.else,t,r):true,ff=(e,t,r)=>{let n=S(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let{mode:o,field:a}=e.aggregate;if(o!=="sum"&&o!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let i=e.condition,l=(i?n.filter(y=>le(i,y,r)===true):n).map((y,w)=>{let g=a?S(y,a):y;if(typeof g!="number"||!Number.isFinite(g)){let $=`${e.field}[${w}]${a?`.${a}`:""}`;throw new Error(`${$} must be a finite number`)}return g}),p=l.reduce((y,w)=>y+w,0),u=o==="sum"?p:l.length===0?0:p/l.length,d=r.context,m;if(e.value!==void 0)m=e.value;else if(e.path)m=e.path.startsWith("$.")?S(t,e.path.substring(2)):S(d,e.path);else throw new Error("Aggregate rule requires value or path");let c=y=>e.error||`${e.field} ${o} ${y} ${JSON.stringify(m)}`;switch(e.operator){case f.equals:return u===m||c("must equal");case f.notEquals:return u!==m||c("must not equal");case f.lessThan:return typeof m=="number"&&u<m||c("must be less than");case f.lessThanEquals:return typeof m=="number"&&u<=m||c("must be less than or equal to");case f.greaterThan:return typeof m=="number"&&u>m||c("must be greater than");case f.greaterThanEquals:return typeof m=="number"&&u>=m||c("must be greater than or equal to");case f.between:{if(!Array.isArray(m)||m.length!==2)throw new Error("between requires a two-element array");let[y,w]=m,[g,$]=y<=w?[y,w]:[w,y];return u>=g&&u<=$||c("must be between")}case f.notBetween:{if(!Array.isArray(m)||m.length!==2)throw new Error("notBetween requires a two-element array");let[y,w]=m,[g,$]=y<=w?[y,w]:[w,y];return u<g||u>$||c("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},uf=(e,t,r)=>{let n=e.field?S(t,e.field):t;if(!Array.isArray(n))throw new Error(`${e.field||"(root)"} must be an array`);let o=d=>e.error||`${e.field} ${d}`,a=[h.all,h.any,h.none,h.atLeast,h.atMost,h.exactly],i=[h.atLeast,h.atMost,h.exactly],s=e.condition;if(a.includes(e.arrayOperator)&&!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(i.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let p=0,u=0;if(a.includes(e.arrayOperator)){if(!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!Rt(n,L))return o("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let d=n.map(m=>le(s,m,r));p=d.filter(m=>m===true).length,u=d.filter(m=>typeof m=="string").length;}switch(e.arrayOperator){case h.empty:return !n.length||o("must be empty");case h.notEmpty:return !!n.length||o("must not be empty");case h.all:return p===n.length||o(`all elements must match (${u} failed)`);case h.any:return !!p||o("at least one element must match");case h.none:return !p||o(`no elements should match (${p} matched)`);case h.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p>=l||o(`at least ${l} elements must match (${p} matched)`);case h.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p<=l||o(`at most ${l} elements must match (${p} matched)`);case h.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p===l||o(`exactly ${l} elements must match (${p} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var In=(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},pf=(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]=In(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]=Et(p,a.on);}else r[a.fieldMap][a.model][a.on]=In(t[s],a.on,s,"oneToOne");}return r};var Tt=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 df=/[.:]/,jn=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"&&df.test(i)&&t.push(`'${r}:${o}.${i}' contains forbidden character . or :`);if(t.length)throw new Error(`validateFieldMapSet:
2
2
  ${t.join(`
3
- `)}`)},mf=(e,t="fieldMap")=>{In({maps:{[t]:e}});};var jn={[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},cf={[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},gf=e=>{let t=jn[e.operator];if(!t)throw new Error(`negate: operator '${e.operator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'. Rewrite the where clause using an invertible operator, or add the inverse operator to the DSL.`);return {...e,operator:t}},yf=e=>{let t=cf[e.dateOperator];return {...e,dateOperator:t}},hf=e=>{let t=jn[e.operator];if(!t)throw new Error(`negate: aggregate operator '${e.operator}' has no inverse in the DSL.`);return {...e,operator:t}},wf=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:Z(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}'`)}},Z=e=>{if(typeof e=="boolean")return !e;if("all"in e)return {any:e.all.map(Z)};if("any"in e)return {all:e.any.map(Z)};if("if"in e)return e.else!==void 0?{if:e.if,then:Z(e.then),else:Z(e.else)}:{all:[e.if,Z(e.then)]};if("arrayOperator"in e)return wf(e);if("dateOperator"in e)return yf(e);if("aggregate"in e)return hf(e);if("field"in e&&"operator"in e)return gf(e);throw new Error("negate: unknown condition shape")};var Vn=e=>"model"in e,Re=e=>{let t=new Set,r=e;for(;!Vn(r);){if(t.has(r))throw new Error("cycle detected in narrowing parent chain");t.add(r),r=r.parent;}return r},Se=e=>{let t=[],r=new Set,n=e;for(;!Vn(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},U=(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 ft=e=>{let t=Re(e),r=e.maps===t.maps?[]:Se(e);return {lens:t,chain:r}},Be=(e,t)=>e===null?new Set(t):new Set(t.filter(r=>e.has(r))),xf=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},_t=(e,t)=>{let r=xf(t);if(r&&(e.picks=Be(e.picks,r)),t.omits)for(let n of t.omits)e.omits.add(n);},Wn=(e,t,r)=>{e.set(t,Be(e.get(t)??null,r));},Un=(e,t,r)=>{let n=e.get(t)??new Set;for(let o of r)n.add(o);e.set(t,n);},Ft=(e,t,r)=>{if(r.enumPicks)for(let[n,o]of Object.entries(r.enumPicks))Wn(e,n,o);if(r.enumOmits)for(let[n,o]of Object.entries(r.enumOmits))Un(t,n,o);},bf=(e,t)=>{_t(e,t),t.where!==void 0&&e.whereClauses.push(t.where);},ke=(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=>{bf(o,m),Ft(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&&Wn(p,g,O.picks),O.omits&&Un(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),S=u.get(y);O&&(g=g.filter(A=>O.has(A))),S&&(g=g.filter(A=>!S.has(A)));let v=s.get(m),R=l.get(m);v&&(g=g.filter(A=>v.has(A))),R&&(g=g.filter(A=>!R.has(A))),o.enumValuesByField.set(m,g);}return o},Of=(e,t)=>!(e.omits.has(t)||e.picks!==null&&!e.picks.has(t)),Gn=(e,t)=>e.enumValuesByField.get(t)??null,Pt=(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=ke(e,i,s,l),y=a[u];if(!Of(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=U(h,i);if(!g)return null;l=[...l,y],i=g.mapName,s=g.modelName;}return null};var $f=(e,t)=>t.length===0?e:{all:[...t,e]},Af=(e,t,r)=>r===w.all?{any:[Z(t),e]}:{all:[t,e]},fe=(e,t,r,n,o)=>{if(typeof e=="boolean")return e;if("all"in e)return {...e,all:e.all.map(a=>fe(a,t,r,n,o))};if("any"in e)return {...e,any:e.any.map(a=>fe(a,t,r,n,o))};if("if"in e)return {...e,if:fe(e.if,t,r,n,o),then:fe(e.then,t,r,n,o),else:e.else!==void 0?fe(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=U(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=U(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=ke(t,l,p,u),y=fe(e.condition,t,l,p,u),h="arrayOperator"in e?e.arrayOperator:void 0;for(let g of c.whereClauses)h?y=Af(y,g,h):y={all:[g,y]};return {...e,condition:y}}return e}return e},vf=(e,t)=>{let r=ft(t),n=ke(r,r.lens.mapName,r.lens.model,[]),o=fe(e,r,r.lens.mapName,r.lens.model,[]);return $f(o,n.whereClauses)};var Ef=e=>{if(e.path!==void 0)return null;let t=e.value;return t===void 0?null:Array.isArray(t)?t:[t]},ue=(e,t,r,n,o,a)=>{if(typeof e=="boolean")return;if("all"in e){for(let c of e.all)ue(c,t,r,n,o,a);return}if("any"in e){for(let c of e.any)ue(c,t,r,n,o,a);return}if("if"in e){ue(e.if,t,r,n,o,a),ue(e.then,t,r,n,o,a),e.else!==void 0&&ue(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=Pt(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=Gn(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=Ef(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;Pt(t,i,s,l,c)||a.push({path:c,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ue(e.condition,t,i,s,l,a);},Ct=(e,t)=>{let r=ft(t),n=[];return ue(e,r,r.lens.mapName,r.lens.model,[],n),ke(r,r.lens.mapName,r.lens.model,[]),{ok:n.length===0,violations:n}};var Rf=e=>({...Tt({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var Kn=(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=Sf(e.where,n,o);for(let d of u)s.push(`${i}.where: ${d}`);}},Sf=(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},kf=(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=Be(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`);}},zn=(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=Be(h.picks,R);},O=R=>{for(let A of R)h.omits.add(A);},S=[...n];r&&S.push(r);for(let R of S){let A=R[y];A&&(A.picks&&g(A.picks),A.omits&&O(A.omits));}let v=[...a];o&&v.push(o);for(let R of v){let A=R.enumPicks?.[d],oe=R.enumOmits?.[d];A&&g(A),oe&&O(oe);}for(let R of i){let A=R.enumPicks?.[d],oe=R.enumOmits?.[d];A&&g(A),oe&&O(oe);}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);},Hn=(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];Kn(e,h,d,u.fields,i,p?.enums,s,l,false),zn(u.fields,e,c,y,d,m,t,s,l);for(let[g,O]of Object.entries(e.relations??{})){let S=u.fields[g];if(!S){l.push(`${s}.relations: '${g}' not on model`);continue}if(S.kind!=="object"&&S.kind!=="bridge"){l.push(`${s}.relations: '${g}' is not a relation (kind=${S.kind})`);continue}let v=U(S,a);if(!v)continue;if(!o[v.mapName]?.models[v.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);Hn(O,R,r,n,o,v.mapName,v.modelName,`${s}.relations.${g}`,l);}},Mf=e=>{let t=[],r=Re(e),n=Se(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);Kn(p,d,void 0,u.fields,l,i.enums,`mapDefaults.${o}.models.${l}`,t,true),zn(u.fields,p,void 0,s,void 0,d,[],`mapDefaults.${o}.models.${l}`,t);}a.enums&&kf(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);Hn(e.root,s,e,n,r.maps,o,a,"root",t);}}if(e.root?.where!==void 0){let o=Ct(e.root.where,e);for(let a of o.violations)t.push(`root.where: '${a.path}' ${a.reason}`);}if(t.length)throw new Error(`validateNarrowing:
3
+ `)}`)},mf=(e,t="fieldMap")=>{jn({maps:{[t]:e}});};var Vn={[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},cf={[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},gf=e=>{let t=Vn[e.operator];if(!t)throw new Error(`negate: operator '${e.operator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'. Rewrite the where clause using an invertible operator, or add the inverse operator to the DSL.`);return {...e,operator:t}},yf=e=>{let t=cf[e.dateOperator];return {...e,dateOperator:t}},hf=e=>{let t=Vn[e.operator];if(!t)throw new Error(`negate: aggregate operator '${e.operator}' has no inverse in the DSL.`);return {...e,operator:t}},wf=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:Z(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}'`)}},Z=e=>{if(typeof e=="boolean")return !e;if("all"in e)return {any:e.all.map(Z)};if("any"in e)return {all:e.any.map(Z)};if("if"in e)return e.else!==void 0?{if:e.if,then:Z(e.then),else:Z(e.else)}:{all:[e.if,Z(e.then)]};if("arrayOperator"in e)return wf(e);if("dateOperator"in e)return yf(e);if("aggregate"in e)return hf(e);if("field"in e&&"operator"in e)return gf(e);throw new Error("negate: unknown condition shape")};var Wn=e=>"model"in e,Re=e=>{let t=new Set,r=e;for(;!Wn(r);){if(t.has(r))throw new Error("cycle detected in narrowing parent chain");t.add(r),r=r.parent;}return r},Se=e=>{let t=[],r=new Set,n=e;for(;!Wn(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},q=(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 ke=e=>{let t=Re(e),r=e.maps===t.maps?[]:Se(e);return {lens:t,chain:r}},Ne=(e,t)=>e===null?new Set(t):new Set(t.filter(r=>e.has(r))),xf=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},_t=(e,t)=>{let r=xf(t);if(r&&(e.picks=Ne(e.picks,r)),t.omits)for(let n of t.omits)e.omits.add(n);},Un=(e,t,r)=>{e.set(t,Ne(e.get(t)??null,r));},Gn=(e,t,r)=>{let n=e.get(t)??new Set;for(let o of r)n.add(o);e.set(t,n);},Pt=(e,t,r)=>{if(r.enumPicks)for(let[n,o]of Object.entries(r.enumPicks))Un(e,n,o);if(r.enumOmits)for(let[n,o]of Object.entries(r.enumOmits))Gn(t,n,o);},bf=(e,t)=>{_t(e,t),t.where!==void 0&&e.whereClauses.push(t.where);},ee=(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=>{bf(o,m),Pt(s,l,m);};for(let m of e.chain){let c=m.mapDefaults?.[t];if(c){let w=c.models?.[r];w&&d(w);for(let[g,$]of Object.entries(c.enums??{}))$.picks&&Un(p,g,$.picks),$.omits&&Gn(u,g,$.omits);}let y=m.root;if(n.length===0){if(t===e.lens.mapName&&r===e.lens.model&&y){d(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){d(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,$=p.get(y),M=u.get(y);$&&(g=g.filter(A=>$.has(A))),M&&(g=g.filter(A=>!M.has(A)));let E=s.get(m),R=l.get(m);E&&(g=g.filter(A=>E.has(A))),R&&(g=g.filter(A=>!R.has(A))),o.enumValuesByField.set(m,g);}return o},Ft=(e,t)=>!(e.omits.has(t)||e.picks!==null&&!e.picks.has(t)),Kn=(e,t)=>e.enumValuesByField.get(t)??null,Ct=(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=ee(e,i,s,l),y=a[u];if(!Ft(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:p,terminalEffect:c,terminalFieldName:y};p.push(c);let g=q(w,i);if(!g)return null;l=[...l,y],i=g.mapName,s=g.modelName;}return null};var Of=(e,t)=>t.length===0?e:{all:[...t,e]},$f=(e,t,r)=>r===h.all?{any:[Z(t),e]}:{all:[t,e]},fe=(e,t,r,n,o)=>{if(typeof e=="boolean")return e;if("all"in e)return {...e,all:e.all.map(a=>fe(a,t,r,n,o))};if("any"in e)return {...e,any:e.any.map(a=>fe(a,t,r,n,o))};if("if"in e)return {...e,if:fe(e.if,t,r,n,o),then:fe(e.then,t,r,n,o),else:e.else!==void 0?fe(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 w=y.fields[s[c]];if(!w)break;if(c===s.length-1){if(w.kind==="object"||w.kind==="bridge"){let g=q(w,l);g&&(u=[...u,s[c]],l=g.mapName,p=g.modelName,m=true);}break}if(w.kind==="object"||w.kind==="bridge"){let g=q(w,l);if(g)u=[...u,s[c]],l=g.mapName,p=g.modelName;else break}else break}if("condition"in e&&e.condition!==void 0&&m){let c=ee(t,l,p,u),y=fe(e.condition,t,l,p,u),w="arrayOperator"in e?e.arrayOperator:void 0;for(let g of c.whereClauses)w?y=$f(y,g,w):y={all:[g,y]};return {...e,condition:y}}return e}return e},Af=(e,t)=>{let r=ke(t),n=ee(r,r.lens.mapName,r.lens.model,[]),o=fe(e,r,r.lens.mapName,r.lens.model,[]);return Of(o,n.whereClauses)};var vf=e=>{if(e.path!==void 0)return null;let t=e.value;return t===void 0?null:Array.isArray(t)?t:[t]},ue=(e,t,r,n,o,a)=>{if(typeof e=="boolean")return;if("all"in e){for(let c of e.all)ue(c,t,r,n,o,a);return}if("any"in e){for(let c of e.any)ue(c,t,r,n,o,a);return}if("if"in e){ue(e.if,t,r,n,o,a),ue(e.then,t,r,n,o,a),e.else!==void 0&&ue(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=Ct(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=Kn(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=vf(e);if(c&&m){let y=new Set(m);for(let w of c)typeof w=="string"&&!y.has(w)&&a.push({path:p,reason:`value '${w}' 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;Ct(t,i,s,l,c)||a.push({path:c,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ue(e.condition,t,i,s,l,a);},Dt=(e,t)=>{let r=ke(t),n=[];return ue(e,r,r.lens.mapName,r.lens.model,[],n),ee(r,r.lens.mapName,r.lens.model,[]),{ok:n.length===0,violations:n}};var Ef=e=>({...Tt({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var zn=(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 w of m)y&&!y.includes(w)&&s.push(`${i}.${u}.${d}: '${w}' is not a known value of enum '${c.type}'`);};for(let[u,d]of Object.entries(e.enumPicks??{}))p("enumPicks",u,d);for(let[u,d]of Object.entries(e.enumOmits??{}))p("enumOmits",u,d);if(e.where!==void 0&&e.where!==true&&e.where!==false){let u=Rf(e.where,n,o);for(let d of u)s.push(`${i}.where: ${d}`);}},Rf=(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},Sf=(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=Ne(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`);}},Hn=(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,w={picks:null,omits:new Set},g=R=>{w.picks=Ne(w.picks,R);},$=R=>{for(let A of R)w.omits.add(A);},M=[...n];r&&M.push(r);for(let R of M){let A=R[y];A&&(A.picks&&g(A.picks),A.omits&&$(A.omits));}let E=[...a];o&&E.push(o);for(let R of E){let A=R.enumPicks?.[d],Fe=R.enumOmits?.[d];A&&g(A),Fe&&$(Fe);}for(let R of i){let A=R.enumPicks?.[d],Fe=R.enumOmits?.[d];A&&g(A),Fe&&$(Fe);}for(let R of m)w.omits.has(R)?l.push(`${s}.${u}.${d}: '${R}' already excluded by inherited enum narrowing`):w.picks&&!w.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);},Jn=(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),w=[...m.map(g=>g),...t];zn(e,w,d,u.fields,i,p?.enums,s,l,false),Hn(u.fields,e,c,y,d,m,t,s,l);for(let[g,$]of Object.entries(e.relations??{})){let M=u.fields[g];if(!M){l.push(`${s}.relations: '${g}' not on model`);continue}if(M.kind!=="object"&&M.kind!=="bridge"){l.push(`${s}.relations: '${g}' is not a relation (kind=${M.kind})`);continue}let E=q(M,a);if(!E)continue;if(!o[E.mapName]?.models[E.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);Jn($,R,r,n,o,E.mapName,E.modelName,`${s}.relations.${g}`,l);}},kf=e=>{let t=[],r=Re(e),n=Se(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);zn(p,d,void 0,u.fields,l,i.enums,`mapDefaults.${o}.models.${l}`,t,true),Hn(u.fields,p,void 0,s,void 0,d,[],`mapDefaults.${o}.models.${l}`,t);}a.enums&&Sf(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);Jn(e.root,s,e,n,r.maps,o,a,"root",t);}}if(e.root?.where!==void 0){let o=Dt(e.root.where,e);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 Yn=()=>({picks:null,omits:new Set,enumPicks:new Map,enumOmits:new Map}),Xn=(e,t)=>{_t(e,t),Ft(e.enumPicks,e.enumOmits,t);},Zn=(e,t,r,n,o,a,i)=>{let s=`${t}::${n}`,l=a.get(s);l||(l=Yn(),a.set(s,l),i.set(s,{mapName:t,modelName:r})),Xn(l,o);let p=e.maps[t]?.models[r];if(p)for(let[u,d]of Object.entries(o.relations??{})){let m=p.fields[u];if(!m)continue;let c=U(m,t);c&&Zn(e,c.mapName,c.modelName,`${n}.${u}`,d,a,i);}},Tf=(e,t,r)=>{let n=e;if(t){let o=new Set(t);n=n.filter(a=>o.has(a));}if(r){let o=new Set(r);n=n.filter(a=>!o.has(a));}return n},Jn=(e,t)=>!(e.omits.has(t)||e.picks!==null&&!e.picks.has(t)),Qn=(e,t,r)=>{let n=e.enumPicks.get(t);return !(e.enumOmits.get(t)?.has(r)||n&&!n.has(r))},_f=e=>{let t=Re(e),r={maps:structuredClone(t.maps),bridges:t.bridges?structuredClone(t.bridges):void 0},n=Se(e),o=new Map,a=new Map;for(let l of n)l.root&&Zn(r,t.mapName,t.model,t.model,l.root,o,a);let i=new Map;for(let l of n)for(let[p,u]of Object.entries(l.mapDefaults??{})){let d=r.maps[p];if(d){for(let[m,c]of Object.entries(u.models??{})){let y=`${p}::${m}`,h=i.get(y);h||(h=Yn(),i.set(y,h)),Xn(h,c);}if(d.enums)for(let[m,c]of Object.entries(u.enums??{})){let y=d.enums[m];y&&(d.enums={...d.enums,[m]:Tf(y,c.picks,c.omits)});}}}let s=new Map;for(let[l,p]of o){let u=a.get(l);if(!u)continue;let d=`${u.mapName}::${u.modelName}`,m=s.get(d)??[];m.push(p),s.set(d,m);}for(let[l,p]of Object.entries(r.maps))for(let[u,d]of Object.entries(p.models)){let m=`${l}::${u}`,c=s.get(m),y=i.get(m);if(!c&&!y)continue;for(let g of Object.keys(d.fields)){let O=c?c.some(v=>Jn(v,g)):true,S=y?Jn(y,g):true;(!O||!S)&&delete d.fields[g];}let h=new Set;for(let g of c??[]){for(let O of g.enumPicks.keys())h.add(O);for(let O of g.enumOmits.keys())h.add(O);}if(y){for(let g of y.enumPicks.keys())h.add(g);for(let g of y.enumOmits.keys())h.add(g);}for(let g of h){let O=d.fields[g];if(!O||O.kind!=="enum")continue;let S=O.values??p.enums?.[O.type];S&&(O.values=S.filter(v=>{let R=c?c.some(oe=>Qn(oe,g,v)):true,A=y?Qn(y,g,v):true;return R&&A}));}}return r.bridges&&(r.bridges=r.bridges.filter(l=>{let[p,u]=l.endpoints,d=r.maps[p.fieldMap]?.models[p.model]?.fields[`${u.fieldMap}:${u.model}`]!==void 0,m=r.maps[u.fieldMap]?.models[u.model]?.fields[`${p.fieldMap}:${p.model}`]!==void 0;return d&&m})),r};var Ff={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},Pf=["Int","Float","Decimal","BigInt"],Me=["String",...Pf,"DateTime"],ee=["String"],ut=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],eo=Object.values(Ff),Zh={check:"check",toPrisma:"toPrisma",toSql:"toSql"},M=["check","toPrisma","toSql"],Te=["check","toPrisma"],pt=["check","toSql"],ew={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},L={[f.equals]:{kinds:ut,targets:M,valueShape:"scalar"},[f.notEquals]:{kinds:ut,targets:M,valueShape:"scalar"},[f.lessThan]:{kinds:Me,targets:M,valueShape:"ordered"},[f.lessThanEquals]:{kinds:Me,targets:M,valueShape:"ordered"},[f.greaterThan]:{kinds:Me,targets:M,valueShape:"ordered"},[f.greaterThanEquals]:{kinds:Me,targets:M,valueShape:"ordered"},[f.in]:{kinds:ut,targets:M,valueShape:"array"},[f.notIn]:{kinds:ut,targets:M,valueShape:"array"},[f.contains]:{kinds:ee,targets:M,valueShape:"string"},[f.notContains]:{kinds:ee,targets:M,valueShape:"string"},[f.startsWith]:{kinds:ee,targets:M,valueShape:"string"},[f.endsWith]:{kinds:ee,targets:M,valueShape:"string"},[f.matches]:{kinds:ee,targets:pt,valueShape:"pattern"},[f.notMatches]:{kinds:ee,targets:pt,valueShape:"pattern"},[f.between]:{kinds:Me,targets:M,valueShape:"range"},[f.notBetween]:{kinds:Me,targets:M,valueShape:"range"},[f.isEmpty]:{kinds:ee,targets:M,valueShape:"none"},[f.notEmpty]:{kinds:ee,targets:M,valueShape:"none"},[f.exists]:{kinds:eo,targets:M,valueShape:"none"},[f.notExists]:{kinds:eo,targets:M,valueShape:"none"}},te={[x.before]:{kinds:["DateTime"],targets:M,valueShape:"dateValue"},[x.after]:{kinds:["DateTime"],targets:M,valueShape:"dateValue"},[x.onOrBefore]:{kinds:["DateTime"],targets:M,valueShape:"dateValue"},[x.onOrAfter]:{kinds:["DateTime"],targets:M,valueShape:"dateValue"},[x.between]:{kinds:["DateTime"],targets:M,valueShape:"dateRange"},[x.notBetween]:{kinds:["DateTime"],targets:M,valueShape:"dateRange"},[x.dayIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"},[x.dayNotIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"}},re={[w.all]:{targets:Te,valueShape:"predicate"},[w.any]:{targets:Te,valueShape:"predicate"},[w.none]:{targets:Te,valueShape:"predicate"},[w.atLeast]:{targets:Te,valueShape:"count"},[w.atMost]:{targets:Te,valueShape:"count"},[w.exactly]:{targets:Te,valueShape:"count"},[w.empty]:{targets:M,valueShape:"none"},[w.notEmpty]:{targets:M,valueShape:"none"}},Cf=new Set(["scalar","ordered"]),Df=new Set(["range"]),tw=[f.equals,f.notEquals,f.lessThan,f.lessThanEquals,f.greaterThan,f.greaterThanEquals,f.between,f.notBetween],to=e=>{let t=L[e];return t?Cf.has(t.valueShape):false},ro=e=>{let t=L[e];return t?Df.has(t.valueShape):false},Dt=e=>{if(Object.hasOwn(L,e))return L[e].valueShape;if(Object.hasOwn(te,e))return te[e].valueShape;if(Object.hasOwn(re,e))return re[e].valueShape;throw new Error(`Unknown operator: ${e}`)},dt=(e,t)=>Object.hasOwn(L,e)?L[e].targets.includes(t):Object.hasOwn(te,e)?te[e].targets.includes(t):Object.hasOwn(re,e)?re[e].targets.includes(t):false,rw=(e,t)=>{let r=Object.keys(L).filter(o=>{let a=L[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))}),n=Object.keys(te).filter(o=>{let a=te[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))});return {field:r,date:n}},nw=e=>Object.keys(re).filter(t=>e?re[t].targets.includes(e):true);var mt=(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 I=(e,t)=>{let r=e.split("."),n=t;for(let o=r.length-1;o>=0;o--)n={[r[o]]:n};return n};var no,oo=e=>{no=e;},ao=(e,t,r)=>{if(!t?.map||!t?.model||!r)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return Nf(e,t,r)},Bf=(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.`)},Nf=(e,t,r)=>{let{map:n,model:o}=t,{intermediateRelations:a,terminalModel:i,terminalEntry:s}=Bf(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 v=mt(n,l,i,s.relationName);if(!v)throw new Error(`Cannot determine FK relationship between '${i}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((v.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");d=v.fromFields?.[0]??"",m=v.toFields?.[0]??"";}let c=e.condition?no(e.condition,{...t,model:l},r):{},y=e.aggregate.mode==="sum"?"_sum":"_avg",h={[p]:{[y]:qf(e)}},g={operation:"groupBy",model:l,args:{by:[d],where:c,having:h},extract:d},O=r.steps.length;r.steps.push(g);let S={__step:O};if(a.length>0){let v={[m]:{in:S}},R=a.map(A=>A.fieldName).join(".");return I(R,v)}return {[m]:{in:S}}},qf=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 io=(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=mt(o,s,a,i.relationName);if(!g){let S=Object.values(o.models[s]?.fields??{}).some(v=>v.kind==="object"&&v.type===a&&v.isList&&!v.fromFields?.length);throw new Error(S?`'${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=Lf(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}}},Lf=(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 Ne,so=e=>{Ne=e;},lo=(e,t,r)=>{if(e.arrayOperator===w.atLeast||e.arrayOperator===w.atMost||e.arrayOperator===w.exactly){if(t?.map&&t?.model&&r)return io(e,t,r,Ne);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=Vf(e,t,r);return I(e.field,n)},If=(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},jf=(e,t)=>{if(!t?.map||!t?.model||!e.field)return t;let r=If(e.field,t.map,t.model);return r?{...t,model:r}:t},Vf=(e,t,r)=>{let n=jf(e,t);switch(e.arrayOperator){case w.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:Ne(e.condition,n,r)};case w.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:Ne(e.condition,n,r)};case w.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:Ne(e.condition,n,r)};case w.empty:return {none:{}};case w.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var po=(e,t)=>{let r=Uf(e,t);return I(e.field,r)},Wf=(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 k(t.context,e.path)}},Uf=(e,t)=>{let r=()=>Wf(e,t);switch(e.dateOperator){case x.before:return {lt:r()};case x.after:return {gt:r()};case x.onOrBefore:return {lte:r()};case x.onOrAfter:return {gte:r()};case x.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between date operator requires an array of two values");let[o,a]=fo(n);return {gte:o,lte:a}}case x.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween date operator requires an array of two values");let[o,a]=fo(n);return {NOT:{gte:o,lte:a}}}case x.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case x.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},fo=e=>{let[t,r]=e;return Gf(t,r)<=0?[t,r]:[r,t]},Gf=(e,t)=>{let r=uo(e),n=uo(t);return r<n?-1:r>n?1:0},uo=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var ct=(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 mo=(e,t)=>{if(e.operator===f.isEmpty)return {OR:[qe(e.field,{equals:null},t),qe(e.field,{equals:""},t)]};if(e.operator===f.notEmpty)return {AND:[qe(e.field,{not:null},t),qe(e.field,{not:""},t)]};let r=zf(e,t);return qe(e.field,r,t)},Kf=(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 k(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},zf=(e,t)=>{let r=()=>Kf(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}`)}},qe=(e,t,r)=>{if(!r?.map||!r?.model)return I(e,t);let n=ct(e,r.map,r.model),o=e.split(".");switch(n.kind){case "fallback":case "direct":return I(e,t);case "bridge":return {};case "json-path":{let a={path:n.jsonPath,...t},i=o.slice(0,n.stopIndex).join(".");return I(i,a)}}};var _e,go=e=>{_e=e;},Hf=(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},G=(e,t)=>{if(typeof e=="boolean"||!t?.map||!t?.model)return false;if("all"in e)return e.all.some(r=>G(r,t));if("any"in e)return e.any.some(r=>G(r,t));if("if"in e)return G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(ct(e.field,t.map,t.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let n=Hf(e.field,t.map,t.model);if(n&&G(e.condition,{...t,model:n}))return true}}return false},yo=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(n=>_e(n,t,r))},ho=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>_e(n,t,r))},wo=(e,t,r)=>{if(G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t))return {};let n=_e(e.if,t,r),o={NOT:n},a=e.then===false?co:_e(e.then,t,r);if(e.else!==void 0){let i=e.else===false?co:_e(e.else,t,r);return {AND:[{OR:[o,a]},{OR:[n,i]}]}}return {OR:[o,a]}},co={AND:[{id:null},{id:{not:null}}]};var Le=(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 yo(e,t,r);if("any"in e)return ho(e,t,r);if("if"in e)return wo(e,t,r);if("arrayOperator"in e)return lo(e,t,r);if("dateOperator"in e)return po(e,t);if("aggregate"in e)return ao(e,t,r);if("field"in e)return mo(e,t);throw new Error("Unknown condition type")};go(Le);so(Le);oo(Le);var Jf=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 Bt(n.where,o)},Bt=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>Bt(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]=Bt(a,t);return n}return e};var Qf=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}},qw=(e,t)=>{let r={steps:[]},n=Le(e,Qf(t),r);return {steps:[...r.steps,{operation:"where",where:n}]}};var E=e=>`"${e.replace(/"/g,'""')}"`;var $=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var Ie=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),P=e=>{let t=e.split(".");if(t.length===1)return E(e);let[r,...n]=t;return n.length===0?E(r):bo(E(r),n)},xo=(e,t)=>{let r=e.split(".");if(r.length===1)return `${E(t)}.${E(e)}`;let[n,...o]=r;return bo(`${E(t)}.${E(n)}`,o)},Nt=e=>`'${e.replace(/'/g,"''")}'`,bo=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(Nt).join("->"),n=Nt(t[t.length-1]);return r?`${e}->${r}->>${n}`:`${e}->>${n}`},Oo=e=>{let t=e.split(".");if(t.length===1)return E(e);let[r,...n]=t;return n.length===0?E(r):Yf(E(r),n)},Yf=(e,t)=>{let r=t.map(Nt).join("->");return `${e}->${r}`};var $o=(e,t)=>{if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let r=Xf(e,t);return eu(r,e,t)},Xf=(e,t)=>{let r=Oo(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)`},Zf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${E(t.currentAlias)}.${E(r)}`:P(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:k(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},eu=(e,t,r)=>{let n=Zf(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} = ${$(r,o)}`;case f.notEquals:return a?`${e} <> ${a}`:o===null?`${e} IS NOT NULL`:`${e} <> ${$(r,o)}`;case f.lessThan:return a?`${e} < ${a}`:`${e} < ${$(r,o)}`;case f.lessThanEquals:return a?`${e} <= ${a}`:`${e} <= ${$(r,o)}`;case f.greaterThan:return a?`${e} > ${a}`:`${e} > ${$(r,o)}`;case f.greaterThanEquals:return a?`${e} >= ${a}`:`${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 ${$(r,s)} AND ${$(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 ${$(r,s)} AND ${$(r,l)}`}default:throw new Error(`Operator '${t.operator}' is not supported for aggregate rules`)}};var Ao=(e,t)=>{if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let r=P(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 qt=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 gt=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return P(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 P(e);let s=i.fields[r[a]];if(!s)return P(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 P(e);d=`t${++m.n}`;let c=tu(t.map,n,o,s,d);if(!c)return P(e);t.joins?.push(c),t.joinRegistry?.set(p,d);}n=s.type,o=d;continue}let l=r.slice(a);return xo(l.join("."),o)}return P(e)},tu=(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)=>`${E(o)}.${E(n.toFields?.[p]??"")} = ${E(r)}.${E(l)}`).join(" AND ");else {let l=ru(e,a,t,n.relationName);if(!l)return null;s=(l.fromFields??[]).map((p,u)=>`${E(o)}.${E(p)} = ${E(r)}.${E(l.toFields?.[u]??"")}`).join(" AND ");}return `LEFT JOIN ${E(i)} AS ${E(o)} ON ${s}`},ru=(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 Ro=(e,t)=>{let r=gt(e.field,t),n=ou(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} < ${$(t,o)}`;case x.after:return a!==void 0?`${r} > ${a}`:`${r} > ${$(t,o)}`;case x.onOrBefore:return a!==void 0?`${r} <= ${a}`:`${r} <= ${$(t,o)}`;case x.onOrAfter:return a!==void 0?`${r} >= ${a}`:`${r} >= ${$(t,o)}`;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]=vo(i);return `${r} BETWEEN ${$(t,s)} AND ${$(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]=vo(i);return `${r} NOT BETWEEN ${$(t,s)} AND ${$(t,l)}`}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=qt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) = ANY(${$(t,i)})`}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let i=qt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) <> ALL(${$(t,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},vo=e=>{let[t,r]=e;return nu(t,r)<=0?[t,r]:[r,t]},nu=(e,t)=>{let r=Eo(e),n=Eo(t);return r<n?-1:r>n?1:0},Eo=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),ou=(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?`${E(t.currentAlias)}.${E(r)}`:P(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:k(t.context,e.path)}}return {type:"value",value:void 0}};var So=(e,t)=>{let r=gt(e.field,t),n=au(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} = ${$(t,o)}`;case f.notEquals:return a!==void 0?`${r} <> ${a}`:o===null?`${r} IS NOT NULL`:`${r} <> ${$(t,o)}`;case f.lessThan:return a!==void 0?`${r} < ${a}`:`${r} < ${$(t,o)}`;case f.lessThanEquals:return a!==void 0?`${r} <= ${a}`:`${r} <= ${$(t,o)}`;case f.greaterThan:return a!==void 0?`${r} > ${a}`:`${r} > ${$(t,o)}`;case f.greaterThanEquals:return a!==void 0?`${r} >= ${a}`:`${r} >= ${$(t,o)}`;case f.in:return !Array.isArray(o)||o.length===0?"FALSE":`${r} = ANY(${$(t,o)})`;case f.notIn:return !Array.isArray(o)||o.length===0?"TRUE":`${r} <> ALL(${$(t,o)})`;case f.contains:return `${r} LIKE ${$(t,`%${Ie(String(o))}%`)}`;case f.notContains:return `${r} NOT LIKE ${$(t,`%${Ie(String(o))}%`)}`;case f.startsWith:return `${r} LIKE ${$(t,`${Ie(String(o))}%`)}`;case f.endsWith:return `${r} LIKE ${$(t,`%${Ie(String(o))}`)}`;case f.matches:return `${r} ~ ${$(t,o)}`;case f.notMatches:return `${r} !~ ${$(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 ${$(t,s)} AND ${$(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 ${$(t,s)} AND ${$(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}`)}},au=(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?`${E(t.currentAlias)}.${E(r)}`:P(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:k(t.context,e.path)}}return {type:"value",value:void 0}};var Fe,ko=e=>{Fe=e;},iu=(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},su=(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},K=(e,t)=>{if(typeof e=="boolean"||!t.map||!t.currentModel)return false;if("all"in e)return e.all.some(r=>K(r,t));if("any"in e)return e.any.some(r=>K(r,t));if("if"in e)return K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(iu(e.field,t.map,t.currentModel))return true;if("condition"in e&&e.condition!==void 0){let r=su(e.field,t.map,t.currentModel);if(r&&K(e.condition,{...t,currentModel:r}))return true}}return false},Mo=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(n=>Fe(n,t)).join(" AND ")})`,To=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(n=>Fe(n,t)).join(" OR ")})`,_o=(e,t)=>{if(K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t))return "TRUE";let r=Fe(e.if,t),n=Fe(e.then,t);if(e.else!==void 0){let o=Fe(e.else,t);return `((NOT(${r}) OR ${n}) AND (${r} OR ${o}))`}return `(NOT(${r}) OR ${n})`};var lu=(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},Lt=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&t.map&&t.currentModel&&lu(e.field,t.map,t.currentModel))return "TRUE";if("all"in e)return Mo(e,t);if("any"in e)return To(e,t);if("if"in e)return _o(e,t);if("arrayOperator"in e)return Ao(e,t);if("dateOperator"in e)return Ro(e,t);if("aggregate"in e)return $o(e,t);if("field"in e)return So(e,t);throw new Error("Unknown condition type")};ko(Lt);var Sx=(e,t)=>{let r=!!(t?.map&&t?.model),n=t?.alias??(r?"t0":void 0),o={params:[],paramIndex:0,context:t?.context,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:Lt(e,o),params:o.params,joins:o.joins??[]}};var fu=new Set(Object.keys(L)),uu=new Set(Object.keys(re)),pu=new Set(Object.keys(te)),du=(e,t={})=>{let r={target:t.target??"check",errors:[]};return ne(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},_x=(e,t={})=>{let r=du(e,t);if(r.ok)return;let n=r.errors.map(o=>`${o.path}: ${o.message}`).join(`
5
+ `)}`)};var Yn=()=>({picks:null,omits:new Set,enumPicks:new Map,enumOmits:new Map}),Xn=(e,t)=>{_t(e,t),Pt(e.enumPicks,e.enumOmits,t);},Zn=(e,t,r,n,o)=>{let a=`${t}::${r}`,i=o.get(a);i||(i=Yn(),o.set(a,i)),Xn(i,n);let s=e.maps[t]?.models[r];if(s)for(let[l,p]of Object.entries(n.relations??{})){let u=s.fields[l];if(!u)continue;let d=q(u,t);d&&Zn(e,d.mapName,d.modelName,p,o);}},Qn=(e,t,r)=>{let n=e;if(t){let o=new Set(t);n=n.filter(a=>o.has(a));}if(r){let o=new Set(r);n=n.filter(a=>!o.has(a));}return n},Mf=e=>{let t=Re(e),r={maps:structuredClone(t.maps),bridges:t.bridges?structuredClone(t.bridges):void 0},n=Se(e),o=new Map;for(let a of n){for(let[i,s]of Object.entries(a.mapDefaults??{})){let l=r.maps[i];if(l){for(let[p,u]of Object.entries(s.models??{})){let d=`${i}::${p}`,m=o.get(d);m||(m=Yn(),o.set(d,m)),Xn(m,u);}if(l.enums)for(let[p,u]of Object.entries(s.enums??{})){let d=l.enums[p];d&&(l.enums={...l.enums,[p]:Qn(d,u.picks,u.omits)});}}}a.root&&Zn(r,t.mapName,t.model,a.root,o);}for(let[a,i]of o){let[s,l]=a.split("::"),p=r.maps[s]?.models[l];if(!p)continue;let u=p.fields,d=i.picks;for(let m of Object.keys(u)){let c=d===null||d.has(m),y=i.omits.has(m);(!c||y)&&delete u[m];}for(let[m,c]of Object.entries(u)){if(c.kind!=="enum")continue;let y=r.maps[s]?.enums?.[c.type],w=c.values??y,g=i.enumPicks.get(m),$=i.enumOmits.get(m);if(!w&&!g&&!$)continue;let E=Qn(w??[],g?Array.from(g):void 0,$?Array.from($):void 0);c.values=E;}}return r.bridges&&(r.bridges=r.bridges.filter(a=>{let[i,s]=a.endpoints,l=r.maps[i.fieldMap]?.models[i.model]?.fields[`${s.fieldMap}:${s.model}`]!==void 0,p=r.maps[s.fieldMap]?.models[s.model]?.fields[`${i.fieldMap}:${i.model}`]!==void 0;return l&&p})),r};var Tf=e=>{let t=ke(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=ee(t,o,a,i),u={};for(let[d,m]of Object.entries(l.fields)){if(!Ft(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=q(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 _f={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},Pf=["Int","Float","Decimal","BigInt"],Me=["String",...Pf,"DateTime"],te=["String"],ut=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],eo=Object.values(_f),rw={check:"check",toPrisma:"toPrisma",toSql:"toSql"},k=["check","toPrisma","toSql"],Te=["check","toPrisma"],pt=["check","toSql"],nw={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},I={[f.equals]:{kinds:ut,targets:k,valueShape:"scalar"},[f.notEquals]:{kinds:ut,targets:k,valueShape:"scalar"},[f.lessThan]:{kinds:Me,targets:k,valueShape:"ordered"},[f.lessThanEquals]:{kinds:Me,targets:k,valueShape:"ordered"},[f.greaterThan]:{kinds:Me,targets:k,valueShape:"ordered"},[f.greaterThanEquals]:{kinds:Me,targets:k,valueShape:"ordered"},[f.in]:{kinds:ut,targets:k,valueShape:"array"},[f.notIn]:{kinds:ut,targets:k,valueShape:"array"},[f.contains]:{kinds:te,targets:k,valueShape:"string"},[f.notContains]:{kinds:te,targets:k,valueShape:"string"},[f.startsWith]:{kinds:te,targets:k,valueShape:"string"},[f.endsWith]:{kinds:te,targets:k,valueShape:"string"},[f.matches]:{kinds:te,targets:pt,valueShape:"pattern"},[f.notMatches]:{kinds:te,targets:pt,valueShape:"pattern"},[f.between]:{kinds:Me,targets:k,valueShape:"range"},[f.notBetween]:{kinds:Me,targets:k,valueShape:"range"},[f.isEmpty]:{kinds:te,targets:k,valueShape:"none"},[f.notEmpty]:{kinds:te,targets:k,valueShape:"none"},[f.exists]:{kinds:eo,targets:k,valueShape:"none"},[f.notExists]:{kinds:eo,targets:k,valueShape:"none"}},re={[x.before]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.after]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.onOrBefore]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.onOrAfter]:{kinds:["DateTime"],targets:k,valueShape:"dateValue"},[x.between]:{kinds:["DateTime"],targets:k,valueShape:"dateRange"},[x.notBetween]:{kinds:["DateTime"],targets:k,valueShape:"dateRange"},[x.dayIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"},[x.dayNotIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"}},ne={[h.all]:{targets:Te,valueShape:"predicate"},[h.any]:{targets:Te,valueShape:"predicate"},[h.none]:{targets:Te,valueShape:"predicate"},[h.atLeast]:{targets:Te,valueShape:"count"},[h.atMost]:{targets:Te,valueShape:"count"},[h.exactly]:{targets:Te,valueShape:"count"},[h.empty]:{targets:k,valueShape:"none"},[h.notEmpty]:{targets:k,valueShape:"none"}},Ff=new Set(["scalar","ordered"]),Cf=new Set(["range"]),ow=[f.equals,f.notEquals,f.lessThan,f.lessThanEquals,f.greaterThan,f.greaterThanEquals,f.between,f.notBetween],to=e=>{let t=I[e];return t?Ff.has(t.valueShape):false},ro=e=>{let t=I[e];return t?Cf.has(t.valueShape):false},Bt=e=>{if(Object.hasOwn(I,e))return I[e].valueShape;if(Object.hasOwn(re,e))return re[e].valueShape;if(Object.hasOwn(ne,e))return ne[e].valueShape;throw new Error(`Unknown operator: ${e}`)},dt=(e,t)=>Object.hasOwn(I,e)?I[e].targets.includes(t):Object.hasOwn(re,e)?re[e].targets.includes(t):Object.hasOwn(ne,e)?ne[e].targets.includes(t):false,aw=(e,t)=>{let r=Object.keys(I).filter(o=>{let a=I[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))}),n=Object.keys(re).filter(o=>{let a=re[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))});return {field:r,date:n}},iw=e=>Object.keys(ne).filter(t=>e?ne[t].targets.includes(e):true);var mt=(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 j=(e,t)=>{let r=e.split("."),n=t;for(let o=r.length-1;o>=0;o--)n={[r[o]]:n};return n};var no,oo=e=>{no=e;},ao=(e,t,r)=>{if(!t?.map||!t?.model||!r)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return Bf(e,t,r)},Df=(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.`)},Bf=(e,t,r)=>{let{map:n,model:o}=t,{intermediateRelations:a,terminalModel:i,terminalEntry:s}=Df(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 E=mt(n,l,i,s.relationName);if(!E)throw new Error(`Cannot determine FK relationship between '${i}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((E.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");d=E.fromFields?.[0]??"",m=E.toFields?.[0]??"";}let c=e.condition?no(e.condition,{...t,model:l},r):{},y=e.aggregate.mode==="sum"?"_sum":"_avg",w={[p]:{[y]:Nf(e)}},g={operation:"groupBy",model:l,args:{by:[d],where:c,having:w},extract:d},$=r.steps.length;r.steps.push(g);let M={__step:$};if(a.length>0){let E={[m]:{in:M}},R=a.map(A=>A.fieldName).join(".");return j(R,E)}return {[m]:{in:M}}},Nf=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 io=(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=mt(o,s,a,i.relationName);if(!g){let M=Object.values(o.models[s]?.fields??{}).some(E=>E.kind==="object"&&E.type===a&&E.isList&&!E.fromFields?.length);throw new Error(M?`'${a}.${e.field}' is an implicit many-to-many relation. Count operators require an explicit join model with a FK \u2014 convert to an explicit @relation or use prisma.$queryRaw.`:`Cannot determine FK relationship between '${a}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`)}if((g.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=g.fromFields?.[0]??"",p=g.toFields?.[0]??"";}let u=e.condition?n(e.condition,{...t,model:s},r):{},d=e.count??1,m=Lf(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 w={__step:y};return {[p]:{in:w}}},Lf=(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 Le,so=e=>{Le=e;},lo=(e,t,r)=>{if(e.arrayOperator===h.atLeast||e.arrayOperator===h.atMost||e.arrayOperator===h.exactly){if(t?.map&&t?.model&&r)return io(e,t,r,Le);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=jf(e,t,r);return j(e.field,n)},qf=(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},If=(e,t)=>{if(!t?.map||!t?.model||!e.field)return t;let r=qf(e.field,t.map,t.model);return r?{...t,model:r}:t},jf=(e,t,r)=>{let n=If(e,t);switch(e.arrayOperator){case h.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:Le(e.condition,n,r)};case h.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:Le(e.condition,n,r)};case h.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:Le(e.condition,n,r)};case h.empty:return {none:{}};case h.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var po=(e,t)=>{let r=Wf(e,t);return j(e.field,r)},Vf=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column date comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve date path '${e.path}'. Pass context when calling toPrisma().`);return S(t.context,e.path)}},Wf=(e,t)=>{let r=()=>Vf(e,t);switch(e.dateOperator){case x.before:return {lt:r()};case x.after:return {gt:r()};case x.onOrBefore:return {lte:r()};case x.onOrAfter:return {gte:r()};case x.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between date operator requires an array of two values");let[o,a]=fo(n);return {gte:o,lte:a}}case x.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween date operator requires an array of two values");let[o,a]=fo(n);return {NOT:{gte:o,lte:a}}}case x.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case x.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},fo=e=>{let[t,r]=e;return Uf(t,r)<=0?[t,r]:[r,t]},Uf=(e,t)=>{let r=uo(e),n=uo(t);return r<n?-1:r>n?1:0},uo=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var ct=(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 mo=(e,t)=>{if(e.operator===f.isEmpty)return {OR:[qe(e.field,{equals:null},t),qe(e.field,{equals:""},t)]};if(e.operator===f.notEmpty)return {AND:[qe(e.field,{not:null},t),qe(e.field,{not:""},t)]};let r=Kf(e,t);return qe(e.field,r,t)},Gf=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve path '${e.path}'. Pass context when calling toPrisma().`);return S(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},Kf=(e,t)=>{let r=()=>Gf(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}`)}},qe=(e,t,r)=>{if(!r?.map||!r?.model)return j(e,t);let n=ct(e,r.map,r.model),o=e.split(".");switch(n.kind){case "fallback":case "direct":return j(e,t);case "bridge":return {};case "json-path":{let a={path:n.jsonPath,...t},i=o.slice(0,n.stopIndex).join(".");return j(i,a)}}};var _e,go=e=>{_e=e;},zf=(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},G=(e,t)=>{if(typeof e=="boolean"||!t?.map||!t?.model)return false;if("all"in e)return e.all.some(r=>G(r,t));if("any"in e)return e.any.some(r=>G(r,t));if("if"in e)return G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(ct(e.field,t.map,t.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let n=zf(e.field,t.map,t.model);if(n&&G(e.condition,{...t,model:n}))return true}}return false},yo=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(n=>_e(n,t,r))},ho=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>_e(n,t,r))},wo=(e,t,r)=>{if(G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t))return {};let n=_e(e.if,t,r),o={NOT:n},a=e.then===false?co:_e(e.then,t,r);if(e.else!==void 0){let i=e.else===false?co:_e(e.else,t,r);return {AND:[{OR:[o,a]},{OR:[n,i]}]}}return {OR:[o,a]}},co={AND:[{id:null},{id:{not:null}}]};var Ie=(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 yo(e,t,r);if("any"in e)return ho(e,t,r);if("if"in e)return wo(e,t,r);if("arrayOperator"in e)return lo(e,t,r);if("dateOperator"in e)return po(e,t);if("aggregate"in e)return ao(e,t,r);if("field"in e)return mo(e,t);throw new Error("Unknown condition type")};go(Ie);so(Ie);oo(Ie);var Hf=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 Nt(n.where,o)},Nt=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>Nt(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]=Nt(a,t);return n}return e};var Jf=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}},jw=(e,t)=>{let r={steps:[]},n=Ie(e,Jf(t),r);return {steps:[...r.steps,{operation:"where",where:n}]}};var v=e=>`"${e.replace(/"/g,'""')}"`;var O=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var je=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),F=e=>{let t=e.split(".");if(t.length===1)return v(e);let[r,...n]=t;return n.length===0?v(r):bo(v(r),n)},xo=(e,t)=>{let r=e.split(".");if(r.length===1)return `${v(t)}.${v(e)}`;let[n,...o]=r;return bo(`${v(t)}.${v(n)}`,o)},Lt=e=>`'${e.replace(/'/g,"''")}'`,bo=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(Lt).join("->"),n=Lt(t[t.length-1]);return r?`${e}->${r}->>${n}`:`${e}->>${n}`},Oo=e=>{let t=e.split(".");if(t.length===1)return v(e);let[r,...n]=t;return n.length===0?v(r):Qf(v(r),n)},Qf=(e,t)=>{let r=t.map(Lt).join("->");return `${e}->${r}`};var $o=(e,t)=>{if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let r=Yf(e,t);return Zf(r,e,t)},Yf=(e,t)=>{let r=Oo(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)`},Xf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${v(t.currentAlias)}.${v(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:S(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},Zf=(e,t,r)=>{let n=Xf(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 Ao=(e,t)=>{if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let r=F(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 qt=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 gt=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return F(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 F(e);let s=i.fields[r[a]];if(!s)return F(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 F(e);d=`t${++m.n}`;let c=eu(t.map,n,o,s,d);if(!c)return F(e);t.joins?.push(c),t.joinRegistry?.set(p,d);}n=s.type,o=d;continue}let l=r.slice(a);return xo(l.join("."),o)}return F(e)},eu=(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)=>`${v(o)}.${v(n.toFields?.[p]??"")} = ${v(r)}.${v(l)}`).join(" AND ");else {let l=tu(e,a,t,n.relationName);if(!l)return null;s=(l.fromFields??[]).map((p,u)=>`${v(o)}.${v(p)} = ${v(r)}.${v(l.toFields?.[u]??"")}`).join(" AND ");}return `LEFT JOIN ${v(i)} AS ${v(o)} ON ${s}`},tu=(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 Ro=(e,t)=>{let r=gt(e.field,t),n=nu(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.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]=vo(i);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]=vo(i);return `${r} NOT BETWEEN ${O(t,s)} AND ${O(t,l)}`}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=qt(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=qt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) <> ALL(${O(t,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},vo=e=>{let[t,r]=e;return ru(t,r)<=0?[t,r]:[r,t]},ru=(e,t)=>{let r=Eo(e),n=Eo(t);return r<n?-1:r>n?1:0},Eo=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),nu=(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?`${v(t.currentAlias)}.${v(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve date path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:S(t.context,e.path)}}return {type:"value",value:void 0}};var So=(e,t)=>{let r=gt(e.field,t),n=ou(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,`%${je(String(o))}%`)}`;case f.notContains:return `${r} NOT LIKE ${O(t,`%${je(String(o))}%`)}`;case f.startsWith:return `${r} LIKE ${O(t,`${je(String(o))}%`)}`;case f.endsWith:return `${r} LIKE ${O(t,`%${je(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}`)}},ou=(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?`${v(t.currentAlias)}.${v(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:S(t.context,e.path)}}return {type:"value",value:void 0}};var Pe,ko=e=>{Pe=e;},au=(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},iu=(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},K=(e,t)=>{if(typeof e=="boolean"||!t.map||!t.currentModel)return false;if("all"in e)return e.all.some(r=>K(r,t));if("any"in e)return e.any.some(r=>K(r,t));if("if"in e)return K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(au(e.field,t.map,t.currentModel))return true;if("condition"in e&&e.condition!==void 0){let r=iu(e.field,t.map,t.currentModel);if(r&&K(e.condition,{...t,currentModel:r}))return true}}return false},Mo=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(n=>Pe(n,t)).join(" AND ")})`,To=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(n=>Pe(n,t)).join(" OR ")})`,_o=(e,t)=>{if(K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t))return "TRUE";let r=Pe(e.if,t),n=Pe(e.then,t);if(e.else!==void 0){let o=Pe(e.else,t);return `((NOT(${r}) OR ${n}) AND (${r} OR ${o}))`}return `(NOT(${r}) OR ${n})`};var su=(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},It=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&t.map&&t.currentModel&&su(e.field,t.map,t.currentModel))return "TRUE";if("all"in e)return Mo(e,t);if("any"in e)return To(e,t);if("if"in e)return _o(e,t);if("arrayOperator"in e)return Ao(e,t);if("dateOperator"in e)return Ro(e,t);if("aggregate"in e)return $o(e,t);if("field"in e)return So(e,t);throw new Error("Unknown condition type")};ko(It);var Tx=(e,t)=>{let r=!!(t?.map&&t?.model),n=t?.alias??(r?"t0":void 0),o={params:[],paramIndex:0,context:t?.context,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:It(e,o),params:o.params,joins:o.joins??[]}};var lu=new Set(Object.keys(I)),fu=new Set(Object.keys(ne)),uu=new Set(Object.keys(re)),pu=(e,t={})=>{let r={target:t.target??"check",errors:[]};return oe(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},Cx=(e,t={})=>{let r=pu(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}`)},ne=(e,t,r)=>{if(typeof e=="boolean"){r.target==="toPrisma"&&e===false&&b(r,t,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!Po(e)){b(r,t,"invalid_condition","Condition must be a boolean or object");return}let n=mu(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":Fo(e.all,`${t}.all`,r);break;case "any":Fo(e.any,`${t}.any`,r);break;case "if":ne(e.if,`${t}.if`,r),ne(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&ne(e.else,`${t}.else`,r);break;case "field":cu(e,t,r);break;case "aggregate":yu(e,t,r);break;case "array":hu(e,t,r);break;case "date":wu(e,t,r);break}},mu=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]},Fo=(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)=>{ne(n,`${t}[${o}]`,r);});},cu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!fu.has(e.operator)){b(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;dt(n,r.target)||b(r,`${t}.operator`,`unsupported_${Wt(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=Dt(n);if(o==="none"){xu(e,t,r);return}Vt(e,t,r)&&("path"in e&&typeof e.path=="string"||gu(o,e.value,n,`${t}.value`,r));},gu=(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":It(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":bu(t)||b(o,n,"invalid_range_value",`Operator '${r}' requires a two-item range`);return}},yu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!Po(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"&&to(e.operator),a=typeof e.operator=="string"&&ro(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()"),ne(e.condition,`${t}.condition`,r)),!Vt(e,t,r)||"path"in e&&typeof e.path=="string")return;let i=e.value;a?Ou(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");},hu=(e,t,r)=>{if(typeof e.field!="string"&&r.target!=="check"&&b(r,`${t}.field`,"field_required","Array rule requires a string field for this target"),typeof e.arrayOperator!="string"||!uu.has(e.arrayOperator)){b(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(dt(n,r.target)||b(r,`${t}.arrayOperator`,`unsupported_${Wt(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`):ne(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&&ne(e.condition,`${t}.condition`,r);break}},wu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!pu.has(e.dateOperator)){b(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;dt(n,r.target)||b(r,`${t}.dateOperator`,`unsupported_${Wt(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=Dt(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(Vt(e,t,r)&&!("path"in e&&typeof e.path=="string")){if(o==="dateRange"){$u(e.value)||b(r,`${t}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return}jt(e.value)||b(r,`${t}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},Vt=(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},xu=(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");},Wt=e=>e==="toPrisma"?"prisma":e==="toSql"?"sql":"check",Po=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),It=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,bu=e=>Array.isArray(e)&&e.length===2&&It(e[0])&&It(e[1]),Ou=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",jt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,$u=e=>Array.isArray(e)&&e.length===2&&jt(e[0])&&jt(e[1]),b=(e,t,r,n)=>{e.errors.push({path:t,code:r,message:n});};/*! Bundled license information:
7
+ ${n}`)},oe=(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(!Fo(e)){b(r,t,"invalid_condition","Condition must be a boolean or object");return}let n=du(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":Po(e.all,`${t}.all`,r);break;case "any":Po(e.any,`${t}.any`,r);break;case "if":oe(e.if,`${t}.if`,r),oe(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&oe(e.else,`${t}.else`,r);break;case "field":mu(e,t,r);break;case "aggregate":gu(e,t,r);break;case "array":yu(e,t,r);break;case "date":hu(e,t,r);break}},du=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]},Po=(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)=>{oe(n,`${t}[${o}]`,r);});},mu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!lu.has(e.operator)){b(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;dt(n,r.target)||b(r,`${t}.operator`,`unsupported_${Ut(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=Bt(n);if(o==="none"){wu(e,t,r);return}Wt(e,t,r)&&("path"in e&&typeof e.path=="string"||cu(o,e.value,n,`${t}.value`,r));},cu=(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":jt(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":xu(t)||b(o,n,"invalid_range_value",`Operator '${r}' requires a two-item range`);return}},gu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!Fo(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"&&to(e.operator),a=typeof e.operator=="string"&&ro(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()"),oe(e.condition,`${t}.condition`,r)),!Wt(e,t,r)||"path"in e&&typeof e.path=="string")return;let i=e.value;a?bu(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");},yu=(e,t,r)=>{if(typeof e.field!="string"&&r.target!=="check"&&b(r,`${t}.field`,"field_required","Array rule requires a string field for this target"),typeof e.arrayOperator!="string"||!fu.has(e.arrayOperator)){b(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(dt(n,r.target)||b(r,`${t}.arrayOperator`,`unsupported_${Ut(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`):oe(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&&oe(e.condition,`${t}.condition`,r);break}},hu=(e,t,r)=>{if(typeof e.field!="string"&&b(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!uu.has(e.dateOperator)){b(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;dt(n,r.target)||b(r,`${t}.dateOperator`,`unsupported_${Ut(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=Bt(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(Wt(e,t,r)&&!("path"in e&&typeof e.path=="string")){if(o==="dateRange"){Ou(e.value)||b(r,`${t}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return}Vt(e.value)||b(r,`${t}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},Wt=(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},wu=(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");},Ut=e=>e==="toPrisma"?"prisma":e==="toSql"?"sql":"check",Fo=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),jt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,xu=e=>Array.isArray(e)&&e.length===2&&jt(e[0])&&jt(e[1]),bu=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",Vt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ou=e=>Array.isArray(e)&&e.length===2&&Vt(e[0])&&Vt(e[1]),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{tw as AGGREGATE_OPERATORS,eo as ALL_KINDS,re as ARRAY_OPERATOR_CATALOG,w as ArrayOperator,te as DATE_OPERATOR_CATALOG,x as DateOperator,ut as EQUATABLE_KINDS,L as FIELD_OPERATOR_CATALOG,Ff as FieldKind,Pf as NUMERIC_KINDS,Me as ORDERABLE_KINDS,f as Operator,Zh as RuleTarget,ee as STRINGY_KINDS,ew as ValueShape,vf as applyLens,_x as assertValidRule,pf as buildBridgeDictionary,le as check,Ct as checkRuleAgainstLens,Rf as createLens,Jf as executePrismaQueryPlan,nw as getArrayOperators,rw as getOperatorsForKind,Dt as getValueShape,ro as isAggregateRangeOperator,to as isAggregateSingleOperator,dt as isOperatorSupportedForTarget,_f as projectNarrowing,Tt as stitchFieldMaps,qw as toPrisma,Sx as toSql,mf as validateFieldMap,In as validateFieldMapSet,Mf as validateNarrowing,du as validateRule};//# sourceMappingURL=index.js.map
19
+ */export{ow as AGGREGATE_OPERATORS,eo as ALL_KINDS,ne as ARRAY_OPERATOR_CATALOG,h as ArrayOperator,re as DATE_OPERATOR_CATALOG,x as DateOperator,ut as EQUATABLE_KINDS,I as FIELD_OPERATOR_CATALOG,_f as FieldKind,Pf as NUMERIC_KINDS,Me as ORDERABLE_KINDS,f as Operator,rw as RuleTarget,te as STRINGY_KINDS,nw as ValueShape,Af as applyLens,Cx as assertValidRule,pf as buildBridgeDictionary,le as check,Dt as checkRuleAgainstLens,Ef as createLens,Hf as executePrismaQueryPlan,iw as getArrayOperators,aw as getOperatorsForKind,Bt as getValueShape,ro as isAggregateRangeOperator,to as isAggregateSingleOperator,dt as isOperatorSupportedForTarget,Tf as projectByPath,Mf as projectNarrowing,Tt as stitchFieldMaps,jw as toPrisma,Tx as toSql,mf as validateFieldMap,jn as validateFieldMapSet,kf as validateNarrowing,pu as validateRule};//# sourceMappingURL=index.js.map
20
20
  //# sourceMappingURL=index.js.map