@directive-run/core 0.4.2 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/worker.d.cts CHANGED
@@ -1,4 +1,4 @@
1
- import { M as ModuleSchema, ab as DistributableSnapshotOptions, aa as DistributableSnapshot, aD as SystemInspection, R as Requirement } from './plugins-cDWoL7A7.cjs';
1
+ import { M as ModuleSchema, ad as DistributableSnapshotOptions, ac as DistributableSnapshot, aH as SystemInspection, R as Requirement } from './plugins-Co2_xohI.cjs';
2
2
 
3
3
  /**
4
4
  * Web Worker Adapter - Run Directive engine off the main thread
package/dist/worker.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { M as ModuleSchema, ab as DistributableSnapshotOptions, aa as DistributableSnapshot, aD as SystemInspection, R as Requirement } from './plugins-cDWoL7A7.js';
1
+ import { M as ModuleSchema, ad as DistributableSnapshotOptions, ac as DistributableSnapshot, aH as SystemInspection, R as Requirement } from './plugins-Co2_xohI.js';
2
2
 
3
3
  /**
4
4
  * Web Worker Adapter - Run Directive engine off the main thread
package/dist/worker.js CHANGED
@@ -1,5 +1,5 @@
1
- var Et=Object.defineProperty;var ge=(n,r)=>()=>(n&&(r=n(n=0)),r);var Dt=(n,r)=>{for(var g in r)Et(n,g,{get:r[g],enumerable:true});};async function Ce(n,r,g){let v,a=new Promise((t,u)=>{v=setTimeout(()=>u(new Error(g)),r);});try{return await Promise.race([n,a])}finally{clearTimeout(v);}}function $e(n,r=50){let g=new WeakSet;function v(a,t){if(t>r)return '"[max depth exceeded]"';if(a===null)return "null";if(a===void 0)return "undefined";let u=typeof a;if(u==="string")return JSON.stringify(a);if(u==="number"||u==="boolean")return String(a);if(u==="function")return '"[function]"';if(u==="symbol")return '"[symbol]"';if(Array.isArray(a)){if(g.has(a))return '"[circular]"';g.add(a);let y=`[${a.map(R=>v(R,t+1)).join(",")}]`;return g.delete(a),y}if(u==="object"){let y=a;if(g.has(y))return '"[circular]"';g.add(y);let l=`{${Object.keys(y).sort().map(E=>`${JSON.stringify(E)}:${v(y[E],t+1)}`).join(",")}}`;return g.delete(y),l}return '"[unknown]"'}return v(n,0)}function Re(n,r=50){let g=new Set(["__proto__","constructor","prototype"]),v=new WeakSet;function a(t,u){if(u>r)return false;if(t==null||typeof t!="object")return true;let y=t;if(v.has(y))return true;if(v.add(y),Array.isArray(y)){for(let R of y)if(!a(R,u+1))return v.delete(y),false;return v.delete(y),true}for(let R of Object.keys(y))if(g.has(R)||!a(y[R],u+1))return v.delete(y),false;return v.delete(y),true}return a(n,0)}function Be(n){let r=$e(n),g=5381;for(let v=0;v<r.length;v++)g=(g<<5)+g^r.charCodeAt(v);return (g>>>0).toString(16)}var Ee=ge(()=>{});function We(n){let{config:r,facts:g,store:v,onSnapshot:a,onTimeTravel:t}=n,u=r.timeTravel??false,y=r.maxSnapshots??100,R=[],w=-1,l=1,E=false,x=false,M=[],W=null,P=-1;function j(){return v.toObject()}function T(){let K=j();return structuredClone(K)}function $(K){if(!Re(K)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}v.batch(()=>{for(let[s,k]of Object.entries(K)){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 u},get isRestoring(){return x},get isPaused(){return E},get snapshots(){return [...R]},get currentIndex(){return w},takeSnapshot(K){if(!u||E)return {id:-1,timestamp:Date.now(),facts:{},trigger:K};let s={id:l++,timestamp:Date.now(),facts:T(),trigger:K};for(w<R.length-1&&R.splice(w+1),R.push(s),w=R.length-1;R.length>y;)R.shift(),w--;return a?.(s),s},restore(K){if(u){E=true,x=true;try{$(K.facts);}finally{E=false,x=false;}}},goBack(K=1){if(!u||R.length===0)return;let s=w,k=w,f=M.find(D=>w>D.startIndex&&w<=D.endIndex);if(f)k=f.startIndex;else if(M.find(_=>w===_.startIndex)){let _=M.find(d=>d.endIndex<w&&w-d.endIndex<=K);k=_?_.startIndex:Math.max(0,w-K);}else k=Math.max(0,w-K);if(s===k)return;w=k;let b=R[w];b&&(this.restore(b),t?.(s,k));},goForward(K=1){if(!u||R.length===0)return;let s=w,k=w,f=M.find(D=>w>=D.startIndex&&w<D.endIndex);if(f?k=f.endIndex:k=Math.min(R.length-1,w+K),s===k)return;w=k;let b=R[w];b&&(this.restore(b),t?.(s,k));},goTo(K){if(!u)return;let s=R.findIndex(b=>b.id===K);if(s===-1){console.warn(`[Directive] Snapshot ${K} not found`);return}let k=w;w=s;let f=R[w];f&&(this.restore(f),t?.(k,s));},replay(){if(!u||R.length===0)return;w=0;let K=R[0];K&&this.restore(K);},export(){return JSON.stringify({version:1,snapshots:R,currentIndex:w})},import(K){if(u)try{let s=JSON.parse(K);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 f of s.snapshots){if(typeof f!="object"||f===null)throw new Error("Invalid snapshot: expected object");if(typeof f.id!="number"||typeof f.timestamp!="number"||typeof f.trigger!="string"||typeof f.facts!="object")throw new Error("Invalid snapshot structure");if(!Re(f.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}R.length=0,R.push(...s.snapshots),w=s.currentIndex;let k=R[w];k&&this.restore(k);}catch(s){console.error("[Directive] Failed to import time-travel data:",s);}},beginChangeset(K){u&&(W=K,P=w);},endChangeset(){!u||W===null||(w>P&&M.push({label:W,startIndex:P,endIndex:w}),W=null,P=-1);},pause(){E=true;},resume(){E=false;}}}function Ke(){let n={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>n,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var Ve=ge(()=>{Ee();});function Tt(n,r){if(r)return r(n);let{type:g,...v}=n,a=$e(v);return `${g}:${a}`}function Le(n,r,g){return {requirement:n,id:Tt(n,g),fromConstraint:r}}var De,qe=ge(()=>{Ee();De=class n{map=new Map;add(r){this.map.has(r.id)||this.map.set(r.id,r);}remove(r){return this.map.delete(r)}has(r){return this.map.has(r)}get(r){return this.map.get(r)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let r=new n;for(let g of this.map.values())r.add(g);return r}diff(r){let g=[],v=[],a=[];for(let t of this.map.values())r.has(t.id)?a.push(t):g.push(t);for(let t of r.map.values())this.map.has(t.id)||v.push(t);return {added:g,removed:v,unchanged:a}}};});function xt(){let n=new Set;return {get isTracking(){return true},track(r){n.add(r);},getDependencies(){return n}}}function Mt(){return Te[Te.length-1]??Ct}function xe(n){let r=xt();Te.push(r);try{return {value:n(),deps:r.getDependencies()}}finally{Te.pop();}}function Pe(n){let r=Te.splice(0,Te.length);try{return n()}finally{Te.push(...r);}}function Ie(n){Mt().track(n);}var Te,Ct,Oe=ge(()=>{Te=[];Ct={isTracking:false,track(){},getDependencies(){return new Set}};});function Ue(n){let{definitions:r,facts:g,requirementKeys:v={},defaultTimeout:a=It,onEvaluate:t,onError:u}=n,y=new Map,R=new Set,w=new Set,l=new Map,E=new Map,x=new Set,M=new Map,W=new Map,P=false,j=new Set,T=new Set,$=new Map,Y=[],K=new Map;function s(){for(let[c,m]of Object.entries(r))if(m.after)for(let S of m.after)r[S]&&($.has(S)||$.set(S,new Set),$.get(S).add(c));}function k(){let c=new Set,m=new Set,S=[];function F(N,J){if(c.has(N))return;if(m.has(N)){let ue=J.indexOf(N),Q=[...J.slice(ue),N].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${Q}. Remove one of the \`after\` dependencies to break the cycle.`)}m.add(N),J.push(N);let ne=r[N];if(ne?.after)for(let ue of ne.after)r[ue]&&F(ue,J);J.pop(),m.delete(N),c.add(N),S.push(N);}for(let N of Object.keys(r))F(N,[]);Y=S,K=new Map(Y.map((N,J)=>[N,J]));}if(k(),s(),process.env.NODE_ENV!=="production"){for(let[c,m]of Object.entries(r))if(m.after)for(let S of m.after)r[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 f(c,m){return m.async!==void 0?m.async:!!w.has(c)}function b(c){let m=r[c];if(!m)throw new Error(`[Directive] Unknown constraint: ${c}`);let S=f(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 y.set(c,F),F}function D(c){return y.get(c)??b(c)}function _(c,m){let S=l.get(c)??new Set;for(let F of S){let N=E.get(F);N?.delete(c),N&&N.size===0&&E.delete(F);}for(let F of m)E.has(F)||E.set(F,new Set),E.get(F).add(c);l.set(c,m);}function d(c){let m=r[c];if(!m)return false;let S=D(c);S.isEvaluating=true,S.error=null;try{let F;if(m.deps)F=m.when(g),M.set(c,new Set(m.deps));else {let N=xe(()=>m.when(g));F=N.value,M.set(c,N.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(N=>(S.lastResult=N,N&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,N),N)).catch(N=>(S.error=N instanceof Error?N:new Error(String(N)),S.lastResult=!1,S.isEvaluating=!1,u?.(c,N),!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,u?.(c,F),false}}async function i(c){let m=r[c];if(!m)return false;let S=D(c),F=m.timeout??a;if(S.isEvaluating=true,S.error=null,m.deps?.length){let N=new Set(m.deps);_(c,N),M.set(c,N);}try{let N=m.when(g),J=await Ce(N,F,`Constraint "${c}" timed out after ${F}ms`);return S.lastResult=J,J&&(S.hitCount++,S.lastActiveAt=Date.now()),S.isEvaluating=!1,t?.(c,J),J}catch(N){return S.error=N instanceof Error?N:new Error(String(N)),S.lastResult=false,S.isEvaluating=false,u?.(c,N),false}}let h=10;function I(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 O(c){let m=r[c];if(!m)return {requirements:[],deps:new Set};let S=m.require;if(typeof S=="function"){let{value:N,deps:J}=xe(()=>S(g));return {requirements:I(N,c),deps:J}}return {requirements:I(S,c),deps:new Set}}function V(c,m){if(m.size===0)return;let S=l.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);l.set(c,S);}let z=null;function C(){return z||(z=Object.keys(r).sort((c,m)=>{let S=D(c),N=D(m).priority-S.priority;if(N!==0)return N;let J=K.get(c)??0,ne=K.get(m)??0;return J-ne})),z}for(let c of Object.keys(r))b(c);if(process.env.NODE_ENV!=="production")for(let[c,m]of Object.entries(r))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 B(c){let m=y.get(c);if(!m||m.after.length===0)return true;for(let S of m.after)if(r[S]&&!R.has(S)&&!T.has(S)&&!j.has(S))return false;return true}return {async evaluate(c){let m=new De;T.clear();let S=C().filter(Q=>!R.has(Q)),F;if(!P||!c||c.size===0)F=S,P=true;else {let Q=new Set;for(let oe of c){let ie=E.get(oe);if(ie)for(let ye of ie)R.has(ye)||Q.add(ye);}for(let oe of x)R.has(oe)||Q.add(oe);x.clear(),F=[...Q];for(let oe of S)if(!Q.has(oe)){let ie=W.get(oe);if(ie)for(let ye of ie)m.add(ye);}}function N(Q,oe){if(R.has(Q))return;let ie=M.get(Q);if(!oe){ie!==void 0&&_(Q,ie),T.add(Q),W.set(Q,[]);return}T.delete(Q);let ye,me;try{let q=O(Q);ye=q.requirements,me=q.deps;}catch(q){u?.(Q,q),ie!==void 0&&_(Q,ie),W.set(Q,[]);return}if(ie!==void 0){let q=new Set(ie);for(let Z of me)q.add(Z);_(Q,q);}else V(Q,me);if(ye.length>0){let q=v[Q],Z=ye.map(re=>Le(re,Q,q));for(let re of Z)m.add(re);W.set(Q,Z);}else W.set(Q,[]);}async function J(Q){let oe=[],ie=[];for(let Z of Q)if(B(Z))ie.push(Z);else {oe.push(Z);let re=W.get(Z);if(re)for(let be of re)m.add(be);}if(ie.length===0)return oe;let ye=[],me=[];for(let Z of ie)D(Z).isAsync?me.push(Z):ye.push(Z);let q=[];for(let Z of ye){let re=d(Z);if(re instanceof Promise){q.push({id:Z,promise:re});continue}N(Z,re);}if(q.length>0){let Z=await Promise.all(q.map(async({id:re,promise:be})=>({id:re,active:await be})));for(let{id:re,active:be}of Z)N(re,be);}if(me.length>0){let Z=await Promise.all(me.map(async re=>({id:re,active:await i(re)})));for(let{id:re,active:be}of Z)N(re,be);}return oe}let ne=F,ue=F.length+1;for(;ne.length>0&&ue>0;){let Q=ne.length;if(ne=await J(ne),ne.length===Q)break;ue--;}return m.all()},getState(c){return y.get(c)},getDependencies(c){return l.get(c)},getAllStates(){return [...y.values()]},disable(c){if(!y.has(c)){console.warn(`[Directive] constraints.disable("${c}") \u2014 no such constraint`);return}R.add(c),z=null,W.delete(c);let m=l.get(c);if(m){for(let S of m){let F=E.get(S);F&&(F.delete(c),F.size===0&&E.delete(S));}l.delete(c);}M.delete(c);},enable(c){if(!y.has(c)){console.warn(`[Directive] constraints.enable("${c}") \u2014 no such constraint`);return}R.delete(c),z=null,x.add(c);},isDisabled(c){return R.has(c)},invalidate(c){let m=E.get(c);if(m)for(let S of m)x.add(S);},markResolved(c){j.add(c);let m=y.get(c);m&&(m.lastResolvedAt=Date.now());let S=$.get(c);if(S)for(let F of S)x.add(F);},isResolved(c){return j.has(c)},registerDefinitions(c){for(let[m,S]of Object.entries(c))r[m]=S,b(m),x.add(m);z=null,k(),s();}}}var It,He=ge(()=>{Ee();qe();Oe();It=5e3;});function ze(n){let{definitions:r,facts:g,onCompute:a,onInvalidate:t,onError:u}=n,y=new Map,R=new Map,w=new Map,l=new Map,E=new Set(["__proto__","constructor","prototype"]),x=0,M=new Set,W=false,P=100,j;function T(b){if(!r[b])throw new Error(`[Directive] Unknown derivation: ${b}`);let _={id:b,compute:()=>Y(b),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return y.set(b,_),_}function $(b){return y.get(b)??T(b)}function Y(b){let D=$(b),_=r[b];if(!_)throw new Error(`[Directive] Unknown derivation: ${b}`);if(D.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${b}`);D.isComputing=true;try{let d=D.cachedValue,{value:i,deps:h}=xe(()=>_(g,j));return D.cachedValue=i,D.isStale=!1,K(b,h),a?.(b,i,d,[...h]),i}catch(d){throw u?.(b,d),d}finally{D.isComputing=false;}}function K(b,D){let _=$(b),d=_.dependencies;for(let i of d)if(y.has(i)){let h=l.get(i);h?.delete(b),h&&h.size===0&&l.delete(i);}else {let h=w.get(i);h?.delete(b),h&&h.size===0&&w.delete(i);}for(let i of D)r[i]?(l.has(i)||l.set(i,new Set),l.get(i).add(b)):(w.has(i)||w.set(i,new Set),w.get(i).add(b));_.dependencies=D;}function s(){if(!(x>0||W)){W=true;try{let b=0;for(;M.size>0;){if(++b>P){let _=[...M];throw M.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${P} iterations. Remaining: ${_.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let D=[...M];M.clear();for(let _ of D)R.get(_)?.forEach(d=>d());}}finally{W=false;}}}function k(b,D=new Set){if(D.has(b))return;D.add(b);let _=y.get(b);if(!_||_.isStale)return;_.isStale=true,t?.(b),M.add(b);let d=l.get(b);if(d)for(let i of d)k(i,D);}return j=new Proxy({},{get(b,D){if(typeof D=="symbol"||E.has(D))return;Ie(D);let _=$(D);return _.isStale&&Y(D),_.cachedValue}}),{get(b){let D=$(b);return D.isStale&&Y(b),D.cachedValue},isStale(b){return y.get(b)?.isStale??true},invalidate(b){let D=w.get(b);if(D){x++;try{for(let _ of D)k(_);}finally{x--,s();}}},invalidateMany(b){x++;try{for(let D of b){let _=w.get(D);if(_)for(let d of _)k(d);}}finally{x--,s();}},invalidateAll(){x++;try{for(let b of y.values())b.isStale||(b.isStale=!0,M.add(b.id));}finally{x--,s();}},subscribe(b,D){for(let _ of b){let d=_;R.has(d)||R.set(d,new Set),R.get(d).add(D);}return ()=>{for(let _ of b){let d=_,i=R.get(d);i?.delete(D),i&&i.size===0&&R.delete(d);}}},getProxy(){return j},getDependencies(b){return $(b).dependencies},registerDefinitions(b){for(let[D,_]of Object.entries(b))r[D]=_,T(D);}}}var Ge=ge(()=>{Oe();});function Ye(n){let{definitions:r,facts:g,store:v,onRun:a,onError:t}=n,u=new Map,y=null,R=false;function w(T){let $=r[T];if(!$)throw new Error(`[Directive] Unknown effect: ${T}`);let Y={id:T,enabled:true,hasExplicitDeps:!!$.deps,dependencies:$.deps?new Set($.deps):null,cleanup:null};return u.set(T,Y),Y}function l(T){return u.get(T)??w(T)}function E(){return v.toObject()}function x(T,$){let Y=l(T);if(!Y.enabled)return false;if(Y.dependencies){for(let K of Y.dependencies)if($.has(K))return true;return false}return true}function M(T){if(T.cleanup){try{T.cleanup();}catch($){t?.(T.id,$),console.error(`[Directive] Effect "${T.id}" cleanup threw an error:`,$);}T.cleanup=null;}}function W(T,$){if(typeof $=="function")if(R)try{$();}catch(Y){t?.(T.id,Y),console.error(`[Directive] Effect "${T.id}" cleanup threw an error:`,Y);}else T.cleanup=$;}async function P(T){let $=l(T),Y=r[T];if(!(!$.enabled||!Y)){M($),a?.(T,$.dependencies?[...$.dependencies]:[]);try{if($.hasExplicitDeps){let K;if(v.batch(()=>{K=Y.run(g,y);}),K instanceof Promise){let s=await K;W($,s);}else W($,K);}else {let K=null,s,k=xe(()=>(v.batch(()=>{s=Y.run(g,y);}),s));K=k.deps;let f=k.value;f instanceof Promise&&(f=await f),W($,f),$.dependencies=K.size>0?K:null;}}catch(K){t?.(T,K),console.error(`[Directive] Effect "${T}" threw an error:`,K);}}}for(let T of Object.keys(r))w(T);return {async runEffects(T){let $=[];for(let Y of Object.keys(r))x(Y,T)&&$.push(Y);await Promise.all($.map(P)),y=E();},async runAll(){let T=Object.keys(r);await Promise.all(T.map($=>l($).enabled?P($):Promise.resolve())),y=E();},disable(T){let $=l(T);$.enabled=false;},enable(T){let $=l(T);$.enabled=true;},isEnabled(T){return l(T).enabled},cleanupAll(){R=true;for(let T of u.values())M(T);},registerDefinitions(T){for(let[$,Y]of Object.entries(T))r[$]=Y,w($);}}}var Je=ge(()=>{Oe();});var Me,Qe=ge(()=>{Me=class extends Error{constructor(g,v,a,t,u=true){super(g);this.source=v;this.sourceId=a;this.context=t;this.recoverable=u;this.name="DirectiveError";}};});var Xe=ge(()=>{Qe();});var Ze=ge(()=>{Xe();});function Ot(n={}){let{delayMs:r=1e3,maxRetries:g=3,backoffMultiplier:v=2,maxDelayMs:a=3e4}=n,t=new Map;function u(y){let R=r*v**(y-1);return Math.min(R,a)}return {scheduleRetry(y,R,w,l,E){if(l>g)return null;let x=u(l),M={source:y,sourceId:R,context:w,attempt:l,nextRetryTime:Date.now()+x,callback:E};return t.set(R,M),M},getPendingRetries(){return Array.from(t.values())},processDueRetries(){let y=Date.now(),R=[];for(let[w,l]of t)l.nextRetryTime<=y&&(R.push(l),t.delete(w));return R},cancelRetry(y){t.delete(y);},clearAll(){t.clear();}}}function et(n={}){let{config:r={},onError:g,onRecovery:v}=n,a=[],t=100,u=Ot(r.retryLater),y=new Map;function R(E,x,M,W){if(M instanceof Me)return M;let P=M instanceof Error?M.message:String(M),j=E!=="system";return new Me(P,E,x,W,j)}function w(E,x,M){let W=(()=>{switch(E){case "constraint":return r.onConstraintError;case "resolver":return r.onResolverError;case "effect":return r.onEffectError;case "derivation":return r.onDerivationError;default:return}})();if(typeof W=="function"){try{let P=W(M,x);if(typeof P=="string")return P}catch(P){console.error("[Directive] Error in error handler callback:",P);}return "skip"}return typeof W=="string"?W:At[E]}return {handleError(E,x,M,W){let P=R(E,x,M,W);a.push(P),a.length>t&&a.shift();try{g?.(P);}catch(T){console.error("[Directive] Error in onError callback:",T);}try{r.onError?.(P);}catch(T){console.error("[Directive] Error in config.onError callback:",T);}let j=w(E,x,M instanceof Error?M:new Error(String(M)));if(j==="retry-later"){let T=(y.get(x)??0)+1;y.set(x,T),u.scheduleRetry(E,x,W,T)||(j="skip",y.delete(x),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${E} "${x}" exceeded max retry-later attempts. Skipping.`));}try{v?.(P,j);}catch(T){console.error("[Directive] Error in onRecovery callback:",T);}if(j==="throw")throw P;return j},getLastError(){return a[a.length-1]??null},getAllErrors(){return [...a]},clearErrors(){a.length=0;},getRetryLaterManager(){return u},processDueRetries(){return u.processDueRetries()},clearRetryAttempts(E){y.delete(E),u.cancelRetry(E);}}}var At,tt=ge(()=>{Ze();At={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};});function $t(n,r=100){try{return JSON.stringify(n)?.slice(0,r)??String(n)}catch{return "[circular or non-serializable]"}}function qt(n){let{schema:r,onChange:g,onBatch:v}=n,t=Object.keys(r).length===0,u=n.validate??process.env.NODE_ENV!=="production",y=n.strictKeys??(process.env.NODE_ENV!=="production"&&!t),R=n.redactErrors??false,w=new Map,l=new Set,E=new Map,x=new Set,M=0,W=[],P=new Set,j=false,T=[],$=100;function Y(i){return i!==null&&typeof i=="object"&&"safeParse"in i&&typeof i.safeParse=="function"&&"_def"in i&&"parse"in i&&typeof i.parse=="function"}function K(i){let h=i;if(h._typeName)return h._typeName;if(Y(i)){let I=i._def;if(I?.typeName)return I.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function s(i){return R?"[redacted]":$t(i)}function k(i,h){if(!u)return;let I=r[i];if(!I){if(y)throw new Error(`[Directive] Unknown fact key: "${i}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${i}"`);return}if(Y(I)){let C=I.safeParse(h);if(!C.success){let B=h===null?"null":Array.isArray(h)?"array":typeof h,A=s(h),c=C.error?.message??C.error?.issues?.[0]?.message??"Validation failed",m=K(I);throw new Error(`[Directive] Validation failed for "${i}": expected ${m}, got ${B} ${A}. ${c}`)}return}let O=I,V=O._validators;if(!V||!Array.isArray(V)||V.length===0)return;let z=O._typeName??"unknown";for(let C=0;C<V.length;C++){let B=V[C];if(typeof B=="function"&&!B(h)){let A=h===null?"null":Array.isArray(h)?"array":typeof h,c=s(h),m="";typeof O._lastFailedIndex=="number"&&O._lastFailedIndex>=0&&(m=` (element at index ${O._lastFailedIndex} failed)`,O._lastFailedIndex=-1);let S=C===0?"":` (validator ${C+1} failed)`;throw new Error(`[Directive] Validation failed for "${i}": expected ${z}, got ${A} ${c}${S}${m}`)}}}function f(i){E.get(i)?.forEach(h=>h());}function b(){x.forEach(i=>i());}function D(i,h,I){if(j){T.push({key:i,value:h,prev:I});return}j=true;try{g?.(i,h,I),f(i),b();let O=0;for(;T.length>0;){if(++O>$)throw T.length=0,new Error(`[Directive] Infinite notification loop detected after ${$} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let V=[...T];T.length=0;for(let z of V)g?.(z.key,z.value,z.prev),f(z.key);b();}}finally{j=false;}}function _(){if(!(M>0)){if(v&&W.length>0&&v([...W]),P.size>0){j=true;try{for(let h of P)f(h);b();let i=0;for(;T.length>0;){if(++i>$)throw T.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${$} iterations.`);let h=[...T];T.length=0;for(let I of h)g?.(I.key,I.value,I.prev),f(I.key);b();}}finally{j=false;}}W.length=0,P.clear();}}let d={get(i){return Ie(i),w.get(i)},has(i){return Ie(i),w.has(i)},set(i,h){k(i,h);let I=w.get(i);Object.is(I,h)||(w.set(i,h),l.add(i),M>0?(W.push({key:i,value:h,prev:I,type:"set"}),P.add(i)):D(i,h,I));},delete(i){let h=w.get(i);w.delete(i),l.delete(i),M>0?(W.push({key:i,value:void 0,prev:h,type:"delete"}),P.add(i)):D(i,void 0,h);},batch(i){M++;try{i();}finally{M--,_();}},subscribe(i,h){for(let I of i){let O=I;E.has(O)||E.set(O,new Set),E.get(O).add(h);}return ()=>{for(let I of i){let O=E.get(I);O&&(O.delete(h),O.size===0&&E.delete(I));}}},subscribeAll(i){return x.add(i),()=>x.delete(i)},toObject(){let i={};for(let h of l)w.has(h)&&(i[h]=w.get(h));return i}};return d.registerKeys=i=>{for(let h of Object.keys(i))Ae.has(h)||(r[h]=i[h],l.add(h));},d}function Pt(n,r){let g=()=>({get:a=>Pe(()=>n.get(a)),has:a=>Pe(()=>n.has(a))});return new Proxy({},{get(a,t){if(t==="$store")return n;if(t==="$snapshot")return g;if(typeof t!="symbol"&&!Ae.has(t))return n.get(t)},set(a,t,u){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Ae.has(t)?false:(n.set(t,u),true)},deleteProperty(a,t){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||Ae.has(t)?false:(n.delete(t),true)},has(a,t){return t==="$store"||t==="$snapshot"?true:typeof t=="symbol"||Ae.has(t)?false:n.has(t)},ownKeys(){return Object.keys(r)},getOwnPropertyDescriptor(a,t){return t==="$store"||t==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}}})}function nt(n){let r=qt(n),g=Pt(r,n.schema);return {store:r,facts:g}}var Ae,rt=ge(()=>{Oe();Ae=Object.freeze(new Set(["__proto__","constructor","prototype"]));});function st(){let n=[];function r(a){if(a)try{return a()}catch(t){console.error("[Directive] Plugin error:",t);return}}async function g(a){if(a)try{return await a()}catch(t){console.error("[Directive] Plugin error:",t);return}}return {register(a){n.some(t=>t.name===a.name)&&(console.warn(`[Directive] Plugin "${a.name}" is already registered, replacing...`),this.unregister(a.name)),n.push(a);},unregister(a){let t=n.findIndex(u=>u.name===a);t!==-1&&n.splice(t,1);},getPlugins(){return [...n]},async emitInit(a){for(let t of n)await g(()=>t.onInit?.(a));},emitStart(a){for(let t of n)r(()=>t.onStart?.(a));},emitStop(a){for(let t of n)r(()=>t.onStop?.(a));},emitDestroy(a){for(let t of n)r(()=>t.onDestroy?.(a));},emitFactSet(a,t,u){for(let y of n)r(()=>y.onFactSet?.(a,t,u));},emitFactDelete(a,t){for(let u of n)r(()=>u.onFactDelete?.(a,t));},emitFactsBatch(a){for(let t of n)r(()=>t.onFactsBatch?.(a));},emitDerivationCompute(a,t,u){for(let y of n)r(()=>y.onDerivationCompute?.(a,t,u));},emitDerivationInvalidate(a){for(let t of n)r(()=>t.onDerivationInvalidate?.(a));},emitReconcileStart(a){for(let t of n)r(()=>t.onReconcileStart?.(a));},emitReconcileEnd(a){for(let t of n)r(()=>t.onReconcileEnd?.(a));},emitConstraintEvaluate(a,t){for(let u of n)r(()=>u.onConstraintEvaluate?.(a,t));},emitConstraintError(a,t){for(let u of n)r(()=>u.onConstraintError?.(a,t));},emitRequirementCreated(a){for(let t of n)r(()=>t.onRequirementCreated?.(a));},emitRequirementMet(a,t){for(let u of n)r(()=>u.onRequirementMet?.(a,t));},emitRequirementCanceled(a){for(let t of n)r(()=>t.onRequirementCanceled?.(a));},emitResolverStart(a,t){for(let u of n)r(()=>u.onResolverStart?.(a,t));},emitResolverComplete(a,t,u){for(let y of n)r(()=>y.onResolverComplete?.(a,t,u));},emitResolverError(a,t,u){for(let y of n)r(()=>y.onResolverError?.(a,t,u));},emitResolverRetry(a,t,u){for(let y of n)r(()=>y.onResolverRetry?.(a,t,u));},emitResolverCancel(a,t){for(let u of n)r(()=>u.onResolverCancel?.(a,t));},emitEffectRun(a){for(let t of n)r(()=>t.onEffectRun?.(a));},emitEffectError(a,t){for(let u of n)r(()=>u.onEffectError?.(a,t));},emitSnapshot(a){for(let t of n)r(()=>t.onSnapshot?.(a));},emitTimeTravel(a,t){for(let u of n)r(()=>u.onTimeTravel?.(a,t));},emitError(a){for(let t of n)r(()=>t.onError?.(a));},emitErrorRecovery(a,t){for(let u of n)r(()=>u.onErrorRecovery?.(a,t));},emitRunComplete(a){for(let t of n)r(()=>t.onRunComplete?.(a));}}}var ot=ge(()=>{});function ct(n,r){let{backoff:g,initialDelay:v=100,maxDelay:a=3e4}=n,t;switch(g){case "none":t=v;break;case "linear":t=v*r;break;case "exponential":t=v*2**(r-1);break;default:t=v;}return Math.max(1,Math.min(t,a))}function ut(n){let{definitions:r,facts:g,store:v,onStart:a,onComplete:t,onError:u,onRetry:y,onCancel:R,onResolutionComplete:w}=n;if(process.env.NODE_ENV!=="production")for(let[d,i]of Object.entries(r)){if(!i.resolve&&!i.resolveBatch&&!i.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${d}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(i.batch?.enabled&&!i.resolveBatch&&!i.resolveBatchWithResults)if(i.resolve)console.warn(`[Directive] Resolver "${d}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${d}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let l=new Map,E=new Map,x=1e3,M=new Map,W=new Map,P=1e3;function j(){if(E.size>x){let d=E.size-x,i=E.keys();for(let h=0;h<d;h++){let I=i.next().value;I&&E.delete(I);}}}function T(d){return typeof d=="object"&&d!==null&&"requirement"in d&&typeof d.requirement=="string"}function $(d){return typeof d=="object"&&d!==null&&"requirement"in d&&typeof d.requirement=="function"}function Y(d,i){return T(d)?i.type===d.requirement:$(d)?d.requirement(i):false}function K(d){let i=d.type,h=W.get(i);if(h)for(let I of h){let O=r[I];if(O&&Y(O,d))return I}for(let[I,O]of Object.entries(r))if(Y(O,d)){if(!W.has(i)){if(W.size>=P){let z=W.keys().next().value;z!==void 0&&W.delete(z);}W.set(i,[]);}let V=W.get(i);return V.includes(I)||V.push(I),I}return null}function s(d){return {facts:g,signal:d,snapshot:()=>g.$snapshot()}}async function k(d,i,h){let I=r[d];if(!I)return;let O={...it,...I.retry},V=null;for(let z=1;z<=O.attempts;z++){if(h.signal.aborted)return;let C=l.get(i.id);C&&(C.attempt=z,C.status={state:"running",requirementId:i.id,startedAt:C.startedAt,attempt:z});try{let B=s(h.signal);if(I.resolve){let c;v.batch(()=>{c=I.resolve(i.requirement,B);});let m=I.timeout;m&&m>0?await Ce(c,m,`Resolver "${d}" timed out after ${m}ms`):await c;}let A=Date.now()-(C?.startedAt??Date.now());E.set(i.id,{state:"success",requirementId:i.id,completedAt:Date.now(),duration:A}),j(),t?.(d,i,A);return}catch(B){if(V=B instanceof Error?B:new Error(String(B)),h.signal.aborted)return;if(O.shouldRetry&&!O.shouldRetry(V,z))break;if(z<O.attempts){if(h.signal.aborted)return;let A=ct(O,z);if(y?.(d,i,z+1),await new Promise(c=>{let m=setTimeout(c,A),S=()=>{clearTimeout(m),c();};h.signal.addEventListener("abort",S,{once:true});}),h.signal.aborted)return}}}E.set(i.id,{state:"error",requirementId:i.id,error:V,failedAt:Date.now(),attempts:O.attempts}),j(),u?.(d,i,V);}async function f(d,i){let h=r[d];if(!h)return;if(!h.resolveBatch&&!h.resolveBatchWithResults){await Promise.all(i.map(A=>{let c=new AbortController;return k(d,A,c)}));return}let I={...it,...h.retry},O={...at,...h.batch},V=new AbortController,z=Date.now(),C=null,B=O.timeoutMs??h.timeout;for(let A=1;A<=I.attempts;A++){if(V.signal.aborted)return;try{let c=s(V.signal),m=i.map(S=>S.requirement);if(h.resolveBatchWithResults){let S,F;if(v.batch(()=>{F=h.resolveBatchWithResults(m,c);}),B&&B>0?S=await Ce(F,B,`Batch resolver "${d}" timed out after ${B}ms`):S=await F,S.length!==i.length)throw new Error(`[Directive] Batch resolver "${d}" returned ${S.length} results but expected ${i.length}. Results array must match input order.`);let N=Date.now()-z,J=!1;for(let ne=0;ne<i.length;ne++){let ue=i[ne],Q=S[ne];if(Q.success)E.set(ue.id,{state:"success",requirementId:ue.id,completedAt:Date.now(),duration:N}),t?.(d,ue,N);else {J=!0;let oe=Q.error??new Error("Batch item failed");E.set(ue.id,{state:"error",requirementId:ue.id,error:oe,failedAt:Date.now(),attempts:A}),u?.(d,ue,oe);}}if(!J||i.some((ne,ue)=>S[ue]?.success))return}else {let S;v.batch(()=>{S=h.resolveBatch(m,c);}),B&&B>0?await Ce(S,B,`Batch resolver "${d}" timed out after ${B}ms`):await S;let F=Date.now()-z;for(let N of i)E.set(N.id,{state:"success",requirementId:N.id,completedAt:Date.now(),duration:F}),t?.(d,N,F);return}}catch(c){if(C=c instanceof Error?c:new Error(String(c)),V.signal.aborted)return;if(I.shouldRetry&&!I.shouldRetry(C,A))break;if(A<I.attempts){let m=ct(I,A);for(let S of i)y?.(d,S,A+1);if(await new Promise(S=>{let F=setTimeout(S,m),N=()=>{clearTimeout(F),S();};V.signal.addEventListener("abort",N,{once:true});}),V.signal.aborted)return}}}for(let A of i)E.set(A.id,{state:"error",requirementId:A.id,error:C,failedAt:Date.now(),attempts:I.attempts}),u?.(d,A,C);j();}function b(d,i){let h=r[d];if(!h)return;let I={...at,...h.batch};M.has(d)||M.set(d,{resolverId:d,requirements:[],timer:null});let O=M.get(d);if(O.requirements.push(i),I.maxSize&&O.requirements.length>=I.maxSize){O.timer&&(clearTimeout(O.timer),O.timer=null),D(d);return}O.timer&&clearTimeout(O.timer),O.timer=setTimeout(()=>{D(d);},I.windowMs);}function D(d){let i=M.get(d);if(!i||i.requirements.length===0)return;let h=[...i.requirements];i.requirements=[],i.timer=null,f(d,h).then(()=>{w?.();});}return {resolve(d){if(l.has(d.id))return;let i=K(d.requirement);if(!i){console.warn(`[Directive] No resolver found for requirement type "${d.requirement.type}" (id: ${d.id})`);return}let h=r[i];if(!h)return;if(h.batch?.enabled){b(i,d);return}let I=new AbortController,O=Date.now(),V={requirementId:d.id,resolverId:i,controller:I,startedAt:O,attempt:1,status:{state:"pending",requirementId:d.id,startedAt:O},originalRequirement:d};l.set(d.id,V),a?.(i,d),k(i,d,I).finally(()=>{l.delete(d.id)&&w?.();});},cancel(d){let i=l.get(d);if(i){i.controller.abort(),l.delete(d),E.set(d,{state:"canceled",requirementId:d,canceledAt:Date.now()}),j(),R?.(i.resolverId,i.originalRequirement);return}for(let h of M.values()){let I=h.requirements.findIndex(O=>O.id===d);if(I!==-1){let[O]=h.requirements.splice(I,1);E.set(d,{state:"canceled",requirementId:d,canceledAt:Date.now()}),j(),O&&R?.(h.resolverId,O);return}}},cancelAll(){let d=[...l.keys()];for(let i of d)this.cancel(i);for(let i of M.values()){i.timer&&clearTimeout(i.timer);for(let h of i.requirements)E.set(h.id,{state:"canceled",requirementId:h.id,canceledAt:Date.now()}),R?.(i.resolverId,h);}M.clear(),j();},getStatus(d){let i=l.get(d);if(i)return i.status;let h=E.get(d);return h||{state:"idle"}},getInflight(){return [...l.keys()]},getInflightInfo(){return [...l.values()].map(d=>({id:d.requirementId,resolverId:d.resolverId,startedAt:d.startedAt}))},isResolving(d){return l.has(d)},processBatches(){for(let d of M.keys())D(d);},hasPendingBatches(){for(let d of M.values())if(d.requirements.length>0)return true;return false},registerDefinitions(d){for(let[i,h]of Object.entries(d))r[i]=h;W.clear();}}}var it,at,lt=ge(()=>{Ee();it={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},at={enabled:false,windowMs:50};});function je(n){let r=Object.create(null),g=Object.create(null),v=Object.create(null),a=Object.create(null),t=Object.create(null),u=Object.create(null),y=new Map;for(let e of n.modules){let o=(p,L)=>{if(p){for(let G of Object.keys(p))if(he.has(G))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${G}" in ${L}. 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 p of Object.keys(e.schema)){let L=y.get(p);if(L)throw new Error(`[Directive] Schema collision: Fact "${p}" is defined in both module "${L}" and "${e.id}". Use namespacing (e.g., "${e.id}::${p}") or merge into one module.`);y.set(p,e.id);}Object.assign(r,e.schema),e.events&&Object.assign(g,e.events),e.derive&&Object.assign(v,e.derive),e.effects&&Object.assign(a,e.effects),e.constraints&&Object.assign(t,e.constraints),e.resolvers&&Object.assign(u,e.resolvers);}let R=null;if(n.modules.some(e=>e.snapshotEvents)){R=new Set;for(let e of n.modules){let o=e;if(o.snapshotEvents)for(let p of o.snapshotEvents)R.add(p);else if(o.events)for(let p of Object.keys(o.events))R.add(p);}}let l=0,E=false;if(process.env.NODE_ENV!=="production"){let e=new Set(Object.keys(v));for(let o of Object.keys(r))e.has(o)&&console.warn(`[Directive] "${o}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let x=st();for(let e of n.plugins??[])x.register(e);let M=et({config:n.errorBoundary,onError:e=>x.emitError(e),onRecovery:(e,o)=>x.emitErrorRecovery(e,o)}),W=null,P=()=>{},j=()=>{},T=null,$=n.debug?.runHistory??false,Y=n.debug?.maxRuns??100,K=[],s=new Map,k=0,f=null,b=[],D=new Map,_=new Map,d=new Map,i=null,h=0,I=0,O={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0},{store:V,facts:z}=nt({schema:r,onChange:(e,o,p)=>{x.emitFactSet(e,o,p),P(e),$&&b.push({key:String(e),oldValue:p,newValue:o}),!T?.isRestoring&&(l===0&&(E=true),q.changedKeys.add(e),Z());},onBatch:e=>{x.emitFactsBatch(e);let o=[];for(let p of e)o.push(p.key);if($)for(let p of e)p.type==="delete"?b.push({key:p.key,oldValue:p.prev,newValue:void 0}):b.push({key:p.key,oldValue:p.prev,newValue:p.value});if(j(o),!T?.isRestoring){l===0&&(E=true);for(let p of e)q.changedKeys.add(p.key);Z();}}}),C=ze({definitions:v,facts:z,onCompute:(e,o,p,L)=>{x.emitDerivationCompute(e,o,L),f&&f.derivationsRecomputed.push({id:e,deps:L?[...L]:[],oldValue:p,newValue:o});},onInvalidate:e=>x.emitDerivationInvalidate(e),onError:(e,o)=>{M.handleError("derivation",e,o)==="retry"&&C.invalidate(e);}});P=e=>C.invalidate(e),j=e=>C.invalidateMany(e);let B=Ye({definitions:a,facts:z,store:V,onRun:(e,o)=>{x.emitEffectRun(e),f&&f.effectsRun.push({id:e,triggeredBy:o});},onError:(e,o)=>{let p=M.handleError("effect",e,o);x.emitEffectError(e,o),f&&f.effectErrors.push({id:e,error:String(o)}),p==="disable"&&B.disable(e),p==="retry"&&(q.changedKeys.add("*"),Z());}}),A=Ue({definitions:t,facts:z,onEvaluate:(e,o)=>x.emitConstraintEvaluate(e,o),onError:(e,o)=>{let p=M.handleError("constraint",e,o);x.emitConstraintError(e,o),p==="disable"&&A.disable(e);}});function c(e){let o=s.get(e);if(o&&o.status==="pending"){o.status="settled";let p=d.get(e);o.duration=p!==void 0?performance.now()-p:Date.now()-o.timestamp,d.delete(e),_.delete(e),o.causalChain=F(o),N(o),I++,x.emitRunComplete(o);}}function m(e){let o=D.get(e);if(D.delete(e),o!==void 0){let p=(_.get(o)??1)-1;p<=0?c(o):_.set(o,p);}}function S(){let e=K.shift();if(e&&(s.delete(e.id),d.delete(e.id),e.status==="pending")){_.delete(e.id);for(let[o,p]of D)p===e.id&&D.delete(o);}}function F(e){let o=[];for(let p of e.factChanges)o.push(`${p.key} changed`);for(let p of e.derivationsRecomputed)o.push(`${p.id} recomputed`);for(let p of e.constraintsHit)o.push(`${p.id} constraint hit`);for(let p of e.requirementsAdded)o.push(`${p.type} requirement added`);for(let p of e.resolversCompleted)o.push(`${p.resolver} resolved (${p.duration.toFixed(0)}ms)`);for(let p of e.resolversErrored)o.push(`${p.resolver} errored`);for(let p of e.effectsRun)o.push(`${p.id} effect ran`);return o.join(" \u2192 ")}function N(e){O.count++,O.totalDuration+=e.duration,O.avgDuration=O.totalDuration/O.count,e.duration>O.maxDuration&&(O.maxDuration=e.duration);let o=e.resolversStarted.length;O.totalResolverCount+=o,O.avgResolverCount=O.totalResolverCount/O.count;let p=e.factChanges.length;O.totalFactChangeCount+=p,O.avgFactChangeCount=O.totalFactChangeCount/O.count;let L=[];O.count>3&&e.duration>O.avgDuration*5&&L.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${O.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&L.push(`${e.resolversErrored.length} resolver(s) errored`),L.length>0&&(e.anomalies=L);}let J=ut({definitions:u,facts:z,store:V,onStart:(e,o)=>x.emitResolverStart(e,o),onComplete:(e,o,p)=>{if(M.clearRetryAttempts(e),x.emitResolverComplete(e,o,p),x.emitRequirementMet(o,e),A.markResolved(o.fromConstraint),$){let L=D.get(o.id);if(L!==void 0){let G=s.get(L);G&&G.resolversCompleted.push({resolver:e,requirementId:o.id,duration:p});}m(o.id);}},onError:(e,o,p)=>{let L=M.handleError("resolver",e,p,o);if(x.emitResolverError(e,o,p),L==="disable"&&A.disable(o.fromConstraint),L==="retry"&&(q.previousRequirements.remove(o.id),Z()),L==="retry-later"){let U=M.getRetryLaterManager().getPendingRetries().find(ee=>ee.sourceId===e);U&&!U.callback&&(U.callback=()=>{Z();});}if($){let G=D.get(o.id);if(G!==void 0){let U=s.get(G);U&&U.resolversErrored.push({resolver:e,requirementId:o.id,error:String(p)});}m(o.id);}},onRetry:(e,o,p)=>x.emitResolverRetry(e,o,p),onCancel:(e,o)=>{x.emitResolverCancel(e,o),x.emitRequirementCanceled(o),$&&m(o.id);},onResolutionComplete:()=>{ie(),Z();}}),ne=new Set;function ue(){for(let e of ne)e();}let Q=n.debug?.timeTravel?We({config:n.debug,facts:z,store:V,onSnapshot:e=>{x.emitSnapshot(e),ue();},onTimeTravel:(e,o)=>{x.emitTimeTravel(e,o),ue();}}):Ke();T=Q;let oe=new Set;function ie(){for(let e of oe)e();}let ye=50,me=0,q={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new De,readyPromise:null,readyResolve:null};function Z(){!q.isRunning||q.reconcileScheduled||q.isInitializing||(q.reconcileScheduled=true,ie(),queueMicrotask(()=>{q.reconcileScheduled=false,q.isRunning&&!q.isInitializing&&re().catch(e=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function re(){if(q.isReconciling)return;if(me++,me>ye){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${ye} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),$&&(b.length=0),me=0;return}q.isReconciling=true,ie();let e=$?performance.now():0;if($){let o=++k;d.set(o,e),f={id:o,timestamp:Date.now(),duration:0,status:"pending",factChanges:b.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]};}try{q.changedKeys.size>0&&((R===null||E)&&Q.takeSnapshot(`facts-changed:${[...q.changedKeys].join(",")}`),E=!1);let o=z.$snapshot();x.emitReconcileStart(o),await B.runEffects(q.changedKeys);let p=new Set(q.changedKeys);q.changedKeys.clear();let L=await A.evaluate(p),G=new De;for(let X of L)G.add(X),x.emitRequirementCreated(X);if(f){let X=new Set(L.map(te=>te.fromConstraint));for(let te of X){let de=A.getState(te);if(de){let se=A.getDependencies(te);f.constraintsHit.push({id:te,priority:de.priority,deps:se?[...se]:[]});}}}let{added:U,removed:ee}=G.diff(q.previousRequirements);if(f){for(let X of U)f.requirementsAdded.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});for(let X of ee)f.requirementsRemoved.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});}for(let X of ee)J.cancel(X.id);for(let X of U)J.resolve(X);if(f){let X=J.getInflightInfo();for(let te of U){let de=X.find(se=>se.id===te.id);f.resolversStarted.push({resolver:de?.resolverId??"unknown",requirementId:te.id}),D.set(te.id,f.id);}}q.previousRequirements=G;let ce=J.getInflightInfo(),le={unmet:L.filter(X=>!J.isResolving(X.id)),inflight:ce,completed:[],canceled:ee.map(X=>({id:X.id,resolverId:ce.find(te=>te.id===X.id)?.resolverId??"unknown"}))};x.emitReconcileEnd(le),q.isReady||(q.isReady=!0,q.readyResolve&&(q.readyResolve(),q.readyResolve=null));}finally{if(f){if(f.duration=performance.now()-e,f.factChanges.length>0||f.constraintsHit.length>0||f.requirementsAdded.length>0||f.effectsRun.length>0){let p=f.resolversStarted.length;p===0?(f.status="settled",f.causalChain=F(f),N(f),K.push(f),s.set(f.id,f),K.length>Y&&S(),I++,x.emitRunComplete(f)):(f.status="pending",K.push(f),s.set(f.id,f),K.length>Y&&S(),I++,_.set(f.id,p));}else d.delete(f.id);f=null;}q.isReconciling=false,q.changedKeys.size>0?Z():q.reconcileScheduled||(me=0),ie();}}let be=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return C.get(o)},has(e,o){return typeof o=="symbol"||he.has(o)?false:o in v},ownKeys(){return Object.keys(v)},getOwnPropertyDescriptor(e,o){if(typeof o!="symbol"&&!he.has(o)&&o in v)return {configurable:true,enumerable:true}}}),wt=new Proxy({},{get(e,o){if(typeof o!="symbol"&&!he.has(o))return p=>{let L=g[o];if(L){l++,(R===null||R.has(o))&&(E=true);try{V.batch(()=>{L(z,{type:o,...p});});}finally{l--;}}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}}}),pe={facts:z,debug:Q.isEnabled?Q:null,derive:be,events:wt,constraints:{disable:e=>A.disable(e),enable:e=>A.enable(e),isDisabled:e=>A.isDisabled(e)},effects:{disable:e=>B.disable(e),enable:e=>B.enable(e),isEnabled:e=>B.isEnabled(e)},get runHistory(){return $?((!i||h!==I)&&(i=[...K],h=I),i):null},initialize(){if(!q.isInitialized){q.isInitializing=true;for(let e of n.modules)e.init&&V.batch(()=>{e.init(z);});n.onAfterModuleInit&&V.batch(()=>{n.onAfterModuleInit();}),q.isInitializing=false,q.isInitialized=true;for(let e of Object.keys(v))C.get(e);}},start(){if(!q.isRunning){q.isInitialized||this.initialize(),q.isRunning=true;for(let e of n.modules)e.hooks?.onStart?.(pe);if(x.emitStart(pe),n.errorBoundary?.retryLater&&!W){let e=Math.max(n.errorBoundary.retryLater.delayMs??1e3,250);W=setInterval(()=>{let o=M.processDueRetries();for(let p of o)p.callback?p.callback():Z();},Math.min(e,500));}Z();}},stop(){if(q.isRunning){q.isRunning=false,W!==null&&(clearInterval(W),W=null),M.getRetryLaterManager().clearAll(),J.cancelAll(),B.cleanupAll();for(let e of n.modules)e.hooks?.onStop?.(pe);x.emitStop(pe);}},destroy(){this.stop(),q.isDestroyed=true,oe.clear(),ne.clear(),K.length=0,s.clear(),D.clear(),_.clear(),d.clear(),b.length=0,f=null,i=null,x.emitDestroy(pe);},dispatch(e){if(he.has(e.type))return;let o=g[e.type];if(o){l++,(R===null||R.has(e.type))&&(E=true);try{V.batch(()=>{o(z,e);});}finally{l--;}}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 C.get(e)},subscribe(e,o){let p=[],L=[];for(let U of e)U in v?p.push(U):U in r?L.push(U):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${U}"`);let G=[];return p.length>0&&G.push(C.subscribe(p,o)),L.length>0&&G.push(V.subscribe(L,o)),()=>{for(let U of G)U();}},watch(e,o,p){let L=p?.equalityFn?(U,ee)=>p.equalityFn(U,ee):(U,ee)=>Object.is(U,ee);if(e in v){let U=C.get(e);return C.subscribe([e],()=>{let ee=C.get(e);if(!L(ee,U)){let ce=U;U=ee,o(ee,ce);}})}process.env.NODE_ENV!=="production"&&(e in r||console.warn(`[Directive] watch: unknown key "${e}"`));let G=V.get(e);return V.subscribe([e],()=>{let U=V.get(e);if(!L(U,G)){let ee=G;G=U,o(U,ee);}})},when(e,o){return new Promise((p,L)=>{let G=V.toObject();if(e(G)){p();return}let U,ee,ce=()=>{U?.(),ee!==void 0&&clearTimeout(ee);};U=V.subscribeAll(()=>{let le=V.toObject();e(le)&&(ce(),p());}),o?.timeout!==void 0&&o.timeout>0&&(ee=setTimeout(()=>{ce(),L(new Error(`[Directive] when: timed out after ${o.timeout}ms`));},o.timeout));})},inspect(){return {unmet:q.previousRequirements.all(),inflight:J.getInflightInfo(),constraints:A.getAllStates().map(e=>({id:e.id,active:e.lastResult??false,disabled:A.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt})),resolvers:Object.fromEntries(J.getInflight().map(e=>[e,J.getStatus(e)])),resolverDefs:Object.entries(u).map(([e,o])=>({id:e,requirement:typeof o.requirement=="string"?o.requirement:"(predicate)"})),runHistoryEnabled:$,...$?{runHistory:K.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 p=q.previousRequirements.all().find(te=>te.id===e);if(!p)return null;let L=A.getState(p.fromConstraint),G=J.getStatus(e),U={},ee=V.toObject();for(let[te,de]of Object.entries(ee))U[te]=de;let ce=[`Requirement "${p.requirement.type}" (id: ${p.id})`,`\u251C\u2500 Produced by constraint: ${p.fromConstraint}`,`\u251C\u2500 Constraint priority: ${L?.priority??0}`,`\u251C\u2500 Constraint active: ${L?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${G.state}`],le=Object.entries(p.requirement).filter(([te])=>te!=="type").map(([te,de])=>`${te}=${JSON.stringify(de)}`).join(", ");le&&ce.push(`\u251C\u2500 Requirement payload: { ${le} }`);let X=Object.entries(U).slice(0,10);return X.length>0&&(ce.push("\u2514\u2500 Relevant facts:"),X.forEach(([te,de],se)=>{let Se=se===X.length-1?" \u2514\u2500":" \u251C\u2500",we=typeof de=="object"?JSON.stringify(de):String(de);ce.push(`${Se} ${te} = ${we.slice(0,50)}${we.length>50?"...":""}`);})),ce.join(`
2
- `)},async settle(e=5e3){let o=Date.now();for(;;){J.hasPendingBatches()&&J.processBatches(),await new Promise(G=>setTimeout(G,0));let p=this.inspect();if(p.inflight.length===0&&!q.isReconciling&&!q.reconcileScheduled&&!J.hasPendingBatches())return;if(Date.now()-o>e){let G=[];p.inflight.length>0&&G.push(`${p.inflight.length} resolvers inflight: ${p.inflight.map(ee=>ee.resolverId).join(", ")}`),q.isReconciling&&G.push("reconciliation in progress"),q.reconcileScheduled&&G.push("reconcile scheduled");let U=q.previousRequirements.all();throw U.length>0&&G.push(`${U.length} unmet requirements: ${U.map(ee=>ee.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${e}ms. ${G.join("; ")}`)}await new Promise(G=>setTimeout(G,10));}},getSnapshot(){return {facts:V.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:o,excludeDerivations:p,includeFacts:L,ttlSeconds:G,metadata:U,includeVersion:ee}=e,ce={},le=Object.keys(v),X;if(o){if(X=o.filter(se=>le.includes(se)),process.env.NODE_ENV!=="production"){let se=o.filter(Se=>!le.includes(Se));se.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${se.join(", ")}. Available: ${le.join(", ")||"(none)"}`);}}else X=le;if(p){let se=new Set(p);X=X.filter(Se=>!se.has(Se));}for(let se of X)try{ce[se]=C.get(se);}catch(Se){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${se}" due to error:`,Se);}if(L&&L.length>0){let se=V.toObject(),Se=Object.keys(se);if(process.env.NODE_ENV!=="production"){let we=L.filter(Rt=>!(Rt in se));we.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${we.join(", ")}. Available: ${Se.join(", ")||"(none)"}`);}for(let we of L)we in se&&(ce[we]=se[we]);}let te=Date.now(),de={data:ce,createdAt:te};return G!==void 0&&G>0&&(de.expiresAt=te+G*1e3),ee&&(de.version=Be(ce)),U&&(de.metadata=U),de},watchDistributableSnapshot(e,o){let{includeDerivations:p,excludeDerivations:L}=e,G=Object.keys(v),U;if(p?U=p.filter(le=>G.includes(le)):U=G,L){let le=new Set(L);U=U.filter(X=>!le.has(X));}if(U.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 C.subscribe(U,()=>{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,p]of Object.entries(e.facts))he.has(o)||V.set(o,p);});},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 J.getInflight().length===0&&!J.hasPendingBatches()&&!q.isReconciling&&!q.reconcileScheduled},get isRunning(){return q.isRunning},get isInitialized(){return q.isInitialized},get isReady(){return q.isReady},whenReady(){return q.isReady?Promise.resolve():q.isRunning?(q.readyPromise||(q.readyPromise=new Promise(e=>{q.readyResolve=e;})),q.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function kt(e){if(q.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(q.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let o=(p,L)=>{if(p){for(let G of Object.keys(p))if(he.has(G))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${G}" in ${L}.`)}};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 p of Object.keys(e.schema))if(p in r)throw new Error(`[Directive] Schema collision: Fact "${p}" already exists. Cannot register module "${e.id}".`);if(process.env.NODE_ENV!=="production"&&e.derive){let p=new Set(Object.keys(r));for(let L of Object.keys(e.derive))p.has(L)&&console.warn(`[Directive] "${L}" exists as both a fact and a derivation after registering module "${e.id}".`);}if(e.snapshotEvents){R===null&&(R=new Set(Object.keys(g)));for(let p of e.snapshotEvents)R.add(p);}else if(R!==null&&e.events)for(let p of Object.keys(e.events))R.add(p);Object.assign(r,e.schema),e.events&&Object.assign(g,e.events),e.derive&&(Object.assign(v,e.derive),C.registerDefinitions(e.derive)),e.effects&&(Object.assign(a,e.effects),B.registerDefinitions(e.effects)),e.constraints&&(Object.assign(t,e.constraints),A.registerDefinitions(e.constraints)),e.resolvers&&(Object.assign(u,e.resolvers),J.registerDefinitions(e.resolvers)),V.registerKeys(e.schema),n.modules.push(e),e.init&&V.batch(()=>{e.init(z);}),e.hooks?.onInit?.(pe),q.isRunning&&(e.hooks?.onStart?.(pe),Z());}pe.registerModule=kt,x.emitInit(pe);for(let e of n.modules)e.hooks?.onInit?.(pe);return pe}var he,dt=ge(()=>{Ve();Ee();He();Ge();Je();tt();rt();ot();qe();lt();he=new Set(["__proto__","constructor","prototype"]);});var vt={};Dt(vt,{createSystem:()=>_t});function jt(n){let r=Object.keys(n),g=new Set,v=new Set,a=[],t=[];function u(y){if(g.has(y))return;if(v.has(y)){let w=t.indexOf(y),l=[...t.slice(w),y].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${l}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}v.add(y),t.push(y);let R=n[y];if(R?.crossModuleDeps)for(let w of Object.keys(R.crossModuleDeps))r.includes(w)&&u(w);t.pop(),v.delete(y),g.add(y),a.push(y);}for(let y of r)u(y);return a}function _t(n){if("module"in n){if(!n.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof n.module);return Wt(n)}let r=n;if(Array.isArray(r.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
1
+ var jt=Object.defineProperty;var ge=(o,r)=>()=>(o&&(r=o(o=0)),r);var _t=(o,r)=>{for(var m in r)jt(o,m,{get:r[m],enumerable:true});};async function Oe(o,r,m){let u,b=new Promise((n,g)=>{u=setTimeout(()=>g(new Error(m)),r);});try{return await Promise.race([o,b])}finally{clearTimeout(u);}}function Ne(o,r=50){let m=new WeakSet;function u(b,n){if(n>r)return '"[max depth exceeded]"';if(b===null)return "null";if(b===void 0)return "undefined";let g=typeof b;if(g==="string")return JSON.stringify(b);if(g==="number"||g==="boolean")return String(b);if(g==="function")return '"[function]"';if(g==="symbol")return '"[symbol]"';if(Array.isArray(b)){if(m.has(b))return '"[circular]"';m.add(b);let y=`[${b.map(w=>u(w,n+1)).join(",")}]`;return m.delete(b),y}if(g==="object"){let y=b;if(m.has(y))return '"[circular]"';m.add(y);let l=`{${Object.keys(y).sort().map(x=>`${JSON.stringify(x)}:${u(y[x],n+1)}`).join(",")}}`;return m.delete(y),l}return '"[unknown]"'}return u(o,0)}function Re(o,r=50){let m=new Set(["__proto__","constructor","prototype"]),u=new WeakSet;function b(n,g){if(g>r)return false;if(n==null||typeof n!="object")return true;let y=n;if(u.has(y))return true;if(u.add(y),Array.isArray(y)){for(let w of y)if(!b(w,g+1))return u.delete(y),false;return u.delete(y),true}for(let w of Object.keys(y))if(m.has(w)||!b(y[w],g+1))return u.delete(y),false;return u.delete(y),true}return b(o,0)}function Je(o){let r=Ne(o),m=5381;for(let u=0;u<r.length;u++)m=(m<<5)+m^r.charCodeAt(u);return (m>>>0).toString(16)}var De=ge(()=>{});function Qe(o){let{config:r,facts:m,store:u,onSnapshot:b,onTimeTravel:n}=o,g=r.timeTravel??false,y=r.maxSnapshots??100,w=[],v=-1,l=1,x=false,E=false,A=[],V=null,B=-1;function N(){return u.toObject()}function S(){let P=N();return structuredClone(P)}function R(P){if(!Re(P)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}u.batch(()=>{for(let[c,D]of Object.entries(P)){if(c==="__proto__"||c==="constructor"||c==="prototype"){console.warn(`[Directive] Skipping dangerous key "${c}" during fact restoration`);continue}m[c]=D;}});}return {get isEnabled(){return g},get isRestoring(){return E},get isPaused(){return x},get snapshots(){return [...w]},get currentIndex(){return v},takeSnapshot(P){if(!g||x)return {id:-1,timestamp:Date.now(),facts:{},trigger:P};let c={id:l++,timestamp:Date.now(),facts:S(),trigger:P};for(v<w.length-1&&w.splice(v+1),w.push(c),v=w.length-1;w.length>y;)w.shift(),v--;return b?.(c),c},restore(P){if(g){x=true,E=true;try{R(P.facts);}finally{x=false,E=false;}}},goBack(P=1){if(!g||w.length===0)return;let c=v,D=v,i=A.find(T=>v>T.startIndex&&v<=T.endIndex);if(i)D=i.startIndex;else if(A.find(_=>v===_.startIndex)){let _=A.find(W=>W.endIndex<v&&v-W.endIndex<=P);D=_?_.startIndex:Math.max(0,v-P);}else D=Math.max(0,v-P);if(c===D)return;v=D;let k=w[v];k&&(this.restore(k),n?.(c,D));},goForward(P=1){if(!g||w.length===0)return;let c=v,D=v,i=A.find(T=>v>=T.startIndex&&v<T.endIndex);if(i?D=i.endIndex:D=Math.min(w.length-1,v+P),c===D)return;v=D;let k=w[v];k&&(this.restore(k),n?.(c,D));},goTo(P){if(!g)return;let c=w.findIndex(k=>k.id===P);if(c===-1){console.warn(`[Directive] Snapshot ${P} not found`);return}let D=v;v=c;let i=w[v];i&&(this.restore(i),n?.(D,c));},replay(){if(!g||w.length===0)return;v=0;let P=w[0];P&&this.restore(P);},export(){return JSON.stringify({version:1,snapshots:w,currentIndex:v})},import(P){if(g)try{let c=JSON.parse(P);if(typeof c!="object"||c===null)throw new Error("Invalid time-travel data: expected object");if(c.version!==1)throw new Error(`Unsupported time-travel export version: ${c.version}`);if(!Array.isArray(c.snapshots))throw new Error("Invalid time-travel data: snapshots must be an array");if(typeof c.currentIndex!="number")throw new Error("Invalid time-travel data: currentIndex must be a number");for(let i of c.snapshots){if(typeof i!="object"||i===null)throw new Error("Invalid snapshot: expected object");if(typeof i.id!="number"||typeof i.timestamp!="number"||typeof i.trigger!="string"||typeof i.facts!="object")throw new Error("Invalid snapshot structure");if(!Re(i.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}w.length=0,w.push(...c.snapshots),v=c.currentIndex;let D=w[v];D&&this.restore(D);}catch(c){console.error("[Directive] Failed to import time-travel data:",c);}},beginChangeset(P){g&&(V=P,B=v);},endChangeset(){!g||V===null||(v>B&&A.push({label:V,startIndex:B,endIndex:v}),V=null,B=-1);},pause(){x=true;},resume(){x=false;}}}function Xe(){let o={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>o,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var Ze=ge(()=>{De();});function Ft(o,r){if(r)return r(o);let m=et.get(o);if(m!==void 0)return m;let{type:u,...b}=o,n=Ne(b),g=`${u}:${n}`;return et.set(o,g),g}function Ve(o,r,m){return {requirement:o,id:Ft(o,m),fromConstraint:r}}var et,Ee,We=ge(()=>{De();et=new WeakMap;Ee=class o{map=new Map;add(r){this.map.has(r.id)||this.map.set(r.id,r);}remove(r){return this.map.delete(r)}has(r){return this.map.has(r)}get(r){return this.map.get(r)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let r=new o;for(let m of this.map.values())r.add(m);return r}diff(r){let m=[],u=[],b=[];for(let n of this.map.values())r.has(n.id)?b.push(n):m.push(n);for(let n of r.map.values())this.map.has(n.id)||u.push(n);return {added:m,removed:u,unchanged:b}}};});function Nt(){let o=new Set;return {get isTracking(){return true},track(r){o.add(r);},getDependencies(){return o}}}function Wt(){return Ce[Ce.length-1]??Vt}function xe(o){let r=Nt();Ce.push(r);try{return {value:o(),deps:r.getDependencies()}}finally{Ce.pop();}}function Be(o){let r=Ce.splice(0,Ce.length);try{return o()}finally{for(let m of r)Ce.push(m);}}function Pe(o){Wt().track(o);}var Ce,Vt,Z,Te=ge(()=>{Ce=[];Vt={isTracking:false,track(){},getDependencies(){return new Set}};Z=Object.freeze(new Set(["__proto__","constructor","prototype"]));});function tt(o){let{definitions:r,facts:m,requirementKeys:u={},defaultTimeout:b=Bt,onEvaluate:n,onError:g}=o,y=new Map,w=new Set,v=new Set,l=new Map,x=new Map,E=new Set,A=new Map,V=new Map,B=false,N=new Set,S=new Set,R=new Map,L=[],P=new Map;function c(){R.clear();for(let[a,p]of Object.entries(r))if(p.after)for(let h of p.after)r[h]&&(R.has(h)||R.set(h,new Set),R.get(h).add(a));}function D(){let a=new Set,p=new Set,h=[];function $(K,G){if(a.has(K))return;if(p.has(K)){let le=G.indexOf(K),Y=[...G.slice(le),K].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${Y}. Remove one of the \`after\` dependencies to break the cycle.`)}p.add(K),G.push(K);let ce=r[K];if(ce?.after)for(let le of ce.after)r[le]&&$(le,G);G.pop(),p.delete(K),a.add(K),h.push(K);}for(let K of Object.keys(r))$(K,[]);L=h,P=new Map(L.map((K,G)=>[K,G]));}if(D(),c(),process.env.NODE_ENV!=="production"){for(let[a,p]of Object.entries(r))if(p.after)for(let h of p.after)r[h]||console.warn(`[Directive] Constraint "${a}" references unknown constraint "${h}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function i(a,p){return p.async!==void 0?p.async:!!v.has(a)}function k(a){let p=r[a];if(!p)throw new Error(`[Directive] Unknown constraint: ${a}`);let h=i(a,p);h&&v.add(a);let $={id:a,priority:p.priority??0,isAsync:h,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:p.after??[],hitCount:0,lastActiveAt:null};return y.set(a,$),$}function T(a){return y.get(a)??k(a)}function _(a,p){let h=l.get(a)??new Set;if(h.size===p.size&&h.size>0){let $=true;for(let K of p)if(!h.has(K)){$=false;break}if($)return}for(let $ of h){let K=x.get($);K?.delete(a),K&&K.size===0&&x.delete($);}for(let $ of p)x.has($)||x.set($,new Set),x.get($).add(a);l.set(a,p);}function W(a){let p=r[a];if(!p)return false;let h=T(a);h.isEvaluating=true,h.error=null;try{let $;if(p.deps)$=p.when(m),A.set(a,new Set(p.deps));else {let K=xe(()=>p.when(m));$=K.value,A.set(a,K.deps);}return $ instanceof Promise?(v.add(a),h.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${a}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),$.then(K=>(h.lastResult=K,K&&(h.hitCount++,h.lastActiveAt=Date.now()),h.isEvaluating=!1,n?.(a,K),K)).catch(K=>(h.error=K instanceof Error?K:new Error(String(K)),h.lastResult=!1,h.isEvaluating=!1,g?.(a,K),!1))):(h.lastResult=$,$&&(h.hitCount++,h.lastActiveAt=Date.now()),h.isEvaluating=!1,n?.(a,$),$)}catch($){return h.error=$ instanceof Error?$:new Error(String($)),h.lastResult=false,h.isEvaluating=false,g?.(a,$),false}}async function s(a){let p=r[a];if(!p)return false;let h=T(a),$=p.timeout??b;if(h.isEvaluating=true,h.error=null,p.deps?.length){let K=new Set(p.deps);_(a,K),A.set(a,K);}try{let K=p.when(m),G=await Oe(K,$,`Constraint "${a}" timed out after ${$}ms`);return h.lastResult=G,G&&(h.hitCount++,h.lastActiveAt=Date.now()),h.isEvaluating=!1,n?.(a,G),G}catch(K){return h.error=K instanceof Error?K:new Error(String(K)),h.lastResult=false,h.isEvaluating=false,g?.(a,K),false}}let f=10;function C(a,p){if(a==null)return [];if(Array.isArray(a)){let h=a.filter($=>$!=null);return process.env.NODE_ENV!=="production"&&h.length>f&&p&&console.warn(`[Directive] Constraint "${p}" produced ${h.length} requirements. Consider splitting into multiple constraints for better performance.`),h}return [a]}function O(a){let p=r[a];if(!p)return {requirements:[],deps:new Set};let h=p.require;if(typeof h=="function"){let{value:K,deps:G}=xe(()=>h(m));return {requirements:C(K,a),deps:G}}return {requirements:C(h,a),deps:new Set}}function j(a,p){if(p.size===0)return;let h=l.get(a)??new Set;for(let $ of p)h.add($),x.has($)||x.set($,new Set),x.get($).add(a);l.set(a,h);}let z=null;function M(){return z||(z=Object.keys(r).sort((a,p)=>{let h=T(a),K=T(p).priority-h.priority;if(K!==0)return K;let G=P.get(a)??0,ce=P.get(p)??0;return G-ce})),z}for(let a of Object.keys(r))k(a);if(process.env.NODE_ENV!=="production")for(let[a,p]of Object.entries(r))p.async&&!p.deps&&console.warn(`[Directive] Async constraint "${a}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function U(a){let p=y.get(a);if(!p||p.after.length===0)return true;for(let h of p.after)if(r[h]&&!w.has(h)&&!S.has(h)&&!N.has(h))return false;return true}return {async evaluate(a){let p=new Ee;S.clear();let h=M().filter(Y=>!w.has(Y)),$;if(!B||!a||a.size===0)$=h,B=true;else {let Y=new Set;for(let se of a){let re=x.get(se);if(re)for(let ye of re)w.has(ye)||Y.add(ye);}for(let se of E)w.has(se)||Y.add(se);E.clear(),$=[...Y];for(let se of h)if(!Y.has(se)){let re=V.get(se);if(re)for(let ye of re)p.add(ye);}}function K(Y,se){if(w.has(Y))return;let re=A.get(Y);if(!se){re!==void 0&&_(Y,re),S.add(Y),V.set(Y,[]);return}S.delete(Y);let ye,pe;try{let q=O(Y);ye=q.requirements,pe=q.deps;}catch(q){g?.(Y,q),re!==void 0&&_(Y,re),V.set(Y,[]);return}if(re!==void 0){let q=new Set(re);for(let X of pe)q.add(X);_(Y,q);}else j(Y,pe);if(ye.length>0){let q=u[Y],X=ye.map(ee=>Ve(ee,Y,q));for(let ee of X)p.add(ee);V.set(Y,X);}else V.set(Y,[]);}async function G(Y){let se=[],re=[];for(let X of Y)if(U(X))re.push(X);else {se.push(X);let ee=V.get(X);if(ee)for(let he of ee)p.add(he);}if(re.length===0)return se;let ye=[],pe=[];for(let X of re)T(X).isAsync?pe.push(X):ye.push(X);let q=[];for(let X of ye){let ee=W(X);if(ee instanceof Promise){q.push({id:X,promise:ee});continue}K(X,ee);}if(q.length>0){let X=await Promise.all(q.map(async({id:ee,promise:he})=>({id:ee,active:await he})));for(let{id:ee,active:he}of X)K(ee,he);}if(pe.length>0){let X=await Promise.all(pe.map(async ee=>({id:ee,active:await s(ee)})));for(let{id:ee,active:he}of X)K(ee,he);}return se}let ce=$,le=$.length+1;for(;ce.length>0&&le>0;){let Y=ce.length;if(ce=await G(ce),ce.length===Y)break;le--;}return p.all()},getState(a){return y.get(a)},getDependencies(a){return l.get(a)},getAllStates(){return [...y.values()]},disable(a){if(!y.has(a)){console.warn(`[Directive] constraints.disable("${a}") \u2014 no such constraint`);return}w.add(a),z=null,V.delete(a);let p=l.get(a);if(p){for(let h of p){let $=x.get(h);$&&($.delete(a),$.size===0&&x.delete(h));}l.delete(a);}A.delete(a);},enable(a){if(!y.has(a)){console.warn(`[Directive] constraints.enable("${a}") \u2014 no such constraint`);return}w.delete(a),z=null,E.add(a);},isDisabled(a){return w.has(a)},invalidate(a){let p=x.get(a);if(p)for(let h of p)E.add(h);},markResolved(a){N.add(a);let p=y.get(a);p&&(p.lastResolvedAt=Date.now());let h=R.get(a);if(h)for(let $ of h)E.add($);},isResolved(a){return N.has(a)},registerDefinitions(a){let p=false;for(let[h,$]of Object.entries(a))r[h]=$,k(h),E.add(h),$.after?.length&&(p=true);z=null,p&&D(),c();},assignDefinition(a,p){if(!r[a])throw new Error(`[Directive] Cannot assign constraint "${a}" \u2014 it does not exist. Use register() to create it.`);r[a]=p,k(a),E.add(a),z=null,D(),c();},unregisterDefinition(a){if(!r[a])return;delete r[a],y.delete(a),w.delete(a),v.delete(a),E.delete(a),S.delete(a),N.delete(a),V.delete(a),A.delete(a);let p=l.get(a);if(p){for(let h of p){let $=x.get(h);$&&($.delete(a),$.size===0&&x.delete(h));}l.delete(a);}R.delete(a);for(let h of R.values())h.delete(a);z=null,D(),c();},async callOne(a,p){if(!r[a])throw new Error(`[Directive] Cannot call constraint "${a}" \u2014 it does not exist.`);if(w.has(a))return [];let $=T(a),K;if($.isAsync)K=await s(a);else {let Y=W(a);K=Y instanceof Promise?await Y:Y;}if(!K)return [];let{requirements:G}=O(a);if(G.length===0)return [];let ce=u[a],le=[];for(let Y of G){let se=p?{...Y,...p}:Y;le.push(Ve(se,a,ce));}return le}}}var Bt,nt=ge(()=>{De();We();Te();Bt=5e3;});function rt(o){let{definitions:r,facts:m,onCompute:b,onInvalidate:n,onError:g}=o,y=new Map,w=new Map,v=new Map,l=new Map,x=0,E=new Set,A=false,V=100,B;function N(i){if(!r[i])throw new Error(`[Directive] Unknown derivation: ${i}`);let T={id:i,compute:()=>R(i),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return y.set(i,T),T}function S(i){return y.get(i)??N(i)}function R(i){let k=S(i),T=r[i];if(!T)throw new Error(`[Directive] Unknown derivation: ${i}`);if(k.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${i}`);k.isComputing=true;try{let _=k.cachedValue,{value:W,deps:s}=xe(()=>T(m,B));return k.cachedValue=W,k.isStale=!1,L(i,s),b?.(i,W,_,[...s]),W}catch(_){throw g?.(i,_),_}finally{k.isComputing=false;}}function L(i,k){let T=S(i),_=T.dependencies;if(_.size===k.size){let W=true;for(let s of k)if(!_.has(s)){W=false;break}if(W)return}for(let W of _)if(y.has(W)){let s=l.get(W);s?.delete(i),s&&s.size===0&&l.delete(W);}else {let s=v.get(W);s?.delete(i),s&&s.size===0&&v.delete(W);}for(let W of k)r[W]?(l.has(W)||l.set(W,new Set),l.get(W).add(i)):(v.has(W)||v.set(W,new Set),v.get(W).add(i));T.dependencies=k;}function P(){if(!(x>0||A)){A=true;try{let i=0;for(;E.size>0;){if(++i>V){let T=[...E];throw E.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${V} iterations. Remaining: ${T.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let k=[...E];E.clear();for(let T of k)w.get(T)?.forEach(_=>_());}}finally{A=false;}}}function c(i,k=new Set){let T=[i];for(;T.length>0;){let _=T.pop();if(k.has(_))continue;k.add(_);let W=y.get(_);if(!W||W.isStale)continue;W.isStale=true,n?.(_),E.add(_);let s=l.get(_);if(s)for(let f of s)T.push(f);}}return B=new Proxy({},{get(i,k){if(typeof k=="symbol"||Z.has(k)||!r[k])return;Pe(k);let T=S(k);return T.isStale&&R(k),T.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(i){let k=S(i);return k.isStale&&R(i),k.cachedValue},isStale(i){return y.get(i)?.isStale??true},invalidate(i){let k=v.get(i);if(!k)return;x++;let T=new Set;try{for(let _ of k)c(_,T);}finally{x--,P();}},invalidateMany(i){x++;let k=new Set;try{for(let T of i){let _=v.get(T);if(_)for(let W of _)c(W,k);}}finally{x--,P();}},invalidateAll(){x++;try{for(let i of y.values())i.isStale||(i.isStale=!0,E.add(i.id));}finally{x--,P();}},subscribe(i,k){for(let T of i){let _=T;w.has(_)||w.set(_,new Set),w.get(_).add(k);}return ()=>{for(let T of i){let _=T,W=w.get(_);W?.delete(k),W&&W.size===0&&w.delete(_);}}},getProxy(){return B},getDependencies(i){return S(i).dependencies},registerDefinitions(i){for(let[k,T]of Object.entries(i))r[k]=T,N(k);},assignDefinition(i,k){if(!r[i])throw new Error(`[Directive] Cannot assign derivation "${i}" \u2014 it does not exist. Use register() to create it.`);r[i]=k;let T=y.get(i);T&&(T.isStale=true,E.add(i)),P();},unregisterDefinition(i){if(!r[i])return;let k=y.get(i);if(k)for(let _ of k.dependencies)if(y.has(_)){let W=l.get(_);W?.delete(i),W&&W.size===0&&l.delete(_);}else {let W=v.get(_);W?.delete(i),W&&W.size===0&&v.delete(_);}let T=l.get(i);if(T){x++;try{for(let _ of T)c(_);}finally{x--;}l.delete(i);}delete r[i],y.delete(i),w.delete(i),E.delete(i),P();},callOne(i){if(!r[i])throw new Error(`[Directive] Cannot call derivation "${i}" \u2014 it does not exist.`);return R(i)}}}var st=ge(()=>{Te();});function ot(o){let{definitions:r,facts:m,store:u,onRun:b,onError:n}=o,g=new Map,y=null,w=false;function v(S){let R=r[S];if(!R)throw new Error(`[Directive] Unknown effect: ${S}`);let L={id:S,enabled:true,hasExplicitDeps:!!R.deps,dependencies:R.deps?new Set(R.deps):null,cleanup:null,stableRunCount:0,depsStable:false};return g.set(S,L),L}function l(S){return g.get(S)??v(S)}function x(){return u.toObject()}function E(S,R){let L=l(S);if(!L.enabled)return false;if(L.dependencies){for(let P of L.dependencies)if(R.has(P))return L.depsStable&&(L.depsStable=false,L.stableRunCount=0),true;return false}return true}function A(S){if(S.cleanup){try{S.cleanup();}catch(R){n?.(S.id,R),console.error(`[Directive] Effect "${S.id}" cleanup threw an error:`,R);}S.cleanup=null;}}function V(S,R){if(typeof R=="function")if(w)try{R();}catch(L){n?.(S.id,L),console.error(`[Directive] Effect "${S.id}" cleanup threw an error:`,L);}else S.cleanup=R;}async function B(S){let R=l(S),L=r[S];if(!(!R.enabled||!L)){A(R),b?.(S,R.dependencies?[...R.dependencies]:[]);try{if(R.hasExplicitDeps){let P;if(u.batch(()=>{P=L.run(m,y);}),P instanceof Promise){let c=await P;V(R,c);}else V(R,P);}else if(R.depsStable&&R.dependencies){let P;if(u.batch(()=>{P=L.run(m,y);}),P instanceof Promise){let c=await P;V(R,c);}else V(R,P);}else {let P,c=xe(()=>(u.batch(()=>{P=L.run(m,y);}),P)),D=c.deps,i=c.value;if(i instanceof Promise&&(i=await i),V(R,i),R.dependencies&&D.size===R.dependencies.size){let k=!0;for(let T of D)if(!R.dependencies.has(T)){k=!1;break}k?(R.stableRunCount++,R.stableRunCount>=Kt&&(R.depsStable=!0)):(R.stableRunCount=0,R.depsStable=!1);}else R.stableRunCount=0,R.depsStable=!1;R.dependencies=D.size>0?D:null;}}catch(P){n?.(S,P),console.error(`[Directive] Effect "${S}" threw an error:`,P),R.hasExplicitDeps||(R.stableRunCount=0,R.depsStable=false);}}}for(let S of Object.keys(r))v(S);return {async runEffects(S){let R=[];for(let L of Object.keys(r))E(L,S)&&R.push(L);await Promise.all(R.map(B)),y=x();},async runAll(){let S=Object.keys(r);await Promise.all(S.map(R=>{let L=l(R);return L.enabled?(L.depsStable=false,L.stableRunCount=0,B(R)):Promise.resolve()})),y=x();},disable(S){let R=l(S);R.enabled=false;},enable(S){let R=l(S);R.enabled=true;},isEnabled(S){return l(S).enabled},cleanupAll(){w=true;for(let S of g.values())A(S);},registerDefinitions(S){for(let[R,L]of Object.entries(S))r[R]=L,v(R);},assignDefinition(S,R){if(!r[S])throw new Error(`[Directive] Cannot assign effect "${S}" \u2014 it does not exist. Use register() to create it.`);let L=g.get(S);L&&A(L),r[S]=R,v(S);},unregisterDefinition(S){if(!r[S])return;let R=g.get(S);R&&A(R),delete r[S],g.delete(S);},async callOne(S){let R=r[S];if(!R)throw new Error(`[Directive] Cannot call effect "${S}" \u2014 it does not exist.`);let L=l(S);if(L.enabled){A(L),b?.(S,L.dependencies?[...L.dependencies]:[]);try{let P;if(u.batch(()=>{P=R.run(m,y);}),P instanceof Promise){let c=await P;V(L,c);}else V(L,P);}catch(P){n?.(S,P),console.error(`[Directive] Effect "${S}" threw an error:`,P);}}}}}var Kt,it=ge(()=>{Te();Kt=3;});var $e,at=ge(()=>{$e=class extends Error{constructor(m,u,b,n,g=true){super(m);this.source=u;this.sourceId=b;this.context=n;this.recoverable=g;this.name="DirectiveError";}};});var ct=ge(()=>{at();});var ut=ge(()=>{ct();});function Ut(o={}){let{delayMs:r=1e3,maxRetries:m=3,backoffMultiplier:u=2,maxDelayMs:b=3e4}=o,n=new Map;function g(y){let w=r*u**(y-1);return Math.min(w,b)}return {scheduleRetry(y,w,v,l,x){if(l>m)return null;let E=g(l),A={source:y,sourceId:w,context:v,attempt:l,nextRetryTime:Date.now()+E,callback:x};return n.set(w,A),A},getPendingRetries(){return Array.from(n.values())},processDueRetries(){let y=Date.now(),w=[];for(let[v,l]of n)l.nextRetryTime<=y&&(w.push(l),n.delete(v));return w},cancelRetry(y){n.delete(y);},clearAll(){n.clear();}}}function lt(o={}){let{config:r={},onError:m,onRecovery:u}=o,b=[],n=100,g=Ut(r.retryLater),y=new Map,w=1e3;function v(E,A,V,B){if(V instanceof $e)return V;let N=V instanceof Error?V.message:String(V),S=E!=="system";return new $e(N,E,A,B,S)}function l(E,A,V){let B=(()=>{switch(E){case "constraint":return r.onConstraintError;case "resolver":return r.onResolverError;case "effect":return r.onEffectError;case "derivation":return r.onDerivationError;default:return}})();if(typeof B=="function"){try{let N=B(V,A);if(typeof N=="string")return N}catch(N){console.error("[Directive] Error in error handler callback:",N);}return "skip"}return typeof B=="string"?B:Lt[E]}return {handleError(E,A,V,B){let N=v(E,A,V,B);b.push(N),b.length>n&&b.shift();try{m?.(N);}catch(R){console.error("[Directive] Error in onError callback:",R);}try{r.onError?.(N);}catch(R){console.error("[Directive] Error in config.onError callback:",R);}let S=l(E,A,V instanceof Error?V:new Error(String(V)));if(S==="retry-later"){let R=(y.get(A)??0)+1;if(y.set(A,R),y.size>w){let P=y.keys().next().value;P!==void 0&&y.delete(P);}g.scheduleRetry(E,A,B,R)||(S="skip",y.delete(A),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${E} "${A}" exceeded max retry-later attempts. Skipping.`));}try{u?.(N,S);}catch(R){console.error("[Directive] Error in onRecovery callback:",R);}if(S==="throw")throw N;return S},getLastError(){return b[b.length-1]??null},getAllErrors(){return [...b]},clearErrors(){b.length=0;},getRetryLaterManager(){return g},processDueRetries(){return g.processDueRetries()},clearRetryAttempts(E){y.delete(E),g.cancelRetry(E);}}}var Lt,dt=ge(()=>{ut();Lt={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};});function zt(o,r=100){try{return JSON.stringify(o)?.slice(0,r)??String(o)}catch{return "[circular or non-serializable]"}}function Ht(o){let{schema:r,onChange:m,onBatch:u}=o,n=Object.keys(r).length===0,g=o.validate??process.env.NODE_ENV!=="production",y=o.strictKeys??(process.env.NODE_ENV!=="production"&&!n),w=o.redactErrors??false,v=new Map,l=new Set,x=new Map,E=new Set,A=0,V=[],B=new Set,N=false,S=[],R=100;function L(s){return s!==null&&typeof s=="object"&&"safeParse"in s&&typeof s.safeParse=="function"&&"_def"in s&&"parse"in s&&typeof s.parse=="function"}function P(s){let f=s;if(f._typeName)return f._typeName;if(L(s)){let C=s._def;if(C?.typeName)return C.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function c(s){return w?"[redacted]":zt(s)}function D(s,f){if(!g)return;let C=r[s];if(!C){if(y)throw new Error(`[Directive] Unknown fact key: "${s}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${s}"`);return}if(L(C)){let M=C.safeParse(f);if(!M.success){let U=f===null?"null":Array.isArray(f)?"array":typeof f,F=c(f),a=M.error?.message??M.error?.issues?.[0]?.message??"Validation failed",p=P(C);throw new Error(`[Directive] Validation failed for "${s}": expected ${p}, got ${U} ${F}. ${a}`)}return}let O=C,j=O._validators;if(!j||!Array.isArray(j)||j.length===0)return;let z=O._typeName??"unknown";for(let M=0;M<j.length;M++){let U=j[M];if(typeof U=="function"&&!U(f)){let F=f===null?"null":Array.isArray(f)?"array":typeof f,a=c(f),p="";typeof O._lastFailedIndex=="number"&&O._lastFailedIndex>=0&&(p=` (element at index ${O._lastFailedIndex} failed)`,O._lastFailedIndex=-1);let h=M===0?"":` (validator ${M+1} failed)`;throw new Error(`[Directive] Validation failed for "${s}": expected ${z}, got ${F} ${a}${h}${p}`)}}}function i(s){x.get(s)?.forEach(f=>f());}function k(){E.forEach(s=>s());}function T(s,f,C){if(N){S.push({key:s,value:f,prev:C});return}N=true;try{m?.(s,f,C),i(s),k();let O=0;for(;S.length>0;){if(++O>R)throw S.length=0,new Error(`[Directive] Infinite notification loop detected after ${R} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let j=[...S];S.length=0;for(let z of j)m?.(z.key,z.value,z.prev),i(z.key);k();}}finally{N=false;}}function _(){if(!(A>0)){if(u&&V.length>0&&u([...V]),B.size>0){N=true;try{for(let f of B)i(f);k();let s=0;for(;S.length>0;){if(++s>R)throw S.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${R} iterations.`);let f=[...S];S.length=0;for(let C of f)m?.(C.key,C.value,C.prev),i(C.key);k();}}finally{N=false;}}V.length=0,B.clear();}}let W={get(s){return Pe(s),v.get(s)},has(s){return Pe(s),v.has(s)},set(s,f){D(s,f);let C=v.get(s);Object.is(C,f)||(v.set(s,f),l.add(s),A>0?(V.push({key:s,value:f,prev:C,type:"set"}),B.add(s)):T(s,f,C));},delete(s){let f=v.get(s);v.delete(s),l.delete(s),A>0?(V.push({key:s,value:void 0,prev:f,type:"delete"}),B.add(s)):T(s,void 0,f);},batch(s){A++;try{s();}finally{A--,_();}},subscribe(s,f){for(let C of s){let O=C;x.has(O)||x.set(O,new Set),x.get(O).add(f);}return ()=>{for(let C of s){let O=x.get(C);O&&(O.delete(f),O.size===0&&x.delete(C));}}},subscribeAll(s){return E.add(s),()=>E.delete(s)},toObject(){let s={};for(let f of l)v.has(f)&&(s[f]=v.get(f));return s}};return W.destroy=()=>{x.clear(),E.clear();},W.registerKeys=s=>{for(let f of Object.keys(s))Z.has(f)||(r[f]=s[f],l.add(f));},W}function Gt(o,r){let m=()=>({get:b=>Be(()=>o.get(b)),has:b=>Be(()=>o.has(b))});return new Proxy({},{get(b,n){if(n==="$store")return o;if(n==="$snapshot")return m;if(typeof n!="symbol"&&!Z.has(n))return o.get(n)},set(b,n,g){return typeof n=="symbol"||n==="$store"||n==="$snapshot"||Z.has(n)?false:(o.set(n,g),true)},deleteProperty(b,n){return typeof n=="symbol"||n==="$store"||n==="$snapshot"||Z.has(n)?false:(o.delete(n),true)},has(b,n){return n==="$store"||n==="$snapshot"?true:typeof n=="symbol"||Z.has(n)?false:o.has(n)},ownKeys(){return Object.keys(r)},getOwnPropertyDescriptor(b,n){return n==="$store"||n==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function ft(o){let r=Ht(o),m=Gt(r,o.schema);return {store:r,facts:m}}var gt=ge(()=>{Te();});function mt(){let o=[];function r(n){if(n)try{return n()}catch(g){console.error("[Directive] Plugin error:",g);return}}async function m(n){if(n)try{return await n()}catch(g){console.error("[Directive] Plugin error:",g);return}}function u(n){return (...g)=>{for(let y of o)r(()=>y[n]?.(...g));}}return {register(n){o.some(g=>g.name===n.name)&&(console.warn(`[Directive] Plugin "${n.name}" is already registered, replacing...`),this.unregister(n.name)),o.push(n);},unregister(n){let g=o.findIndex(y=>y.name===n);g!==-1&&o.splice(g,1);},getPlugins(){return [...o]},async emitInit(n){for(let g of o)await m(()=>g.onInit?.(n));},emitStart:u("onStart"),emitStop:u("onStop"),emitDestroy:u("onDestroy"),emitFactSet:u("onFactSet"),emitFactDelete:u("onFactDelete"),emitFactsBatch:u("onFactsBatch"),emitDerivationCompute:u("onDerivationCompute"),emitDerivationInvalidate:u("onDerivationInvalidate"),emitReconcileStart:u("onReconcileStart"),emitReconcileEnd:u("onReconcileEnd"),emitConstraintEvaluate:u("onConstraintEvaluate"),emitConstraintError:u("onConstraintError"),emitRequirementCreated:u("onRequirementCreated"),emitRequirementMet:u("onRequirementMet"),emitRequirementCanceled:u("onRequirementCanceled"),emitResolverStart:u("onResolverStart"),emitResolverComplete:u("onResolverComplete"),emitResolverError:u("onResolverError"),emitResolverRetry:u("onResolverRetry"),emitResolverCancel:u("onResolverCancel"),emitEffectRun:u("onEffectRun"),emitEffectError:u("onEffectError"),emitSnapshot:u("onSnapshot"),emitTimeTravel:u("onTimeTravel"),emitError:u("onError"),emitErrorRecovery:u("onErrorRecovery"),emitDefinitionRegister:u("onDefinitionRegister"),emitDefinitionAssign:u("onDefinitionAssign"),emitDefinitionUnregister:u("onDefinitionUnregister"),emitDefinitionCall:u("onDefinitionCall"),emitRunComplete:u("onRunComplete")}}var yt=ge(()=>{});function Yt(o,r){let{backoff:m,initialDelay:u=100,maxDelay:b=3e4}=o,n;switch(m){case "none":n=u;break;case "linear":n=u*r;break;case "exponential":n=u*2**(r-1);break;default:n=u;}return Math.max(1,Math.min(n,b))}function ht(o){let{definitions:r,facts:m,store:u,onStart:b,onComplete:n,onError:g,onRetry:y,onCancel:w,onResolutionComplete:v}=o;if(process.env.NODE_ENV!=="production")for(let[s,f]of Object.entries(r)){if(!f.resolve&&!f.resolveBatch&&!f.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${s}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(f.batch?.enabled&&!f.resolveBatch&&!f.resolveBatchWithResults)if(f.resolve)console.warn(`[Directive] Resolver "${s}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${s}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let l=new Map,x=new Map,E=1e3,A=new Map,V=new Map,B=1e3;function N(){if(x.size>E){let s=x.size-E,f=x.keys();for(let C=0;C<s;C++){let O=f.next().value;O&&x.delete(O);}}}function S(s){return typeof s=="object"&&s!==null&&"requirement"in s&&typeof s.requirement=="string"}function R(s){return typeof s=="object"&&s!==null&&"requirement"in s&&typeof s.requirement=="function"}function L(s,f){return S(s)?f.type===s.requirement:R(s)?s.requirement(f):false}function P(s){let f=s.type,C=V.get(f);if(C){V.delete(f),V.set(f,C);for(let O of C){let j=r[O];if(j&&L(j,s))return O}}for(let[O,j]of Object.entries(r))if(L(j,s)){if(!V.has(f)){if(V.size>=B){let z=V.keys().next().value;z!==void 0&&V.delete(z);}V.set(f,new Set);}return V.get(f).add(O),O}return null}function c(s){return {facts:m,signal:s,snapshot:()=>m.$snapshot()}}async function D(s,f,C,O){let j=s instanceof Error?s:new Error(String(s));if(O.signal.aborted)return {action:"abort",error:j};if(C.shouldRetry&&!C.shouldRetry(j,f))return {action:"break",error:j};if(f<C.attempts){if(O.signal.aborted)return {action:"abort",error:j};let z=Yt(C,f);if(await new Promise(M=>{let U=setTimeout(M,z),F=()=>{clearTimeout(U),M();};O.signal.addEventListener("abort",F,{once:true});}),O.signal.aborted)return {action:"abort",error:j}}return {action:"continue",error:j}}async function i(s,f,C){let O=r[s];if(!O)return;let j={...pt,...O.retry},z=null;for(let M=1;M<=j.attempts;M++){if(C.signal.aborted)return;let U=l.get(f.id);U&&(U.attempt=M,U.status={state:"running",requirementId:f.id,startedAt:U.startedAt,attempt:M});try{let F=c(C.signal);if(O.resolve){let p;u.batch(()=>{p=O.resolve(f.requirement,F);});let h=O.timeout;h&&h>0?await Oe(p,h,`Resolver "${s}" timed out after ${h}ms`):await p;}let a=Date.now()-(U?.startedAt??Date.now());x.set(f.id,{state:"success",requirementId:f.id,completedAt:Date.now(),duration:a}),N(),n?.(s,f,a);return}catch(F){let a=await D(F,M,j,C);if(z=a.error,a.action==="abort")return;if(a.action==="break")break;M<j.attempts&&y?.(s,f,M+1);}}x.set(f.id,{state:"error",requirementId:f.id,error:z,failedAt:Date.now(),attempts:j.attempts}),N(),g?.(s,f,z);}async function k(s,f){let C=r[s];if(!C)return;if(!C.resolveBatch&&!C.resolveBatchWithResults){await Promise.all(f.map(a=>{let p=new AbortController;return i(s,a,p)}));return}let O={...pt,...C.retry},j={...vt,...C.batch},z=new AbortController,M=Date.now(),U=null,F=j.timeoutMs??C.timeout;for(let a=1;a<=O.attempts;a++){if(z.signal.aborted)return;try{let p=c(z.signal),h=f.map($=>$.requirement);if(C.resolveBatchWithResults){let $,K;if(u.batch(()=>{K=C.resolveBatchWithResults(h,p);}),F&&F>0?$=await Oe(K,F,`Batch resolver "${s}" timed out after ${F}ms`):$=await K,$.length!==f.length)throw new Error(`[Directive] Batch resolver "${s}" returned ${$.length} results but expected ${f.length}. Results array must match input order.`);let G=Date.now()-M,ce=!1;for(let le=0;le<f.length;le++){let Y=f[le],se=$[le];if(se.success)x.set(Y.id,{state:"success",requirementId:Y.id,completedAt:Date.now(),duration:G}),n?.(s,Y,G);else {ce=!0;let re=se.error??new Error("Batch item failed");x.set(Y.id,{state:"error",requirementId:Y.id,error:re,failedAt:Date.now(),attempts:a}),g?.(s,Y,re);}}if(!ce||f.some((le,Y)=>$[Y]?.success))return}else {let $;u.batch(()=>{$=C.resolveBatch(h,p);}),F&&F>0?await Oe($,F,`Batch resolver "${s}" timed out after ${F}ms`):await $;let K=Date.now()-M;for(let G of f)x.set(G.id,{state:"success",requirementId:G.id,completedAt:Date.now(),duration:K}),n?.(s,G,K);return}}catch(p){let h=await D(p,a,O,z);if(U=h.error,h.action==="abort")return;if(h.action==="break")break;if(a<O.attempts)for(let $ of f)y?.(s,$,a+1);}}for(let a of f)x.set(a.id,{state:"error",requirementId:a.id,error:U,failedAt:Date.now(),attempts:O.attempts}),g?.(s,a,U);N();}function T(s,f){let C=r[s];if(!C)return;let O={...vt,...C.batch};A.has(s)||A.set(s,{resolverId:s,requirements:[],timer:null});let j=A.get(s);if(j.requirements.push(f),O.maxSize&&j.requirements.length>=O.maxSize){j.timer&&(clearTimeout(j.timer),j.timer=null),_(s);return}j.timer&&clearTimeout(j.timer),j.timer=setTimeout(()=>{_(s);},O.windowMs);}function _(s){let f=A.get(s);if(!f||f.requirements.length===0)return;let C=[...f.requirements];f.requirements=[],f.timer=null,k(s,C).then(()=>{v?.();});}return {resolve(s){if(l.has(s.id))return;let f=P(s.requirement);if(!f){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] No resolver found for requirement type "${s.requirement.type}" (id: ${s.id})`);return}let C=r[f];if(!C)return;if(C.batch?.enabled){T(f,s);return}let O=new AbortController,j=Date.now(),z={requirementId:s.id,resolverId:f,controller:O,startedAt:j,attempt:1,status:{state:"pending",requirementId:s.id,startedAt:j},originalRequirement:s};l.set(s.id,z),b?.(f,s),i(f,s,O).finally(()=>{l.delete(s.id)&&v?.();});},cancel(s){let f=l.get(s);if(f){f.controller.abort(),l.delete(s),x.set(s,{state:"canceled",requirementId:s,canceledAt:Date.now()}),N(),w?.(f.resolverId,f.originalRequirement);return}for(let C of A.values()){let O=C.requirements.findIndex(j=>j.id===s);if(O!==-1){let[j]=C.requirements.splice(O,1);x.set(s,{state:"canceled",requirementId:s,canceledAt:Date.now()}),N(),j&&w?.(C.resolverId,j);return}}},cancelAll(){let s=[...l.keys()];for(let f of s)this.cancel(f);for(let f of A.values()){f.timer&&clearTimeout(f.timer);for(let C of f.requirements)x.set(C.id,{state:"canceled",requirementId:C.id,canceledAt:Date.now()}),w?.(f.resolverId,C);}A.clear(),N();},getStatus(s){let f=l.get(s);if(f)return f.status;let C=x.get(s);return C||{state:"idle"}},getInflight(){return [...l.keys()]},getInflightInfo(){return [...l.values()].map(s=>({id:s.requirementId,resolverId:s.resolverId,startedAt:s.startedAt}))},isResolving(s){return l.has(s)},processBatches(){for(let s of A.keys())_(s);},hasPendingBatches(){for(let s of A.values())if(s.requirements.length>0)return true;return false},registerDefinitions(s){for(let[f,C]of Object.entries(s))r[f]=C;V.clear();},assignDefinition(s,f){if(!r[s])throw new Error(`[Directive] Cannot assign resolver "${s}" \u2014 it does not exist. Use register() to create it.`);r[s]=f,V.clear();},unregisterDefinition(s){if(!r[s])return;for(let[C,O]of l)O.resolverId===s&&(O.controller.abort(),l.delete(C),x.set(C,{state:"canceled",requirementId:C,canceledAt:Date.now()}),w?.(s,O.originalRequirement));let f=A.get(s);if(f){f.timer&&clearTimeout(f.timer);for(let C of f.requirements)x.set(C.id,{state:"canceled",requirementId:C.id,canceledAt:Date.now()}),w?.(s,C);A.delete(s);}delete r[s],V.clear(),N();},async callOne(s,f){let C=r[s];if(!C)throw new Error(`[Directive] Cannot call resolver "${s}" \u2014 it does not exist.`);let O=new AbortController,j=c(O.signal);if(C.resolve){let z;u.batch(()=>{z=C.resolve(f,j);}),await z;}},destroy(){this.cancelAll(),x.clear(),V.clear();}}}var pt,vt,wt=ge(()=>{De();pt={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},vt={enabled:false,windowMs:50};});function Ke(o){let r=Object.create(null),m=Object.create(null),u=Object.create(null),b=Object.create(null),n=Object.create(null),g=Object.create(null),y=new Map;for(let e of o.modules){let t=(d,I)=>{if(d)for(let H of Object.keys(d)){if(Z.has(H))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${H}" in ${I}. This could indicate a prototype pollution attempt.`);if(I==="schema"&&H.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${H}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};if(t(e.schema,"schema"),t(e.events,"events"),t(e.derive,"derive"),t(e.effects,"effects"),t(e.constraints,"constraints"),t(e.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let d of Object.keys(e.schema)){let I=y.get(d);if(I)throw new Error(`[Directive] Schema collision: Fact "${d}" is defined in both module "${I}" and "${e.id}". Use namespacing (e.g., "${e.id}::${d}") or merge into one module.`);y.set(d,e.id);}Object.assign(r,e.schema),e.events&&Object.assign(m,e.events),e.derive&&Object.assign(u,e.derive),e.effects&&Object.assign(b,e.effects),e.constraints&&Object.assign(n,e.constraints),e.resolvers&&Object.assign(g,e.resolvers);}let w=null;if(o.modules.some(e=>e.snapshotEvents)){w=new Set;for(let e of o.modules){let t=e;if(t.snapshotEvents)for(let d of t.snapshotEvents)w.add(d);else if(t.events)for(let d of Object.keys(t.events))w.add(d);}}let l=0,x=false;if(process.env.NODE_ENV!=="production"){let e=new Set(Object.keys(u));for(let t of Object.keys(r))e.has(t)&&console.warn(`[Directive] "${t}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let E=mt();for(let e of o.plugins??[])E.register(e);let A=lt({config:o.errorBoundary,onError:e=>E.emitError(e),onRecovery:(e,t)=>E.emitErrorRecovery(e,t)}),V=null,B=()=>{},N=()=>{},S=null,R=o.debug?.runHistory??false,L=o.debug?.maxRuns??100,P=[],c=new Map,D=0,i=null,k=[],T=new Map,_=new Map,W=new Map,s=null,f=0,C=0,O={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0},{store:j,facts:z}=ft({schema:r,onChange:(e,t,d)=>{E.emitFactSet(e,t,d),B(e),R&&k.push({key:String(e),oldValue:d,newValue:t}),!S?.isRestoring&&(l===0&&(x=true),q.changedKeys.add(e),me());},onBatch:e=>{E.emitFactsBatch(e);let t=[];for(let d of e)t.push(d.key);if(R)for(let d of e)d.type==="delete"?k.push({key:d.key,oldValue:d.prev,newValue:void 0}):k.push({key:d.key,oldValue:d.prev,newValue:d.value});if(N(t),!S?.isRestoring){l===0&&(x=true);for(let d of e)q.changedKeys.add(d.key);me();}}}),M=rt({definitions:u,facts:z,onCompute:(e,t,d,I)=>{E.emitDerivationCompute(e,t,I),i&&i.derivationsRecomputed.push({id:e,deps:I?[...I]:[],oldValue:d,newValue:t});},onInvalidate:e=>E.emitDerivationInvalidate(e),onError:(e,t)=>{A.handleError("derivation",e,t)==="retry"&&M.invalidate(e);}});B=e=>M.invalidate(e),N=e=>M.invalidateMany(e);let U=ot({definitions:b,facts:z,store:j,onRun:(e,t)=>{E.emitEffectRun(e),i&&i.effectsRun.push({id:e,triggeredBy:t});},onError:(e,t)=>{let d=A.handleError("effect",e,t);E.emitEffectError(e,t),i&&i.effectErrors.push({id:e,error:String(t)}),d==="disable"&&U.disable(e),d==="retry"&&(q.changedKeys.add("*"),me());}}),F=tt({definitions:n,facts:z,onEvaluate:(e,t)=>E.emitConstraintEvaluate(e,t),onError:(e,t)=>{let d=A.handleError("constraint",e,t);E.emitConstraintError(e,t),d==="disable"&&F.disable(e);}});function a(e){let t=c.get(e);if(t&&t.status==="pending"){t.status="settled";let d=W.get(e);t.duration=d!==void 0?performance.now()-d:Date.now()-t.timestamp,W.delete(e),_.delete(e),t.causalChain=$(t),K(t),C++,E.emitRunComplete(t);}}function p(e){let t=T.get(e);if(T.delete(e),t!==void 0){let d=(_.get(t)??1)-1;d<=0?a(t):_.set(t,d);}}function h(){let e=P.shift();if(e&&(c.delete(e.id),W.delete(e.id),e.status==="pending")){_.delete(e.id);for(let[t,d]of T)d===e.id&&T.delete(t);}}function $(e){let t=[];for(let d of e.factChanges)t.push(`${d.key} changed`);for(let d of e.derivationsRecomputed)t.push(`${d.id} recomputed`);for(let d of e.constraintsHit)t.push(`${d.id} constraint hit`);for(let d of e.requirementsAdded)t.push(`${d.type} requirement added`);for(let d of e.resolversCompleted)t.push(`${d.resolver} resolved (${d.duration.toFixed(0)}ms)`);for(let d of e.resolversErrored)t.push(`${d.resolver} errored`);for(let d of e.effectsRun)t.push(`${d.id} effect ran`);return t.join(" \u2192 ")}function K(e){O.count++,O.totalDuration+=e.duration,O.avgDuration=O.totalDuration/O.count,e.duration>O.maxDuration&&(O.maxDuration=e.duration);let t=e.resolversStarted.length;O.totalResolverCount+=t,O.avgResolverCount=O.totalResolverCount/O.count;let d=e.factChanges.length;O.totalFactChangeCount+=d,O.avgFactChangeCount=O.totalFactChangeCount/O.count;let I=[];O.count>3&&e.duration>O.avgDuration*5&&I.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${O.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&I.push(`${e.resolversErrored.length} resolver(s) errored`),I.length>0&&(e.anomalies=I);}let G=ht({definitions:g,facts:z,store:j,onStart:(e,t)=>E.emitResolverStart(e,t),onComplete:(e,t,d)=>{if(A.clearRetryAttempts(e),E.emitResolverComplete(e,t,d),E.emitRequirementMet(t,e),F.markResolved(t.fromConstraint),R){let I=T.get(t.id);if(I!==void 0){let H=c.get(I);H&&H.resolversCompleted.push({resolver:e,requirementId:t.id,duration:d});}p(t.id);}},onError:(e,t,d)=>{let I=A.handleError("resolver",e,d,t);if(E.emitResolverError(e,t,d),I==="disable"&&F.disable(t.fromConstraint),I==="retry"&&(q.previousRequirements.remove(t.id),me()),I==="retry-later"){let J=A.getRetryLaterManager().getPendingRetries().find(ne=>ne.sourceId===e);J&&!J.callback&&(J.callback=()=>{me();});}if(R){let H=T.get(t.id);if(H!==void 0){let J=c.get(H);J&&J.resolversErrored.push({resolver:e,requirementId:t.id,error:String(d)});}p(t.id);}},onRetry:(e,t,d)=>E.emitResolverRetry(e,t,d),onCancel:(e,t)=>{E.emitResolverCancel(e,t),E.emitRequirementCanceled(t),R&&p(t.id);},onResolutionComplete:()=>{re(),me();}}),ce=new Set;function le(){for(let e of ce)e();}let Y=o.debug?.timeTravel?Qe({config:o.debug,facts:z,store:j,onSnapshot:e=>{E.emitSnapshot(e),le();},onTimeTravel:(e,t)=>{E.emitTimeTravel(e,t),le();}}):Xe();S=Y;let se=new Set;function re(){for(let e of se)e();}let ye=50,pe=0,q={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new Ee,readyPromise:null,readyResolve:null},X={constraints:new Set,resolvers:new Set,derivations:new Set,effects:new Set},ee={constraints:new Map,resolvers:new Map,derivations:new Map,effects:new Map},he=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]),Me=[];function qe(e){if(typeof e!="string"||e.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String(e)}`);if(Z.has(e))throw new Error(`[Directive] Security: Definition ID "${e}" is a blocked property.`);if(e.includes("::"))throw new Error(`[Directive] Definition ID "${e}" cannot contain "::". This separator is reserved for namespacing.`)}function Ae(e,t,d){if(q.isDestroyed)throw new Error(`[Directive] Cannot register ${e} "${t}" on a destroyed system.`);if(qe(t),q.isReconciling){Me.push({op:"register",type:e,id:t,def:d});return}He(e,t,d);}function Ie(e,t,d){if(q.isDestroyed)throw new Error(`[Directive] Cannot assign ${e} "${t}" on a destroyed system.`);if(qe(t),q.isReconciling){Me.push({op:"assign",type:e,id:t,def:d});return}Ge(e,t,d);}function je(e,t){if(q.isDestroyed)throw new Error(`[Directive] Cannot unregister ${e} "${t}" on a destroyed system.`);if(qe(t),q.isReconciling){Me.push({op:"unregister",type:e,id:t});return}Ye(e,t);}function _e(e,t,d){if(q.isDestroyed)throw new Error(`[Directive] Cannot call ${e} "${t}" on a destroyed system.`);switch(qe(t),E.emitDefinitionCall(e,t,d),e){case "constraint":return F.callOne(t,d);case "resolver":return G.callOne(t,d);case "derivation":return M.callOne(t);case "effect":return U.callOne(t)}}function He(e,t,d){switch(e){case "constraint":{if(t in n)throw new Error(`[Directive] Constraint "${t}" already exists. Use assign() to override.`);let I=d;n[t]=I,F.registerDefinitions({[t]:I}),X.constraints.add(t),E.emitDefinitionRegister(e,t,d),me();break}case "resolver":{if(t in g)throw new Error(`[Directive] Resolver "${t}" already exists. Use assign() to override.`);let I=d;g[t]=I,G.registerDefinitions({[t]:I}),X.resolvers.add(t),E.emitDefinitionRegister(e,t,d),me();break}case "derivation":{if(he.has(t))throw new Error(`[Directive] Derivation ID "${t}" conflicts with a reserved derive method name.`);if(t in u)throw new Error(`[Directive] Derivation "${t}" already exists. Use assign() to override.`);u[t]=d,M.registerDefinitions({[t]:d}),X.derivations.add(t),E.emitDefinitionRegister(e,t,d);break}case "effect":{if(t in b)throw new Error(`[Directive] Effect "${t}" already exists. Use assign() to override.`);let I=d;b[t]=I,U.registerDefinitions({[t]:I}),X.effects.add(t),E.emitDefinitionRegister(e,t,d);break}}}function Ge(e,t,d){switch(e){case "constraint":{if(!(t in n))throw new Error(`[Directive] Constraint "${t}" does not exist. Use register() to create it.`);let I=n[t];F.assignDefinition(t,d),ee.constraints.set(t,I),n[t]=d,E.emitDefinitionAssign(e,t,d,I),me();break}case "resolver":{if(!(t in g))throw new Error(`[Directive] Resolver "${t}" does not exist. Use register() to create it.`);let I=g[t];G.assignDefinition(t,d),ee.resolvers.set(t,I),g[t]=d,E.emitDefinitionAssign(e,t,d,I),me();break}case "derivation":{if(he.has(t))throw new Error(`[Directive] Derivation ID "${t}" conflicts with a reserved derive method name.`);if(!(t in u))throw new Error(`[Directive] Derivation "${t}" does not exist. Use register() to create it.`);let I=u[t];M.assignDefinition(t,d),ee.derivations.set(t,I),u[t]=d,E.emitDefinitionAssign(e,t,d,I);break}case "effect":{if(!(t in b))throw new Error(`[Directive] Effect "${t}" does not exist. Use register() to create it.`);let I=b[t];U.assignDefinition(t,d),ee.effects.set(t,I),b[t]=d,E.emitDefinitionAssign(e,t,d,I);break}}}function Ye(e,t){switch(e){case "constraint":{if(!X.constraints.has(t)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static constraint "${t}". Only dynamically registered constraints can be removed.`);return}F.unregisterDefinition(t),delete n[t],X.constraints.delete(t),ee.constraints.delete(t),E.emitDefinitionUnregister(e,t),me();break}case "resolver":{if(!X.resolvers.has(t)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static resolver "${t}". Only dynamically registered resolvers can be removed.`);return}G.unregisterDefinition(t),delete g[t],X.resolvers.delete(t),ee.resolvers.delete(t),E.emitDefinitionUnregister(e,t);break}case "derivation":{if(!X.derivations.has(t)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static derivation "${t}". Only dynamically registered derivations can be removed.`);return}M.unregisterDefinition(t),delete u[t],X.derivations.delete(t),ee.derivations.delete(t),E.emitDefinitionUnregister(e,t);break}case "effect":{if(!X.effects.has(t)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static effect "${t}". Only dynamically registered effects can be removed.`);return}U.unregisterDefinition(t),delete b[t],X.effects.delete(t),ee.effects.delete(t),E.emitDefinitionUnregister(e,t);break}}}function Ot(){if(Me.length===0)return;let e=Me.splice(0);for(let t of e)try{switch(t.op){case "register":He(t.type,t.id,t.def);break;case "assign":Ge(t.type,t.id,t.def);break;case "unregister":Ye(t.type,t.id);break}}catch(d){process.env.NODE_ENV!=="production"&&console.error(`[Directive] Error in deferred ${t.op} for ${t.type} "${t.id}":`,d);}}function me(){!q.isRunning||q.reconcileScheduled||q.isInitializing||(q.reconcileScheduled=true,re(),queueMicrotask(()=>{q.reconcileScheduled=false,q.isRunning&&!q.isInitializing&&$t().catch(e=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function $t(){if(q.isReconciling)return;if(pe++,pe>ye){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${ye} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),R&&(k.length=0),pe=0;return}q.isReconciling=true,re();let e=R?performance.now():0;if(R){let t=++D;W.set(t,e),i={id:t,timestamp:Date.now(),duration:0,status:"pending",factChanges:k.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]};}try{q.changedKeys.size>0&&((w===null||x)&&Y.takeSnapshot(`facts-changed:${[...q.changedKeys].join(",")}`),x=!1);let t=z.$snapshot();E.emitReconcileStart(t),await U.runEffects(q.changedKeys);let d=new Set(q.changedKeys);q.changedKeys.clear();let I=await F.evaluate(d),H=new Ee;for(let te of I)H.add(te),E.emitRequirementCreated(te);if(i){let te=new Set(I.map(oe=>oe.fromConstraint));for(let oe of te){let ie=F.getState(oe);if(ie){let ae=F.getDependencies(oe);i.constraintsHit.push({id:oe,priority:ie.priority,deps:ae?[...ae]:[]});}}}let{added:J,removed:ne}=H.diff(q.previousRequirements);if(i){for(let te of J)i.requirementsAdded.push({id:te.id,type:te.requirement.type,fromConstraint:te.fromConstraint});for(let te of ne)i.requirementsRemoved.push({id:te.id,type:te.requirement.type,fromConstraint:te.fromConstraint});}for(let te of ne)G.cancel(te.id);for(let te of J)G.resolve(te);if(i){let te=G.getInflightInfo(),oe=new Map(te.map(ie=>[ie.id,ie]));for(let ie of J){let ae=oe.get(ie.id);i.resolversStarted.push({resolver:ae?.resolverId??"unknown",requirementId:ie.id}),T.set(ie.id,i.id);}}q.previousRequirements=H;let ue=G.getInflightInfo(),de={unmet:I.filter(te=>!G.isResolving(te.id)),inflight:ue,completed:[],canceled:ne.map(te=>({id:te.id,resolverId:ue.find(oe=>oe.id===te.id)?.resolverId??"unknown"}))};E.emitReconcileEnd(de),q.isReady||(q.isReady=!0,q.readyResolve&&(q.readyResolve(),q.readyResolve=null));}finally{if(i){if(i.duration=performance.now()-e,i.factChanges.length>0||i.constraintsHit.length>0||i.requirementsAdded.length>0||i.effectsRun.length>0){let d=i.resolversStarted.length;d===0?(i.status="settled",i.causalChain=$(i),K(i),P.push(i),c.set(i.id,i),P.length>L&&h(),C++,E.emitRunComplete(i)):(i.status="pending",P.push(i),c.set(i.id,i),P.length>L&&h(),C++,_.set(i.id,d));}else W.delete(i.id);i=null;}q.isReconciling=false,Ot(),q.changedKeys.size>0?me():q.reconcileScheduled||(pe=0),re();}}let Fe={register:(e,t)=>Ae("derivation",e,t),assign:(e,t)=>Ie("derivation",e,t),unregister:e=>je("derivation",e),call:e=>_e("derivation",e),isDynamic:e=>X.derivations.has(e),listDynamic:()=>[...X.derivations]},It=new Proxy({},{get(e,t){if(typeof t!="symbol"&&!Z.has(t)){if(t in Fe)return Fe[t];if(t in u)return M.get(t)}},has(e,t){return typeof t=="symbol"||Z.has(t)?false:t in u||t in Fe},ownKeys(){return Object.keys(u)},getOwnPropertyDescriptor(e,t){if(typeof t!="symbol"&&!Z.has(t)&&(t in u||t in Fe))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),Pt=new Proxy({},{get(e,t){if(typeof t!="symbol"&&!Z.has(t))return d=>{let I=m[t];if(I){l++,(w===null||w.has(t))&&(x=true);try{j.batch(()=>{I(z,{type:t,...d});});}finally{l--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${t}". No handler is registered for this event. Available events: ${Object.keys(m).join(", ")||"(none)"}`);}},has(e,t){return typeof t=="symbol"||Z.has(t)?false:t in m},ownKeys(){return Object.keys(m)},getOwnPropertyDescriptor(e,t){if(typeof t!="symbol"&&!Z.has(t)&&t in m)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),ve={facts:z,debug:Y.isEnabled?Y:null,derive:It,events:Pt,constraints:{disable:e=>F.disable(e),enable:e=>F.enable(e),isDisabled:e=>F.isDisabled(e),register:(e,t)=>Ae("constraint",e,t),assign:(e,t)=>Ie("constraint",e,t),unregister:e=>je("constraint",e),call:(e,t)=>_e("constraint",e,t),isDynamic:e=>X.constraints.has(e),listDynamic:()=>[...X.constraints]},effects:{disable:e=>U.disable(e),enable:e=>U.enable(e),isEnabled:e=>U.isEnabled(e),register:(e,t)=>Ae("effect",e,t),assign:(e,t)=>Ie("effect",e,t),unregister:e=>je("effect",e),call:e=>_e("effect",e),isDynamic:e=>X.effects.has(e),listDynamic:()=>[...X.effects]},resolvers:{register:(e,t)=>Ae("resolver",e,t),assign:(e,t)=>Ie("resolver",e,t),unregister:e=>je("resolver",e),call:(e,t)=>_e("resolver",e,t),isDynamic:e=>X.resolvers.has(e),listDynamic:()=>[...X.resolvers]},get runHistory(){return R?((!s||f!==C)&&(s=[...P],f=C),s):null},initialize(){if(!q.isInitialized){q.isInitializing=true;for(let e of o.modules)e.init&&j.batch(()=>{e.init(z);});o.onAfterModuleInit&&j.batch(()=>{o.onAfterModuleInit();}),q.isInitializing=false,q.isInitialized=true;for(let e of Object.keys(u))M.get(e);}},start(){if(!q.isRunning){q.isInitialized||this.initialize(),q.isRunning=true;for(let e of o.modules)e.hooks?.onStart?.(ve);if(E.emitStart(ve),o.errorBoundary?.retryLater&&!V){let e=Math.max(o.errorBoundary.retryLater.delayMs??1e3,250);V=setInterval(()=>{let t=A.processDueRetries();for(let d of t)d.callback?d.callback():me();},Math.min(e,500));}me();}},stop(){if(q.isRunning){q.isRunning=false,V!==null&&(clearInterval(V),V=null),A.getRetryLaterManager().clearAll(),G.cancelAll(),U.cleanupAll();for(let e of o.modules)e.hooks?.onStop?.(ve);E.emitStop(ve);}},destroy(){q.isDestroyed||(this.stop(),q.isDestroyed=true,j.destroy?.(),G.destroy(),A.clearErrors(),se.clear(),ce.clear(),Me.length=0,P.length=0,c.clear(),T.clear(),_.clear(),W.clear(),k.length=0,i=null,s=null,X.constraints.clear(),X.resolvers.clear(),X.derivations.clear(),X.effects.clear(),ee.constraints.clear(),ee.resolvers.clear(),ee.derivations.clear(),ee.effects.clear(),E.emitDestroy(ve));},dispatch(e){if(Z.has(e.type))return;let t=m[e.type];if(t){l++,(w===null||w.has(e.type))&&(x=true);try{j.batch(()=>{t(z,e);});}finally{l--;}}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(m).join(", ")||"(none)"}`);},read(e){return M.get(e)},subscribe(e,t){let d=[],I=[];for(let J of e)J in u?d.push(J):J in r?I.push(J):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${J}"`);let H=[];return d.length>0&&H.push(M.subscribe(d,t)),I.length>0&&H.push(j.subscribe(I,t)),()=>{for(let J of H)J();}},watch(e,t,d){let I=d?.equalityFn?(J,ne)=>d.equalityFn(J,ne):(J,ne)=>Object.is(J,ne);if(e in u){let J=M.get(e);return M.subscribe([e],()=>{let ne=M.get(e);if(!I(ne,J)){let ue=J;J=ne,t(ne,ue);}})}process.env.NODE_ENV!=="production"&&(e in r||console.warn(`[Directive] watch: unknown key "${e}"`));let H=j.get(e);return j.subscribe([e],()=>{let J=j.get(e);if(!I(J,H)){let ne=H;H=J,t(J,ne);}})},when(e,t){return new Promise((d,I)=>{let H=j.toObject();if(e(H)){d();return}let J,ne,ue=()=>{J?.(),ne!==void 0&&clearTimeout(ne);};J=j.subscribeAll(()=>{let de=j.toObject();e(de)&&(ue(),d());}),t?.timeout!==void 0&&t.timeout>0&&(ne=setTimeout(()=>{ue(),I(new Error(`[Directive] when: timed out after ${t.timeout}ms`));},t.timeout));})},inspect(){return {unmet:q.previousRequirements.all(),inflight:G.getInflightInfo(),constraints:F.getAllStates().map(e=>({id:e.id,active:e.lastResult??false,disabled:F.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt})),resolvers:Object.fromEntries(G.getInflight().map(e=>[e,G.getStatus(e)])),resolverDefs:Object.entries(g).map(([e,t])=>({id:e,requirement:typeof t.requirement=="string"?t.requirement:"(predicate)"})),runHistoryEnabled:R,...R?{runHistory:P.map(e=>({...e,factChanges:e.factChanges.map(t=>({...t})),derivationsRecomputed:e.derivationsRecomputed.map(t=>({...t,deps:[...t.deps]})),constraintsHit:e.constraintsHit.map(t=>({...t,deps:[...t.deps]})),requirementsAdded:e.requirementsAdded.map(t=>({...t})),requirementsRemoved:e.requirementsRemoved.map(t=>({...t})),resolversStarted:e.resolversStarted.map(t=>({...t})),resolversCompleted:e.resolversCompleted.map(t=>({...t})),resolversErrored:e.resolversErrored.map(t=>({...t})),effectsRun:e.effectsRun.map(t=>({...t,triggeredBy:[...t.triggeredBy]})),effectErrors:e.effectErrors.map(t=>({...t}))}))}:{}}},explain(e){let d=q.previousRequirements.all().find(oe=>oe.id===e);if(!d)return null;let I=F.getState(d.fromConstraint),H=G.getStatus(e),J={},ne=j.toObject();for(let[oe,ie]of Object.entries(ne))J[oe]=ie;let ue=[`Requirement "${d.requirement.type}" (id: ${d.id})`,`\u251C\u2500 Produced by constraint: ${d.fromConstraint}`,`\u251C\u2500 Constraint priority: ${I?.priority??0}`,`\u251C\u2500 Constraint active: ${I?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${H.state}`],de=Object.entries(d.requirement).filter(([oe])=>oe!=="type").map(([oe,ie])=>`${oe}=${JSON.stringify(ie)}`).join(", ");de&&ue.push(`\u251C\u2500 Requirement payload: { ${de} }`);let te=Object.entries(J).slice(0,10);return te.length>0&&(ue.push("\u2514\u2500 Relevant facts:"),te.forEach(([oe,ie],ae)=>{let Se=ae===te.length-1?" \u2514\u2500":" \u251C\u2500",ke=typeof ie=="object"?JSON.stringify(ie):String(ie);ue.push(`${Se} ${oe} = ${ke.slice(0,50)}${ke.length>50?"...":""}`);})),ue.join(`
2
+ `)},getOriginal(e,t){let I={constraint:ee.constraints,resolver:ee.resolvers,derivation:ee.derivations,effect:ee.effects}[e];if(I)return I.get(t)},restoreOriginal(e,t){let I={constraint:ee.constraints,resolver:ee.resolvers,derivation:ee.derivations,effect:ee.effects}[e];if(!I||!I.has(t))return false;let H=I.get(t);return Ie(e,t,H),I.delete(t),true},async settle(e=5e3){let t=Date.now();for(;;){G.hasPendingBatches()&&G.processBatches(),await new Promise(H=>setTimeout(H,0));let d=this.inspect();if(d.inflight.length===0&&!q.isReconciling&&!q.reconcileScheduled&&!G.hasPendingBatches())return;if(Date.now()-t>e){let H=[];d.inflight.length>0&&H.push(`${d.inflight.length} resolvers inflight: ${d.inflight.map(ne=>ne.resolverId).join(", ")}`),q.isReconciling&&H.push("reconciliation in progress"),q.reconcileScheduled&&H.push("reconcile scheduled");let J=q.previousRequirements.all();throw J.length>0&&H.push(`${J.length} unmet requirements: ${J.map(ne=>ne.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${e}ms. ${H.join("; ")}`)}await new Promise(H=>setTimeout(H,10));}},getSnapshot(){return {facts:j.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:t,excludeDerivations:d,includeFacts:I,ttlSeconds:H,metadata:J,includeVersion:ne}=e,ue={},de=Object.keys(u),te;if(t){if(te=t.filter(ae=>de.includes(ae)),process.env.NODE_ENV!=="production"){let ae=t.filter(Se=>!de.includes(Se));ae.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${ae.join(", ")}. Available: ${de.join(", ")||"(none)"}`);}}else te=de;if(d){let ae=new Set(d);te=te.filter(Se=>!ae.has(Se));}for(let ae of te)try{ue[ae]=M.get(ae);}catch(Se){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${ae}" due to error:`,Se);}if(I&&I.length>0){let ae=j.toObject(),Se=Object.keys(ae);if(process.env.NODE_ENV!=="production"){let ke=I.filter(At=>!(At in ae));ke.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${ke.join(", ")}. Available: ${Se.join(", ")||"(none)"}`);}for(let ke of I)ke in ae&&(ue[ke]=ae[ke]);}let oe=Date.now(),ie={data:ue,createdAt:oe};return H!==void 0&&H>0&&(ie.expiresAt=oe+H*1e3),ne&&(ie.version=Je(ue)),J&&(ie.metadata=J),ie},watchDistributableSnapshot(e,t){let{includeDerivations:d,excludeDerivations:I}=e,H=Object.keys(u),J;if(d?J=d.filter(de=>H.includes(de)):J=H,I){let de=new Set(I);J=J.filter(te=>!de.has(te));}if(J.length===0)return process.env.NODE_ENV!=="production"&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let ue=this.getDistributableSnapshot({...e,includeVersion:true}).version;return M.subscribe(J,()=>{let de=this.getDistributableSnapshot({...e,includeVersion:true});de.version!==ue&&(ue=de.version,t(de));})},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.");j.batch(()=>{for(let[t,d]of Object.entries(e.facts))Z.has(t)||j.set(t,d);});},onSettledChange(e){return se.add(e),()=>{se.delete(e);}},onTimeTravelChange(e){return ce.add(e),()=>{ce.delete(e);}},batch(e){j.batch(e);},get isSettled(){return G.getInflight().length===0&&!G.hasPendingBatches()&&!q.isReconciling&&!q.reconcileScheduled},get isRunning(){return q.isRunning},get isInitialized(){return q.isInitialized},get isReady(){return q.isReady},whenReady(){return q.isReady?Promise.resolve():q.isRunning?(q.readyPromise||(q.readyPromise=new Promise(e=>{q.readyResolve=e;})),q.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function qt(e){if(q.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(q.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let t=(d,I)=>{if(d)for(let H of Object.keys(d)){if(Z.has(H))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${H}" in ${I}.`);if(I==="schema"&&H.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${H}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};t(e.schema,"schema"),t(e.events,"events"),t(e.derive,"derive"),t(e.effects,"effects"),t(e.constraints,"constraints"),t(e.resolvers,"resolvers");for(let d of Object.keys(e.schema))if(d in r)throw new Error(`[Directive] Schema collision: Fact "${d}" already exists. Cannot register module "${e.id}".`);if(process.env.NODE_ENV!=="production"&&e.derive){let d=new Set(Object.keys(r));for(let I of Object.keys(e.derive))d.has(I)&&console.warn(`[Directive] "${I}" exists as both a fact and a derivation after registering module "${e.id}".`);}if(e.snapshotEvents){w===null&&(w=new Set(Object.keys(m)));for(let d of e.snapshotEvents)w.add(d);}else if(w!==null&&e.events)for(let d of Object.keys(e.events))w.add(d);Object.assign(r,e.schema),e.events&&Object.assign(m,e.events),e.derive&&(Object.assign(u,e.derive),M.registerDefinitions(e.derive)),e.effects&&(Object.assign(b,e.effects),U.registerDefinitions(e.effects)),e.constraints&&(Object.assign(n,e.constraints),F.registerDefinitions(e.constraints)),e.resolvers&&(Object.assign(g,e.resolvers),G.registerDefinitions(e.resolvers)),j.registerKeys(e.schema),o.modules.push(e),e.init&&j.batch(()=>{e.init(z);}),e.hooks?.onInit?.(ve),q.isRunning&&(e.hooks?.onStart?.(ve),me());}ve.registerModule=qt,E.emitInit(ve);for(let e of o.modules)e.hooks?.onInit?.(ve);return ve}var St=ge(()=>{Ze();De();nt();st();it();dt();gt();yt();We();wt();Te();});var xt={};_t(xt,{createSystem:()=>Qt});function Jt(o){let r=Object.keys(o),m=new Set,u=new Set,b=[],n=[];function g(y){if(m.has(y))return;if(u.has(y)){let v=n.indexOf(y),l=[...n.slice(v),y].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${l}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}u.add(y),n.push(y);let w=o[y];if(w?.crossModuleDeps)for(let v of Object.keys(w.crossModuleDeps))r.includes(v)&&g(v);n.pop(),u.delete(y),m.add(y),b.push(y);}for(let y of r)g(y);return b}function Qt(o){if("module"in o){if(!o.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof o.module);return tn(o)}let r=o;if(Array.isArray(r.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
3
3
 
4
4
  Instead of:
5
5
  createSystem({ modules: [authModule, dataModule] })
@@ -8,5 +8,10 @@ Use:
8
8
  createSystem({ modules: { auth: authModule, data: dataModule } })
9
9
 
10
10
  Or for a single module:
11
- createSystem({ module: counterModule })`);return Ft(r)}function Ft(n){let r=n.modules,g=new Set(Object.keys(r)),v=n.debug?.snapshotModules?new Set(n.debug.snapshotModules):null;if(n.tickMs!==void 0&&n.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(process.env.NODE_ENV!=="production"){for(let[s,k]of Object.entries(r))if(k.crossModuleDeps)for(let f of Object.keys(k.crossModuleDeps))f===s?console.warn(`[Directive] Module "${s}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):g.has(f)||console.warn(`[Directive] Module "${s}" declares crossModuleDeps.${f}, but no module with namespace "${f}" exists in the system. Available modules: ${[...g].join(", ")}`);}if(process.env.NODE_ENV!=="production"&&n.debug?.snapshotModules)for(let s of n.debug.snapshotModules)g.has(s)||console.warn(`[Directive] debug.snapshotModules entry "${s}" doesn't match any module. Available modules: ${[...g].join(", ")}`);let a,t=n.initOrder??"auto";if(Array.isArray(t)){let s=t,k=Object.keys(r).filter(f=>!s.includes(f));if(k.length>0)throw new Error(`[Directive] initOrder is missing modules: ${k.join(", ")}. All modules must be included in the explicit order.`);a=s;}else t==="declaration"?a=Object.keys(r):a=jt(r);let u=n.debug,y=n.errorBoundary;n.zeroConfig&&(u={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...n.debug},y={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...n.errorBoundary});for(let s of Object.keys(r)){if(s.includes(H))throw new Error(`[Directive] Module name "${s}" contains the reserved separator "${H}". Module names cannot contain "${H}".`);let k=r[s];if(k){for(let f of Object.keys(k.schema.facts))if(f.includes(H))throw new Error(`[Directive] Schema key "${f}" in module "${s}" contains the reserved separator "${H}". Schema keys cannot contain "${H}".`)}}let R=[];for(let s of a){let k=r[s];if(!k)continue;let f=k.crossModuleDeps&&Object.keys(k.crossModuleDeps).length>0,b=f?Object.keys(k.crossModuleDeps):[],D={};for(let[C,B]of Object.entries(k.schema.facts))D[`${s}${H}${C}`]=B;let _={};if(k.schema.derivations)for(let[C,B]of Object.entries(k.schema.derivations))_[`${s}${H}${C}`]=B;let d={};if(k.schema.events)for(let[C,B]of Object.entries(k.schema.events))d[`${s}${H}${C}`]=B;let i=k.init?C=>{let B=fe(C,s);k.init(B);}:void 0,h={};if(k.derive)for(let[C,B]of Object.entries(k.derive))h[`${s}${H}${C}`]=(A,c)=>{let m=f?ve(A,s,b):fe(A,s),S=Fe(c,s);return B(m,S)};let I={};if(k.events)for(let[C,B]of Object.entries(k.events))I[`${s}${H}${C}`]=(A,c)=>{let m=fe(A,s);B(m,c);};let O={};if(k.constraints)for(let[C,B]of Object.entries(k.constraints)){let A=B;O[`${s}${H}${C}`]={...A,deps:A.deps?.map(c=>`${s}${H}${c}`),when:c=>{let m=f?ve(c,s,b):fe(c,s);return A.when(m)},require:typeof A.require=="function"?c=>{let m=f?ve(c,s,b):fe(c,s);return A.require(m)}:A.require};}let V={};if(k.resolvers)for(let[C,B]of Object.entries(k.resolvers)){let A=B;V[`${s}${H}${C}`]={...A,resolve:async(c,m)=>{let S=_e(m.facts,r,()=>Object.keys(r));await A.resolve(c,{facts:S[s],signal:m.signal});}};}let z={};if(k.effects)for(let[C,B]of Object.entries(k.effects)){let A=B;z[`${s}${H}${C}`]={...A,run:(c,m)=>{let S=f?ve(c,s,b):fe(c,s),F=m?f?ve(m,s,b):fe(m,s):void 0;return A.run(S,F)},deps:A.deps?.map(c=>`${s}${H}${c}`)};}R.push({id:k.id,schema:{facts:D,derivations:_,events:d,requirements:k.schema.requirements??{}},init:i,derive:h,events:I,effects:z,constraints:O,resolvers:V,hooks:k.hooks,snapshotEvents:v&&!v.has(s)?[]:k.snapshotEvents?.map(C=>`${s}${H}${C}`)});}process.env.NODE_ENV!=="production"&&n.tickMs&&n.tickMs>0&&(R.some(k=>k.events&&Object.keys(k.events).some(f=>f.endsWith(`${H}tick`)))||console.warn(`[Directive] tickMs is set to ${n.tickMs}ms but no module defines a "tick" event handler.`));let w=null,l=null;function E(s){for(let[k,f]of Object.entries(s)){if(ae.has(k)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${k}". Skipping.`);continue}if(!g.has(k)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${k}". Available modules: ${[...g].join(", ")}`);continue}if(f&&typeof f=="object"&&!Re(f))throw new Error(`[Directive] initialFacts/hydrate for namespace "${k}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[b,D]of Object.entries(f))ae.has(b)||(l.facts[`${k}${H}${b}`]=D);}}l=je({modules:R.map(s=>({id:s.id,schema:s.schema.facts,requirements:s.schema.requirements,init:s.init,derive:s.derive,events:s.events,effects:s.effects,constraints:s.constraints,resolvers:s.resolvers,hooks:s.hooks,snapshotEvents:s.snapshotEvents})),plugins:n.plugins,debug:u,errorBoundary:y,tickMs:n.tickMs,onAfterModuleInit:()=>{n.initialFacts&&E(n.initialFacts),w&&(E(w),w=null);}});let x=new Map;for(let s of Object.keys(r)){let k=r[s];if(!k)continue;let f=[];for(let b of Object.keys(k.schema.facts))f.push(`${s}${H}${b}`);if(k.schema.derivations)for(let b of Object.keys(k.schema.derivations))f.push(`${s}${H}${b}`);x.set(s,f);}let M={names:null};function W(){return M.names===null&&(M.names=Object.keys(r)),M.names}let P=_e(l.facts,r,W),j=Nt(l.derive,r,W),T=Bt(l,r,W),$=null,Y=n.tickMs;return {_mode:"namespaced",facts:P,debug:l.debug,derive:j,events:T,constraints:l.constraints,effects:l.effects,get runHistory(){return l.runHistory},get isRunning(){return l.isRunning},get isSettled(){return l.isSettled},get isInitialized(){return l.isInitialized},get isReady(){return l.isReady},whenReady:l.whenReady.bind(l),async hydrate(s){if(l.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let k=await s();k&&typeof k=="object"&&(w=k);},initialize(){l.initialize();},start(){if(l.start(),Y&&Y>0){let s=Object.keys(R[0]?.events??{}).find(k=>k.endsWith(`${H}tick`));s&&($=setInterval(()=>{l.dispatch({type:s});},Y));}},stop(){$&&(clearInterval($),$=null),l.stop();},destroy(){this.stop(),l.destroy();},dispatch(s){l.dispatch(s);},batch:l.batch.bind(l),read(s){return l.read(ke(s))},subscribe(s,k){let f=[];for(let b of s)if(b.endsWith(".*")){let D=b.slice(0,-2),_=x.get(D);_?f.push(..._):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${b}" \u2014 namespace "${D}" not found.`);}else f.push(ke(b));return l.subscribe(f,k)},subscribeModule(s,k){let f=x.get(s);return !f||f.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${s}") \u2014 namespace not found. Available: ${[...x.keys()].join(", ")}`),()=>{}):l.subscribe(f,k)},watch(s,k,f){return l.watch(ke(s),k,f)},when(s,k){return l.when(()=>s(P),k)},onSettledChange:l.onSettledChange.bind(l),onTimeTravelChange:l.onTimeTravelChange.bind(l),inspect:l.inspect.bind(l),settle:l.settle.bind(l),explain:l.explain.bind(l),getSnapshot:l.getSnapshot.bind(l),restore:l.restore.bind(l),getDistributableSnapshot(s){let k={...s,includeDerivations:s?.includeDerivations?.map(ke),excludeDerivations:s?.excludeDerivations?.map(ke),includeFacts:s?.includeFacts?.map(ke)},f=l.getDistributableSnapshot(k),b={};for(let[D,_]of Object.entries(f.data)){let d=D.indexOf(H);if(d>0){let i=D.slice(0,d),h=D.slice(d+H.length);b[i]||(b[i]={}),b[i][h]=_;}else b._root||(b._root={}),b._root[D]=_;}return {...f,data:b}},watchDistributableSnapshot(s,k){let f={...s,includeDerivations:s?.includeDerivations?.map(ke),excludeDerivations:s?.excludeDerivations?.map(ke),includeFacts:s?.includeFacts?.map(ke)};return l.watchDistributableSnapshot(f,b=>{let D={};for(let[_,d]of Object.entries(b.data)){let i=_.indexOf(H);if(i>0){let h=_.slice(0,i),I=_.slice(i+H.length);D[h]||(D[h]={}),D[h][I]=d;}else D._root||(D._root={}),D._root[_]=d;}k({...b,data:D});})},registerModule(s,k){if(g.has(s))throw new Error(`[Directive] Module namespace "${s}" already exists. Cannot register a duplicate namespace.`);if(s.includes(H))throw new Error(`[Directive] Module name "${s}" contains the reserved separator "${H}".`);if(ae.has(s))throw new Error(`[Directive] Module name "${s}" is a blocked property.`);for(let C of Object.keys(k.schema.facts))if(C.includes(H))throw new Error(`[Directive] Schema key "${C}" in module "${s}" contains the reserved separator "${H}".`);let f=k,b=f.crossModuleDeps&&Object.keys(f.crossModuleDeps).length>0,D=b?Object.keys(f.crossModuleDeps):[],_={};for(let[C,B]of Object.entries(f.schema.facts))_[`${s}${H}${C}`]=B;let d=f.init?C=>{let B=fe(C,s);f.init(B);}:void 0,i={};if(f.derive)for(let[C,B]of Object.entries(f.derive))i[`${s}${H}${C}`]=(A,c)=>{let m=b?ve(A,s,D):fe(A,s),S=Fe(c,s);return B(m,S)};let h={};if(f.events)for(let[C,B]of Object.entries(f.events))h[`${s}${H}${C}`]=(A,c)=>{let m=fe(A,s);B(m,c);};let I={};if(f.constraints)for(let[C,B]of Object.entries(f.constraints)){let A=B;I[`${s}${H}${C}`]={...A,deps:A.deps?.map(c=>`${s}${H}${c}`),when:c=>{let m=b?ve(c,s,D):fe(c,s);return A.when(m)},require:typeof A.require=="function"?c=>{let m=b?ve(c,s,D):fe(c,s);return A.require(m)}:A.require};}let O={};if(f.resolvers)for(let[C,B]of Object.entries(f.resolvers)){let A=B;O[`${s}${H}${C}`]={...A,resolve:async(c,m)=>{let S=_e(m.facts,r,W);await A.resolve(c,{facts:S[s],signal:m.signal});}};}let V={};if(f.effects)for(let[C,B]of Object.entries(f.effects)){let A=B;V[`${s}${H}${C}`]={...A,run:(c,m)=>{let S=b?ve(c,s,D):fe(c,s),F=m?b?ve(m,s,D):fe(m,s):void 0;return A.run(S,F)},deps:A.deps?.map(c=>`${s}${H}${c}`)};}g.add(s),r[s]=f,M.names=null;let z=[];for(let C of Object.keys(f.schema.facts))z.push(`${s}${H}${C}`);if(f.schema.derivations)for(let C of Object.keys(f.schema.derivations))z.push(`${s}${H}${C}`);x.set(s,z),l.registerModule({id:f.id,schema:_,requirements:f.schema.requirements??{},init:d,derive:Object.keys(i).length>0?i:void 0,events:Object.keys(h).length>0?h:void 0,effects:Object.keys(V).length>0?V:void 0,constraints:Object.keys(I).length>0?I:void 0,resolvers:Object.keys(O).length>0?O:void 0,hooks:f.hooks,snapshotEvents:v&&!v.has(s)?[]:f.snapshotEvents?.map(C=>`${s}${H}${C}`)});}}}function ke(n){if(n.includes(".")){let[r,...g]=n.split(".");return `${r}${H}${g.join(H)}`}return n}function fe(n,r){let g=ft.get(n);if(g){let a=g.get(r);if(a)return a}else g=new Map,ft.set(n,g);let v=new Proxy({},{get(a,t){if(typeof t!="symbol"&&!ae.has(t))return t==="$store"||t==="$snapshot"?n[t]:n[`${r}${H}${t}`]},set(a,t,u){return typeof t=="symbol"||ae.has(t)?false:(n[`${r}${H}${t}`]=u,true)},has(a,t){return typeof t=="symbol"||ae.has(t)?false:`${r}${H}${t}`in n},deleteProperty(a,t){return typeof t=="symbol"||ae.has(t)?false:(delete n[`${r}${H}${t}`],true)}});return g.set(r,v),v}function _e(n,r,g){let v=gt.get(n);if(v)return v;let a=new Proxy({},{get(t,u){if(typeof u!="symbol"&&!ae.has(u)&&Object.hasOwn(r,u))return fe(n,u)},has(t,u){return typeof u=="symbol"||ae.has(u)?false:Object.hasOwn(r,u)},ownKeys(){return g()},getOwnPropertyDescriptor(t,u){if(typeof u!="symbol"&&Object.hasOwn(r,u))return {configurable:true,enumerable:true}}});return gt.set(n,a),a}function ve(n,r,g){let v=`${r}:${JSON.stringify([...g].sort())}`,a=pt.get(n);if(a){let R=a.get(v);if(R)return R}else a=new Map,pt.set(n,a);let t=new Set(g),u=["self",...g],y=new Proxy({},{get(R,w){if(typeof w!="symbol"&&!ae.has(w)){if(w==="self")return fe(n,r);if(t.has(w))return fe(n,w);process.env.NODE_ENV!=="production"&&typeof w=="string"&&console.warn(`[Directive] Module "${r}" accessed undeclared cross-module property "${w}". Add it to crossModuleDeps or use "facts.self.${w}" for own module facts.`);}},has(R,w){return typeof w=="symbol"||ae.has(w)?false:w==="self"||t.has(w)},ownKeys(){return u},getOwnPropertyDescriptor(R,w){if(typeof w!="symbol"&&(w==="self"||t.has(w)))return {configurable:true,enumerable:true}}});return a.set(v,y),y}function Fe(n,r){let g=mt.get(n);if(g){let a=g.get(r);if(a)return a}else g=new Map,mt.set(n,g);let v=new Proxy({},{get(a,t){if(typeof t!="symbol"&&!ae.has(t))return n[`${r}${H}${t}`]},has(a,t){return typeof t=="symbol"||ae.has(t)?false:`${r}${H}${t}`in n}});return g.set(r,v),v}function Nt(n,r,g){let v=yt.get(n);if(v)return v;let a=new Proxy({},{get(t,u){if(typeof u!="symbol"&&!ae.has(u)&&Object.hasOwn(r,u))return Fe(n,u)},has(t,u){return typeof u=="symbol"||ae.has(u)?false:Object.hasOwn(r,u)},ownKeys(){return g()},getOwnPropertyDescriptor(t,u){if(typeof u!="symbol"&&Object.hasOwn(r,u))return {configurable:true,enumerable:true}}});return yt.set(n,a),a}function Bt(n,r,g){let v=ht.get(n);return v||(v=new Map,ht.set(n,v)),new Proxy({},{get(a,t){if(typeof t=="symbol"||ae.has(t)||!Object.hasOwn(r,t))return;let u=v.get(t);if(u)return u;let y=new Proxy({},{get(R,w){if(typeof w!="symbol"&&!ae.has(w))return l=>{n.dispatch({type:`${t}${H}${w}`,...l});}}});return v.set(t,y),y},has(a,t){return typeof t=="symbol"||ae.has(t)?false:Object.hasOwn(r,t)},ownKeys(){return g()},getOwnPropertyDescriptor(a,t){if(typeof t!="symbol"&&Object.hasOwn(r,t))return {configurable:true,enumerable:true}}})}function Wt(n){let r=n.module;if(!r)throw new Error("[Directive] createSystem requires a module. Got: "+typeof r);if(n.tickMs!==void 0&&n.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(n.initialFacts&&!Re(n.initialFacts))throw new Error("[Directive] initialFacts contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");process.env.NODE_ENV!=="production"&&(r.crossModuleDeps&&Object.keys(r.crossModuleDeps).length>0&&console.warn("[Directive] Single module mode ignores crossModuleDeps. Use multiple modules if cross-module access is needed: createSystem({ modules: { ... } })"),n.tickMs&&n.tickMs>0&&(r.events&&"tick"in r.events||console.warn(`[Directive] tickMs is set to ${n.tickMs}ms but module has no "tick" event handler.`)),n.debug?.snapshotModules&&console.warn("[Directive] debug.snapshotModules has no effect in single-module mode. Use snapshotEvents on the module definition instead, or switch to createSystem({ modules: { ... } }) for multi-module filtering."));let g=n.debug,v=n.errorBoundary;n.zeroConfig&&(g={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...n.debug},v={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...n.errorBoundary});let a=null,t=null;t=je({modules:[{id:r.id,schema:r.schema.facts,requirements:r.schema.requirements,init:r.init,derive:r.derive,events:r.events,effects:r.effects,constraints:r.constraints,resolvers:r.resolvers,hooks:r.hooks,snapshotEvents:r.snapshotEvents}],plugins:n.plugins,debug:g,errorBoundary:v,tickMs:n.tickMs,onAfterModuleInit:()=>{if(n.initialFacts)for(let[l,E]of Object.entries(n.initialFacts))ae.has(l)||(t.facts[l]=E);if(a){for(let[l,E]of Object.entries(a))ae.has(l)||(t.facts[l]=E);a=null;}}});let u=new Proxy({},{get(l,E){if(typeof E!="symbol"&&!ae.has(E))return x=>{t.dispatch({type:E,...x});}}}),y=null,R=n.tickMs;return {_mode:"single",facts:t.facts,debug:t.debug,derive:t.derive,events:u,constraints:t.constraints,effects:t.effects,get runHistory(){return t.runHistory},get isRunning(){return t.isRunning},get isSettled(){return t.isSettled},get isInitialized(){return t.isInitialized},get isReady(){return t.isReady},whenReady:t.whenReady.bind(t),async hydrate(l){if(t.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let E=await l();E&&typeof E=="object"&&(a=E);},initialize(){t.initialize();},start(){t.start(),R&&R>0&&r.events&&"tick"in r.events&&(y=setInterval(()=>{t.dispatch({type:"tick"});},R));},stop(){y&&(clearInterval(y),y=null),t.stop();},destroy(){this.stop(),t.destroy();},dispatch(l){t.dispatch(l);},batch:t.batch.bind(t),read(l){return t.read(l)},subscribe(l,E){return t.subscribe(l,E)},watch(l,E,x){return t.watch(l,E,x)},when(l,E){return t.when(l,E)},onSettledChange:t.onSettledChange.bind(t),onTimeTravelChange:t.onTimeTravelChange.bind(t),inspect:t.inspect.bind(t),settle:t.settle.bind(t),explain:t.explain.bind(t),getSnapshot:t.getSnapshot.bind(t),restore:t.restore.bind(t),getDistributableSnapshot:t.getDistributableSnapshot.bind(t),watchDistributableSnapshot:t.watchDistributableSnapshot.bind(t),registerModule(l){t.registerModule({id:l.id,schema:l.schema.facts,requirements:l.schema.requirements,init:l.init,derive:l.derive,events:l.events,effects:l.effects,constraints:l.constraints,resolvers:l.resolvers,hooks:l.hooks,snapshotEvents:l.snapshotEvents});}}}var ae,H,ft,gt,yt,mt,pt,ht,bt=ge(()=>{Ee();dt();ae=Object.freeze(new Set(["__proto__","constructor","prototype"])),H="::";ft=new WeakMap,gt=new WeakMap,yt=new WeakMap,mt=new WeakMap;pt=new WeakMap;ht=new WeakMap;});function In(n){let{worker:r,onFactChange:g,onDerivationChange:v,onRequirementCreated:a,onRequirementMet:t,onError:u}=n,y=new Map,R=0,w=null,l=null,E=null,x=null;r.onmessage=P=>{let j=P.data;switch(j.type){case "READY":w?.(),w=null;break;case "STARTED":l?.(),l=null;break;case "STOPPED":E?.(),E=null;break;case "DESTROYED":x?.(),x=null;break;case "FACT_CHANGED":g?.(j.key,j.value,j.prev);break;case "DERIVATION_CHANGED":v?.(j.key,j.value);break;case "REQUIREMENT_CREATED":a?.(j.requirement);break;case "REQUIREMENT_MET":t?.(j.requirementId,j.resolverId);break;case "ERROR":u?.(j.error,j.source);break;case "SNAPSHOT_RESULT":{let T=y.get(j.requestId);T&&(T.resolve(j.snapshot),y.delete(j.requestId));break}case "INSPECT_RESULT":{let T=y.get(j.requestId);T&&(T.resolve(j.inspection),y.delete(j.requestId));break}case "SETTLE_RESULT":{let T=y.get(j.requestId);T&&(j.success?T.resolve(void 0):T.reject(new Error(j.error||"Settle failed")),y.delete(j.requestId));break}}},r.onerror=P=>{u?.(P.message,"worker");};function M(P){r.postMessage(P);}function W(P){return new Promise((j,T)=>{y.set(P.requestId,{resolve:j,reject:T}),M(P);})}return {init(P){return new Promise(j=>{w=j,M({type:"INIT",config:P});})},start(){return new Promise(P=>{l=P,M({type:"START"});})},stop(){return new Promise(P=>{E=P,M({type:"STOP"});})},destroy(){return new Promise(P=>{x=P,M({type:"DESTROY"});})},setFact(P,j){M({type:"SET_FACT",key:P,value:j});},setFacts(P){M({type:"SET_FACTS",facts:P});},dispatch(P){M({type:"DISPATCH",event:P});},getSnapshot(P){let j=`snapshot-${++R}`;return W({type:"GET_SNAPSHOT",options:P,requestId:j})},inspect(){let P=`inspect-${++R}`;return W({type:"INSPECT",requestId:P})},settle(P){let j=`settle-${++R}`;return W({type:"SETTLE",timeout:P,requestId:j})},terminate(){r.terminate();}}}var Ne=null;function St(){return Ne||(Ne=new Map),Ne}function On(n,r){St().set(n,r);}function An(){let n=null;self.onmessage=async r=>{let g=r.data;try{switch(g.type){case "INIT":{n=await Kt(g.config),postMessage({type:"READY"});break}case "START":{n&&(n.start(),postMessage({type:"STARTED"}));break}case "STOP":{n&&(n.stop(),postMessage({type:"STOPPED"}));break}case "DESTROY":{n&&(n.destroy(),n=null,postMessage({type:"DESTROYED"}));break}case "SET_FACT":{n&&n.setFact(g.key,g.value);break}case "SET_FACTS":{n&&n.setFacts(g.facts);break}case "DISPATCH":{n&&n.dispatch(g.event);break}case "GET_SNAPSHOT":{if(n){let v=n.getSnapshot(g.options);postMessage({type:"SNAPSHOT_RESULT",requestId:g.requestId,snapshot:v});}break}case "INSPECT":{if(n){let v=n.inspect();postMessage({type:"INSPECT_RESULT",requestId:g.requestId,inspection:v});}break}case "SETTLE":{if(n)try{await n.settle(g.timeout),postMessage({type:"SETTLE_RESULT",requestId:g.requestId,success:!0});}catch(v){postMessage({type:"SETTLE_RESULT",requestId:g.requestId,success:!1,error:v instanceof Error?v.message:String(v)});}break}}}catch(v){postMessage({type:"ERROR",error:v instanceof Error?v.message:String(v),source:g.type});}};}async function Kt(n){let{createSystem:r}=await Promise.resolve().then(()=>(bt(),vt)),g=St(),v={};for(let u of n.moduleNames){let y=g.get(u);if(!y)throw new Error(`[Directive Worker] Module "${u}" not registered. Call registerWorkerModule('${u}', module) before handling messages.`);v[u]=y;}let t=r({modules:v,plugins:[{name:"__worker-tracking__",onFactSet:(u,y,R)=>{postMessage({type:"FACT_CHANGED",key:u,value:y,prev:R});},onDerivationCompute:(u,y)=>{postMessage({type:"DERIVATION_CHANGED",key:u,value:y});},onRequirementCreated:u=>{postMessage({type:"REQUIREMENT_CREATED",requirement:{...u.requirement,id:u.id}});},onRequirementMet:(u,y)=>{postMessage({type:"REQUIREMENT_MET",requirementId:u.id,resolverId:y});}}],debug:n.debug});return {start:()=>t.start(),stop:()=>t.stop(),destroy:()=>t.destroy(),setFact:(u,y)=>{t.facts[u]=y;},setFacts:u=>{let y=t.facts;if(y.$store?.batch)y.$store.batch(()=>{for(let[R,w]of Object.entries(u))y[R]=w;});else for(let[R,w]of Object.entries(u))y[R]=w;},dispatch:u=>{t.dispatch(u);},getSnapshot:u=>t.getDistributableSnapshot(u),inspect:()=>t.inspect(),settle:u=>t.settle(u)}}export{In as createWorkerClient,St as getWorkerModuleRegistry,An as handleWorkerMessages,On as registerWorkerModule};//# sourceMappingURL=worker.js.map
11
+ createSystem({ module: counterModule })`);let m=r.modules;if(m&&typeof m=="object"&&"id"in m&&"schema"in m)throw new Error(`[Directive] A single module was passed to \`modules:\`. For a single module, use \`module:\` instead:
12
+
13
+ createSystem({ module: myModule })
14
+
15
+ For multiple modules, wrap in an object:
16
+ createSystem({ modules: { myName: myModule } })`);return Xt(r)}function Xt(o){let r=o.modules,m=new Set(Object.keys(r)),u=o.debug?.snapshotModules?new Set(o.debug.snapshotModules):null;if(o.tickMs!==void 0&&o.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(process.env.NODE_ENV!=="production"){for(let[c,D]of Object.entries(r))if(D.crossModuleDeps)for(let i of Object.keys(D.crossModuleDeps))i===c?console.warn(`[Directive] Module "${c}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):m.has(i)||console.warn(`[Directive] Module "${c}" declares crossModuleDeps.${i}, but no module with namespace "${i}" exists in the system. Available modules: ${[...m].join(", ")}`);}if(process.env.NODE_ENV!=="production"&&o.debug?.snapshotModules)for(let c of o.debug.snapshotModules)m.has(c)||console.warn(`[Directive] debug.snapshotModules entry "${c}" doesn't match any module. Available modules: ${[...m].join(", ")}`);let b,n=o.initOrder??"auto";if(Array.isArray(n)){let c=n,D=Object.keys(r).filter(i=>!c.includes(i));if(D.length>0)throw new Error(`[Directive] initOrder is missing modules: ${D.join(", ")}. All modules must be included in the explicit order.`);b=c;}else n==="declaration"?b=Object.keys(r):b=Jt(r);let g=o.debug,y=o.errorBoundary;o.zeroConfig&&(g={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...o.debug},y={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...o.errorBoundary});for(let c of Object.keys(r)){if(c.includes(Q))throw new Error(`[Directive] Module name "${c}" contains the reserved separator "${Q}". Module names cannot contain "${Q}".`);let D=r[c];if(D){for(let i of Object.keys(D.schema.facts))if(i.includes(Q))throw new Error(`[Directive] Schema key "${i}" in module "${c}" contains the reserved separator "${Q}". Schema keys cannot contain "${Q}".`)}}let w=[];for(let c of b){let D=r[c];if(!D)continue;let i=D.crossModuleDeps&&Object.keys(D.crossModuleDeps).length>0,k=i?Object.keys(D.crossModuleDeps):[],T={};for(let[M,U]of Object.entries(D.schema.facts))T[`${c}${Q}${M}`]=U;let _={};if(D.schema.derivations)for(let[M,U]of Object.entries(D.schema.derivations))_[`${c}${Q}${M}`]=U;let W={};if(D.schema.events)for(let[M,U]of Object.entries(D.schema.events))W[`${c}${Q}${M}`]=U;let s=D.init?M=>{let U=fe(M,c);D.init(U);}:void 0,f={};if(D.derive)for(let[M,U]of Object.entries(D.derive))f[`${c}${Q}${M}`]=(F,a)=>{let p=i?we(F,c,k):fe(F,c),h=Le(a,c);return U(p,h)};let C={};if(D.events)for(let[M,U]of Object.entries(D.events))C[`${c}${Q}${M}`]=(F,a)=>{let p=fe(F,c);U(p,a);};let O={};if(D.constraints)for(let[M,U]of Object.entries(D.constraints)){let F=U;O[`${c}${Q}${M}`]={...F,deps:F.deps?.map(a=>`${c}${Q}${a}`),when:a=>{let p=i?we(a,c,k):fe(a,c);return F.when(p)},require:typeof F.require=="function"?a=>{let p=i?we(a,c,k):fe(a,c);return F.require(p)}:F.require};}let j={};if(D.resolvers)for(let[M,U]of Object.entries(D.resolvers)){let F=U;j[`${c}${Q}${M}`]={...F,resolve:async(a,p)=>{let h=Ue(p.facts,r,()=>Object.keys(r));await F.resolve(a,{facts:h[c],signal:p.signal});}};}let z={};if(D.effects)for(let[M,U]of Object.entries(D.effects)){let F=U;z[`${c}${Q}${M}`]={...F,run:(a,p)=>{let h=i?we(a,c,k):fe(a,c),$=p?i?we(p,c,k):fe(p,c):void 0;return F.run(h,$)},deps:F.deps?.map(a=>`${c}${Q}${a}`)};}w.push({id:D.id,schema:{facts:T,derivations:_,events:W,requirements:D.schema.requirements??{}},init:s,derive:f,events:C,effects:z,constraints:O,resolvers:j,hooks:D.hooks,snapshotEvents:u&&!u.has(c)?[]:D.snapshotEvents?.map(M=>`${c}${Q}${M}`)});}process.env.NODE_ENV!=="production"&&o.tickMs&&o.tickMs>0&&(w.some(D=>D.events&&Object.keys(D.events).some(i=>i.endsWith(`${Q}tick`)))||console.warn(`[Directive] tickMs is set to ${o.tickMs}ms but no module defines a "tick" event handler.`));let v=null,l=null;function x(c){for(let[D,i]of Object.entries(c)){if(Z.has(D)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${D}". Skipping.`);continue}if(!m.has(D)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${D}". Available modules: ${[...m].join(", ")}`);continue}if(i&&typeof i=="object"&&!Re(i))throw new Error(`[Directive] initialFacts/hydrate for namespace "${D}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[k,T]of Object.entries(i))Z.has(k)||(l.facts[`${D}${Q}${k}`]=T);}}l=Ke({modules:w.map(c=>({id:c.id,schema:c.schema.facts,requirements:c.schema.requirements,init:c.init,derive:c.derive,events:c.events,effects:c.effects,constraints:c.constraints,resolvers:c.resolvers,hooks:c.hooks,snapshotEvents:c.snapshotEvents})),plugins:o.plugins,debug:g,errorBoundary:y,tickMs:o.tickMs,onAfterModuleInit:()=>{o.initialFacts&&x(o.initialFacts),v&&(x(v),v=null);}});let E=new Map;for(let c of Object.keys(r)){let D=r[c];if(!D)continue;let i=[];for(let k of Object.keys(D.schema.facts))i.push(`${c}${Q}${k}`);if(D.schema.derivations)for(let k of Object.keys(D.schema.derivations))i.push(`${c}${Q}${k}`);E.set(c,i);}let A={names:null};function V(){return A.names===null&&(A.names=Object.keys(r)),A.names}let B=Ue(l.facts,r,V),N=Zt(l.derive,r,V),S=en(l,r,V),R=null,L=o.tickMs,P={_mode:"namespaced",facts:B,debug:l.debug,derive:N,events:S,constraints:l.constraints,effects:l.effects,resolvers:l.resolvers,get runHistory(){return l.runHistory},get isRunning(){return l.isRunning},get isSettled(){return l.isSettled},get isInitialized(){return l.isInitialized},get isReady(){return l.isReady},whenReady:l.whenReady.bind(l),async hydrate(c){if(l.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let D=await c();D&&typeof D=="object"&&(v=D);},initialize(){l.initialize();},start(){if(l.start(),L&&L>0){let c=Object.keys(w[0]?.events??{}).find(D=>D.endsWith(`${Q}tick`));c&&(R=setInterval(()=>{l.dispatch({type:c});},L));}},stop(){R&&(clearInterval(R),R=null),l.stop();},destroy(){this.stop(),l.destroy();},dispatch(c){l.dispatch(c);},batch:l.batch.bind(l),read(c){return l.read(be(c))},subscribe(c,D){let i=[];for(let k of c)if(k.endsWith(".*")){let T=k.slice(0,-2),_=E.get(T);_?i.push(..._):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${k}" \u2014 namespace "${T}" not found.`);}else i.push(be(k));return l.subscribe(i,D)},subscribeModule(c,D){let i=E.get(c);return !i||i.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${c}") \u2014 namespace not found. Available: ${[...E.keys()].join(", ")}`),()=>{}):l.subscribe(i,D)},watch(c,D,i){return l.watch(be(c),D,i)},when(c,D){return l.when(()=>c(B),D)},onSettledChange:l.onSettledChange.bind(l),onTimeTravelChange:l.onTimeTravelChange.bind(l),inspect:l.inspect.bind(l),settle:l.settle.bind(l),explain:l.explain.bind(l),getSnapshot:l.getSnapshot.bind(l),restore:l.restore.bind(l),getDistributableSnapshot(c){let D={...c,includeDerivations:c?.includeDerivations?.map(be),excludeDerivations:c?.excludeDerivations?.map(be),includeFacts:c?.includeFacts?.map(be)},i=l.getDistributableSnapshot(D),k={};for(let[T,_]of Object.entries(i.data)){let W=T.indexOf(Q);if(W>0){let s=T.slice(0,W),f=T.slice(W+Q.length);k[s]||(k[s]={}),k[s][f]=_;}else k._root||(k._root={}),k._root[T]=_;}return {...i,data:k}},watchDistributableSnapshot(c,D){let i={...c,includeDerivations:c?.includeDerivations?.map(be),excludeDerivations:c?.excludeDerivations?.map(be),includeFacts:c?.includeFacts?.map(be)};return l.watchDistributableSnapshot(i,k=>{let T={};for(let[_,W]of Object.entries(k.data)){let s=_.indexOf(Q);if(s>0){let f=_.slice(0,s),C=_.slice(s+Q.length);T[f]||(T[f]={}),T[f][C]=W;}else T._root||(T._root={}),T._root[_]=W;}D({...k,data:T});})},registerModule(c,D){if(m.has(c))throw new Error(`[Directive] Module namespace "${c}" already exists. Cannot register a duplicate namespace.`);if(c.includes(Q))throw new Error(`[Directive] Module name "${c}" contains the reserved separator "${Q}".`);if(Z.has(c))throw new Error(`[Directive] Module name "${c}" is a blocked property.`);for(let M of Object.keys(D.schema.facts))if(M.includes(Q))throw new Error(`[Directive] Schema key "${M}" in module "${c}" contains the reserved separator "${Q}".`);let i=D,k=i.crossModuleDeps&&Object.keys(i.crossModuleDeps).length>0,T=k?Object.keys(i.crossModuleDeps):[],_={};for(let[M,U]of Object.entries(i.schema.facts))_[`${c}${Q}${M}`]=U;let W=i.init?M=>{let U=fe(M,c);i.init(U);}:void 0,s={};if(i.derive)for(let[M,U]of Object.entries(i.derive))s[`${c}${Q}${M}`]=(F,a)=>{let p=k?we(F,c,T):fe(F,c),h=Le(a,c);return U(p,h)};let f={};if(i.events)for(let[M,U]of Object.entries(i.events))f[`${c}${Q}${M}`]=(F,a)=>{let p=fe(F,c);U(p,a);};let C={};if(i.constraints)for(let[M,U]of Object.entries(i.constraints)){let F=U;C[`${c}${Q}${M}`]={...F,deps:F.deps?.map(a=>`${c}${Q}${a}`),when:a=>{let p=k?we(a,c,T):fe(a,c);return F.when(p)},require:typeof F.require=="function"?a=>{let p=k?we(a,c,T):fe(a,c);return F.require(p)}:F.require};}let O={};if(i.resolvers)for(let[M,U]of Object.entries(i.resolvers)){let F=U;O[`${c}${Q}${M}`]={...F,resolve:async(a,p)=>{let h=Ue(p.facts,r,V);await F.resolve(a,{facts:h[c],signal:p.signal});}};}let j={};if(i.effects)for(let[M,U]of Object.entries(i.effects)){let F=U;j[`${c}${Q}${M}`]={...F,run:(a,p)=>{let h=k?we(a,c,T):fe(a,c),$=p?k?we(p,c,T):fe(p,c):void 0;return F.run(h,$)},deps:F.deps?.map(a=>`${c}${Q}${a}`)};}m.add(c),r[c]=i,A.names=null;let z=[];for(let M of Object.keys(i.schema.facts))z.push(`${c}${Q}${M}`);if(i.schema.derivations)for(let M of Object.keys(i.schema.derivations))z.push(`${c}${Q}${M}`);E.set(c,z),l.registerModule({id:i.id,schema:_,requirements:i.schema.requirements??{},init:W,derive:Object.keys(s).length>0?s:void 0,events:Object.keys(f).length>0?f:void 0,effects:Object.keys(j).length>0?j:void 0,constraints:Object.keys(C).length>0?C:void 0,resolvers:Object.keys(O).length>0?O:void 0,hooks:i.hooks,snapshotEvents:u&&!u.has(c)?[]:i.snapshotEvents?.map(M=>`${c}${Q}${M}`)});}};return process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!P.isRunning&&!P.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0),P}function be(o){if(o.includes(".")){let[r,...m]=o.split(".");return `${r}${Q}${m.join(Q)}`}return o}function fe(o,r){let m=kt.get(o);if(m){let b=m.get(r);if(b)return b}else m=new Map,kt.set(o,m);let u=new Proxy({},{get(b,n){if(typeof n!="symbol"&&!Z.has(n))return n==="$store"||n==="$snapshot"?o[n]:o[`${r}${Q}${n}`]},set(b,n,g){return typeof n=="symbol"||Z.has(n)?false:(o[`${r}${Q}${n}`]=g,true)},has(b,n){return typeof n=="symbol"||Z.has(n)?false:`${r}${Q}${n}`in o},deleteProperty(b,n){return typeof n=="symbol"||Z.has(n)?false:(delete o[`${r}${Q}${n}`],true)},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return m.set(r,u),u}function Ue(o,r,m){let u=bt.get(o);if(u)return u;let b=new Proxy({},{get(n,g){if(typeof g!="symbol"&&!Z.has(g)&&Object.hasOwn(r,g))return fe(o,g)},has(n,g){return typeof g=="symbol"||Z.has(g)?false:Object.hasOwn(r,g)},ownKeys(){return m()},getOwnPropertyDescriptor(n,g){if(typeof g!="symbol"&&Object.hasOwn(r,g))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return bt.set(o,b),b}function we(o,r,m){let u=`${r}:${JSON.stringify([...m].sort())}`,b=Et.get(o);if(b){let w=b.get(u);if(w)return w}else b=new Map,Et.set(o,b);let n=new Set(m),g=["self",...m],y=new Proxy({},{get(w,v){if(typeof v!="symbol"&&!Z.has(v)){if(v==="self")return fe(o,r);if(n.has(v))return fe(o,v);process.env.NODE_ENV!=="production"&&typeof v=="string"&&console.warn(`[Directive] Module "${r}" accessed undeclared cross-module property "${v}". Add it to crossModuleDeps or use "facts.self.${v}" for own module facts.`);}},has(w,v){return typeof v=="symbol"||Z.has(v)?false:v==="self"||n.has(v)},ownKeys(){return g},getOwnPropertyDescriptor(w,v){if(typeof v!="symbol"&&(v==="self"||n.has(v)))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return b.set(u,y),y}function Le(o,r){let m=Dt.get(o);if(m){let b=m.get(r);if(b)return b}else m=new Map,Dt.set(o,m);let u=new Proxy({},{get(b,n){if(typeof n!="symbol"&&!Z.has(n))return o[`${r}${Q}${n}`]},has(b,n){return typeof n=="symbol"||Z.has(n)?false:`${r}${Q}${n}`in o},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return m.set(r,u),u}function Zt(o,r,m){let u=Rt.get(o);if(u)return u;let b=new Proxy({},{get(n,g){if(typeof g!="symbol"&&!Z.has(g)&&Object.hasOwn(r,g))return Le(o,g)},has(n,g){return typeof g=="symbol"||Z.has(g)?false:Object.hasOwn(r,g)},ownKeys(){return m()},getOwnPropertyDescriptor(n,g){if(typeof g!="symbol"&&Object.hasOwn(r,g))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return Rt.set(o,b),b}function en(o,r,m){let u=Ct.get(o);return u||(u=new Map,Ct.set(o,u)),new Proxy({},{get(b,n){if(typeof n=="symbol"||Z.has(n)||!Object.hasOwn(r,n))return;let g=u.get(n);if(g)return g;let y=new Proxy({},{get(w,v){if(typeof v!="symbol"&&!Z.has(v))return l=>{o.dispatch({type:`${n}${Q}${v}`,...l});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return u.set(n,y),y},has(b,n){return typeof n=="symbol"||Z.has(n)?false:Object.hasOwn(r,n)},ownKeys(){return m()},getOwnPropertyDescriptor(b,n){if(typeof n!="symbol"&&Object.hasOwn(r,n))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function tn(o){let r=o.module;if(!r)throw new Error("[Directive] createSystem requires a module. Got: "+typeof r);if(o.tickMs!==void 0&&o.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(o.initialFacts&&!Re(o.initialFacts))throw new Error("[Directive] initialFacts contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");process.env.NODE_ENV!=="production"&&(r.crossModuleDeps&&Object.keys(r.crossModuleDeps).length>0&&console.warn("[Directive] Single module mode ignores crossModuleDeps. Use multiple modules if cross-module access is needed: createSystem({ modules: { ... } })"),o.tickMs&&o.tickMs>0&&(r.events&&"tick"in r.events||console.warn(`[Directive] tickMs is set to ${o.tickMs}ms but module has no "tick" event handler.`)),o.debug?.snapshotModules&&console.warn("[Directive] debug.snapshotModules has no effect in single-module mode. Use snapshotEvents on the module definition instead, or switch to createSystem({ modules: { ... } }) for multi-module filtering."));let m=o.debug,u=o.errorBoundary;o.zeroConfig&&(m={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...o.debug},u={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...o.errorBoundary});let b=null,n=null;n=Ke({modules:[{id:r.id,schema:r.schema.facts,requirements:r.schema.requirements,init:r.init,derive:r.derive,events:r.events,effects:r.effects,constraints:r.constraints,resolvers:r.resolvers,hooks:r.hooks,snapshotEvents:r.snapshotEvents}],plugins:o.plugins,debug:m,errorBoundary:u,tickMs:o.tickMs,onAfterModuleInit:()=>{if(o.initialFacts)for(let[l,x]of Object.entries(o.initialFacts))Z.has(l)||(n.facts[l]=x);if(b){for(let[l,x]of Object.entries(b))Z.has(l)||(n.facts[l]=x);b=null;}}});let g=new Proxy({},{get(l,x){if(typeof x!="symbol"&&!Z.has(x))return E=>{n.dispatch({type:x,...E});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),y=null,w=o.tickMs,v={_mode:"single",facts:n.facts,debug:n.debug,derive:n.derive,events:g,constraints:n.constraints,effects:n.effects,resolvers:n.resolvers,get runHistory(){return n.runHistory},get isRunning(){return n.isRunning},get isSettled(){return n.isSettled},get isInitialized(){return n.isInitialized},get isReady(){return n.isReady},whenReady:n.whenReady.bind(n),async hydrate(l){if(n.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let x=await l();x&&typeof x=="object"&&(b=x);},initialize(){n.initialize();},start(){n.start(),w&&w>0&&r.events&&"tick"in r.events&&(y=setInterval(()=>{n.dispatch({type:"tick"});},w));},stop(){y&&(clearInterval(y),y=null),n.stop();},destroy(){this.stop(),n.destroy();},dispatch(l){n.dispatch(l);},batch:n.batch.bind(n),read(l){return n.read(l)},subscribe(l,x){return n.subscribe(l,x)},watch(l,x,E){return n.watch(l,x,E)},when(l,x){return n.when(l,x)},onSettledChange:n.onSettledChange.bind(n),onTimeTravelChange:n.onTimeTravelChange.bind(n),inspect:n.inspect.bind(n),settle:n.settle.bind(n),explain:n.explain.bind(n),getSnapshot:n.getSnapshot.bind(n),restore:n.restore.bind(n),getDistributableSnapshot:n.getDistributableSnapshot.bind(n),watchDistributableSnapshot:n.watchDistributableSnapshot.bind(n),registerModule(l){n.registerModule({id:l.id,schema:l.schema.facts,requirements:l.schema.requirements,init:l.init,derive:l.derive,events:l.events,effects:l.effects,constraints:l.constraints,resolvers:l.resolvers,hooks:l.hooks,snapshotEvents:l.snapshotEvents});}};return process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!v.isRunning&&!v.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0),v}var Q,kt,bt,Rt,Dt,Et,Ct,Tt=ge(()=>{De();St();Te();Q="::";kt=new WeakMap,bt=new WeakMap,Rt=new WeakMap,Dt=new WeakMap;Et=new WeakMap;Ct=new WeakMap;});function zn(o){let{worker:r,onFactChange:m,onDerivationChange:u,onRequirementCreated:b,onRequirementMet:n,onError:g}=o,y=new Map,w=0,v=null,l=null,x=null,E=null;r.onmessage=B=>{let N=B.data;switch(N.type){case "READY":v?.(),v=null;break;case "STARTED":l?.(),l=null;break;case "STOPPED":x?.(),x=null;break;case "DESTROYED":E?.(),E=null;break;case "FACT_CHANGED":m?.(N.key,N.value,N.prev);break;case "DERIVATION_CHANGED":u?.(N.key,N.value);break;case "REQUIREMENT_CREATED":b?.(N.requirement);break;case "REQUIREMENT_MET":n?.(N.requirementId,N.resolverId);break;case "ERROR":g?.(N.error,N.source);break;case "SNAPSHOT_RESULT":{let S=y.get(N.requestId);S&&(S.resolve(N.snapshot),y.delete(N.requestId));break}case "INSPECT_RESULT":{let S=y.get(N.requestId);S&&(S.resolve(N.inspection),y.delete(N.requestId));break}case "SETTLE_RESULT":{let S=y.get(N.requestId);S&&(N.success?S.resolve(void 0):S.reject(new Error(N.error||"Settle failed")),y.delete(N.requestId));break}}},r.onerror=B=>{g?.(B.message,"worker");};function A(B){r.postMessage(B);}function V(B){return new Promise((N,S)=>{y.set(B.requestId,{resolve:N,reject:S}),A(B);})}return {init(B){return new Promise(N=>{v=N,A({type:"INIT",config:B});})},start(){return new Promise(B=>{l=B,A({type:"START"});})},stop(){return new Promise(B=>{x=B,A({type:"STOP"});})},destroy(){return new Promise(B=>{E=B,A({type:"DESTROY"});})},setFact(B,N){A({type:"SET_FACT",key:B,value:N});},setFacts(B){A({type:"SET_FACTS",facts:B});},dispatch(B){A({type:"DISPATCH",event:B});},getSnapshot(B){let N=`snapshot-${++w}`;return V({type:"GET_SNAPSHOT",options:B,requestId:N})},inspect(){let B=`inspect-${++w}`;return V({type:"INSPECT",requestId:B})},settle(B){let N=`settle-${++w}`;return V({type:"SETTLE",timeout:B,requestId:N})},terminate(){r.terminate();}}}var ze=null;function Mt(){return ze||(ze=new Map),ze}function Hn(o,r){Mt().set(o,r);}function Gn(){let o=null;self.onmessage=async r=>{let m=r.data;try{switch(m.type){case "INIT":{o=await nn(m.config),postMessage({type:"READY"});break}case "START":{o&&(o.start(),postMessage({type:"STARTED"}));break}case "STOP":{o&&(o.stop(),postMessage({type:"STOPPED"}));break}case "DESTROY":{o&&(o.destroy(),o=null,postMessage({type:"DESTROYED"}));break}case "SET_FACT":{o&&o.setFact(m.key,m.value);break}case "SET_FACTS":{o&&o.setFacts(m.facts);break}case "DISPATCH":{o&&o.dispatch(m.event);break}case "GET_SNAPSHOT":{if(o){let u=o.getSnapshot(m.options);postMessage({type:"SNAPSHOT_RESULT",requestId:m.requestId,snapshot:u});}break}case "INSPECT":{if(o){let u=o.inspect();postMessage({type:"INSPECT_RESULT",requestId:m.requestId,inspection:u});}break}case "SETTLE":{if(o)try{await o.settle(m.timeout),postMessage({type:"SETTLE_RESULT",requestId:m.requestId,success:!0});}catch(u){postMessage({type:"SETTLE_RESULT",requestId:m.requestId,success:!1,error:u instanceof Error?u.message:String(u)});}break}}}catch(u){postMessage({type:"ERROR",error:u instanceof Error?u.message:String(u),source:m.type});}};}async function nn(o){let{createSystem:r}=await Promise.resolve().then(()=>(Tt(),xt)),m=Mt(),u={};for(let g of o.moduleNames){let y=m.get(g);if(!y)throw new Error(`[Directive Worker] Module "${g}" not registered. Call registerWorkerModule('${g}', module) before handling messages.`);u[g]=y;}let n=r({modules:u,plugins:[{name:"__worker-tracking__",onFactSet:(g,y,w)=>{postMessage({type:"FACT_CHANGED",key:g,value:y,prev:w});},onDerivationCompute:(g,y)=>{postMessage({type:"DERIVATION_CHANGED",key:g,value:y});},onRequirementCreated:g=>{postMessage({type:"REQUIREMENT_CREATED",requirement:{...g.requirement,id:g.id}});},onRequirementMet:(g,y)=>{postMessage({type:"REQUIREMENT_MET",requirementId:g.id,resolverId:y});}}],debug:o.debug});return {start:()=>n.start(),stop:()=>n.stop(),destroy:()=>n.destroy(),setFact:(g,y)=>{n.facts[g]=y;},setFacts:g=>{let y=n.facts;if(y.$store?.batch)y.$store.batch(()=>{for(let[w,v]of Object.entries(g))y[w]=v;});else for(let[w,v]of Object.entries(g))y[w]=v;},dispatch:g=>{n.dispatch(g);},getSnapshot:g=>n.getDistributableSnapshot(g),inspect:()=>n.inspect(),settle:g=>n.settle(g)}}export{zn as createWorkerClient,Mt as getWorkerModuleRegistry,Gn as handleWorkerMessages,Hn as registerWorkerModule};//# sourceMappingURL=worker.js.map
12
17
  //# sourceMappingURL=worker.js.map