@directive-run/core 0.4.0 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/testing.js CHANGED
@@ -1,4 +1,4 @@
1
- async function Te(r,n,g){let p,i=new Promise((t,f)=>{p=setTimeout(()=>f(new Error(g)),n);});try{return await Promise.race([r,i])}finally{clearTimeout(p);}}function $e(r,n=50){let g=new WeakSet;function p(i,t){if(t>n)return '"[max depth exceeded]"';if(i===null)return "null";if(i===void 0)return "undefined";let f=typeof i;if(f==="string")return JSON.stringify(i);if(f==="number"||f==="boolean")return String(i);if(f==="function")return '"[function]"';if(f==="symbol")return '"[symbol]"';if(Array.isArray(i)){if(g.has(i))return '"[circular]"';g.add(i);let R=`[${i.map(D=>p(D,t+1)).join(",")}]`;return g.delete(i),R}if(f==="object"){let R=i;if(g.has(R))return '"[circular]"';g.add(R);let u=`{${Object.keys(R).sort().map(E=>`${JSON.stringify(E)}:${p(R[E],t+1)}`).join(",")}}`;return g.delete(R),u}return '"[unknown]"'}return p(r,0)}function Re(r,n=50){let g=new Set(["__proto__","constructor","prototype"]),p=new WeakSet;function i(t,f){if(f>n)return false;if(t==null||typeof t!="object")return true;let R=t;if(p.has(R))return true;if(p.add(R),Array.isArray(R)){for(let D of R)if(!i(D,f+1))return p.delete(R),false;return p.delete(R),true}for(let D of Object.keys(R))if(g.has(D)||!i(R[D],f+1))return p.delete(R),false;return p.delete(R),true}return i(r,0)}function Pe(r){let n=$e(r),g=5381;for(let p=0;p<n.length;p++)g=(g<<5)+g^n.charCodeAt(p);return (g>>>0).toString(16)}function je(r){let{config:n,facts:g,store:p,onSnapshot:i,onTimeTravel:t}=r,f=n.timeTravel??false,R=n.maxSnapshots??100,D=[],w=-1,u=1,E=false,v=false,x=[],q=null,W=-1;function z(){return p.toObject()}function C(){let B=z();return structuredClone(B)}function M(B){if(!Re(B)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}p.batch(()=>{for(let[s,k]of Object.entries(B)){if(s==="__proto__"||s==="constructor"||s==="prototype"){console.warn(`[Directive] Skipping dangerous key "${s}" during fact restoration`);continue}g[s]=k;}});}return {get isEnabled(){return f},get isRestoring(){return v},get isPaused(){return E},get snapshots(){return [...D]},get currentIndex(){return w},takeSnapshot(B){if(!f||E)return {id:-1,timestamp:Date.now(),facts:{},trigger:B};let s={id:u++,timestamp:Date.now(),facts:C(),trigger:B};for(w<D.length-1&&D.splice(w+1),D.push(s),w=D.length-1;D.length>R;)D.shift(),w--;return i?.(s),s},restore(B){if(f){E=true,v=true;try{M(B.facts);}finally{E=false,v=false;}}},goBack(B=1){if(!f||D.length===0)return;let s=w,k=w,d=x.find(T=>w>T.startIndex&&w<=T.endIndex);if(d)k=d.startIndex;else if(x.find(j=>w===j.startIndex)){let j=x.find(l=>l.endIndex<w&&w-l.endIndex<=B);k=j?j.startIndex:Math.max(0,w-B);}else k=Math.max(0,w-B);if(s===k)return;w=k;let b=D[w];b&&(this.restore(b),t?.(s,k));},goForward(B=1){if(!f||D.length===0)return;let s=w,k=w,d=x.find(T=>w>=T.startIndex&&w<T.endIndex);if(d?k=d.endIndex:k=Math.min(D.length-1,w+B),s===k)return;w=k;let b=D[w];b&&(this.restore(b),t?.(s,k));},goTo(B){if(!f)return;let s=D.findIndex(b=>b.id===B);if(s===-1){console.warn(`[Directive] Snapshot ${B} not found`);return}let k=w;w=s;let d=D[w];d&&(this.restore(d),t?.(k,s));},replay(){if(!f||D.length===0)return;w=0;let B=D[0];B&&this.restore(B);},export(){return JSON.stringify({version:1,snapshots:D,currentIndex:w})},import(B){if(f)try{let s=JSON.parse(B);if(typeof s!="object"||s===null)throw new Error("Invalid time-travel data: expected object");if(s.version!==1)throw new Error(`Unsupported time-travel export version: ${s.version}`);if(!Array.isArray(s.snapshots))throw new Error("Invalid time-travel data: snapshots must be an array");if(typeof s.currentIndex!="number")throw new Error("Invalid time-travel data: currentIndex must be a number");for(let d of s.snapshots){if(typeof d!="object"||d===null)throw new Error("Invalid snapshot: expected object");if(typeof d.id!="number"||typeof d.timestamp!="number"||typeof d.trigger!="string"||typeof d.facts!="object")throw new Error("Invalid snapshot structure");if(!Re(d.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}D.length=0,D.push(...s.snapshots),w=s.currentIndex;let k=D[w];k&&this.restore(k);}catch(s){console.error("[Directive] Failed to import time-travel data:",s);}},beginChangeset(B){f&&(q=B,W=w);},endChangeset(){!f||q===null||(w>W&&x.push({label:q,startIndex:W,endIndex:w}),q=null,W=-1);},pause(){E=true;},resume(){E=false;}}}function Fe(){let r={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>r,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}function it(r,n){if(n)return n(r);let{type:g,...p}=r,i=$e(p);return `${g}:${i}`}function _e(r,n,g){return {requirement:r,id:it(r,g),fromConstraint:n}}var ke=class r{map=new Map;add(n){this.map.has(n.id)||this.map.set(n.id,n);}remove(n){return this.map.delete(n)}has(n){return this.map.has(n)}get(n){return this.map.get(n)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let n=new r;for(let g of this.map.values())n.add(g);return n}diff(n){let g=[],p=[],i=[];for(let t of this.map.values())n.has(t.id)?i.push(t):g.push(t);for(let t of n.map.values())this.map.has(t.id)||p.push(t);return {added:g,removed:p,unchanged:i}}};var De=[];function at(){let r=new Set;return {get isTracking(){return true},track(n){r.add(n);},getDependencies(){return r}}}var ct={isTracking:false,track(){},getDependencies(){return new Set}};function ut(){return De[De.length-1]??ct}function Ee(r){let n=at();De.push(n);try{return {value:r(),deps:n.getDependencies()}}finally{De.pop();}}function qe(r){let n=De.splice(0,De.length);try{return r()}finally{De.push(...n);}}function Ce(r){ut().track(r);}var lt=5e3;function Ne(r){let{definitions:n,facts:g,requirementKeys:p={},defaultTimeout:i=lt,onEvaluate:t,onError:f}=r,R=new Map,D=new Set,w=new Set,u=new Map,E=new Map,v=new Set,x=new Map,q=new Map,W=false,z=new Set,C=new Set,M=new Map,G=[],B=new Map;function s(){for(let[c,m]of Object.entries(n))if(m.after)for(let S of m.after)n[S]&&(M.has(S)||M.set(S,new Set),M.get(S).add(c));}function k(){let c=new Set,m=new Set,S=[];function F(_,X){if(c.has(_))return;if(m.has(_)){let ue=X.indexOf(_),Y=[...X.slice(ue),_].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${Y}. Remove one of the \`after\` dependencies to break the cycle.`)}m.add(_),X.push(_);let ne=n[_];if(ne?.after)for(let ue of ne.after)n[ue]&&F(ue,X);X.pop(),m.delete(_),c.add(_),S.push(_);}for(let _ of Object.keys(n))F(_,[]);G=S,B=new Map(G.map((_,X)=>[_,X]));}if(k(),s(),process.env.NODE_ENV!=="production"){for(let[c,m]of Object.entries(n))if(m.after)for(let S of m.after)n[S]||console.warn(`[Directive] Constraint "${c}" references unknown constraint "${S}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function d(c,m){return m.async!==void 0?m.async:!!w.has(c)}function b(c){let m=n[c];if(!m)throw new Error(`[Directive] Unknown constraint: ${c}`);let S=d(c,m);S&&w.add(c);let F={id:c,priority:m.priority??0,isAsync:S,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:m.after??[],hitCount:0,lastActiveAt:null};return R.set(c,F),F}function T(c){return R.get(c)??b(c)}function j(c,m){let S=u.get(c)??new Set;for(let F of S){let _=E.get(F);_?.delete(c),_&&_.size===0&&E.delete(F);}for(let F of m)E.has(F)||E.set(F,new Set),E.get(F).add(c);u.set(c,m);}function l(c){let m=n[c];if(!m)return false;let S=T(c);S.isEvaluating=true,S.error=null;try{let F;if(m.deps)F=m.when(g),x.set(c,new Set(m.deps));else {let _=Ee(()=>m.when(g));F=_.value,x.set(c,_.deps);}return F instanceof Promise?(w.add(c),S.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${c}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),F.then(_=>(S.lastResult=_,_&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,_),_)).catch(_=>(S.error=_ instanceof Error?_:new Error(String(_)),S.lastResult=!1,S.isEvaluating=!1,f?.(c,_),!1))):(S.lastResult=F,F&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,F),F)}catch(F){return S.error=F instanceof Error?F:new Error(String(F)),S.lastResult=false,S.isEvaluating=false,f?.(c,F),false}}async function a(c){let m=n[c];if(!m)return false;let S=T(c),F=m.timeout??i;if(S.isEvaluating=true,S.error=null,m.deps?.length){let _=new Set(m.deps);j(c,_),x.set(c,_);}try{let _=m.when(g),X=await Te(_,F,`Constraint "${c}" timed out after ${F}ms`);return S.lastResult=X,X&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,X),X}catch(_){return S.error=_ instanceof Error?_:new Error(String(_)),S.lastResult=false,S.isEvaluating=false,f?.(c,_),false}}let h=10;function A(c,m){if(c==null)return [];if(Array.isArray(c)){let S=c.filter(F=>F!=null);return process.env.NODE_ENV!=="production"&&S.length>h&&m&&console.warn(`[Directive] Constraint "${m}" produced ${S.length} requirements. Consider splitting into multiple constraints for better performance.`),S}return [c]}function I(c){let m=n[c];if(!m)return {requirements:[],deps:new Set};let S=m.require;if(typeof S=="function"){let{value:_,deps:X}=Ee(()=>S(g));return {requirements:A(_,c),deps:X}}return {requirements:A(S,c),deps:new Set}}function V(c,m){if(m.size===0)return;let S=u.get(c)??new Set;for(let F of m)S.add(F),E.has(F)||E.set(F,new Set),E.get(F).add(c);u.set(c,S);}let U=null;function $(){return U||(U=Object.keys(n).sort((c,m)=>{let S=T(c),_=T(m).priority-S.priority;if(_!==0)return _;let X=B.get(c)??0,ne=B.get(m)??0;return X-ne})),U}for(let c of Object.keys(n))b(c);if(process.env.NODE_ENV!=="production")for(let[c,m]of Object.entries(n))m.async&&!m.deps&&console.warn(`[Directive] Async constraint "${c}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function N(c){let m=R.get(c);if(!m||m.after.length===0)return true;for(let S of m.after)if(n[S]&&!D.has(S)&&!C.has(S)&&!z.has(S))return false;return true}return {async evaluate(c){let m=new ke;C.clear();let S=$().filter(Y=>!D.has(Y)),F;if(!W||!c||c.size===0)F=S,W=true;else {let Y=new Set;for(let oe of c){let ie=E.get(oe);if(ie)for(let ge of ie)D.has(ge)||Y.add(ge);}for(let oe of v)D.has(oe)||Y.add(oe);v.clear(),F=[...Y];for(let oe of S)if(!Y.has(oe)){let ie=q.get(oe);if(ie)for(let ge of ie)m.add(ge);}}function _(Y,oe){if(D.has(Y))return;let ie=x.get(Y);if(!oe){ie!==void 0&&j(Y,ie),C.add(Y),q.set(Y,[]);return}C.delete(Y);let ge,me;try{let P=I(Y);ge=P.requirements,me=P.deps;}catch(P){f?.(Y,P),ie!==void 0&&j(Y,ie),q.set(Y,[]);return}if(ie!==void 0){let P=new Set(ie);for(let Q of me)P.add(Q);j(Y,P);}else V(Y,me);if(ge.length>0){let P=p[Y],Q=ge.map(re=>_e(re,Y,P));for(let re of Q)m.add(re);q.set(Y,Q);}else q.set(Y,[]);}async function X(Y){let oe=[],ie=[];for(let Q of Y)if(N(Q))ie.push(Q);else {oe.push(Q);let re=q.get(Q);if(re)for(let ve of re)m.add(ve);}if(ie.length===0)return oe;let ge=[],me=[];for(let Q of ie)T(Q).isAsync?me.push(Q):ge.push(Q);let P=[];for(let Q of ge){let re=l(Q);if(re instanceof Promise){P.push({id:Q,promise:re});continue}_(Q,re);}if(P.length>0){let Q=await Promise.all(P.map(async({id:re,promise:ve})=>({id:re,active:await ve})));for(let{id:re,active:ve}of Q)_(re,ve);}if(me.length>0){let Q=await Promise.all(me.map(async re=>({id:re,active:await a(re)})));for(let{id:re,active:ve}of Q)_(re,ve);}return oe}let ne=F,ue=F.length+1;for(;ne.length>0&&ue>0;){let Y=ne.length;if(ne=await X(ne),ne.length===Y)break;ue--;}return m.all()},getState(c){return R.get(c)},getDependencies(c){return u.get(c)},getAllStates(){return [...R.values()]},disable(c){if(!R.has(c)){console.warn(`[Directive] constraints.disable("${c}") \u2014 no such constraint`);return}D.add(c),U=null,q.delete(c);let m=u.get(c);if(m){for(let S of m){let F=E.get(S);F&&(F.delete(c),F.size===0&&E.delete(S));}u.delete(c);}x.delete(c);},enable(c){if(!R.has(c)){console.warn(`[Directive] constraints.enable("${c}") \u2014 no such constraint`);return}D.delete(c),U=null,v.add(c);},isDisabled(c){return D.has(c)},invalidate(c){let m=E.get(c);if(m)for(let S of m)v.add(S);},markResolved(c){z.add(c);let m=R.get(c);m&&(m.lastResolvedAt=Date.now());let S=M.get(c);if(S)for(let F of S)v.add(F);},isResolved(c){return z.has(c)},registerDefinitions(c){for(let[m,S]of Object.entries(c))n[m]=S,b(m),v.add(m);U=null,k(),s();}}}function Be(r){let{definitions:n,facts:g,onCompute:i,onInvalidate:t,onError:f}=r,R=new Map,D=new Map,w=new Map,u=new Map,E=new Set(["__proto__","constructor","prototype"]),v=0,x=new Set,q=false,W=100,z;function C(b){if(!n[b])throw new Error(`[Directive] Unknown derivation: ${b}`);let j={id:b,compute:()=>G(b),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return R.set(b,j),j}function M(b){return R.get(b)??C(b)}function G(b){let T=M(b),j=n[b];if(!j)throw new Error(`[Directive] Unknown derivation: ${b}`);if(T.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${b}`);T.isComputing=true;try{let l=T.cachedValue,{value:a,deps:h}=Ee(()=>j(g,z));return T.cachedValue=a,T.isStale=!1,B(b,h),i?.(b,a,l,[...h]),a}catch(l){throw f?.(b,l),l}finally{T.isComputing=false;}}function B(b,T){let j=M(b),l=j.dependencies;for(let a of l)if(R.has(a)){let h=u.get(a);h?.delete(b),h&&h.size===0&&u.delete(a);}else {let h=w.get(a);h?.delete(b),h&&h.size===0&&w.delete(a);}for(let a of T)n[a]?(u.has(a)||u.set(a,new Set),u.get(a).add(b)):(w.has(a)||w.set(a,new Set),w.get(a).add(b));j.dependencies=T;}function s(){if(!(v>0||q)){q=true;try{let b=0;for(;x.size>0;){if(++b>W){let j=[...x];throw x.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${W} iterations. Remaining: ${j.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let T=[...x];x.clear();for(let j of T)D.get(j)?.forEach(l=>l());}}finally{q=false;}}}function k(b,T=new Set){if(T.has(b))return;T.add(b);let j=R.get(b);if(!j||j.isStale)return;j.isStale=true,t?.(b),x.add(b);let l=u.get(b);if(l)for(let a of l)k(a,T);}return z=new Proxy({},{get(b,T){if(typeof T=="symbol"||E.has(T))return;Ce(T);let j=M(T);return j.isStale&&G(T),j.cachedValue}}),{get(b){let T=M(b);return T.isStale&&G(b),T.cachedValue},isStale(b){return R.get(b)?.isStale??true},invalidate(b){let T=w.get(b);if(T){v++;try{for(let j of T)k(j);}finally{v--,s();}}},invalidateMany(b){v++;try{for(let T of b){let j=w.get(T);if(j)for(let l of j)k(l);}}finally{v--,s();}},invalidateAll(){v++;try{for(let b of R.values())b.isStale||(b.isStale=!0,x.add(b.id));}finally{v--,s();}},subscribe(b,T){for(let j of b){let l=j;D.has(l)||D.set(l,new Set),D.get(l).add(T);}return ()=>{for(let j of b){let l=j,a=D.get(l);a?.delete(T),a&&a.size===0&&D.delete(l);}}},getProxy(){return z},getDependencies(b){return M(b).dependencies},registerDefinitions(b){for(let[T,j]of Object.entries(b))n[T]=j,C(T);}}}function Ve(r){let{definitions:n,facts:g,store:p,onRun:i,onError:t}=r,f=new Map,R=null,D=false;function w(C){let M=n[C];if(!M)throw new Error(`[Directive] Unknown effect: ${C}`);let G={id:C,enabled:true,hasExplicitDeps:!!M.deps,dependencies:M.deps?new Set(M.deps):null,cleanup:null};return f.set(C,G),G}function u(C){return f.get(C)??w(C)}function E(){return p.toObject()}function v(C,M){let G=u(C);if(!G.enabled)return false;if(G.dependencies){for(let B of G.dependencies)if(M.has(B))return true;return false}return true}function x(C){if(C.cleanup){try{C.cleanup();}catch(M){t?.(C.id,M),console.error(`[Directive] Effect "${C.id}" cleanup threw an error:`,M);}C.cleanup=null;}}function q(C,M){if(typeof M=="function")if(D)try{M();}catch(G){t?.(C.id,G),console.error(`[Directive] Effect "${C.id}" cleanup threw an error:`,G);}else C.cleanup=M;}async function W(C){let M=u(C),G=n[C];if(!(!M.enabled||!G)){x(M),i?.(C,M.dependencies?[...M.dependencies]:[]);try{if(M.hasExplicitDeps){let B;if(p.batch(()=>{B=G.run(g,R);}),B instanceof Promise){let s=await B;q(M,s);}else q(M,B);}else {let B=null,s,k=Ee(()=>(p.batch(()=>{s=G.run(g,R);}),s));B=k.deps;let d=k.value;d instanceof Promise&&(d=await d),q(M,d),M.dependencies=B.size>0?B:null;}}catch(B){t?.(C,B),console.error(`[Directive] Effect "${C}" threw an error:`,B);}}}for(let C of Object.keys(n))w(C);return {async runEffects(C){let M=[];for(let G of Object.keys(n))v(G,C)&&M.push(G);await Promise.all(M.map(W)),R=E();},async runAll(){let C=Object.keys(n);await Promise.all(C.map(M=>u(M).enabled?W(M):Promise.resolve())),R=E();},disable(C){let M=u(C);M.enabled=false;},enable(C){let M=u(C);M.enabled=true;},isEnabled(C){return u(C).enabled},cleanupAll(){D=true;for(let C of f.values())x(C);},registerDefinitions(C){for(let[M,G]of Object.entries(C))n[M]=G,w(M);}}}var xe=class extends Error{constructor(g,p,i,t,f=true){super(g);this.source=p;this.sourceId=i;this.context=t;this.recoverable=f;this.name="DirectiveError";}};function dt(r={}){let{delayMs:n=1e3,maxRetries:g=3,backoffMultiplier:p=2,maxDelayMs:i=3e4}=r,t=new Map;function f(R){let D=n*Math.pow(p,R-1);return Math.min(D,i)}return {scheduleRetry(R,D,w,u,E){if(u>g)return null;let v=f(u),x={source:R,sourceId:D,context:w,attempt:u,nextRetryTime:Date.now()+v,callback:E};return t.set(D,x),x},getPendingRetries(){return Array.from(t.values())},processDueRetries(){let R=Date.now(),D=[];for(let[w,u]of t)u.nextRetryTime<=R&&(D.push(u),t.delete(w));return D},cancelRetry(R){t.delete(R);},clearAll(){t.clear();}}}var ft={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function Ke(r={}){let{config:n={},onError:g,onRecovery:p}=r,i=[],t=100,f=dt(n.retryLater),R=new Map;function D(E,v,x,q){if(x instanceof xe)return x;let W=x instanceof Error?x.message:String(x),z=E!=="system";return new xe(W,E,v,q,z)}function w(E,v,x){let q=(()=>{switch(E){case "constraint":return n.onConstraintError;case "resolver":return n.onResolverError;case "effect":return n.onEffectError;case "derivation":return n.onDerivationError;default:return}})();if(typeof q=="function"){try{let W=q(x,v);if(typeof W=="string")return W}catch(W){console.error("[Directive] Error in error handler callback:",W);}return "skip"}return typeof q=="string"?q:ft[E]}return {handleError(E,v,x,q){let W=D(E,v,x,q);i.push(W),i.length>t&&i.shift();try{g?.(W);}catch(C){console.error("[Directive] Error in onError callback:",C);}try{n.onError?.(W);}catch(C){console.error("[Directive] Error in config.onError callback:",C);}let z=w(E,v,x instanceof Error?x:new Error(String(x)));if(z==="retry-later"){let C=(R.get(v)??0)+1;R.set(v,C),f.scheduleRetry(E,v,q,C)||(z="skip",R.delete(v),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${E} "${v}" exceeded max retry-later attempts. Skipping.`));}try{p?.(W,z);}catch(C){console.error("[Directive] Error in onRecovery callback:",C);}if(z==="throw")throw W;return z},getLastError(){return i[i.length-1]??null},getAllErrors(){return [...i]},clearErrors(){i.length=0;},getRetryLaterManager(){return f},processDueRetries(){return f.processDueRetries()},clearRetryAttempts(E){R.delete(E),f.cancelRetry(E);}}}function gt(r,n=100){try{return JSON.stringify(r)?.slice(0,n)??String(r)}catch{return "[circular or non-serializable]"}}function mt(r){let{schema:n,onChange:g,onBatch:p}=r,t=Object.keys(n).length===0,f=r.validate??process.env.NODE_ENV!=="production",R=r.strictKeys??(process.env.NODE_ENV!=="production"&&!t),D=r.redactErrors??false,w=new Map,u=new Set,E=new Map,v=new Set,x=0,q=[],W=new Set,z=false,C=[],M=100;function G(a){return a!==null&&typeof a=="object"&&"safeParse"in a&&typeof a.safeParse=="function"&&"_def"in a&&"parse"in a&&typeof a.parse=="function"}function B(a){let h=a;if(h._typeName)return h._typeName;if(G(a)){let A=a._def;if(A?.typeName)return A.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function s(a){return D?"[redacted]":gt(a)}function k(a,h){if(!f)return;let A=n[a];if(!A){if(R)throw new Error(`[Directive] Unknown fact key: "${a}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${a}"`);return}if(G(A)){let $=A.safeParse(h);if(!$.success){let N=h===null?"null":Array.isArray(h)?"array":typeof h,O=s(h),c=$.error?.message??$.error?.issues?.[0]?.message??"Validation failed",m=B(A);throw new Error(`[Directive] Validation failed for "${a}": expected ${m}, got ${N} ${O}. ${c}`)}return}let I=A,V=I._validators;if(!V||!Array.isArray(V)||V.length===0)return;let U=I._typeName??"unknown";for(let $=0;$<V.length;$++){let N=V[$];if(typeof N=="function"&&!N(h)){let O=h===null?"null":Array.isArray(h)?"array":typeof h,c=s(h),m="";typeof I._lastFailedIndex=="number"&&I._lastFailedIndex>=0&&(m=` (element at index ${I._lastFailedIndex} failed)`,I._lastFailedIndex=-1);let S=$===0?"":` (validator ${$+1} failed)`;throw new Error(`[Directive] Validation failed for "${a}": expected ${U}, got ${O} ${c}${S}${m}`)}}}function d(a){E.get(a)?.forEach(h=>h());}function b(){v.forEach(a=>a());}function T(a,h,A){if(z){C.push({key:a,value:h,prev:A});return}z=true;try{g?.(a,h,A),d(a),b();let I=0;for(;C.length>0;){if(++I>M)throw C.length=0,new Error(`[Directive] Infinite notification loop detected after ${M} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let V=[...C];C.length=0;for(let U of V)g?.(U.key,U.value,U.prev),d(U.key);b();}}finally{z=false;}}function j(){if(!(x>0)){if(p&&q.length>0&&p([...q]),W.size>0){z=true;try{for(let h of W)d(h);b();let a=0;for(;C.length>0;){if(++a>M)throw C.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${M} iterations.`);let h=[...C];C.length=0;for(let A of h)g?.(A.key,A.value,A.prev),d(A.key);b();}}finally{z=false;}}q.length=0,W.clear();}}let l={get(a){return Ce(a),w.get(a)},has(a){return Ce(a),w.has(a)},set(a,h){k(a,h);let A=w.get(a);Object.is(A,h)||(w.set(a,h),u.add(a),x>0?(q.push({key:a,value:h,prev:A,type:"set"}),W.add(a)):T(a,h,A));},delete(a){let h=w.get(a);w.delete(a),u.delete(a),x>0?(q.push({key:a,value:void 0,prev:h,type:"delete"}),W.add(a)):T(a,void 0,h);},batch(a){x++;try{a();}finally{x--,j();}},subscribe(a,h){for(let A of a){let I=A;E.has(I)||E.set(I,new Set),E.get(I).add(h);}return ()=>{for(let A of a){let I=E.get(A);I&&(I.delete(h),I.size===0&&E.delete(A));}}},subscribeAll(a){return v.add(a),()=>v.delete(a)},toObject(){let a={};for(let h of u)w.has(h)&&(a[h]=w.get(h));return a}};return l.registerKeys=a=>{for(let h of Object.keys(a))Me.has(h)||(n[h]=a[h],u.add(h));},l}var Me=Object.freeze(new Set(["__proto__","constructor","prototype"]));function yt(r,n){let g=()=>({get:i=>qe(()=>r.get(i)),has:i=>qe(()=>r.has(i))});return new Proxy({},{get(i,t){if(t==="$store")return r;if(t==="$snapshot")return g;if(typeof t!="symbol"&&!Me.has(t))return r.get(t)},set(i,t,f){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Me.has(t)?false:(r.set(t,f),true)},deleteProperty(i,t){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Me.has(t)?false:(r.delete(t),true)},has(i,t){return t==="$store"||t==="$snapshot"?true:typeof t=="symbol"||Me.has(t)?false:r.has(t)},ownKeys(){return Object.keys(n)},getOwnPropertyDescriptor(i,t){return t==="$store"||t==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}}})}function We(r){let n=mt(r),g=yt(n,r.schema);return {store:n,facts:g}}function ze(){let r=[];function n(i){if(i)try{return i()}catch(t){console.error("[Directive] Plugin error:",t);return}}async function g(i){if(i)try{return await i()}catch(t){console.error("[Directive] Plugin error:",t);return}}return {register(i){r.some(t=>t.name===i.name)&&(console.warn(`[Directive] Plugin "${i.name}" is already registered, replacing...`),this.unregister(i.name)),r.push(i);},unregister(i){let t=r.findIndex(f=>f.name===i);t!==-1&&r.splice(t,1);},getPlugins(){return [...r]},async emitInit(i){for(let t of r)await g(()=>t.onInit?.(i));},emitStart(i){for(let t of r)n(()=>t.onStart?.(i));},emitStop(i){for(let t of r)n(()=>t.onStop?.(i));},emitDestroy(i){for(let t of r)n(()=>t.onDestroy?.(i));},emitFactSet(i,t,f){for(let R of r)n(()=>R.onFactSet?.(i,t,f));},emitFactDelete(i,t){for(let f of r)n(()=>f.onFactDelete?.(i,t));},emitFactsBatch(i){for(let t of r)n(()=>t.onFactsBatch?.(i));},emitDerivationCompute(i,t,f){for(let R of r)n(()=>R.onDerivationCompute?.(i,t,f));},emitDerivationInvalidate(i){for(let t of r)n(()=>t.onDerivationInvalidate?.(i));},emitReconcileStart(i){for(let t of r)n(()=>t.onReconcileStart?.(i));},emitReconcileEnd(i){for(let t of r)n(()=>t.onReconcileEnd?.(i));},emitConstraintEvaluate(i,t){for(let f of r)n(()=>f.onConstraintEvaluate?.(i,t));},emitConstraintError(i,t){for(let f of r)n(()=>f.onConstraintError?.(i,t));},emitRequirementCreated(i){for(let t of r)n(()=>t.onRequirementCreated?.(i));},emitRequirementMet(i,t){for(let f of r)n(()=>f.onRequirementMet?.(i,t));},emitRequirementCanceled(i){for(let t of r)n(()=>t.onRequirementCanceled?.(i));},emitResolverStart(i,t){for(let f of r)n(()=>f.onResolverStart?.(i,t));},emitResolverComplete(i,t,f){for(let R of r)n(()=>R.onResolverComplete?.(i,t,f));},emitResolverError(i,t,f){for(let R of r)n(()=>R.onResolverError?.(i,t,f));},emitResolverRetry(i,t,f){for(let R of r)n(()=>R.onResolverRetry?.(i,t,f));},emitResolverCancel(i,t){for(let f of r)n(()=>f.onResolverCancel?.(i,t));},emitEffectRun(i){for(let t of r)n(()=>t.onEffectRun?.(i));},emitEffectError(i,t){for(let f of r)n(()=>f.onEffectError?.(i,t));},emitSnapshot(i){for(let t of r)n(()=>t.onSnapshot?.(i));},emitTimeTravel(i,t){for(let f of r)n(()=>f.onTimeTravel?.(i,t));},emitError(i){for(let t of r)n(()=>t.onError?.(i));},emitErrorRecovery(i,t){for(let f of r)n(()=>f.onErrorRecovery?.(i,t));},emitRunComplete(i){for(let t of r)n(()=>t.onRunComplete?.(i));}}}var He={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},Le={enabled:false,windowMs:50};function Ue(r,n){let{backoff:g,initialDelay:p=100,maxDelay:i=3e4}=r,t;switch(g){case "none":t=p;break;case "linear":t=p*n;break;case "exponential":t=p*Math.pow(2,n-1);break;default:t=p;}return Math.max(1,Math.min(t,i))}function Je(r){let{definitions:n,facts:g,store:p,onStart:i,onComplete:t,onError:f,onRetry:R,onCancel:D,onResolutionComplete:w}=r;if(process.env.NODE_ENV!=="production")for(let[l,a]of Object.entries(n)){if(!a.resolve&&!a.resolveBatch&&!a.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${l}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(a.batch?.enabled&&!a.resolveBatch&&!a.resolveBatchWithResults)if(a.resolve)console.warn(`[Directive] Resolver "${l}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${l}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let u=new Map,E=new Map,v=1e3,x=new Map,q=new Map,W=1e3;function z(){if(E.size>v){let l=E.size-v,a=E.keys();for(let h=0;h<l;h++){let A=a.next().value;A&&E.delete(A);}}}function C(l){return typeof l=="object"&&l!==null&&"requirement"in l&&typeof l.requirement=="string"}function M(l){return typeof l=="object"&&l!==null&&"requirement"in l&&typeof l.requirement=="function"}function G(l,a){return C(l)?a.type===l.requirement:M(l)?l.requirement(a):false}function B(l){let a=l.type,h=q.get(a);if(h)for(let A of h){let I=n[A];if(I&&G(I,l))return A}for(let[A,I]of Object.entries(n))if(G(I,l)){if(!q.has(a)){if(q.size>=W){let U=q.keys().next().value;U!==void 0&&q.delete(U);}q.set(a,[]);}let V=q.get(a);return V.includes(A)||V.push(A),A}return null}function s(l){return {facts:g,signal:l,snapshot:()=>g.$snapshot()}}async function k(l,a,h){let A=n[l];if(!A)return;let I={...He,...A.retry},V=null;for(let U=1;U<=I.attempts;U++){if(h.signal.aborted)return;let $=u.get(a.id);$&&($.attempt=U,$.status={state:"running",requirementId:a.id,startedAt:$.startedAt,attempt:U});try{let N=s(h.signal);if(A.resolve){let c;p.batch(()=>{c=A.resolve(a.requirement,N);});let m=A.timeout;m&&m>0?await Te(c,m,`Resolver "${l}" timed out after ${m}ms`):await c;}let O=Date.now()-($?.startedAt??Date.now());E.set(a.id,{state:"success",requirementId:a.id,completedAt:Date.now(),duration:O}),z(),t?.(l,a,O);return}catch(N){if(V=N instanceof Error?N:new Error(String(N)),h.signal.aborted)return;if(I.shouldRetry&&!I.shouldRetry(V,U))break;if(U<I.attempts){if(h.signal.aborted)return;let O=Ue(I,U);if(R?.(l,a,U+1),await new Promise(c=>{let m=setTimeout(c,O),S=()=>{clearTimeout(m),c();};h.signal.addEventListener("abort",S,{once:true});}),h.signal.aborted)return}}}E.set(a.id,{state:"error",requirementId:a.id,error:V,failedAt:Date.now(),attempts:I.attempts}),z(),f?.(l,a,V);}async function d(l,a){let h=n[l];if(!h)return;if(!h.resolveBatch&&!h.resolveBatchWithResults){await Promise.all(a.map(O=>{let c=new AbortController;return k(l,O,c)}));return}let A={...He,...h.retry},I={...Le,...h.batch},V=new AbortController,U=Date.now(),$=null,N=I.timeoutMs??h.timeout;for(let O=1;O<=A.attempts;O++){if(V.signal.aborted)return;try{let c=s(V.signal),m=a.map(S=>S.requirement);if(h.resolveBatchWithResults){let S,F;if(p.batch(()=>{F=h.resolveBatchWithResults(m,c);}),N&&N>0?S=await Te(F,N,`Batch resolver "${l}" timed out after ${N}ms`):S=await F,S.length!==a.length)throw new Error(`[Directive] Batch resolver "${l}" returned ${S.length} results but expected ${a.length}. Results array must match input order.`);let _=Date.now()-U,X=!1;for(let ne=0;ne<a.length;ne++){let ue=a[ne],Y=S[ne];if(Y.success)E.set(ue.id,{state:"success",requirementId:ue.id,completedAt:Date.now(),duration:_}),t?.(l,ue,_);else {X=!0;let oe=Y.error??new Error("Batch item failed");E.set(ue.id,{state:"error",requirementId:ue.id,error:oe,failedAt:Date.now(),attempts:O}),f?.(l,ue,oe);}}if(!X||a.some((ne,ue)=>S[ue]?.success))return}else {let S;p.batch(()=>{S=h.resolveBatch(m,c);}),N&&N>0?await Te(S,N,`Batch resolver "${l}" timed out after ${N}ms`):await S;let F=Date.now()-U;for(let _ of a)E.set(_.id,{state:"success",requirementId:_.id,completedAt:Date.now(),duration:F}),t?.(l,_,F);return}}catch(c){if($=c instanceof Error?c:new Error(String(c)),V.signal.aborted)return;if(A.shouldRetry&&!A.shouldRetry($,O))break;if(O<A.attempts){let m=Ue(A,O);for(let S of a)R?.(l,S,O+1);if(await new Promise(S=>{let F=setTimeout(S,m),_=()=>{clearTimeout(F),S();};V.signal.addEventListener("abort",_,{once:true});}),V.signal.aborted)return}}}for(let O of a)E.set(O.id,{state:"error",requirementId:O.id,error:$,failedAt:Date.now(),attempts:A.attempts}),f?.(l,O,$);z();}function b(l,a){let h=n[l];if(!h)return;let A={...Le,...h.batch};x.has(l)||x.set(l,{resolverId:l,requirements:[],timer:null});let I=x.get(l);if(I.requirements.push(a),A.maxSize&&I.requirements.length>=A.maxSize){I.timer&&(clearTimeout(I.timer),I.timer=null),T(l);return}I.timer&&clearTimeout(I.timer),I.timer=setTimeout(()=>{T(l);},A.windowMs);}function T(l){let a=x.get(l);if(!a||a.requirements.length===0)return;let h=[...a.requirements];a.requirements=[],a.timer=null,d(l,h).then(()=>{w?.();});}return {resolve(l){if(u.has(l.id))return;let a=B(l.requirement);if(!a){console.warn(`[Directive] No resolver found for requirement type "${l.requirement.type}" (id: ${l.id})`);return}let h=n[a];if(!h)return;if(h.batch?.enabled){b(a,l);return}let A=new AbortController,I=Date.now(),V={requirementId:l.id,resolverId:a,controller:A,startedAt:I,attempt:1,status:{state:"pending",requirementId:l.id,startedAt:I},originalRequirement:l};u.set(l.id,V),i?.(a,l),k(a,l,A).finally(()=>{u.delete(l.id)&&w?.();});},cancel(l){let a=u.get(l);if(a){a.controller.abort(),u.delete(l),E.set(l,{state:"canceled",requirementId:l,canceledAt:Date.now()}),z(),D?.(a.resolverId,a.originalRequirement);return}for(let h of x.values()){let A=h.requirements.findIndex(I=>I.id===l);if(A!==-1){let[I]=h.requirements.splice(A,1);E.set(l,{state:"canceled",requirementId:l,canceledAt:Date.now()}),z(),I&&D?.(h.resolverId,I);return}}},cancelAll(){let l=[...u.keys()];for(let a of l)this.cancel(a);for(let a of x.values()){a.timer&&clearTimeout(a.timer);for(let h of a.requirements)E.set(h.id,{state:"canceled",requirementId:h.id,canceledAt:Date.now()}),D?.(a.resolverId,h);}x.clear(),z();},getStatus(l){let a=u.get(l);if(a)return a.status;let h=E.get(l);return h||{state:"idle"}},getInflight(){return [...u.keys()]},getInflightInfo(){return [...u.values()].map(l=>({id:l.requirementId,resolverId:l.resolverId,startedAt:l.startedAt}))},isResolving(l){return u.has(l)},processBatches(){for(let l of x.keys())T(l);},hasPendingBatches(){for(let l of x.values())if(l.requirements.length>0)return true;return false},registerDefinitions(l){for(let[a,h]of Object.entries(l))n[a]=h;q.clear();}}}var he=new Set(["__proto__","constructor","prototype"]);function Ae(r){let n=Object.create(null),g=Object.create(null),p=Object.create(null),i=Object.create(null),t=Object.create(null),f=Object.create(null),R=new Map;for(let e of r.modules){let o=(y,K)=>{if(y){for(let J of Object.keys(y))if(he.has(J))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${J}" in ${K}. This could indicate a prototype pollution attempt.`)}};if(o(e.schema,"schema"),o(e.events,"events"),o(e.derive,"derive"),o(e.effects,"effects"),o(e.constraints,"constraints"),o(e.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let y of Object.keys(e.schema)){let K=R.get(y);if(K)throw new Error(`[Directive] Schema collision: Fact "${y}" is defined in both module "${K}" and "${e.id}". Use namespacing (e.g., "${e.id}::${y}") or merge into one module.`);R.set(y,e.id);}Object.assign(n,e.schema),e.events&&Object.assign(g,e.events),e.derive&&Object.assign(p,e.derive),e.effects&&Object.assign(i,e.effects),e.constraints&&Object.assign(t,e.constraints),e.resolvers&&Object.assign(f,e.resolvers);}let D=null;if(r.modules.some(e=>e.snapshotEvents)){D=new Set;for(let e of r.modules){let o=e;if(o.snapshotEvents)for(let y of o.snapshotEvents)D.add(y);else if(o.events)for(let y of Object.keys(o.events))D.add(y);}}let u=0,E=false;if(process.env.NODE_ENV!=="production"){let e=new Set(Object.keys(p));for(let o of Object.keys(n))e.has(o)&&console.warn(`[Directive] "${o}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let v=ze();for(let e of r.plugins??[])v.register(e);let x=Ke({config:r.errorBoundary,onError:e=>v.emitError(e),onRecovery:(e,o)=>v.emitErrorRecovery(e,o)}),q=null,W=()=>{},z=()=>{},C=null,M=r.debug?.runHistory??false,G=r.debug?.maxRuns??100,B=[],s=new Map,k=0,d=null,b=[],T=new Map,j=new Map,l=new Map,a=null,h=0,A=0,I={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0},{store:V,facts:U}=We({schema:n,onChange:(e,o,y)=>{v.emitFactSet(e,o,y),W(e),M&&b.push({key:String(e),oldValue:y,newValue:o}),!C?.isRestoring&&(u===0&&(E=true),P.changedKeys.add(e),Q());},onBatch:e=>{v.emitFactsBatch(e);let o=[];for(let y of e)o.push(y.key);if(M)for(let y of e)y.type==="delete"?b.push({key:y.key,oldValue:y.prev,newValue:void 0}):b.push({key:y.key,oldValue:y.prev,newValue:y.value});if(z(o),!C?.isRestoring){u===0&&(E=true);for(let y of e)P.changedKeys.add(y.key);Q();}}}),$=Be({definitions:p,facts:U,onCompute:(e,o,y,K)=>{v.emitDerivationCompute(e,o,K),d&&d.derivationsRecomputed.push({id:e,deps:K?[...K]:[],oldValue:y,newValue:o});},onInvalidate:e=>v.emitDerivationInvalidate(e),onError:(e,o)=>{x.handleError("derivation",e,o)==="retry"&&$.invalidate(e);}});W=e=>$.invalidate(e),z=e=>$.invalidateMany(e);let N=Ve({definitions:i,facts:U,store:V,onRun:(e,o)=>{v.emitEffectRun(e),d&&d.effectsRun.push({id:e,triggeredBy:o});},onError:(e,o)=>{let y=x.handleError("effect",e,o);v.emitEffectError(e,o),d&&d.effectErrors.push({id:e,error:String(o)}),y==="disable"&&N.disable(e),y==="retry"&&(P.changedKeys.add("*"),Q());}}),O=Ne({definitions:t,facts:U,onEvaluate:(e,o)=>v.emitConstraintEvaluate(e,o),onError:(e,o)=>{let y=x.handleError("constraint",e,o);v.emitConstraintError(e,o),y==="disable"&&O.disable(e);}});function c(e){let o=s.get(e);if(o&&o.status==="pending"){o.status="settled";let y=l.get(e);o.duration=y!==void 0?performance.now()-y:Date.now()-o.timestamp,l.delete(e),j.delete(e),o.causalChain=F(o),_(o),A++,v.emitRunComplete(o);}}function m(e){let o=T.get(e);if(T.delete(e),o!==void 0){let y=(j.get(o)??1)-1;y<=0?c(o):j.set(o,y);}}function S(){let e=B.shift();if(e&&(s.delete(e.id),l.delete(e.id),e.status==="pending")){j.delete(e.id);for(let[o,y]of T)y===e.id&&T.delete(o);}}function F(e){let o=[];for(let y of e.factChanges)o.push(`${y.key} changed`);for(let y of e.derivationsRecomputed)o.push(`${y.id} recomputed`);for(let y of e.constraintsHit)o.push(`${y.id} constraint hit`);for(let y of e.requirementsAdded)o.push(`${y.type} requirement added`);for(let y of e.resolversCompleted)o.push(`${y.resolver} resolved (${y.duration.toFixed(0)}ms)`);for(let y of e.resolversErrored)o.push(`${y.resolver} errored`);for(let y of e.effectsRun)o.push(`${y.id} effect ran`);return o.join(" \u2192 ")}function _(e){I.count++,I.totalDuration+=e.duration,I.avgDuration=I.totalDuration/I.count,e.duration>I.maxDuration&&(I.maxDuration=e.duration);let o=e.resolversStarted.length;I.totalResolverCount+=o,I.avgResolverCount=I.totalResolverCount/I.count;let y=e.factChanges.length;I.totalFactChangeCount+=y,I.avgFactChangeCount=I.totalFactChangeCount/I.count;let K=[];I.count>3&&e.duration>I.avgDuration*5&&K.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${I.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&K.push(`${e.resolversErrored.length} resolver(s) errored`),K.length>0&&(e.anomalies=K);}let X=Je({definitions:f,facts:U,store:V,onStart:(e,o)=>v.emitResolverStart(e,o),onComplete:(e,o,y)=>{if(x.clearRetryAttempts(e),v.emitResolverComplete(e,o,y),v.emitRequirementMet(o,e),O.markResolved(o.fromConstraint),M){let K=T.get(o.id);if(K!==void 0){let J=s.get(K);J&&J.resolversCompleted.push({resolver:e,requirementId:o.id,duration:y});}m(o.id);}},onError:(e,o,y)=>{let K=x.handleError("resolver",e,y,o);if(v.emitResolverError(e,o,y),K==="disable"&&O.disable(o.fromConstraint),K==="retry"&&(P.previousRequirements.remove(o.id),Q()),K==="retry-later"){let H=x.getRetryLaterManager().getPendingRetries().find(ee=>ee.sourceId===e);H&&!H.callback&&(H.callback=()=>{Q();});}if(M){let J=T.get(o.id);if(J!==void 0){let H=s.get(J);H&&H.resolversErrored.push({resolver:e,requirementId:o.id,error:String(y)});}m(o.id);}},onRetry:(e,o,y)=>v.emitResolverRetry(e,o,y),onCancel:(e,o)=>{v.emitResolverCancel(e,o),v.emitRequirementCanceled(o),M&&m(o.id);},onResolutionComplete:()=>{ie(),Q();}}),ne=new Set;function ue(){for(let e of ne)e();}let Y=r.debug?.timeTravel?je({config:r.debug,facts:U,store:V,onSnapshot:e=>{v.emitSnapshot(e),ue();},onTimeTravel:(e,o)=>{v.emitTimeTravel(e,o),ue();}}):Fe();C=Y;let oe=new Set;function ie(){for(let e of oe)e();}let ge=50,me=0,P={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new ke,readyPromise:null,readyResolve:null};function Q(){!P.isRunning||P.reconcileScheduled||P.isInitializing||(P.reconcileScheduled=true,ie(),queueMicrotask(()=>{P.reconcileScheduled=false,P.isRunning&&!P.isInitializing&&re().catch(e=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function re(){if(P.isReconciling)return;if(me++,me>ge){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${ge} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),M&&(b.length=0),me=0;return}P.isReconciling=true,ie();let e=M?performance.now():0;if(M){let o=++k;l.set(o,e),d={id:o,timestamp:Date.now(),duration:0,status:"pending",factChanges:b.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]};}try{P.changedKeys.size>0&&((D===null||E)&&Y.takeSnapshot(`facts-changed:${[...P.changedKeys].join(",")}`),E=!1);let o=U.$snapshot();v.emitReconcileStart(o),await N.runEffects(P.changedKeys);let y=new Set(P.changedKeys);P.changedKeys.clear();let K=await O.evaluate(y),J=new ke;for(let Z of K)J.add(Z),v.emitRequirementCreated(Z);if(d){let Z=new Set(K.map(te=>te.fromConstraint));for(let te of Z){let de=O.getState(te);if(de){let se=O.getDependencies(te);d.constraintsHit.push({id:te,priority:de.priority,deps:se?[...se]:[]});}}}let{added:H,removed:ee}=J.diff(P.previousRequirements);if(d){for(let Z of H)d.requirementsAdded.push({id:Z.id,type:Z.requirement.type,fromConstraint:Z.fromConstraint});for(let Z of ee)d.requirementsRemoved.push({id:Z.id,type:Z.requirement.type,fromConstraint:Z.fromConstraint});}for(let Z of ee)X.cancel(Z.id);for(let Z of H)X.resolve(Z);if(d){let Z=X.getInflightInfo();for(let te of H){let de=Z.find(se=>se.id===te.id);d.resolversStarted.push({resolver:de?.resolverId??"unknown",requirementId:te.id}),T.set(te.id,d.id);}}P.previousRequirements=J;let ce=X.getInflightInfo(),le={unmet:K.filter(Z=>!X.isResolving(Z.id)),inflight:ce,completed:[],canceled:ee.map(Z=>({id:Z.id,resolverId:ce.find(te=>te.id===Z.id)?.resolverId??"unknown"}))};v.emitReconcileEnd(le),P.isReady||(P.isReady=!0,P.readyResolve&&(P.readyResolve(),P.readyResolve=null));}finally{if(d){if(d.duration=performance.now()-e,d.factChanges.length>0||d.constraintsHit.length>0||d.requirementsAdded.length>0||d.effectsRun.length>0){let y=d.resolversStarted.length;y===0?(d.status="settled",d.causalChain=F(d),_(d),B.push(d),s.set(d.id,d),B.length>G&&S(),A++,v.emitRunComplete(d)):(d.status="pending",B.push(d),s.set(d.id,d),B.length>G&&S(),A++,j.set(d.id,y));}else l.delete(d.id);d=null;}P.isReconciling=false,P.changedKeys.size>0?Q():P.reconcileScheduled||(me=0),ie();}}let ve=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return $.get(o)},has(e,o){return typeof o=="symbol"||he.has(o)?false:o in p},ownKeys(){return Object.keys(p)},getOwnPropertyDescriptor(e,o){if(typeof o!="symbol"&&!he.has(o)&&o in p)return {configurable:true,enumerable:true}}}),rt=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return y=>{let K=g[o];if(K){u++,(D===null||D.has(o))&&(E=true);try{V.batch(()=>{K(U,{type:o,...y});});}finally{u--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${o}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);}},has(e,o){return typeof o=="symbol"||he.has(o)?false:o in g},ownKeys(){return Object.keys(g)},getOwnPropertyDescriptor(e,o){if(typeof o!="symbol"&&!he.has(o)&&o in g)return {configurable:true,enumerable:true}}}),ye={facts:U,debug:Y.isEnabled?Y:null,derive:ve,events:rt,constraints:{disable:e=>O.disable(e),enable:e=>O.enable(e),isDisabled:e=>O.isDisabled(e)},effects:{disable:e=>N.disable(e),enable:e=>N.enable(e),isEnabled:e=>N.isEnabled(e)},get runHistory(){return M?((!a||h!==A)&&(a=[...B],h=A),a):null},initialize(){if(!P.isInitialized){P.isInitializing=true;for(let e of r.modules)e.init&&V.batch(()=>{e.init(U);});r.onAfterModuleInit&&V.batch(()=>{r.onAfterModuleInit();}),P.isInitializing=false,P.isInitialized=true;for(let e of Object.keys(p))$.get(e);}},start(){if(!P.isRunning){P.isInitialized||this.initialize(),P.isRunning=true;for(let e of r.modules)e.hooks?.onStart?.(ye);if(v.emitStart(ye),r.errorBoundary?.retryLater&&!q){let e=Math.max(r.errorBoundary.retryLater.delayMs??1e3,250);q=setInterval(()=>{let o=x.processDueRetries();for(let y of o)y.callback?y.callback():Q();},Math.min(e,500));}Q();}},stop(){if(P.isRunning){P.isRunning=false,q!==null&&(clearInterval(q),q=null),x.getRetryLaterManager().clearAll(),X.cancelAll(),N.cleanupAll();for(let e of r.modules)e.hooks?.onStop?.(ye);v.emitStop(ye);}},destroy(){this.stop(),P.isDestroyed=true,oe.clear(),ne.clear(),B.length=0,s.clear(),T.clear(),j.clear(),l.clear(),b.length=0,d=null,a=null,v.emitDestroy(ye);},dispatch(e){if(he.has(e.type))return;let o=g[e.type];if(o){u++,(D===null||D.has(e.type))&&(E=true);try{V.batch(()=>{o(U,e);});}finally{u--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${e.type}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);},read(e){return $.get(e)},subscribe(e,o){let y=[],K=[];for(let H of e)H in p?y.push(H):H in n?K.push(H):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${H}"`);let J=[];return y.length>0&&J.push($.subscribe(y,o)),K.length>0&&J.push(V.subscribe(K,o)),()=>{for(let H of J)H();}},watch(e,o,y){let K=y?.equalityFn?(H,ee)=>y.equalityFn(H,ee):(H,ee)=>Object.is(H,ee);if(e in p){let H=$.get(e);return $.subscribe([e],()=>{let ee=$.get(e);if(!K(ee,H)){let ce=H;H=ee,o(ee,ce);}})}process.env.NODE_ENV!=="production"&&(e in n||console.warn(`[Directive] watch: unknown key "${e}"`));let J=V.get(e);return V.subscribe([e],()=>{let H=V.get(e);if(!K(H,J)){let ee=J;J=H,o(H,ee);}})},when(e,o){return new Promise((y,K)=>{let J=V.toObject();if(e(J)){y();return}let H,ee,ce=()=>{H?.(),ee!==void 0&&clearTimeout(ee);};H=V.subscribeAll(()=>{let le=V.toObject();e(le)&&(ce(),y());}),o?.timeout!==void 0&&o.timeout>0&&(ee=setTimeout(()=>{ce(),K(new Error(`[Directive] when: timed out after ${o.timeout}ms`));},o.timeout));})},inspect(){return {unmet:P.previousRequirements.all(),inflight:X.getInflightInfo(),constraints:O.getAllStates().map(e=>({id:e.id,active:e.lastResult??false,disabled:O.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt})),resolvers:Object.fromEntries(X.getInflight().map(e=>[e,X.getStatus(e)])),resolverDefs:Object.entries(f).map(([e,o])=>({id:e,requirement:typeof o.requirement=="string"?o.requirement:"(predicate)"})),runHistoryEnabled:M,...M?{runHistory:B.map(e=>({...e,factChanges:e.factChanges.map(o=>({...o})),derivationsRecomputed:e.derivationsRecomputed.map(o=>({...o,deps:[...o.deps]})),constraintsHit:e.constraintsHit.map(o=>({...o,deps:[...o.deps]})),requirementsAdded:e.requirementsAdded.map(o=>({...o})),requirementsRemoved:e.requirementsRemoved.map(o=>({...o})),resolversStarted:e.resolversStarted.map(o=>({...o})),resolversCompleted:e.resolversCompleted.map(o=>({...o})),resolversErrored:e.resolversErrored.map(o=>({...o})),effectsRun:e.effectsRun.map(o=>({...o,triggeredBy:[...o.triggeredBy]})),effectErrors:e.effectErrors.map(o=>({...o}))}))}:{}}},explain(e){let y=P.previousRequirements.all().find(te=>te.id===e);if(!y)return null;let K=O.getState(y.fromConstraint),J=X.getStatus(e),H={},ee=V.toObject();for(let[te,de]of Object.entries(ee))H[te]=de;let ce=[`Requirement "${y.requirement.type}" (id: ${y.id})`,`\u251C\u2500 Produced by constraint: ${y.fromConstraint}`,`\u251C\u2500 Constraint priority: ${K?.priority??0}`,`\u251C\u2500 Constraint active: ${K?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${J.state}`],le=Object.entries(y.requirement).filter(([te])=>te!=="type").map(([te,de])=>`${te}=${JSON.stringify(de)}`).join(", ");le&&ce.push(`\u251C\u2500 Requirement payload: { ${le} }`);let Z=Object.entries(H).slice(0,10);return Z.length>0&&(ce.push("\u2514\u2500 Relevant facts:"),Z.forEach(([te,de],se)=>{let be=se===Z.length-1?" \u2514\u2500":" \u251C\u2500",we=typeof de=="object"?JSON.stringify(de):String(de);ce.push(`${be} ${te} = ${we.slice(0,50)}${we.length>50?"...":""}`);})),ce.join(`
1
+ async function Te(r,n,g){let p,i=new Promise((t,f)=>{p=setTimeout(()=>f(new Error(g)),n);});try{return await Promise.race([r,i])}finally{clearTimeout(p);}}function $e(r,n=50){let g=new WeakSet;function p(i,t){if(t>n)return '"[max depth exceeded]"';if(i===null)return "null";if(i===void 0)return "undefined";let f=typeof i;if(f==="string")return JSON.stringify(i);if(f==="number"||f==="boolean")return String(i);if(f==="function")return '"[function]"';if(f==="symbol")return '"[symbol]"';if(Array.isArray(i)){if(g.has(i))return '"[circular]"';g.add(i);let R=`[${i.map(D=>p(D,t+1)).join(",")}]`;return g.delete(i),R}if(f==="object"){let R=i;if(g.has(R))return '"[circular]"';g.add(R);let u=`{${Object.keys(R).sort().map(E=>`${JSON.stringify(E)}:${p(R[E],t+1)}`).join(",")}}`;return g.delete(R),u}return '"[unknown]"'}return p(r,0)}function Re(r,n=50){let g=new Set(["__proto__","constructor","prototype"]),p=new WeakSet;function i(t,f){if(f>n)return false;if(t==null||typeof t!="object")return true;let R=t;if(p.has(R))return true;if(p.add(R),Array.isArray(R)){for(let D of R)if(!i(D,f+1))return p.delete(R),false;return p.delete(R),true}for(let D of Object.keys(R))if(g.has(D)||!i(R[D],f+1))return p.delete(R),false;return p.delete(R),true}return i(r,0)}function Pe(r){let n=$e(r),g=5381;for(let p=0;p<n.length;p++)g=(g<<5)+g^n.charCodeAt(p);return (g>>>0).toString(16)}function je(r){let{config:n,facts:g,store:p,onSnapshot:i,onTimeTravel:t}=r,f=n.timeTravel??false,R=n.maxSnapshots??100,D=[],w=-1,u=1,E=false,v=false,x=[],q=null,W=-1;function z(){return p.toObject()}function C(){let B=z();return structuredClone(B)}function M(B){if(!Re(B)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}p.batch(()=>{for(let[s,k]of Object.entries(B)){if(s==="__proto__"||s==="constructor"||s==="prototype"){console.warn(`[Directive] Skipping dangerous key "${s}" during fact restoration`);continue}g[s]=k;}});}return {get isEnabled(){return f},get isRestoring(){return v},get isPaused(){return E},get snapshots(){return [...D]},get currentIndex(){return w},takeSnapshot(B){if(!f||E)return {id:-1,timestamp:Date.now(),facts:{},trigger:B};let s={id:u++,timestamp:Date.now(),facts:C(),trigger:B};for(w<D.length-1&&D.splice(w+1),D.push(s),w=D.length-1;D.length>R;)D.shift(),w--;return i?.(s),s},restore(B){if(f){E=true,v=true;try{M(B.facts);}finally{E=false,v=false;}}},goBack(B=1){if(!f||D.length===0)return;let s=w,k=w,d=x.find(T=>w>T.startIndex&&w<=T.endIndex);if(d)k=d.startIndex;else if(x.find(j=>w===j.startIndex)){let j=x.find(l=>l.endIndex<w&&w-l.endIndex<=B);k=j?j.startIndex:Math.max(0,w-B);}else k=Math.max(0,w-B);if(s===k)return;w=k;let b=D[w];b&&(this.restore(b),t?.(s,k));},goForward(B=1){if(!f||D.length===0)return;let s=w,k=w,d=x.find(T=>w>=T.startIndex&&w<T.endIndex);if(d?k=d.endIndex:k=Math.min(D.length-1,w+B),s===k)return;w=k;let b=D[w];b&&(this.restore(b),t?.(s,k));},goTo(B){if(!f)return;let s=D.findIndex(b=>b.id===B);if(s===-1){console.warn(`[Directive] Snapshot ${B} not found`);return}let k=w;w=s;let d=D[w];d&&(this.restore(d),t?.(k,s));},replay(){if(!f||D.length===0)return;w=0;let B=D[0];B&&this.restore(B);},export(){return JSON.stringify({version:1,snapshots:D,currentIndex:w})},import(B){if(f)try{let s=JSON.parse(B);if(typeof s!="object"||s===null)throw new Error("Invalid time-travel data: expected object");if(s.version!==1)throw new Error(`Unsupported time-travel export version: ${s.version}`);if(!Array.isArray(s.snapshots))throw new Error("Invalid time-travel data: snapshots must be an array");if(typeof s.currentIndex!="number")throw new Error("Invalid time-travel data: currentIndex must be a number");for(let d of s.snapshots){if(typeof d!="object"||d===null)throw new Error("Invalid snapshot: expected object");if(typeof d.id!="number"||typeof d.timestamp!="number"||typeof d.trigger!="string"||typeof d.facts!="object")throw new Error("Invalid snapshot structure");if(!Re(d.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}D.length=0,D.push(...s.snapshots),w=s.currentIndex;let k=D[w];k&&this.restore(k);}catch(s){console.error("[Directive] Failed to import time-travel data:",s);}},beginChangeset(B){f&&(q=B,W=w);},endChangeset(){!f||q===null||(w>W&&x.push({label:q,startIndex:W,endIndex:w}),q=null,W=-1);},pause(){E=true;},resume(){E=false;}}}function Fe(){let r={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>r,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}function it(r,n){if(n)return n(r);let{type:g,...p}=r,i=$e(p);return `${g}:${i}`}function _e(r,n,g){return {requirement:r,id:it(r,g),fromConstraint:n}}var ke=class r{map=new Map;add(n){this.map.has(n.id)||this.map.set(n.id,n);}remove(n){return this.map.delete(n)}has(n){return this.map.has(n)}get(n){return this.map.get(n)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let n=new r;for(let g of this.map.values())n.add(g);return n}diff(n){let g=[],p=[],i=[];for(let t of this.map.values())n.has(t.id)?i.push(t):g.push(t);for(let t of n.map.values())this.map.has(t.id)||p.push(t);return {added:g,removed:p,unchanged:i}}};var De=[];function at(){let r=new Set;return {get isTracking(){return true},track(n){r.add(n);},getDependencies(){return r}}}var ct={isTracking:false,track(){},getDependencies(){return new Set}};function ut(){return De[De.length-1]??ct}function Ee(r){let n=at();De.push(n);try{return {value:r(),deps:n.getDependencies()}}finally{De.pop();}}function qe(r){let n=De.splice(0,De.length);try{return r()}finally{De.push(...n);}}function Ce(r){ut().track(r);}var lt=5e3;function Ne(r){let{definitions:n,facts:g,requirementKeys:p={},defaultTimeout:i=lt,onEvaluate:t,onError:f}=r,R=new Map,D=new Set,w=new Set,u=new Map,E=new Map,v=new Set,x=new Map,q=new Map,W=false,z=new Set,C=new Set,M=new Map,G=[],B=new Map;function s(){for(let[c,m]of Object.entries(n))if(m.after)for(let S of m.after)n[S]&&(M.has(S)||M.set(S,new Set),M.get(S).add(c));}function k(){let c=new Set,m=new Set,S=[];function F(_,X){if(c.has(_))return;if(m.has(_)){let ue=X.indexOf(_),Y=[...X.slice(ue),_].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${Y}. Remove one of the \`after\` dependencies to break the cycle.`)}m.add(_),X.push(_);let ne=n[_];if(ne?.after)for(let ue of ne.after)n[ue]&&F(ue,X);X.pop(),m.delete(_),c.add(_),S.push(_);}for(let _ of Object.keys(n))F(_,[]);G=S,B=new Map(G.map((_,X)=>[_,X]));}if(k(),s(),process.env.NODE_ENV!=="production"){for(let[c,m]of Object.entries(n))if(m.after)for(let S of m.after)n[S]||console.warn(`[Directive] Constraint "${c}" references unknown constraint "${S}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function d(c,m){return m.async!==void 0?m.async:!!w.has(c)}function b(c){let m=n[c];if(!m)throw new Error(`[Directive] Unknown constraint: ${c}`);let S=d(c,m);S&&w.add(c);let F={id:c,priority:m.priority??0,isAsync:S,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:m.after??[],hitCount:0,lastActiveAt:null};return R.set(c,F),F}function T(c){return R.get(c)??b(c)}function j(c,m){let S=u.get(c)??new Set;for(let F of S){let _=E.get(F);_?.delete(c),_&&_.size===0&&E.delete(F);}for(let F of m)E.has(F)||E.set(F,new Set),E.get(F).add(c);u.set(c,m);}function l(c){let m=n[c];if(!m)return false;let S=T(c);S.isEvaluating=true,S.error=null;try{let F;if(m.deps)F=m.when(g),x.set(c,new Set(m.deps));else {let _=Ee(()=>m.when(g));F=_.value,x.set(c,_.deps);}return F instanceof Promise?(w.add(c),S.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${c}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),F.then(_=>(S.lastResult=_,_&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,_),_)).catch(_=>(S.error=_ instanceof Error?_:new Error(String(_)),S.lastResult=!1,S.isEvaluating=!1,f?.(c,_),!1))):(S.lastResult=F,F&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,F),F)}catch(F){return S.error=F instanceof Error?F:new Error(String(F)),S.lastResult=false,S.isEvaluating=false,f?.(c,F),false}}async function a(c){let m=n[c];if(!m)return false;let S=T(c),F=m.timeout??i;if(S.isEvaluating=true,S.error=null,m.deps?.length){let _=new Set(m.deps);j(c,_),x.set(c,_);}try{let _=m.when(g),X=await Te(_,F,`Constraint "${c}" timed out after ${F}ms`);return S.lastResult=X,X&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,X),X}catch(_){return S.error=_ instanceof Error?_:new Error(String(_)),S.lastResult=false,S.isEvaluating=false,f?.(c,_),false}}let h=10;function A(c,m){if(c==null)return [];if(Array.isArray(c)){let S=c.filter(F=>F!=null);return process.env.NODE_ENV!=="production"&&S.length>h&&m&&console.warn(`[Directive] Constraint "${m}" produced ${S.length} requirements. Consider splitting into multiple constraints for better performance.`),S}return [c]}function I(c){let m=n[c];if(!m)return {requirements:[],deps:new Set};let S=m.require;if(typeof S=="function"){let{value:_,deps:X}=Ee(()=>S(g));return {requirements:A(_,c),deps:X}}return {requirements:A(S,c),deps:new Set}}function V(c,m){if(m.size===0)return;let S=u.get(c)??new Set;for(let F of m)S.add(F),E.has(F)||E.set(F,new Set),E.get(F).add(c);u.set(c,S);}let U=null;function $(){return U||(U=Object.keys(n).sort((c,m)=>{let S=T(c),_=T(m).priority-S.priority;if(_!==0)return _;let X=B.get(c)??0,ne=B.get(m)??0;return X-ne})),U}for(let c of Object.keys(n))b(c);if(process.env.NODE_ENV!=="production")for(let[c,m]of Object.entries(n))m.async&&!m.deps&&console.warn(`[Directive] Async constraint "${c}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function N(c){let m=R.get(c);if(!m||m.after.length===0)return true;for(let S of m.after)if(n[S]&&!D.has(S)&&!C.has(S)&&!z.has(S))return false;return true}return {async evaluate(c){let m=new ke;C.clear();let S=$().filter(Y=>!D.has(Y)),F;if(!W||!c||c.size===0)F=S,W=true;else {let Y=new Set;for(let oe of c){let ie=E.get(oe);if(ie)for(let ge of ie)D.has(ge)||Y.add(ge);}for(let oe of v)D.has(oe)||Y.add(oe);v.clear(),F=[...Y];for(let oe of S)if(!Y.has(oe)){let ie=q.get(oe);if(ie)for(let ge of ie)m.add(ge);}}function _(Y,oe){if(D.has(Y))return;let ie=x.get(Y);if(!oe){ie!==void 0&&j(Y,ie),C.add(Y),q.set(Y,[]);return}C.delete(Y);let ge,me;try{let P=I(Y);ge=P.requirements,me=P.deps;}catch(P){f?.(Y,P),ie!==void 0&&j(Y,ie),q.set(Y,[]);return}if(ie!==void 0){let P=new Set(ie);for(let Q of me)P.add(Q);j(Y,P);}else V(Y,me);if(ge.length>0){let P=p[Y],Q=ge.map(re=>_e(re,Y,P));for(let re of Q)m.add(re);q.set(Y,Q);}else q.set(Y,[]);}async function X(Y){let oe=[],ie=[];for(let Q of Y)if(N(Q))ie.push(Q);else {oe.push(Q);let re=q.get(Q);if(re)for(let ve of re)m.add(ve);}if(ie.length===0)return oe;let ge=[],me=[];for(let Q of ie)T(Q).isAsync?me.push(Q):ge.push(Q);let P=[];for(let Q of ge){let re=l(Q);if(re instanceof Promise){P.push({id:Q,promise:re});continue}_(Q,re);}if(P.length>0){let Q=await Promise.all(P.map(async({id:re,promise:ve})=>({id:re,active:await ve})));for(let{id:re,active:ve}of Q)_(re,ve);}if(me.length>0){let Q=await Promise.all(me.map(async re=>({id:re,active:await a(re)})));for(let{id:re,active:ve}of Q)_(re,ve);}return oe}let ne=F,ue=F.length+1;for(;ne.length>0&&ue>0;){let Y=ne.length;if(ne=await X(ne),ne.length===Y)break;ue--;}return m.all()},getState(c){return R.get(c)},getDependencies(c){return u.get(c)},getAllStates(){return [...R.values()]},disable(c){if(!R.has(c)){console.warn(`[Directive] constraints.disable("${c}") \u2014 no such constraint`);return}D.add(c),U=null,q.delete(c);let m=u.get(c);if(m){for(let S of m){let F=E.get(S);F&&(F.delete(c),F.size===0&&E.delete(S));}u.delete(c);}x.delete(c);},enable(c){if(!R.has(c)){console.warn(`[Directive] constraints.enable("${c}") \u2014 no such constraint`);return}D.delete(c),U=null,v.add(c);},isDisabled(c){return D.has(c)},invalidate(c){let m=E.get(c);if(m)for(let S of m)v.add(S);},markResolved(c){z.add(c);let m=R.get(c);m&&(m.lastResolvedAt=Date.now());let S=M.get(c);if(S)for(let F of S)v.add(F);},isResolved(c){return z.has(c)},registerDefinitions(c){for(let[m,S]of Object.entries(c))n[m]=S,b(m),v.add(m);U=null,k(),s();}}}function Be(r){let{definitions:n,facts:g,onCompute:i,onInvalidate:t,onError:f}=r,R=new Map,D=new Map,w=new Map,u=new Map,E=new Set(["__proto__","constructor","prototype"]),v=0,x=new Set,q=false,W=100,z;function C(b){if(!n[b])throw new Error(`[Directive] Unknown derivation: ${b}`);let j={id:b,compute:()=>G(b),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return R.set(b,j),j}function M(b){return R.get(b)??C(b)}function G(b){let T=M(b),j=n[b];if(!j)throw new Error(`[Directive] Unknown derivation: ${b}`);if(T.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${b}`);T.isComputing=true;try{let l=T.cachedValue,{value:a,deps:h}=Ee(()=>j(g,z));return T.cachedValue=a,T.isStale=!1,B(b,h),i?.(b,a,l,[...h]),a}catch(l){throw f?.(b,l),l}finally{T.isComputing=false;}}function B(b,T){let j=M(b),l=j.dependencies;for(let a of l)if(R.has(a)){let h=u.get(a);h?.delete(b),h&&h.size===0&&u.delete(a);}else {let h=w.get(a);h?.delete(b),h&&h.size===0&&w.delete(a);}for(let a of T)n[a]?(u.has(a)||u.set(a,new Set),u.get(a).add(b)):(w.has(a)||w.set(a,new Set),w.get(a).add(b));j.dependencies=T;}function s(){if(!(v>0||q)){q=true;try{let b=0;for(;x.size>0;){if(++b>W){let j=[...x];throw x.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${W} iterations. Remaining: ${j.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let T=[...x];x.clear();for(let j of T)D.get(j)?.forEach(l=>l());}}finally{q=false;}}}function k(b,T=new Set){if(T.has(b))return;T.add(b);let j=R.get(b);if(!j||j.isStale)return;j.isStale=true,t?.(b),x.add(b);let l=u.get(b);if(l)for(let a of l)k(a,T);}return z=new Proxy({},{get(b,T){if(typeof T=="symbol"||E.has(T))return;Ce(T);let j=M(T);return j.isStale&&G(T),j.cachedValue}}),{get(b){let T=M(b);return T.isStale&&G(b),T.cachedValue},isStale(b){return R.get(b)?.isStale??true},invalidate(b){let T=w.get(b);if(T){v++;try{for(let j of T)k(j);}finally{v--,s();}}},invalidateMany(b){v++;try{for(let T of b){let j=w.get(T);if(j)for(let l of j)k(l);}}finally{v--,s();}},invalidateAll(){v++;try{for(let b of R.values())b.isStale||(b.isStale=!0,x.add(b.id));}finally{v--,s();}},subscribe(b,T){for(let j of b){let l=j;D.has(l)||D.set(l,new Set),D.get(l).add(T);}return ()=>{for(let j of b){let l=j,a=D.get(l);a?.delete(T),a&&a.size===0&&D.delete(l);}}},getProxy(){return z},getDependencies(b){return M(b).dependencies},registerDefinitions(b){for(let[T,j]of Object.entries(b))n[T]=j,C(T);}}}function Ve(r){let{definitions:n,facts:g,store:p,onRun:i,onError:t}=r,f=new Map,R=null,D=false;function w(C){let M=n[C];if(!M)throw new Error(`[Directive] Unknown effect: ${C}`);let G={id:C,enabled:true,hasExplicitDeps:!!M.deps,dependencies:M.deps?new Set(M.deps):null,cleanup:null};return f.set(C,G),G}function u(C){return f.get(C)??w(C)}function E(){return p.toObject()}function v(C,M){let G=u(C);if(!G.enabled)return false;if(G.dependencies){for(let B of G.dependencies)if(M.has(B))return true;return false}return true}function x(C){if(C.cleanup){try{C.cleanup();}catch(M){t?.(C.id,M),console.error(`[Directive] Effect "${C.id}" cleanup threw an error:`,M);}C.cleanup=null;}}function q(C,M){if(typeof M=="function")if(D)try{M();}catch(G){t?.(C.id,G),console.error(`[Directive] Effect "${C.id}" cleanup threw an error:`,G);}else C.cleanup=M;}async function W(C){let M=u(C),G=n[C];if(!(!M.enabled||!G)){x(M),i?.(C,M.dependencies?[...M.dependencies]:[]);try{if(M.hasExplicitDeps){let B;if(p.batch(()=>{B=G.run(g,R);}),B instanceof Promise){let s=await B;q(M,s);}else q(M,B);}else {let B=null,s,k=Ee(()=>(p.batch(()=>{s=G.run(g,R);}),s));B=k.deps;let d=k.value;d instanceof Promise&&(d=await d),q(M,d),M.dependencies=B.size>0?B:null;}}catch(B){t?.(C,B),console.error(`[Directive] Effect "${C}" threw an error:`,B);}}}for(let C of Object.keys(n))w(C);return {async runEffects(C){let M=[];for(let G of Object.keys(n))v(G,C)&&M.push(G);await Promise.all(M.map(W)),R=E();},async runAll(){let C=Object.keys(n);await Promise.all(C.map(M=>u(M).enabled?W(M):Promise.resolve())),R=E();},disable(C){let M=u(C);M.enabled=false;},enable(C){let M=u(C);M.enabled=true;},isEnabled(C){return u(C).enabled},cleanupAll(){D=true;for(let C of f.values())x(C);},registerDefinitions(C){for(let[M,G]of Object.entries(C))n[M]=G,w(M);}}}var xe=class extends Error{constructor(g,p,i,t,f=true){super(g);this.source=p;this.sourceId=i;this.context=t;this.recoverable=f;this.name="DirectiveError";}};function dt(r={}){let{delayMs:n=1e3,maxRetries:g=3,backoffMultiplier:p=2,maxDelayMs:i=3e4}=r,t=new Map;function f(R){let D=n*p**(R-1);return Math.min(D,i)}return {scheduleRetry(R,D,w,u,E){if(u>g)return null;let v=f(u),x={source:R,sourceId:D,context:w,attempt:u,nextRetryTime:Date.now()+v,callback:E};return t.set(D,x),x},getPendingRetries(){return Array.from(t.values())},processDueRetries(){let R=Date.now(),D=[];for(let[w,u]of t)u.nextRetryTime<=R&&(D.push(u),t.delete(w));return D},cancelRetry(R){t.delete(R);},clearAll(){t.clear();}}}var ft={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function Ke(r={}){let{config:n={},onError:g,onRecovery:p}=r,i=[],t=100,f=dt(n.retryLater),R=new Map;function D(E,v,x,q){if(x instanceof xe)return x;let W=x instanceof Error?x.message:String(x),z=E!=="system";return new xe(W,E,v,q,z)}function w(E,v,x){let q=(()=>{switch(E){case "constraint":return n.onConstraintError;case "resolver":return n.onResolverError;case "effect":return n.onEffectError;case "derivation":return n.onDerivationError;default:return}})();if(typeof q=="function"){try{let W=q(x,v);if(typeof W=="string")return W}catch(W){console.error("[Directive] Error in error handler callback:",W);}return "skip"}return typeof q=="string"?q:ft[E]}return {handleError(E,v,x,q){let W=D(E,v,x,q);i.push(W),i.length>t&&i.shift();try{g?.(W);}catch(C){console.error("[Directive] Error in onError callback:",C);}try{n.onError?.(W);}catch(C){console.error("[Directive] Error in config.onError callback:",C);}let z=w(E,v,x instanceof Error?x:new Error(String(x)));if(z==="retry-later"){let C=(R.get(v)??0)+1;R.set(v,C),f.scheduleRetry(E,v,q,C)||(z="skip",R.delete(v),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${E} "${v}" exceeded max retry-later attempts. Skipping.`));}try{p?.(W,z);}catch(C){console.error("[Directive] Error in onRecovery callback:",C);}if(z==="throw")throw W;return z},getLastError(){return i[i.length-1]??null},getAllErrors(){return [...i]},clearErrors(){i.length=0;},getRetryLaterManager(){return f},processDueRetries(){return f.processDueRetries()},clearRetryAttempts(E){R.delete(E),f.cancelRetry(E);}}}function gt(r,n=100){try{return JSON.stringify(r)?.slice(0,n)??String(r)}catch{return "[circular or non-serializable]"}}function mt(r){let{schema:n,onChange:g,onBatch:p}=r,t=Object.keys(n).length===0,f=r.validate??process.env.NODE_ENV!=="production",R=r.strictKeys??(process.env.NODE_ENV!=="production"&&!t),D=r.redactErrors??false,w=new Map,u=new Set,E=new Map,v=new Set,x=0,q=[],W=new Set,z=false,C=[],M=100;function G(a){return a!==null&&typeof a=="object"&&"safeParse"in a&&typeof a.safeParse=="function"&&"_def"in a&&"parse"in a&&typeof a.parse=="function"}function B(a){let h=a;if(h._typeName)return h._typeName;if(G(a)){let A=a._def;if(A?.typeName)return A.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function s(a){return D?"[redacted]":gt(a)}function k(a,h){if(!f)return;let A=n[a];if(!A){if(R)throw new Error(`[Directive] Unknown fact key: "${a}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${a}"`);return}if(G(A)){let $=A.safeParse(h);if(!$.success){let N=h===null?"null":Array.isArray(h)?"array":typeof h,O=s(h),c=$.error?.message??$.error?.issues?.[0]?.message??"Validation failed",m=B(A);throw new Error(`[Directive] Validation failed for "${a}": expected ${m}, got ${N} ${O}. ${c}`)}return}let I=A,V=I._validators;if(!V||!Array.isArray(V)||V.length===0)return;let U=I._typeName??"unknown";for(let $=0;$<V.length;$++){let N=V[$];if(typeof N=="function"&&!N(h)){let O=h===null?"null":Array.isArray(h)?"array":typeof h,c=s(h),m="";typeof I._lastFailedIndex=="number"&&I._lastFailedIndex>=0&&(m=` (element at index ${I._lastFailedIndex} failed)`,I._lastFailedIndex=-1);let S=$===0?"":` (validator ${$+1} failed)`;throw new Error(`[Directive] Validation failed for "${a}": expected ${U}, got ${O} ${c}${S}${m}`)}}}function d(a){E.get(a)?.forEach(h=>h());}function b(){v.forEach(a=>a());}function T(a,h,A){if(z){C.push({key:a,value:h,prev:A});return}z=true;try{g?.(a,h,A),d(a),b();let I=0;for(;C.length>0;){if(++I>M)throw C.length=0,new Error(`[Directive] Infinite notification loop detected after ${M} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let V=[...C];C.length=0;for(let U of V)g?.(U.key,U.value,U.prev),d(U.key);b();}}finally{z=false;}}function j(){if(!(x>0)){if(p&&q.length>0&&p([...q]),W.size>0){z=true;try{for(let h of W)d(h);b();let a=0;for(;C.length>0;){if(++a>M)throw C.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${M} iterations.`);let h=[...C];C.length=0;for(let A of h)g?.(A.key,A.value,A.prev),d(A.key);b();}}finally{z=false;}}q.length=0,W.clear();}}let l={get(a){return Ce(a),w.get(a)},has(a){return Ce(a),w.has(a)},set(a,h){k(a,h);let A=w.get(a);Object.is(A,h)||(w.set(a,h),u.add(a),x>0?(q.push({key:a,value:h,prev:A,type:"set"}),W.add(a)):T(a,h,A));},delete(a){let h=w.get(a);w.delete(a),u.delete(a),x>0?(q.push({key:a,value:void 0,prev:h,type:"delete"}),W.add(a)):T(a,void 0,h);},batch(a){x++;try{a();}finally{x--,j();}},subscribe(a,h){for(let A of a){let I=A;E.has(I)||E.set(I,new Set),E.get(I).add(h);}return ()=>{for(let A of a){let I=E.get(A);I&&(I.delete(h),I.size===0&&E.delete(A));}}},subscribeAll(a){return v.add(a),()=>v.delete(a)},toObject(){let a={};for(let h of u)w.has(h)&&(a[h]=w.get(h));return a}};return l.registerKeys=a=>{for(let h of Object.keys(a))Me.has(h)||(n[h]=a[h],u.add(h));},l}var Me=Object.freeze(new Set(["__proto__","constructor","prototype"]));function yt(r,n){let g=()=>({get:i=>qe(()=>r.get(i)),has:i=>qe(()=>r.has(i))});return new Proxy({},{get(i,t){if(t==="$store")return r;if(t==="$snapshot")return g;if(typeof t!="symbol"&&!Me.has(t))return r.get(t)},set(i,t,f){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Me.has(t)?false:(r.set(t,f),true)},deleteProperty(i,t){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Me.has(t)?false:(r.delete(t),true)},has(i,t){return t==="$store"||t==="$snapshot"?true:typeof t=="symbol"||Me.has(t)?false:r.has(t)},ownKeys(){return Object.keys(n)},getOwnPropertyDescriptor(i,t){return t==="$store"||t==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}}})}function We(r){let n=mt(r),g=yt(n,r.schema);return {store:n,facts:g}}function ze(){let r=[];function n(i){if(i)try{return i()}catch(t){console.error("[Directive] Plugin error:",t);return}}async function g(i){if(i)try{return await i()}catch(t){console.error("[Directive] Plugin error:",t);return}}return {register(i){r.some(t=>t.name===i.name)&&(console.warn(`[Directive] Plugin "${i.name}" is already registered, replacing...`),this.unregister(i.name)),r.push(i);},unregister(i){let t=r.findIndex(f=>f.name===i);t!==-1&&r.splice(t,1);},getPlugins(){return [...r]},async emitInit(i){for(let t of r)await g(()=>t.onInit?.(i));},emitStart(i){for(let t of r)n(()=>t.onStart?.(i));},emitStop(i){for(let t of r)n(()=>t.onStop?.(i));},emitDestroy(i){for(let t of r)n(()=>t.onDestroy?.(i));},emitFactSet(i,t,f){for(let R of r)n(()=>R.onFactSet?.(i,t,f));},emitFactDelete(i,t){for(let f of r)n(()=>f.onFactDelete?.(i,t));},emitFactsBatch(i){for(let t of r)n(()=>t.onFactsBatch?.(i));},emitDerivationCompute(i,t,f){for(let R of r)n(()=>R.onDerivationCompute?.(i,t,f));},emitDerivationInvalidate(i){for(let t of r)n(()=>t.onDerivationInvalidate?.(i));},emitReconcileStart(i){for(let t of r)n(()=>t.onReconcileStart?.(i));},emitReconcileEnd(i){for(let t of r)n(()=>t.onReconcileEnd?.(i));},emitConstraintEvaluate(i,t){for(let f of r)n(()=>f.onConstraintEvaluate?.(i,t));},emitConstraintError(i,t){for(let f of r)n(()=>f.onConstraintError?.(i,t));},emitRequirementCreated(i){for(let t of r)n(()=>t.onRequirementCreated?.(i));},emitRequirementMet(i,t){for(let f of r)n(()=>f.onRequirementMet?.(i,t));},emitRequirementCanceled(i){for(let t of r)n(()=>t.onRequirementCanceled?.(i));},emitResolverStart(i,t){for(let f of r)n(()=>f.onResolverStart?.(i,t));},emitResolverComplete(i,t,f){for(let R of r)n(()=>R.onResolverComplete?.(i,t,f));},emitResolverError(i,t,f){for(let R of r)n(()=>R.onResolverError?.(i,t,f));},emitResolverRetry(i,t,f){for(let R of r)n(()=>R.onResolverRetry?.(i,t,f));},emitResolverCancel(i,t){for(let f of r)n(()=>f.onResolverCancel?.(i,t));},emitEffectRun(i){for(let t of r)n(()=>t.onEffectRun?.(i));},emitEffectError(i,t){for(let f of r)n(()=>f.onEffectError?.(i,t));},emitSnapshot(i){for(let t of r)n(()=>t.onSnapshot?.(i));},emitTimeTravel(i,t){for(let f of r)n(()=>f.onTimeTravel?.(i,t));},emitError(i){for(let t of r)n(()=>t.onError?.(i));},emitErrorRecovery(i,t){for(let f of r)n(()=>f.onErrorRecovery?.(i,t));},emitRunComplete(i){for(let t of r)n(()=>t.onRunComplete?.(i));}}}var He={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},Le={enabled:false,windowMs:50};function Ue(r,n){let{backoff:g,initialDelay:p=100,maxDelay:i=3e4}=r,t;switch(g){case "none":t=p;break;case "linear":t=p*n;break;case "exponential":t=p*2**(n-1);break;default:t=p;}return Math.max(1,Math.min(t,i))}function Je(r){let{definitions:n,facts:g,store:p,onStart:i,onComplete:t,onError:f,onRetry:R,onCancel:D,onResolutionComplete:w}=r;if(process.env.NODE_ENV!=="production")for(let[l,a]of Object.entries(n)){if(!a.resolve&&!a.resolveBatch&&!a.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${l}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(a.batch?.enabled&&!a.resolveBatch&&!a.resolveBatchWithResults)if(a.resolve)console.warn(`[Directive] Resolver "${l}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${l}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let u=new Map,E=new Map,v=1e3,x=new Map,q=new Map,W=1e3;function z(){if(E.size>v){let l=E.size-v,a=E.keys();for(let h=0;h<l;h++){let A=a.next().value;A&&E.delete(A);}}}function C(l){return typeof l=="object"&&l!==null&&"requirement"in l&&typeof l.requirement=="string"}function M(l){return typeof l=="object"&&l!==null&&"requirement"in l&&typeof l.requirement=="function"}function G(l,a){return C(l)?a.type===l.requirement:M(l)?l.requirement(a):false}function B(l){let a=l.type,h=q.get(a);if(h)for(let A of h){let I=n[A];if(I&&G(I,l))return A}for(let[A,I]of Object.entries(n))if(G(I,l)){if(!q.has(a)){if(q.size>=W){let U=q.keys().next().value;U!==void 0&&q.delete(U);}q.set(a,[]);}let V=q.get(a);return V.includes(A)||V.push(A),A}return null}function s(l){return {facts:g,signal:l,snapshot:()=>g.$snapshot()}}async function k(l,a,h){let A=n[l];if(!A)return;let I={...He,...A.retry},V=null;for(let U=1;U<=I.attempts;U++){if(h.signal.aborted)return;let $=u.get(a.id);$&&($.attempt=U,$.status={state:"running",requirementId:a.id,startedAt:$.startedAt,attempt:U});try{let N=s(h.signal);if(A.resolve){let c;p.batch(()=>{c=A.resolve(a.requirement,N);});let m=A.timeout;m&&m>0?await Te(c,m,`Resolver "${l}" timed out after ${m}ms`):await c;}let O=Date.now()-($?.startedAt??Date.now());E.set(a.id,{state:"success",requirementId:a.id,completedAt:Date.now(),duration:O}),z(),t?.(l,a,O);return}catch(N){if(V=N instanceof Error?N:new Error(String(N)),h.signal.aborted)return;if(I.shouldRetry&&!I.shouldRetry(V,U))break;if(U<I.attempts){if(h.signal.aborted)return;let O=Ue(I,U);if(R?.(l,a,U+1),await new Promise(c=>{let m=setTimeout(c,O),S=()=>{clearTimeout(m),c();};h.signal.addEventListener("abort",S,{once:true});}),h.signal.aborted)return}}}E.set(a.id,{state:"error",requirementId:a.id,error:V,failedAt:Date.now(),attempts:I.attempts}),z(),f?.(l,a,V);}async function d(l,a){let h=n[l];if(!h)return;if(!h.resolveBatch&&!h.resolveBatchWithResults){await Promise.all(a.map(O=>{let c=new AbortController;return k(l,O,c)}));return}let A={...He,...h.retry},I={...Le,...h.batch},V=new AbortController,U=Date.now(),$=null,N=I.timeoutMs??h.timeout;for(let O=1;O<=A.attempts;O++){if(V.signal.aborted)return;try{let c=s(V.signal),m=a.map(S=>S.requirement);if(h.resolveBatchWithResults){let S,F;if(p.batch(()=>{F=h.resolveBatchWithResults(m,c);}),N&&N>0?S=await Te(F,N,`Batch resolver "${l}" timed out after ${N}ms`):S=await F,S.length!==a.length)throw new Error(`[Directive] Batch resolver "${l}" returned ${S.length} results but expected ${a.length}. Results array must match input order.`);let _=Date.now()-U,X=!1;for(let ne=0;ne<a.length;ne++){let ue=a[ne],Y=S[ne];if(Y.success)E.set(ue.id,{state:"success",requirementId:ue.id,completedAt:Date.now(),duration:_}),t?.(l,ue,_);else {X=!0;let oe=Y.error??new Error("Batch item failed");E.set(ue.id,{state:"error",requirementId:ue.id,error:oe,failedAt:Date.now(),attempts:O}),f?.(l,ue,oe);}}if(!X||a.some((ne,ue)=>S[ue]?.success))return}else {let S;p.batch(()=>{S=h.resolveBatch(m,c);}),N&&N>0?await Te(S,N,`Batch resolver "${l}" timed out after ${N}ms`):await S;let F=Date.now()-U;for(let _ of a)E.set(_.id,{state:"success",requirementId:_.id,completedAt:Date.now(),duration:F}),t?.(l,_,F);return}}catch(c){if($=c instanceof Error?c:new Error(String(c)),V.signal.aborted)return;if(A.shouldRetry&&!A.shouldRetry($,O))break;if(O<A.attempts){let m=Ue(A,O);for(let S of a)R?.(l,S,O+1);if(await new Promise(S=>{let F=setTimeout(S,m),_=()=>{clearTimeout(F),S();};V.signal.addEventListener("abort",_,{once:true});}),V.signal.aborted)return}}}for(let O of a)E.set(O.id,{state:"error",requirementId:O.id,error:$,failedAt:Date.now(),attempts:A.attempts}),f?.(l,O,$);z();}function b(l,a){let h=n[l];if(!h)return;let A={...Le,...h.batch};x.has(l)||x.set(l,{resolverId:l,requirements:[],timer:null});let I=x.get(l);if(I.requirements.push(a),A.maxSize&&I.requirements.length>=A.maxSize){I.timer&&(clearTimeout(I.timer),I.timer=null),T(l);return}I.timer&&clearTimeout(I.timer),I.timer=setTimeout(()=>{T(l);},A.windowMs);}function T(l){let a=x.get(l);if(!a||a.requirements.length===0)return;let h=[...a.requirements];a.requirements=[],a.timer=null,d(l,h).then(()=>{w?.();});}return {resolve(l){if(u.has(l.id))return;let a=B(l.requirement);if(!a){console.warn(`[Directive] No resolver found for requirement type "${l.requirement.type}" (id: ${l.id})`);return}let h=n[a];if(!h)return;if(h.batch?.enabled){b(a,l);return}let A=new AbortController,I=Date.now(),V={requirementId:l.id,resolverId:a,controller:A,startedAt:I,attempt:1,status:{state:"pending",requirementId:l.id,startedAt:I},originalRequirement:l};u.set(l.id,V),i?.(a,l),k(a,l,A).finally(()=>{u.delete(l.id)&&w?.();});},cancel(l){let a=u.get(l);if(a){a.controller.abort(),u.delete(l),E.set(l,{state:"canceled",requirementId:l,canceledAt:Date.now()}),z(),D?.(a.resolverId,a.originalRequirement);return}for(let h of x.values()){let A=h.requirements.findIndex(I=>I.id===l);if(A!==-1){let[I]=h.requirements.splice(A,1);E.set(l,{state:"canceled",requirementId:l,canceledAt:Date.now()}),z(),I&&D?.(h.resolverId,I);return}}},cancelAll(){let l=[...u.keys()];for(let a of l)this.cancel(a);for(let a of x.values()){a.timer&&clearTimeout(a.timer);for(let h of a.requirements)E.set(h.id,{state:"canceled",requirementId:h.id,canceledAt:Date.now()}),D?.(a.resolverId,h);}x.clear(),z();},getStatus(l){let a=u.get(l);if(a)return a.status;let h=E.get(l);return h||{state:"idle"}},getInflight(){return [...u.keys()]},getInflightInfo(){return [...u.values()].map(l=>({id:l.requirementId,resolverId:l.resolverId,startedAt:l.startedAt}))},isResolving(l){return u.has(l)},processBatches(){for(let l of x.keys())T(l);},hasPendingBatches(){for(let l of x.values())if(l.requirements.length>0)return true;return false},registerDefinitions(l){for(let[a,h]of Object.entries(l))n[a]=h;q.clear();}}}var he=new Set(["__proto__","constructor","prototype"]);function Ae(r){let n=Object.create(null),g=Object.create(null),p=Object.create(null),i=Object.create(null),t=Object.create(null),f=Object.create(null),R=new Map;for(let e of r.modules){let o=(y,K)=>{if(y){for(let J of Object.keys(y))if(he.has(J))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${J}" in ${K}. This could indicate a prototype pollution attempt.`)}};if(o(e.schema,"schema"),o(e.events,"events"),o(e.derive,"derive"),o(e.effects,"effects"),o(e.constraints,"constraints"),o(e.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let y of Object.keys(e.schema)){let K=R.get(y);if(K)throw new Error(`[Directive] Schema collision: Fact "${y}" is defined in both module "${K}" and "${e.id}". Use namespacing (e.g., "${e.id}::${y}") or merge into one module.`);R.set(y,e.id);}Object.assign(n,e.schema),e.events&&Object.assign(g,e.events),e.derive&&Object.assign(p,e.derive),e.effects&&Object.assign(i,e.effects),e.constraints&&Object.assign(t,e.constraints),e.resolvers&&Object.assign(f,e.resolvers);}let D=null;if(r.modules.some(e=>e.snapshotEvents)){D=new Set;for(let e of r.modules){let o=e;if(o.snapshotEvents)for(let y of o.snapshotEvents)D.add(y);else if(o.events)for(let y of Object.keys(o.events))D.add(y);}}let u=0,E=false;if(process.env.NODE_ENV!=="production"){let e=new Set(Object.keys(p));for(let o of Object.keys(n))e.has(o)&&console.warn(`[Directive] "${o}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let v=ze();for(let e of r.plugins??[])v.register(e);let x=Ke({config:r.errorBoundary,onError:e=>v.emitError(e),onRecovery:(e,o)=>v.emitErrorRecovery(e,o)}),q=null,W=()=>{},z=()=>{},C=null,M=r.debug?.runHistory??false,G=r.debug?.maxRuns??100,B=[],s=new Map,k=0,d=null,b=[],T=new Map,j=new Map,l=new Map,a=null,h=0,A=0,I={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0},{store:V,facts:U}=We({schema:n,onChange:(e,o,y)=>{v.emitFactSet(e,o,y),W(e),M&&b.push({key:String(e),oldValue:y,newValue:o}),!C?.isRestoring&&(u===0&&(E=true),P.changedKeys.add(e),Q());},onBatch:e=>{v.emitFactsBatch(e);let o=[];for(let y of e)o.push(y.key);if(M)for(let y of e)y.type==="delete"?b.push({key:y.key,oldValue:y.prev,newValue:void 0}):b.push({key:y.key,oldValue:y.prev,newValue:y.value});if(z(o),!C?.isRestoring){u===0&&(E=true);for(let y of e)P.changedKeys.add(y.key);Q();}}}),$=Be({definitions:p,facts:U,onCompute:(e,o,y,K)=>{v.emitDerivationCompute(e,o,K),d&&d.derivationsRecomputed.push({id:e,deps:K?[...K]:[],oldValue:y,newValue:o});},onInvalidate:e=>v.emitDerivationInvalidate(e),onError:(e,o)=>{x.handleError("derivation",e,o)==="retry"&&$.invalidate(e);}});W=e=>$.invalidate(e),z=e=>$.invalidateMany(e);let N=Ve({definitions:i,facts:U,store:V,onRun:(e,o)=>{v.emitEffectRun(e),d&&d.effectsRun.push({id:e,triggeredBy:o});},onError:(e,o)=>{let y=x.handleError("effect",e,o);v.emitEffectError(e,o),d&&d.effectErrors.push({id:e,error:String(o)}),y==="disable"&&N.disable(e),y==="retry"&&(P.changedKeys.add("*"),Q());}}),O=Ne({definitions:t,facts:U,onEvaluate:(e,o)=>v.emitConstraintEvaluate(e,o),onError:(e,o)=>{let y=x.handleError("constraint",e,o);v.emitConstraintError(e,o),y==="disable"&&O.disable(e);}});function c(e){let o=s.get(e);if(o&&o.status==="pending"){o.status="settled";let y=l.get(e);o.duration=y!==void 0?performance.now()-y:Date.now()-o.timestamp,l.delete(e),j.delete(e),o.causalChain=F(o),_(o),A++,v.emitRunComplete(o);}}function m(e){let o=T.get(e);if(T.delete(e),o!==void 0){let y=(j.get(o)??1)-1;y<=0?c(o):j.set(o,y);}}function S(){let e=B.shift();if(e&&(s.delete(e.id),l.delete(e.id),e.status==="pending")){j.delete(e.id);for(let[o,y]of T)y===e.id&&T.delete(o);}}function F(e){let o=[];for(let y of e.factChanges)o.push(`${y.key} changed`);for(let y of e.derivationsRecomputed)o.push(`${y.id} recomputed`);for(let y of e.constraintsHit)o.push(`${y.id} constraint hit`);for(let y of e.requirementsAdded)o.push(`${y.type} requirement added`);for(let y of e.resolversCompleted)o.push(`${y.resolver} resolved (${y.duration.toFixed(0)}ms)`);for(let y of e.resolversErrored)o.push(`${y.resolver} errored`);for(let y of e.effectsRun)o.push(`${y.id} effect ran`);return o.join(" \u2192 ")}function _(e){I.count++,I.totalDuration+=e.duration,I.avgDuration=I.totalDuration/I.count,e.duration>I.maxDuration&&(I.maxDuration=e.duration);let o=e.resolversStarted.length;I.totalResolverCount+=o,I.avgResolverCount=I.totalResolverCount/I.count;let y=e.factChanges.length;I.totalFactChangeCount+=y,I.avgFactChangeCount=I.totalFactChangeCount/I.count;let K=[];I.count>3&&e.duration>I.avgDuration*5&&K.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${I.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&K.push(`${e.resolversErrored.length} resolver(s) errored`),K.length>0&&(e.anomalies=K);}let X=Je({definitions:f,facts:U,store:V,onStart:(e,o)=>v.emitResolverStart(e,o),onComplete:(e,o,y)=>{if(x.clearRetryAttempts(e),v.emitResolverComplete(e,o,y),v.emitRequirementMet(o,e),O.markResolved(o.fromConstraint),M){let K=T.get(o.id);if(K!==void 0){let J=s.get(K);J&&J.resolversCompleted.push({resolver:e,requirementId:o.id,duration:y});}m(o.id);}},onError:(e,o,y)=>{let K=x.handleError("resolver",e,y,o);if(v.emitResolverError(e,o,y),K==="disable"&&O.disable(o.fromConstraint),K==="retry"&&(P.previousRequirements.remove(o.id),Q()),K==="retry-later"){let H=x.getRetryLaterManager().getPendingRetries().find(ee=>ee.sourceId===e);H&&!H.callback&&(H.callback=()=>{Q();});}if(M){let J=T.get(o.id);if(J!==void 0){let H=s.get(J);H&&H.resolversErrored.push({resolver:e,requirementId:o.id,error:String(y)});}m(o.id);}},onRetry:(e,o,y)=>v.emitResolverRetry(e,o,y),onCancel:(e,o)=>{v.emitResolverCancel(e,o),v.emitRequirementCanceled(o),M&&m(o.id);},onResolutionComplete:()=>{ie(),Q();}}),ne=new Set;function ue(){for(let e of ne)e();}let Y=r.debug?.timeTravel?je({config:r.debug,facts:U,store:V,onSnapshot:e=>{v.emitSnapshot(e),ue();},onTimeTravel:(e,o)=>{v.emitTimeTravel(e,o),ue();}}):Fe();C=Y;let oe=new Set;function ie(){for(let e of oe)e();}let ge=50,me=0,P={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new ke,readyPromise:null,readyResolve:null};function Q(){!P.isRunning||P.reconcileScheduled||P.isInitializing||(P.reconcileScheduled=true,ie(),queueMicrotask(()=>{P.reconcileScheduled=false,P.isRunning&&!P.isInitializing&&re().catch(e=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function re(){if(P.isReconciling)return;if(me++,me>ge){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${ge} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),M&&(b.length=0),me=0;return}P.isReconciling=true,ie();let e=M?performance.now():0;if(M){let o=++k;l.set(o,e),d={id:o,timestamp:Date.now(),duration:0,status:"pending",factChanges:b.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]};}try{P.changedKeys.size>0&&((D===null||E)&&Y.takeSnapshot(`facts-changed:${[...P.changedKeys].join(",")}`),E=!1);let o=U.$snapshot();v.emitReconcileStart(o),await N.runEffects(P.changedKeys);let y=new Set(P.changedKeys);P.changedKeys.clear();let K=await O.evaluate(y),J=new ke;for(let Z of K)J.add(Z),v.emitRequirementCreated(Z);if(d){let Z=new Set(K.map(te=>te.fromConstraint));for(let te of Z){let de=O.getState(te);if(de){let se=O.getDependencies(te);d.constraintsHit.push({id:te,priority:de.priority,deps:se?[...se]:[]});}}}let{added:H,removed:ee}=J.diff(P.previousRequirements);if(d){for(let Z of H)d.requirementsAdded.push({id:Z.id,type:Z.requirement.type,fromConstraint:Z.fromConstraint});for(let Z of ee)d.requirementsRemoved.push({id:Z.id,type:Z.requirement.type,fromConstraint:Z.fromConstraint});}for(let Z of ee)X.cancel(Z.id);for(let Z of H)X.resolve(Z);if(d){let Z=X.getInflightInfo();for(let te of H){let de=Z.find(se=>se.id===te.id);d.resolversStarted.push({resolver:de?.resolverId??"unknown",requirementId:te.id}),T.set(te.id,d.id);}}P.previousRequirements=J;let ce=X.getInflightInfo(),le={unmet:K.filter(Z=>!X.isResolving(Z.id)),inflight:ce,completed:[],canceled:ee.map(Z=>({id:Z.id,resolverId:ce.find(te=>te.id===Z.id)?.resolverId??"unknown"}))};v.emitReconcileEnd(le),P.isReady||(P.isReady=!0,P.readyResolve&&(P.readyResolve(),P.readyResolve=null));}finally{if(d){if(d.duration=performance.now()-e,d.factChanges.length>0||d.constraintsHit.length>0||d.requirementsAdded.length>0||d.effectsRun.length>0){let y=d.resolversStarted.length;y===0?(d.status="settled",d.causalChain=F(d),_(d),B.push(d),s.set(d.id,d),B.length>G&&S(),A++,v.emitRunComplete(d)):(d.status="pending",B.push(d),s.set(d.id,d),B.length>G&&S(),A++,j.set(d.id,y));}else l.delete(d.id);d=null;}P.isReconciling=false,P.changedKeys.size>0?Q():P.reconcileScheduled||(me=0),ie();}}let ve=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return $.get(o)},has(e,o){return typeof o=="symbol"||he.has(o)?false:o in p},ownKeys(){return Object.keys(p)},getOwnPropertyDescriptor(e,o){if(typeof o!="symbol"&&!he.has(o)&&o in p)return {configurable:true,enumerable:true}}}),rt=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return y=>{let K=g[o];if(K){u++,(D===null||D.has(o))&&(E=true);try{V.batch(()=>{K(U,{type:o,...y});});}finally{u--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${o}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);}},has(e,o){return typeof o=="symbol"||he.has(o)?false:o in g},ownKeys(){return Object.keys(g)},getOwnPropertyDescriptor(e,o){if(typeof o!="symbol"&&!he.has(o)&&o in g)return {configurable:true,enumerable:true}}}),ye={facts:U,debug:Y.isEnabled?Y:null,derive:ve,events:rt,constraints:{disable:e=>O.disable(e),enable:e=>O.enable(e),isDisabled:e=>O.isDisabled(e)},effects:{disable:e=>N.disable(e),enable:e=>N.enable(e),isEnabled:e=>N.isEnabled(e)},get runHistory(){return M?((!a||h!==A)&&(a=[...B],h=A),a):null},initialize(){if(!P.isInitialized){P.isInitializing=true;for(let e of r.modules)e.init&&V.batch(()=>{e.init(U);});r.onAfterModuleInit&&V.batch(()=>{r.onAfterModuleInit();}),P.isInitializing=false,P.isInitialized=true;for(let e of Object.keys(p))$.get(e);}},start(){if(!P.isRunning){P.isInitialized||this.initialize(),P.isRunning=true;for(let e of r.modules)e.hooks?.onStart?.(ye);if(v.emitStart(ye),r.errorBoundary?.retryLater&&!q){let e=Math.max(r.errorBoundary.retryLater.delayMs??1e3,250);q=setInterval(()=>{let o=x.processDueRetries();for(let y of o)y.callback?y.callback():Q();},Math.min(e,500));}Q();}},stop(){if(P.isRunning){P.isRunning=false,q!==null&&(clearInterval(q),q=null),x.getRetryLaterManager().clearAll(),X.cancelAll(),N.cleanupAll();for(let e of r.modules)e.hooks?.onStop?.(ye);v.emitStop(ye);}},destroy(){this.stop(),P.isDestroyed=true,oe.clear(),ne.clear(),B.length=0,s.clear(),T.clear(),j.clear(),l.clear(),b.length=0,d=null,a=null,v.emitDestroy(ye);},dispatch(e){if(he.has(e.type))return;let o=g[e.type];if(o){u++,(D===null||D.has(e.type))&&(E=true);try{V.batch(()=>{o(U,e);});}finally{u--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${e.type}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);},read(e){return $.get(e)},subscribe(e,o){let y=[],K=[];for(let H of e)H in p?y.push(H):H in n?K.push(H):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${H}"`);let J=[];return y.length>0&&J.push($.subscribe(y,o)),K.length>0&&J.push(V.subscribe(K,o)),()=>{for(let H of J)H();}},watch(e,o,y){let K=y?.equalityFn?(H,ee)=>y.equalityFn(H,ee):(H,ee)=>Object.is(H,ee);if(e in p){let H=$.get(e);return $.subscribe([e],()=>{let ee=$.get(e);if(!K(ee,H)){let ce=H;H=ee,o(ee,ce);}})}process.env.NODE_ENV!=="production"&&(e in n||console.warn(`[Directive] watch: unknown key "${e}"`));let J=V.get(e);return V.subscribe([e],()=>{let H=V.get(e);if(!K(H,J)){let ee=J;J=H,o(H,ee);}})},when(e,o){return new Promise((y,K)=>{let J=V.toObject();if(e(J)){y();return}let H,ee,ce=()=>{H?.(),ee!==void 0&&clearTimeout(ee);};H=V.subscribeAll(()=>{let le=V.toObject();e(le)&&(ce(),y());}),o?.timeout!==void 0&&o.timeout>0&&(ee=setTimeout(()=>{ce(),K(new Error(`[Directive] when: timed out after ${o.timeout}ms`));},o.timeout));})},inspect(){return {unmet:P.previousRequirements.all(),inflight:X.getInflightInfo(),constraints:O.getAllStates().map(e=>({id:e.id,active:e.lastResult??false,disabled:O.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt})),resolvers:Object.fromEntries(X.getInflight().map(e=>[e,X.getStatus(e)])),resolverDefs:Object.entries(f).map(([e,o])=>({id:e,requirement:typeof o.requirement=="string"?o.requirement:"(predicate)"})),runHistoryEnabled:M,...M?{runHistory:B.map(e=>({...e,factChanges:e.factChanges.map(o=>({...o})),derivationsRecomputed:e.derivationsRecomputed.map(o=>({...o,deps:[...o.deps]})),constraintsHit:e.constraintsHit.map(o=>({...o,deps:[...o.deps]})),requirementsAdded:e.requirementsAdded.map(o=>({...o})),requirementsRemoved:e.requirementsRemoved.map(o=>({...o})),resolversStarted:e.resolversStarted.map(o=>({...o})),resolversCompleted:e.resolversCompleted.map(o=>({...o})),resolversErrored:e.resolversErrored.map(o=>({...o})),effectsRun:e.effectsRun.map(o=>({...o,triggeredBy:[...o.triggeredBy]})),effectErrors:e.effectErrors.map(o=>({...o}))}))}:{}}},explain(e){let y=P.previousRequirements.all().find(te=>te.id===e);if(!y)return null;let K=O.getState(y.fromConstraint),J=X.getStatus(e),H={},ee=V.toObject();for(let[te,de]of Object.entries(ee))H[te]=de;let ce=[`Requirement "${y.requirement.type}" (id: ${y.id})`,`\u251C\u2500 Produced by constraint: ${y.fromConstraint}`,`\u251C\u2500 Constraint priority: ${K?.priority??0}`,`\u251C\u2500 Constraint active: ${K?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${J.state}`],le=Object.entries(y.requirement).filter(([te])=>te!=="type").map(([te,de])=>`${te}=${JSON.stringify(de)}`).join(", ");le&&ce.push(`\u251C\u2500 Requirement payload: { ${le} }`);let Z=Object.entries(H).slice(0,10);return Z.length>0&&(ce.push("\u2514\u2500 Relevant facts:"),Z.forEach(([te,de],se)=>{let be=se===Z.length-1?" \u2514\u2500":" \u251C\u2500",we=typeof de=="object"?JSON.stringify(de):String(de);ce.push(`${be} ${te} = ${we.slice(0,50)}${we.length>50?"...":""}`);})),ce.join(`
2
2
  `)},async settle(e=5e3){let o=Date.now();for(;;){X.hasPendingBatches()&&X.processBatches(),await new Promise(J=>setTimeout(J,0));let y=this.inspect();if(y.inflight.length===0&&!P.isReconciling&&!P.reconcileScheduled&&!X.hasPendingBatches())return;if(Date.now()-o>e){let J=[];y.inflight.length>0&&J.push(`${y.inflight.length} resolvers inflight: ${y.inflight.map(ee=>ee.resolverId).join(", ")}`),P.isReconciling&&J.push("reconciliation in progress"),P.reconcileScheduled&&J.push("reconcile scheduled");let H=P.previousRequirements.all();throw H.length>0&&J.push(`${H.length} unmet requirements: ${H.map(ee=>ee.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${e}ms. ${J.join("; ")}`)}await new Promise(J=>setTimeout(J,10));}},getSnapshot(){return {facts:V.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:o,excludeDerivations:y,includeFacts:K,ttlSeconds:J,metadata:H,includeVersion:ee}=e,ce={},le=Object.keys(p),Z;if(o){if(Z=o.filter(se=>le.includes(se)),process.env.NODE_ENV!=="production"){let se=o.filter(be=>!le.includes(be));se.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${se.join(", ")}. Available: ${le.join(", ")||"(none)"}`);}}else Z=le;if(y){let se=new Set(y);Z=Z.filter(be=>!se.has(be));}for(let se of Z)try{ce[se]=$.get(se);}catch(be){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${se}" due to error:`,be);}if(K&&K.length>0){let se=V.toObject(),be=Object.keys(se);if(process.env.NODE_ENV!=="production"){let we=K.filter(ot=>!(ot in se));we.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${we.join(", ")}. Available: ${be.join(", ")||"(none)"}`);}for(let we of K)we in se&&(ce[we]=se[we]);}let te=Date.now(),de={data:ce,createdAt:te};return J!==void 0&&J>0&&(de.expiresAt=te+J*1e3),ee&&(de.version=Pe(ce)),H&&(de.metadata=H),de},watchDistributableSnapshot(e,o){let{includeDerivations:y,excludeDerivations:K}=e,J=Object.keys(p),H;if(y?H=y.filter(le=>J.includes(le)):H=J,K){let le=new Set(K);H=H.filter(Z=>!le.has(Z));}if(H.length===0)return process.env.NODE_ENV!=="production"&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let ce=this.getDistributableSnapshot({...e,includeVersion:true}).version;return $.subscribe(H,()=>{let le=this.getDistributableSnapshot({...e,includeVersion:true});le.version!==ce&&(ce=le.version,o(le));})},restore(e){if(!e||typeof e!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!e.facts||typeof e.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!Re(e))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");V.batch(()=>{for(let[o,y]of Object.entries(e.facts))he.has(o)||V.set(o,y);});},onSettledChange(e){return oe.add(e),()=>{oe.delete(e);}},onTimeTravelChange(e){return ne.add(e),()=>{ne.delete(e);}},batch(e){V.batch(e);},get isSettled(){return X.getInflight().length===0&&!X.hasPendingBatches()&&!P.isReconciling&&!P.reconcileScheduled},get isRunning(){return P.isRunning},get isInitialized(){return P.isInitialized},get isReady(){return P.isReady},whenReady(){return P.isReady?Promise.resolve():P.isRunning?(P.readyPromise||(P.readyPromise=new Promise(e=>{P.readyResolve=e;})),P.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function st(e){if(P.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(P.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let o=(y,K)=>{if(y){for(let J of Object.keys(y))if(he.has(J))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${J}" in ${K}.`)}};o(e.schema,"schema"),o(e.events,"events"),o(e.derive,"derive"),o(e.effects,"effects"),o(e.constraints,"constraints"),o(e.resolvers,"resolvers");for(let y of Object.keys(e.schema))if(y in n)throw new Error(`[Directive] Schema collision: Fact "${y}" already exists. Cannot register module "${e.id}".`);if(process.env.NODE_ENV!=="production"&&e.derive){let y=new Set(Object.keys(n));for(let K of Object.keys(e.derive))y.has(K)&&console.warn(`[Directive] "${K}" exists as both a fact and a derivation after registering module "${e.id}".`);}if(e.snapshotEvents){D===null&&(D=new Set(Object.keys(g)));for(let y of e.snapshotEvents)D.add(y);}else if(D!==null&&e.events)for(let y of Object.keys(e.events))D.add(y);Object.assign(n,e.schema),e.events&&Object.assign(g,e.events),e.derive&&(Object.assign(p,e.derive),$.registerDefinitions(e.derive)),e.effects&&(Object.assign(i,e.effects),N.registerDefinitions(e.effects)),e.constraints&&(Object.assign(t,e.constraints),O.registerDefinitions(e.constraints)),e.resolvers&&(Object.assign(f,e.resolvers),X.registerDefinitions(e.resolvers)),V.registerKeys(e.schema),r.modules.push(e),e.init&&V.batch(()=>{e.init(U);}),e.hooks?.onInit?.(ye),P.isRunning&&(e.hooks?.onStart?.(ye),Q());}ye.registerModule=st,v.emitInit(ye);for(let e of r.modules)e.hooks?.onInit?.(ye);return ye}var ae=Object.freeze(new Set(["__proto__","constructor","prototype"])),L="::";function ht(r){let n=Object.keys(r),g=new Set,p=new Set,i=[],t=[];function f(R){if(g.has(R))return;if(p.has(R)){let w=t.indexOf(R),u=[...t.slice(w),R].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${u}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}p.add(R),t.push(R);let D=r[R];if(D?.crossModuleDeps)for(let w of Object.keys(D.crossModuleDeps))n.includes(w)&&f(w);t.pop(),p.delete(R),g.add(R),i.push(R);}for(let R of n)f(R);return i}var Ge=new WeakMap,Xe=new WeakMap,Ye=new WeakMap,Ze=new WeakMap;function tt(r){if("module"in r){if(!r.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof r.module);return wt(r)}let n=r;if(Array.isArray(n.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
3
3
 
4
4
  Instead of: