@directive-run/core 0.5.0 → 0.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
- 'use strict';var xe=class extends Error{constructor(o,i,y,s,p=true){super(o);this.source=i;this.sourceId=y;this.context=s;this.recoverable=p;this.name="DirectiveError";}};function ot(){return {create(e){return e}}}function it(){return {create(e){return e}}}function at(e){return e}function ct(e){return e}function Ot(e){return e._mode==="single"}function It(e){return e._mode==="namespaced"}function Be(e=[],n,o,i,y,s){return {_type:void 0,_validators:e,_typeName:n,_default:o,_transform:i,_description:y,_refinements:s,validate(p){return Be([...e,p],n,o,i,y,s)}}}function ce(e,n,o,i,y,s){return {...Be(e,n,o,i,y,s),default(m){return ce(e,n,m,i,y,s)},transform(m){return ce([],n,void 0,l=>{let c=i?i(l):l;return m(c)},y)},brand(){return ce(e,`Branded<${n}>`,o,i,y,s)},describe(m){return ce(e,n,o,i,m,s)},refine(m,f){let l=[...s??[],{predicate:m,message:f}];return ce([...e,m],n,o,i,y,l)},nullable(){return ce([m=>m===null||e.every(f=>f(m))],`${n} | null`,o,i,y)},optional(){return ce([m=>m===void 0||e.every(f=>f(m))],`${n} | undefined`,o,i,y)}}}var At={string(){return ce([e=>typeof e=="string"],"string")},number(){let e=(n,o,i,y,s)=>({...ce(n,"number",o,i,y,s),min(m){return e([...n,f=>f>=m],o,i,y,s)},max(m){return e([...n,f=>f<=m],o,i,y,s)},default(m){return e(n,m,i,y,s)},describe(m){return e(n,o,i,m,s)},refine(m,f){let l=[...s??[],{predicate:m,message:f}];return e([...n,m],o,i,y,l)}});return e([n=>typeof n=="number"])},boolean(){return ce([e=>typeof e=="boolean"],"boolean")},array(){let e=(n,o,i,y,s)=>{let p=ce(n,"array",i,void 0,y),m=s??{value:-1};return {...p,get _lastFailedIndex(){return m.value},set _lastFailedIndex(l){m.value=l;},of(l){let c={value:-1};return e([...n,S=>{for(let w=0;w<S.length;w++){let j=S[w];if(!l._validators.every(_=>_(j)))return c.value=w,false}return true}],l,i,y,c)},nonEmpty(){return e([...n,l=>l.length>0],o,i,y,m)},maxLength(l){return e([...n,c=>c.length<=l],o,i,y,m)},minLength(l){return e([...n,c=>c.length>=l],o,i,y,m)},default(l){return e(n,o,l,y,m)},describe(l){return e(n,o,i,l,m)}}};return e([n=>Array.isArray(n)])},object(){let e=(n,o,i)=>({...ce(n,"object",o,void 0,i),shape(s){return e([...n,p=>{for(let[m,f]of Object.entries(s)){let l=p[m],c=f;if(c&&!c._validators.every(S=>S(l)))return false}return true}],o,i)},nonNull(){return e([...n,s=>s!=null],o,i)},hasKeys(...s){return e([...n,p=>s.every(m=>m in p)],o,i)},default(s){return e(n,s,i)},describe(s){return e(n,o,s)}});return e([n=>typeof n=="object"&&n!==null&&!Array.isArray(n)])},enum(...e){process.env.NODE_ENV!=="production"&&e.length===0&&console.warn("[Directive] t.enum() called with no values - this will reject all strings");let n=new Set(e);return ce([o=>typeof o=="string"&&n.has(o)],`enum(${e.join("|")})`)},literal(e){return ce([n=>n===e],`literal(${String(e)})`)},nullable(e){let n=e._typeName??"unknown";return Be([o=>o===null?true:e._validators.every(i=>i(o))],`${n} | null`)},optional(e){let n=e._typeName??"unknown";return Be([o=>o===void 0?true:e._validators.every(i=>i(o))],`${n} | undefined`)},union(...e){process.env.NODE_ENV!=="production"&&e.length===0&&console.warn("[Directive] t.union() called with no types - this will reject all values");let n=e.map(o=>o._typeName??"unknown");return ce([o=>e.some(i=>i._validators.every(y=>y(o)))],n.join(" | "))},record(e){let n=e._typeName??"unknown";return ce([o=>typeof o!="object"||o===null||Array.isArray(o)?false:Object.values(o).every(i=>e._validators.every(y=>y(i)))],`Record<string, ${n}>`)},tuple(...e){process.env.NODE_ENV!=="production"&&e.length===0&&console.warn("[Directive] t.tuple() called with no types - this will only accept empty arrays");let n=e.map(o=>o._typeName??"unknown");return ce([o=>!Array.isArray(o)||o.length!==e.length?false:e.every((i,y)=>i._validators.every(s=>s(o[y])))],`[${n.join(", ")}]`)},date(){return ce([e=>e instanceof Date&&!Number.isNaN(e.getTime())],"Date")},uuid(){let e=/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;return ce([n=>typeof n=="string"&&e.test(n)],"uuid")},email(){let e=/^[^\s@]+@[^\s@]+\.[^\s@]+$/;return ce([n=>typeof n=="string"&&e.test(n)],"email")},url(){return ce([e=>{if(typeof e!="string")return false;try{return new URL(e),!0}catch{return false}}],"url")},bigint(){return ce([e=>typeof e=="bigint"],"bigint")}};function ut(e,n){if(process.env.NODE_ENV!=="production"){!e||typeof e!="string"?console.warn("[Directive] Module ID must be a non-empty string"):/^(__[a-z][a-z0-9_-]*|[a-z][a-z0-9-]*)$/i.test(e)||console.warn(`[Directive] Module ID "${e}" should follow kebab-case convention (e.g., "my-module")`),n.schema?n.schema.facts||console.warn("[Directive] Module schema.facts is required"):console.warn("[Directive] Module schema is required");let i=n.schema?.derivations??{},y=n.derive??{},s=new Set(Object.keys(i)),p=new Set(Object.keys(y));for(let S of p)s.has(S)||console.warn(`[Directive] Derivation "${S}" not declared in schema.derivations`);for(let S of s)p.has(S)||console.warn(`[Directive] schema.derivations["${S}"] has no matching implementation in derive`);let m=n.schema?.events??{},f=n.events??{},l=new Set(Object.keys(m)),c=new Set(Object.keys(f));for(let S of c)l.has(S)||console.warn(`[Directive] Event "${S}" not declared in schema.events`);for(let S of l)c.has(S)||console.warn(`[Directive] schema.events["${S}"] has no matching handler in events`);if(n.snapshotEvents){n.snapshotEvents.length===0&&console.warn("[Directive] snapshotEvents is an empty array \u2014 no events will create time-travel snapshots. Omit snapshotEvents entirely to snapshot all events, or list specific events.");let S=new Set(Object.keys(n.schema?.events??{}));for(let w of n.snapshotEvents)S.has(w)||console.warn(`[Directive] snapshotEvents entry "${w}" not declared in schema.events. Available events: ${[...S].join(", ")||"(none)"}`);}if(n.resolvers&&n.schema?.requirements){let S=new Set(Object.keys(n.schema.requirements));for(let[w,j]of Object.entries(n.resolvers)){let _=j;typeof _.requirement=="string"&&!S.has(_.requirement)&&console.warn(`[Directive] Resolver "${w}" references unknown requirement type "${_.requirement}". Available types: ${[...S].join(", ")||"(none)"}`);}}}let o="crossModuleDeps"in n?n.crossModuleDeps:void 0;return {id:e,schema:n.schema,init:n.init,derive:n.derive??{},events:n.events??{},effects:n.effects,constraints:n.constraints,resolvers:n.resolvers,hooks:n.hooks,snapshotEvents:n.snapshotEvents,crossModuleDeps:o}}function Ft(e){return n=>ut(n,e)}async function Te(e,n,o){let i,y=new Promise((s,p)=>{i=setTimeout(()=>p(new Error(o)),n);});try{return await Promise.race([e,y])}finally{clearTimeout(i);}}function Ie(e,n=50){let o=new WeakSet;function i(y,s){if(s>n)return '"[max depth exceeded]"';if(y===null)return "null";if(y===void 0)return "undefined";let p=typeof y;if(p==="string")return JSON.stringify(y);if(p==="number"||p==="boolean")return String(y);if(p==="function")return '"[function]"';if(p==="symbol")return '"[symbol]"';if(Array.isArray(y)){if(o.has(y))return '"[circular]"';o.add(y);let m=`[${y.map(f=>i(f,s+1)).join(",")}]`;return o.delete(y),m}if(p==="object"){let m=y;if(o.has(m))return '"[circular]"';o.add(m);let c=`{${Object.keys(m).sort().map(S=>`${JSON.stringify(S)}:${i(m[S],s+1)}`).join(",")}}`;return o.delete(m),c}return '"[unknown]"'}return i(e,0)}function ke(e,n=50){let o=new Set(["__proto__","constructor","prototype"]),i=new WeakSet;function y(s,p){if(p>n)return false;if(s==null||typeof s!="object")return true;let m=s;if(i.has(m))return true;if(i.add(m),Array.isArray(m)){for(let f of m)if(!y(f,p+1))return i.delete(m),false;return i.delete(m),true}for(let f of Object.keys(m))if(o.has(f)||!y(m[f],p+1))return i.delete(m),false;return i.delete(m),true}return y(e,0)}function jt(e,n){if(e===n)return true;if(!e||!n)return false;let o=Object.keys(e),i=Object.keys(n);if(o.length!==i.length)return false;for(let y of o)if(e[y]!==n[y])return false;return true}function lt(e){let n=Ie(e),o=5381;for(let i=0;i<n.length;i++)o=(o<<5)+o^n.charCodeAt(i);return (o>>>0).toString(16)}function dt(e,n=Date.now()){return e.expiresAt!==void 0&&n>e.expiresAt}function _t(e,n=Date.now()){if(!e||typeof e!="object")throw new Error("[Directive] Invalid snapshot: expected an object with 'data' and 'createdAt' properties.");if(!("data"in e))throw new Error("[Directive] Invalid snapshot: missing required 'data' property.");if(!("createdAt"in e)||typeof e.createdAt!="number")throw new Error("[Directive] Invalid snapshot: missing or invalid 'createdAt' property (expected number).");if(dt(e,n)){let o=new Date(e.expiresAt).toISOString();throw new Error(`[Directive] Snapshot expired at ${o}. Obtain a fresh snapshot from the source.`)}return e.data}function Nt(e,n){let o=[];function i(s,p,m){if(s==null){p!=null&&o.push({path:m,oldValue:s,newValue:p,type:"added"});return}if(p==null){o.push({path:m,oldValue:s,newValue:p,type:"removed"});return}if(typeof s!="object"||typeof p!="object"){Object.is(s,p)||o.push({path:m,oldValue:s,newValue:p,type:"changed"});return}if(Array.isArray(s)&&Array.isArray(p)){if(s.length!==p.length){o.push({path:m,oldValue:s,newValue:p,type:"changed"});return}for(let S=0;S<s.length;S++)i(s[S],p[S],`${m}[${S}]`);return}let f=s,l=p,c=new Set([...Object.keys(f),...Object.keys(l)]);for(let S of c){let w=m?`${m}.${S}`:S;S in f?S in l?i(f[S],l[S],w):o.push({path:w,oldValue:f[S],newValue:void 0,type:"removed"}):o.push({path:w,oldValue:void 0,newValue:l[S],type:"added"});}}i(e.data,n.data,"");let y=e.version!==n.version&&(e.version!==void 0||n.version!==void 0);return {identical:o.length===0,changes:o,versionChanged:y,oldVersion:e.version,newVersion:n.version}}function Bt(e){return "signature"in e&&typeof e.signature=="string"}async function Kt(e,n){let o=Ie({data:e.data,createdAt:e.createdAt,expiresAt:e.expiresAt,version:e.version,metadata:e.metadata}),i=await ft(o,n);return {...e,signature:i,algorithm:"hmac-sha256"}}async function Wt(e,n){if(!e.signature||e.algorithm!=="hmac-sha256")return false;let o=Ie({data:e.data,createdAt:e.createdAt,expiresAt:e.expiresAt,version:e.version,metadata:e.metadata}),i=await ft(o,n);return Vt(e.signature,i)}async function ft(e,n){let o=typeof n=="string"?new TextEncoder().encode(n):n,i={name:"HMAC",hash:{name:"SHA-256"}},y=await crypto.subtle.importKey("raw",o,i,false,["sign"]),s=new TextEncoder().encode(e),p=await crypto.subtle.sign("HMAC",y,s);return Array.from(new Uint8Array(p)).map(m=>m.toString(16).padStart(2,"0")).join("")}function Vt(e,n){if(e.length!==n.length)return false;let o=0;for(let i=0;i<e.length;i++)o|=e.charCodeAt(i)^n.charCodeAt(i);return o===0}function Ve(e){let{config:n,facts:o,store:i,onSnapshot:y,onTimeTravel:s}=e,p=n.timeTravel??false,m=n.maxSnapshots??100,f=[],l=-1,c=1,S=false,w=false,j=[],_=null,Q=-1;function G(){return i.toObject()}function x(){let O=G();return structuredClone(O)}function D(O){if(!ke(O)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}i.batch(()=>{for(let[g,M]of Object.entries(O)){if(g==="__proto__"||g==="constructor"||g==="prototype"){console.warn(`[Directive] Skipping dangerous key "${g}" during fact restoration`);continue}o[g]=M;}});}return {get isEnabled(){return p},get isRestoring(){return w},get isPaused(){return S},get snapshots(){return [...f]},get currentIndex(){return l},takeSnapshot(O){if(!p||S)return {id:-1,timestamp:Date.now(),facts:{},trigger:O};let g={id:c++,timestamp:Date.now(),facts:x(),trigger:O};for(l<f.length-1&&f.splice(l+1),f.push(g),l=f.length-1;f.length>m;)f.shift(),l--;return y?.(g),g},restore(O){if(p){S=true,w=true;try{D(O.facts);}finally{S=false,w=false;}}},goBack(O=1){if(!p||f.length===0)return;let g=l,M=l,u=j.find(C=>l>C.startIndex&&l<=C.endIndex);if(u)M=u.startIndex;else if(j.find(F=>l===F.startIndex)){let F=j.find(B=>B.endIndex<l&&l-B.endIndex<=O);M=F?F.startIndex:Math.max(0,l-O);}else M=Math.max(0,l-O);if(g===M)return;l=M;let k=f[l];k&&(this.restore(k),s?.(g,M));},goForward(O=1){if(!p||f.length===0)return;let g=l,M=l,u=j.find(C=>l>=C.startIndex&&l<C.endIndex);if(u?M=u.endIndex:M=Math.min(f.length-1,l+O),g===M)return;l=M;let k=f[l];k&&(this.restore(k),s?.(g,M));},goTo(O){if(!p)return;let g=f.findIndex(k=>k.id===O);if(g===-1){console.warn(`[Directive] Snapshot ${O} not found`);return}let M=l;l=g;let u=f[l];u&&(this.restore(u),s?.(M,g));},replay(){if(!p||f.length===0)return;l=0;let O=f[0];O&&this.restore(O);},export(){return JSON.stringify({version:1,snapshots:f,currentIndex:l})},import(O){if(p)try{let g=JSON.parse(O);if(typeof g!="object"||g===null)throw new Error("Invalid time-travel data: expected object");if(g.version!==1)throw new Error(`Unsupported time-travel export version: ${g.version}`);if(!Array.isArray(g.snapshots))throw new Error("Invalid time-travel data: snapshots must be an array");if(typeof g.currentIndex!="number")throw new Error("Invalid time-travel data: currentIndex must be a number");for(let u of g.snapshots){if(typeof u!="object"||u===null)throw new Error("Invalid snapshot: expected object");if(typeof u.id!="number"||typeof u.timestamp!="number"||typeof u.trigger!="string"||typeof u.facts!="object")throw new Error("Invalid snapshot structure");if(!ke(u.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}f.length=0,f.push(...g.snapshots),l=g.currentIndex;let M=f[l];M&&this.restore(M);}catch(g){console.error("[Directive] Failed to import time-travel data:",g);}},beginChangeset(O){p&&(_=O,Q=l);},endChangeset(){!p||_===null||(l>Q&&j.push({label:_,startIndex:Q,endIndex:l}),_=null,Q=-1);},pause(){S=true;},resume(){S=false;}}}function ze(){let e={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>e,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var gt=new WeakMap;function mt(e,n){if(n)return n(e);let o=gt.get(e);if(o!==void 0)return o;let{type:i,...y}=e,s=Ie(y),p=`${i}:${s}`;return gt.set(e,p),p}function Ue(e,n,o){return {requirement:e,id:mt(e,o),fromConstraint:n}}function zt(e){return n=>({type:e,...n})}function Ut(e,n){return e.type===n}function Lt(e){return n=>n.type===e}var De=class e{map=new Map;add(n){this.map.has(n.id)||this.map.set(n.id,n);}remove(n){return this.map.delete(n)}has(n){return this.map.has(n)}get(n){return this.map.get(n)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let n=new e;for(let o of this.map.values())n.add(o);return n}diff(n){let o=[],i=[],y=[];for(let s of this.map.values())n.has(s.id)?y.push(s):o.push(s);for(let s of n.map.values())this.map.has(s.id)||i.push(s);return {added:o,removed:i,unchanged:y}}};var Me=[];function Ht(){let e=new Set;return {get isTracking(){return true},track(n){e.add(n);},getDependencies(){return e}}}var Jt={isTracking:false,track(){},getDependencies(){return new Set}};function yt(){return Me[Me.length-1]??Jt}function Xt(){return Me.length>0}function Ee(e){let n=Ht();Me.push(n);try{return {value:e(),deps:n.getDependencies()}}finally{Me.pop();}}function Ke(e){let n=Me.splice(0,Me.length);try{return e()}finally{for(let o of n)Me.push(o);}}function $e(e){yt().track(e);}var Z=Object.freeze(new Set(["__proto__","constructor","prototype"]));var Gt=5e3;function Le(e){let{definitions:n,facts:o,requirementKeys:i={},defaultTimeout:y=Gt,onEvaluate:s,onError:p}=e,m=new Map,f=new Set,l=new Set,c=new Map,S=new Map,w=new Set,j=new Map,_=new Map,Q=false,G=new Set,x=new Set,D=new Map,V=[],O=new Map;function g(){D.clear();for(let[d,b]of Object.entries(n))if(b.after)for(let R of b.after)n[R]&&(D.has(R)||D.set(R,new Set),D.get(R).add(d));}function M(){let d=new Set,b=new Set,R=[];function q(K,L){if(d.has(K))return;if(b.has(K)){let de=L.indexOf(K),H=[...L.slice(de),K].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${H}. Remove one of the \`after\` dependencies to break the cycle.`)}b.add(K),L.push(K);let ue=n[K];if(ue?.after)for(let de of ue.after)n[de]&&q(de,L);L.pop(),b.delete(K),d.add(K),R.push(K);}for(let K of Object.keys(n))q(K,[]);V=R,O=new Map(V.map((K,L)=>[K,L]));}if(M(),g(),process.env.NODE_ENV!=="production"){for(let[d,b]of Object.entries(n))if(b.after)for(let R of b.after)n[R]||console.warn(`[Directive] Constraint "${d}" references unknown constraint "${R}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function u(d,b){return b.async!==void 0?b.async:!!l.has(d)}function k(d){let b=n[d];if(!b)throw new Error(`[Directive] Unknown constraint: ${d}`);let R=u(d,b);R&&l.add(d);let q={id:d,priority:b.priority??0,isAsync:R,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:b.after??[],hitCount:0,lastActiveAt:null};return m.set(d,q),q}function C(d){return m.get(d)??k(d)}function F(d,b){let R=c.get(d)??new Set;if(R.size===b.size&&R.size>0){let q=true;for(let K of b)if(!R.has(K)){q=false;break}if(q)return}for(let q of R){let K=S.get(q);K?.delete(d),K&&K.size===0&&S.delete(q);}for(let q of b)S.has(q)||S.set(q,new Set),S.get(q).add(d);c.set(d,b);}function B(d){let b=n[d];if(!b)return false;let R=C(d);R.isEvaluating=true,R.error=null;try{let q;if(b.deps)q=b.when(o),j.set(d,new Set(b.deps));else {let K=Ee(()=>b.when(o));q=K.value,j.set(d,K.deps);}return q instanceof Promise?(l.add(d),R.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${d}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),q.then(K=>(R.lastResult=K,K&&(R.hitCount++,R.lastActiveAt=Date.now()),R.isEvaluating=!1,s?.(d,K),K)).catch(K=>(R.error=K instanceof Error?K:new Error(String(K)),R.lastResult=!1,R.isEvaluating=!1,p?.(d,K),!1))):(R.lastResult=q,q&&(R.hitCount++,R.lastActiveAt=Date.now()),R.isEvaluating=!1,s?.(d,q),q)}catch(q){return R.error=q instanceof Error?q:new Error(String(q)),R.lastResult=false,R.isEvaluating=false,p?.(d,q),false}}async function a(d){let b=n[d];if(!b)return false;let R=C(d),q=b.timeout??y;if(R.isEvaluating=true,R.error=null,b.deps?.length){let K=new Set(b.deps);F(d,K),j.set(d,K);}try{let K=b.when(o),L=await Te(K,q,`Constraint "${d}" timed out after ${q}ms`);return R.lastResult=L,L&&(R.hitCount++,R.lastActiveAt=Date.now()),R.isEvaluating=!1,s?.(d,L),L}catch(K){return R.error=K instanceof Error?K:new Error(String(K)),R.lastResult=false,R.isEvaluating=false,p?.(d,K),false}}let v=10;function E(d,b){if(d==null)return [];if(Array.isArray(d)){let R=d.filter(q=>q!=null);return process.env.NODE_ENV!=="production"&&R.length>v&&b&&console.warn(`[Directive] Constraint "${b}" produced ${R.length} requirements. Consider splitting into multiple constraints for better performance.`),R}return [d]}function $(d){let b=n[d];if(!b)return {requirements:[],deps:new Set};let R=b.require;if(typeof R=="function"){let{value:K,deps:L}=Ee(()=>R(o));return {requirements:E(K,d),deps:L}}return {requirements:E(R,d),deps:new Set}}function A(d,b){if(b.size===0)return;let R=c.get(d)??new Set;for(let q of b)R.add(q),S.has(q)||S.set(q,new Set),S.get(q).add(d);c.set(d,R);}let z=null;function T(){return z||(z=Object.keys(n).sort((d,b)=>{let R=C(d),K=C(b).priority-R.priority;if(K!==0)return K;let L=O.get(d)??0,ue=O.get(b)??0;return L-ue})),z}for(let d of Object.keys(n))k(d);if(process.env.NODE_ENV!=="production")for(let[d,b]of Object.entries(n))b.async&&!b.deps&&console.warn(`[Directive] Async constraint "${d}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function W(d){let b=m.get(d);if(!b||b.after.length===0)return true;for(let R of b.after)if(n[R]&&!f.has(R)&&!x.has(R)&&!G.has(R))return false;return true}return {async evaluate(d){let b=new De;x.clear();let R=T().filter(H=>!f.has(H)),q;if(!Q||!d||d.size===0)q=R,Q=true;else {let H=new Set;for(let se of d){let re=S.get(se);if(re)for(let ye of re)f.has(ye)||H.add(ye);}for(let se of w)f.has(se)||H.add(se);w.clear(),q=[...H];for(let se of R)if(!H.has(se)){let re=_.get(se);if(re)for(let ye of re)b.add(ye);}}function K(H,se){if(f.has(H))return;let re=j.get(H);if(!se){re!==void 0&&F(H,re),x.add(H),_.set(H,[]);return}x.delete(H);let ye,pe;try{let I=$(H);ye=I.requirements,pe=I.deps;}catch(I){p?.(H,I),re!==void 0&&F(H,re),_.set(H,[]);return}if(re!==void 0){let I=new Set(re);for(let Y of pe)I.add(Y);F(H,I);}else A(H,pe);if(ye.length>0){let I=i[H],Y=ye.map(ee=>Ue(ee,H,I));for(let ee of Y)b.add(ee);_.set(H,Y);}else _.set(H,[]);}async function L(H){let se=[],re=[];for(let Y of H)if(W(Y))re.push(Y);else {se.push(Y);let ee=_.get(Y);if(ee)for(let ve of ee)b.add(ve);}if(re.length===0)return se;let ye=[],pe=[];for(let Y of re)C(Y).isAsync?pe.push(Y):ye.push(Y);let I=[];for(let Y of ye){let ee=B(Y);if(ee instanceof Promise){I.push({id:Y,promise:ee});continue}K(Y,ee);}if(I.length>0){let Y=await Promise.all(I.map(async({id:ee,promise:ve})=>({id:ee,active:await ve})));for(let{id:ee,active:ve}of Y)K(ee,ve);}if(pe.length>0){let Y=await Promise.all(pe.map(async ee=>({id:ee,active:await a(ee)})));for(let{id:ee,active:ve}of Y)K(ee,ve);}return se}let ue=q,de=q.length+1;for(;ue.length>0&&de>0;){let H=ue.length;if(ue=await L(ue),ue.length===H)break;de--;}return b.all()},getState(d){return m.get(d)},getDependencies(d){return c.get(d)},getAllStates(){return [...m.values()]},disable(d){if(!m.has(d)){console.warn(`[Directive] constraints.disable("${d}") \u2014 no such constraint`);return}f.add(d),z=null,_.delete(d);let b=c.get(d);if(b){for(let R of b){let q=S.get(R);q&&(q.delete(d),q.size===0&&S.delete(R));}c.delete(d);}j.delete(d);},enable(d){if(!m.has(d)){console.warn(`[Directive] constraints.enable("${d}") \u2014 no such constraint`);return}f.delete(d),z=null,w.add(d);},isDisabled(d){return f.has(d)},invalidate(d){let b=S.get(d);if(b)for(let R of b)w.add(R);},markResolved(d){G.add(d);let b=m.get(d);b&&(b.lastResolvedAt=Date.now());let R=D.get(d);if(R)for(let q of R)w.add(q);},isResolved(d){return G.has(d)},registerDefinitions(d){let b=false;for(let[R,q]of Object.entries(d))n[R]=q,k(R),w.add(R),q.after?.length&&(b=true);z=null,b&&M(),g();},assignDefinition(d,b){if(!n[d])throw new Error(`[Directive] Cannot assign constraint "${d}" \u2014 it does not exist. Use register() to create it.`);n[d]=b,k(d),w.add(d),z=null,M(),g();},unregisterDefinition(d){if(!n[d])return;delete n[d],m.delete(d),f.delete(d),l.delete(d),w.delete(d),x.delete(d),G.delete(d),_.delete(d),j.delete(d);let b=c.get(d);if(b){for(let R of b){let q=S.get(R);q&&(q.delete(d),q.size===0&&S.delete(R));}c.delete(d);}D.delete(d);for(let R of D.values())R.delete(d);z=null,M(),g();},async callOne(d,b){if(!n[d])throw new Error(`[Directive] Cannot call constraint "${d}" \u2014 it does not exist.`);if(f.has(d))return [];let q=C(d),K;if(q.isAsync)K=await a(d);else {let H=B(d);K=H instanceof Promise?await H:H;}if(!K)return [];let{requirements:L}=$(d);if(L.length===0)return [];let ue=i[d],de=[];for(let H of L){let se=b?{...H,...b}:H;de.push(Ue(se,d,ue));}return de}}}function He(e){let{definitions:n,facts:o,store:i,onCompute:y,onInvalidate:s,onError:p}=e,m=new Map,f=new Map,l=new Map,c=new Map,S=0,w=new Set,j=false,_=100,Q;function G(u){if(!n[u])throw new Error(`[Directive] Unknown derivation: ${u}`);let C={id:u,compute:()=>D(u),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return m.set(u,C),C}function x(u){return m.get(u)??G(u)}function D(u){let k=x(u),C=n[u];if(!C)throw new Error(`[Directive] Unknown derivation: ${u}`);if(k.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${u}`);k.isComputing=true;try{let F=k.cachedValue,{value:B,deps:a}=Ee(()=>C(o,Q));return k.cachedValue=B,k.isStale=!1,V(u,a),y?.(u,B,F,[...a]),B}catch(F){throw p?.(u,F),F}finally{k.isComputing=false;}}function V(u,k){let C=x(u),F=C.dependencies;if(F.size===k.size){let B=true;for(let a of k)if(!F.has(a)){B=false;break}if(B)return}for(let B of F)if(m.has(B)){let a=c.get(B);a?.delete(u),a&&a.size===0&&c.delete(B);}else {let a=l.get(B);a?.delete(u),a&&a.size===0&&l.delete(B);}for(let B of k)n[B]?(c.has(B)||c.set(B,new Set),c.get(B).add(u)):(l.has(B)||l.set(B,new Set),l.get(B).add(u));C.dependencies=k;}function O(){if(!(S>0||j)){j=true;try{let u=0;for(;w.size>0;){if(++u>_){let C=[...w];throw w.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${_} iterations. Remaining: ${C.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let k=[...w];w.clear();for(let C of k)f.get(C)?.forEach(F=>F());}}finally{j=false;}}}function g(u,k=new Set){let C=[u];for(;C.length>0;){let F=C.pop();if(k.has(F))continue;k.add(F);let B=m.get(F);if(!B||B.isStale)continue;B.isStale=true,s?.(F),w.add(F);let a=c.get(F);if(a)for(let v of a)C.push(v);}}return Q=new Proxy({},{get(u,k){if(typeof k=="symbol"||Z.has(k)||!n[k])return;$e(k);let C=x(k);return C.isStale&&D(k),C.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(u){let k=x(u);return k.isStale&&D(u),k.cachedValue},isStale(u){return m.get(u)?.isStale??true},invalidate(u){let k=l.get(u);if(!k)return;S++;let C=new Set;try{for(let F of k)g(F,C);}finally{S--,O();}},invalidateMany(u){S++;let k=new Set;try{for(let C of u){let F=l.get(C);if(F)for(let B of F)g(B,k);}}finally{S--,O();}},invalidateAll(){S++;try{for(let u of m.values())u.isStale||(u.isStale=!0,w.add(u.id));}finally{S--,O();}},subscribe(u,k){for(let C of u){let F=C;f.has(F)||f.set(F,new Set),f.get(F).add(k);}return ()=>{for(let C of u){let F=C,B=f.get(F);B?.delete(k),B&&B.size===0&&f.delete(F);}}},getProxy(){return Q},getDependencies(u){return x(u).dependencies},registerDefinitions(u){for(let[k,C]of Object.entries(u))n[k]=C,G(k);},assignDefinition(u,k){if(!n[u])throw new Error(`[Directive] Cannot assign derivation "${u}" \u2014 it does not exist. Use register() to create it.`);n[u]=k;let C=m.get(u);C&&(C.isStale=true,w.add(u)),O();},unregisterDefinition(u){if(!n[u])return;let k=m.get(u);if(k)for(let F of k.dependencies)if(m.has(F)){let B=c.get(F);B?.delete(u),B&&B.size===0&&c.delete(F);}else {let B=l.get(F);B?.delete(u),B&&B.size===0&&l.delete(F);}let C=c.get(u);if(C){S++;try{for(let F of C)g(F);}finally{S--;}c.delete(u);}delete n[u],m.delete(u),f.delete(u),w.delete(u),O();},callOne(u){if(!n[u])throw new Error(`[Directive] Cannot call derivation "${u}" \u2014 it does not exist.`);return D(u)}}}var Yt=3;function Je(e){let{definitions:n,facts:o,store:i,onRun:y,onError:s}=e,p=new Map,m=null,f=false;function l(x){let D=n[x];if(!D)throw new Error(`[Directive] Unknown effect: ${x}`);let V={id:x,enabled:true,hasExplicitDeps:!!D.deps,dependencies:D.deps?new Set(D.deps):null,cleanup:null,stableRunCount:0,depsStable:false};return p.set(x,V),V}function c(x){return p.get(x)??l(x)}function S(){return i.toObject()}function w(x,D){let V=c(x);if(!V.enabled)return false;if(V.dependencies){for(let O of V.dependencies)if(D.has(O))return V.depsStable&&(V.depsStable=false,V.stableRunCount=0),true;return false}return true}function j(x){if(x.cleanup){try{x.cleanup();}catch(D){s?.(x.id,D),console.error(`[Directive] Effect "${x.id}" cleanup threw an error:`,D);}x.cleanup=null;}}function _(x,D){if(typeof D=="function")if(f)try{D();}catch(V){s?.(x.id,V),console.error(`[Directive] Effect "${x.id}" cleanup threw an error:`,V);}else x.cleanup=D;}async function Q(x){let D=c(x),V=n[x];if(!(!D.enabled||!V)){j(D),y?.(x,D.dependencies?[...D.dependencies]:[]);try{if(D.hasExplicitDeps){let O;if(i.batch(()=>{O=V.run(o,m);}),O instanceof Promise){let g=await O;_(D,g);}else _(D,O);}else if(D.depsStable&&D.dependencies){let O;if(i.batch(()=>{O=V.run(o,m);}),O instanceof Promise){let g=await O;_(D,g);}else _(D,O);}else {let O,g=Ee(()=>(i.batch(()=>{O=V.run(o,m);}),O)),M=g.deps,u=g.value;if(u instanceof Promise&&(u=await u),_(D,u),D.dependencies&&M.size===D.dependencies.size){let k=!0;for(let C of M)if(!D.dependencies.has(C)){k=!1;break}k?(D.stableRunCount++,D.stableRunCount>=Yt&&(D.depsStable=!0)):(D.stableRunCount=0,D.depsStable=!1);}else D.stableRunCount=0,D.depsStable=!1;D.dependencies=M.size>0?M:null;}}catch(O){s?.(x,O),console.error(`[Directive] Effect "${x}" threw an error:`,O),D.hasExplicitDeps||(D.stableRunCount=0,D.depsStable=false);}}}for(let x of Object.keys(n))l(x);return {async runEffects(x){let D=[];for(let V of Object.keys(n))w(V,x)&&D.push(V);await Promise.all(D.map(Q)),m=S();},async runAll(){let x=Object.keys(n);await Promise.all(x.map(D=>{let V=c(D);return V.enabled?(V.depsStable=false,V.stableRunCount=0,Q(D)):Promise.resolve()})),m=S();},disable(x){let D=c(x);D.enabled=false;},enable(x){let D=c(x);D.enabled=true;},isEnabled(x){return c(x).enabled},cleanupAll(){f=true;for(let x of p.values())j(x);},registerDefinitions(x){for(let[D,V]of Object.entries(x))n[D]=V,l(D);},assignDefinition(x,D){if(!n[x])throw new Error(`[Directive] Cannot assign effect "${x}" \u2014 it does not exist. Use register() to create it.`);let V=p.get(x);V&&j(V),n[x]=D,l(x);},unregisterDefinition(x){if(!n[x])return;let D=p.get(x);D&&j(D),delete n[x],p.delete(x);},async callOne(x){let D=n[x];if(!D)throw new Error(`[Directive] Cannot call effect "${x}" \u2014 it does not exist.`);let V=c(x);if(V.enabled){j(V),y?.(x,V.dependencies?[...V.dependencies]:[]);try{let O;if(i.batch(()=>{O=D.run(o,m);}),O instanceof Promise){let g=await O;_(V,g);}else _(V,O);}catch(O){s?.(x,O),console.error(`[Directive] Effect "${x}" threw an error:`,O);}}}}}function pt(e={}){let{delayMs:n=1e3,maxRetries:o=3,backoffMultiplier:i=2,maxDelayMs:y=3e4}=e,s=new Map;function p(m){let f=n*i**(m-1);return Math.min(f,y)}return {scheduleRetry(m,f,l,c,S){if(c>o)return null;let w=p(c),j={source:m,sourceId:f,context:l,attempt:c,nextRetryTime:Date.now()+w,callback:S};return s.set(f,j),j},getPendingRetries(){return Array.from(s.values())},processDueRetries(){let m=Date.now(),f=[];for(let[l,c]of s)c.nextRetryTime<=m&&(f.push(c),s.delete(l));return f},cancelRetry(m){s.delete(m);},clearAll(){s.clear();}}}var Zt={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function Xe(e={}){let{config:n={},onError:o,onRecovery:i}=e,y=[],s=100,p=pt(n.retryLater),m=new Map,f=1e3;function l(w,j,_,Q){if(_ instanceof xe)return _;let G=_ instanceof Error?_.message:String(_),x=w!=="system";return new xe(G,w,j,Q,x)}function c(w,j,_){let Q=(()=>{switch(w){case "constraint":return n.onConstraintError;case "resolver":return n.onResolverError;case "effect":return n.onEffectError;case "derivation":return n.onDerivationError;default:return}})();if(typeof Q=="function"){try{let G=Q(_,j);if(typeof G=="string")return G}catch(G){console.error("[Directive] Error in error handler callback:",G);}return "skip"}return typeof Q=="string"?Q:Zt[w]}return {handleError(w,j,_,Q){let G=l(w,j,_,Q);y.push(G),y.length>s&&y.shift();try{o?.(G);}catch(D){console.error("[Directive] Error in onError callback:",D);}try{n.onError?.(G);}catch(D){console.error("[Directive] Error in config.onError callback:",D);}let x=c(w,j,_ instanceof Error?_:new Error(String(_)));if(x==="retry-later"){let D=(m.get(j)??0)+1;if(m.set(j,D),m.size>f){let O=m.keys().next().value;O!==void 0&&m.delete(O);}p.scheduleRetry(w,j,Q,D)||(x="skip",m.delete(j),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${w} "${j}" exceeded max retry-later attempts. Skipping.`));}try{i?.(G,x);}catch(D){console.error("[Directive] Error in onRecovery callback:",D);}if(x==="throw")throw G;return x},getLastError(){return y[y.length-1]??null},getAllErrors(){return [...y]},clearErrors(){y.length=0;},getRetryLaterManager(){return p},processDueRetries(){return p.processDueRetries()},clearRetryAttempts(w){m.delete(w),p.cancelRetry(w);}}}function Qt(e,n=100){try{return JSON.stringify(e)?.slice(0,n)??String(e)}catch{return "[circular or non-serializable]"}}function ht(e){let{schema:n,onChange:o,onBatch:i}=e,s=Object.keys(n).length===0,p=e.validate??process.env.NODE_ENV!=="production",m=e.strictKeys??(process.env.NODE_ENV!=="production"&&!s),f=e.redactErrors??false,l=new Map,c=new Set,S=new Map,w=new Set,j=0,_=[],Q=new Set,G=false,x=[],D=100;function V(a){return a!==null&&typeof a=="object"&&"safeParse"in a&&typeof a.safeParse=="function"&&"_def"in a&&"parse"in a&&typeof a.parse=="function"}function O(a){let v=a;if(v._typeName)return v._typeName;if(V(a)){let E=a._def;if(E?.typeName)return E.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function g(a){return f?"[redacted]":Qt(a)}function M(a,v){if(!p)return;let E=n[a];if(!E){if(m)throw new Error(`[Directive] Unknown fact key: "${a}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${a}"`);return}if(V(E)){let T=E.safeParse(v);if(!T.success){let W=v===null?"null":Array.isArray(v)?"array":typeof v,N=g(v),d=T.error?.message??T.error?.issues?.[0]?.message??"Validation failed",b=O(E);throw new Error(`[Directive] Validation failed for "${a}": expected ${b}, got ${W} ${N}. ${d}`)}return}let $=E,A=$._validators;if(!A||!Array.isArray(A)||A.length===0)return;let z=$._typeName??"unknown";for(let T=0;T<A.length;T++){let W=A[T];if(typeof W=="function"&&!W(v)){let N=v===null?"null":Array.isArray(v)?"array":typeof v,d=g(v),b="";typeof $._lastFailedIndex=="number"&&$._lastFailedIndex>=0&&(b=` (element at index ${$._lastFailedIndex} failed)`,$._lastFailedIndex=-1);let R=T===0?"":` (validator ${T+1} failed)`;throw new Error(`[Directive] Validation failed for "${a}": expected ${z}, got ${N} ${d}${R}${b}`)}}}function u(a){S.get(a)?.forEach(v=>v());}function k(){w.forEach(a=>a());}function C(a,v,E){if(G){x.push({key:a,value:v,prev:E});return}G=true;try{o?.(a,v,E),u(a),k();let $=0;for(;x.length>0;){if(++$>D)throw x.length=0,new Error(`[Directive] Infinite notification loop detected after ${D} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let A=[...x];x.length=0;for(let z of A)o?.(z.key,z.value,z.prev),u(z.key);k();}}finally{G=false;}}function F(){if(!(j>0)){if(i&&_.length>0&&i([..._]),Q.size>0){G=true;try{for(let v of Q)u(v);k();let a=0;for(;x.length>0;){if(++a>D)throw x.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${D} iterations.`);let v=[...x];x.length=0;for(let E of v)o?.(E.key,E.value,E.prev),u(E.key);k();}}finally{G=false;}}_.length=0,Q.clear();}}let B={get(a){return $e(a),l.get(a)},has(a){return $e(a),l.has(a)},set(a,v){M(a,v);let E=l.get(a);Object.is(E,v)||(l.set(a,v),c.add(a),j>0?(_.push({key:a,value:v,prev:E,type:"set"}),Q.add(a)):C(a,v,E));},delete(a){let v=l.get(a);l.delete(a),c.delete(a),j>0?(_.push({key:a,value:void 0,prev:v,type:"delete"}),Q.add(a)):C(a,void 0,v);},batch(a){j++;try{a();}finally{j--,F();}},subscribe(a,v){for(let E of a){let $=E;S.has($)||S.set($,new Set),S.get($).add(v);}return ()=>{for(let E of a){let $=S.get(E);$&&($.delete(v),$.size===0&&S.delete(E));}}},subscribeAll(a){return w.add(a),()=>w.delete(a)},toObject(){let a={};for(let v of c)l.has(v)&&(a[v]=l.get(v));return a}};return B.destroy=()=>{S.clear(),w.clear();},B.registerKeys=a=>{for(let v of Object.keys(a))Z.has(v)||(n[v]=a[v],c.add(v));},B}function vt(e,n){let o=()=>({get:y=>Ke(()=>e.get(y)),has:y=>Ke(()=>e.has(y))});return new Proxy({},{get(y,s){if(s==="$store")return e;if(s==="$snapshot")return o;if(typeof s!="symbol"&&!Z.has(s))return e.get(s)},set(y,s,p){return typeof s=="symbol"||s==="$store"||s==="$snapshot"||Z.has(s)?false:(e.set(s,p),true)},deleteProperty(y,s){return typeof s=="symbol"||s==="$store"||s==="$snapshot"||Z.has(s)?false:(e.delete(s),true)},has(y,s){return s==="$store"||s==="$snapshot"?true:typeof s=="symbol"||Z.has(s)?false:e.has(s)},ownKeys(){return Object.keys(n)},getOwnPropertyDescriptor(y,s){return s==="$store"||s==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Ge(e){let n=ht(e),o=vt(n,e.schema);return {store:n,facts:o}}function Ye(){let e=[];function n(s){if(s)try{return s()}catch(p){console.error("[Directive] Plugin error:",p);return}}async function o(s){if(s)try{return await s()}catch(p){console.error("[Directive] Plugin error:",p);return}}function i(s){return (...p)=>{for(let m of e)n(()=>m[s]?.(...p));}}return {register(s){e.some(p=>p.name===s.name)&&(console.warn(`[Directive] Plugin "${s.name}" is already registered, replacing...`),this.unregister(s.name)),e.push(s);},unregister(s){let p=e.findIndex(m=>m.name===s);p!==-1&&e.splice(p,1);},getPlugins(){return [...e]},async emitInit(s){for(let p of e)await o(()=>p.onInit?.(s));},emitStart:i("onStart"),emitStop:i("onStop"),emitDestroy:i("onDestroy"),emitFactSet:i("onFactSet"),emitFactDelete:i("onFactDelete"),emitFactsBatch:i("onFactsBatch"),emitDerivationCompute:i("onDerivationCompute"),emitDerivationInvalidate:i("onDerivationInvalidate"),emitReconcileStart:i("onReconcileStart"),emitReconcileEnd:i("onReconcileEnd"),emitConstraintEvaluate:i("onConstraintEvaluate"),emitConstraintError:i("onConstraintError"),emitRequirementCreated:i("onRequirementCreated"),emitRequirementMet:i("onRequirementMet"),emitRequirementCanceled:i("onRequirementCanceled"),emitResolverStart:i("onResolverStart"),emitResolverComplete:i("onResolverComplete"),emitResolverError:i("onResolverError"),emitResolverRetry:i("onResolverRetry"),emitResolverCancel:i("onResolverCancel"),emitEffectRun:i("onEffectRun"),emitEffectError:i("onEffectError"),emitSnapshot:i("onSnapshot"),emitTimeTravel:i("onTimeTravel"),emitError:i("onError"),emitErrorRecovery:i("onErrorRecovery"),emitDefinitionRegister:i("onDefinitionRegister"),emitDefinitionAssign:i("onDefinitionAssign"),emitDefinitionUnregister:i("onDefinitionUnregister"),emitDefinitionCall:i("onDefinitionCall"),emitRunComplete:i("onRunComplete")}}var St={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},bt={enabled:false,windowMs:50};function en(e,n){let{backoff:o,initialDelay:i=100,maxDelay:y=3e4}=e,s;switch(o){case "none":s=i;break;case "linear":s=i*n;break;case "exponential":s=i*2**(n-1);break;default:s=i;}return Math.max(1,Math.min(s,y))}function Ze(e){let{definitions:n,facts:o,store:i,onStart:y,onComplete:s,onError:p,onRetry:m,onCancel:f,onResolutionComplete:l}=e;if(process.env.NODE_ENV!=="production")for(let[a,v]of Object.entries(n)){if(!v.resolve&&!v.resolveBatch&&!v.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${a}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(v.batch?.enabled&&!v.resolveBatch&&!v.resolveBatchWithResults)if(v.resolve)console.warn(`[Directive] Resolver "${a}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${a}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let c=new Map,S=new Map,w=1e3,j=new Map,_=new Map,Q=1e3;function G(){if(S.size>w){let a=S.size-w,v=S.keys();for(let E=0;E<a;E++){let $=v.next().value;$&&S.delete($);}}}function x(a){return typeof a=="object"&&a!==null&&"requirement"in a&&typeof a.requirement=="string"}function D(a){return typeof a=="object"&&a!==null&&"requirement"in a&&typeof a.requirement=="function"}function V(a,v){return x(a)?v.type===a.requirement:D(a)?a.requirement(v):false}function O(a){let v=a.type,E=_.get(v);if(E){_.delete(v),_.set(v,E);for(let $ of E){let A=n[$];if(A&&V(A,a))return $}}for(let[$,A]of Object.entries(n))if(V(A,a)){if(!_.has(v)){if(_.size>=Q){let z=_.keys().next().value;z!==void 0&&_.delete(z);}_.set(v,new Set);}return _.get(v).add($),$}return null}function g(a){return {facts:o,signal:a,snapshot:()=>o.$snapshot()}}async function M(a,v,E,$){let A=a instanceof Error?a:new Error(String(a));if($.signal.aborted)return {action:"abort",error:A};if(E.shouldRetry&&!E.shouldRetry(A,v))return {action:"break",error:A};if(v<E.attempts){if($.signal.aborted)return {action:"abort",error:A};let z=en(E,v);if(await new Promise(T=>{let W=setTimeout(T,z),N=()=>{clearTimeout(W),T();};$.signal.addEventListener("abort",N,{once:true});}),$.signal.aborted)return {action:"abort",error:A}}return {action:"continue",error:A}}async function u(a,v,E){let $=n[a];if(!$)return;let A={...St,...$.retry},z=null;for(let T=1;T<=A.attempts;T++){if(E.signal.aborted)return;let W=c.get(v.id);W&&(W.attempt=T,W.status={state:"running",requirementId:v.id,startedAt:W.startedAt,attempt:T});try{let N=g(E.signal);if($.resolve){let b;i.batch(()=>{b=$.resolve(v.requirement,N);});let R=$.timeout;R&&R>0?await Te(b,R,`Resolver "${a}" timed out after ${R}ms`):await b;}let d=Date.now()-(W?.startedAt??Date.now());S.set(v.id,{state:"success",requirementId:v.id,completedAt:Date.now(),duration:d}),G(),s?.(a,v,d);return}catch(N){let d=await M(N,T,A,E);if(z=d.error,d.action==="abort")return;if(d.action==="break")break;T<A.attempts&&m?.(a,v,T+1);}}S.set(v.id,{state:"error",requirementId:v.id,error:z,failedAt:Date.now(),attempts:A.attempts}),G(),p?.(a,v,z);}async function k(a,v){let E=n[a];if(!E)return;if(!E.resolveBatch&&!E.resolveBatchWithResults){await Promise.all(v.map(d=>{let b=new AbortController;return u(a,d,b)}));return}let $={...St,...E.retry},A={...bt,...E.batch},z=new AbortController,T=Date.now(),W=null,N=A.timeoutMs??E.timeout;for(let d=1;d<=$.attempts;d++){if(z.signal.aborted)return;try{let b=g(z.signal),R=v.map(q=>q.requirement);if(E.resolveBatchWithResults){let q,K;if(i.batch(()=>{K=E.resolveBatchWithResults(R,b);}),N&&N>0?q=await Te(K,N,`Batch resolver "${a}" timed out after ${N}ms`):q=await K,q.length!==v.length)throw new Error(`[Directive] Batch resolver "${a}" returned ${q.length} results but expected ${v.length}. Results array must match input order.`);let L=Date.now()-T,ue=!1;for(let de=0;de<v.length;de++){let H=v[de],se=q[de];if(se.success)S.set(H.id,{state:"success",requirementId:H.id,completedAt:Date.now(),duration:L}),s?.(a,H,L);else {ue=!0;let re=se.error??new Error("Batch item failed");S.set(H.id,{state:"error",requirementId:H.id,error:re,failedAt:Date.now(),attempts:d}),p?.(a,H,re);}}if(!ue||v.some((de,H)=>q[H]?.success))return}else {let q;i.batch(()=>{q=E.resolveBatch(R,b);}),N&&N>0?await Te(q,N,`Batch resolver "${a}" timed out after ${N}ms`):await q;let K=Date.now()-T;for(let L of v)S.set(L.id,{state:"success",requirementId:L.id,completedAt:Date.now(),duration:K}),s?.(a,L,K);return}}catch(b){let R=await M(b,d,$,z);if(W=R.error,R.action==="abort")return;if(R.action==="break")break;if(d<$.attempts)for(let q of v)m?.(a,q,d+1);}}for(let d of v)S.set(d.id,{state:"error",requirementId:d.id,error:W,failedAt:Date.now(),attempts:$.attempts}),p?.(a,d,W);G();}function C(a,v){let E=n[a];if(!E)return;let $={...bt,...E.batch};j.has(a)||j.set(a,{resolverId:a,requirements:[],timer:null});let A=j.get(a);if(A.requirements.push(v),$.maxSize&&A.requirements.length>=$.maxSize){A.timer&&(clearTimeout(A.timer),A.timer=null),F(a);return}A.timer&&clearTimeout(A.timer),A.timer=setTimeout(()=>{F(a);},$.windowMs);}function F(a){let v=j.get(a);if(!v||v.requirements.length===0)return;let E=[...v.requirements];v.requirements=[],v.timer=null,k(a,E).then(()=>{l?.();});}return {resolve(a){if(c.has(a.id))return;let v=O(a.requirement);if(!v){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] No resolver found for requirement type "${a.requirement.type}" (id: ${a.id})`);return}let E=n[v];if(!E)return;if(E.batch?.enabled){C(v,a);return}let $=new AbortController,A=Date.now(),z={requirementId:a.id,resolverId:v,controller:$,startedAt:A,attempt:1,status:{state:"pending",requirementId:a.id,startedAt:A},originalRequirement:a};c.set(a.id,z),y?.(v,a),u(v,a,$).finally(()=>{c.delete(a.id)&&l?.();});},cancel(a){let v=c.get(a);if(v){v.controller.abort(),c.delete(a),S.set(a,{state:"canceled",requirementId:a,canceledAt:Date.now()}),G(),f?.(v.resolverId,v.originalRequirement);return}for(let E of j.values()){let $=E.requirements.findIndex(A=>A.id===a);if($!==-1){let[A]=E.requirements.splice($,1);S.set(a,{state:"canceled",requirementId:a,canceledAt:Date.now()}),G(),A&&f?.(E.resolverId,A);return}}},cancelAll(){let a=[...c.keys()];for(let v of a)this.cancel(v);for(let v of j.values()){v.timer&&clearTimeout(v.timer);for(let E of v.requirements)S.set(E.id,{state:"canceled",requirementId:E.id,canceledAt:Date.now()}),f?.(v.resolverId,E);}j.clear(),G();},getStatus(a){let v=c.get(a);if(v)return v.status;let E=S.get(a);return E||{state:"idle"}},getInflight(){return [...c.keys()]},getInflightInfo(){return [...c.values()].map(a=>({id:a.requirementId,resolverId:a.resolverId,startedAt:a.startedAt}))},isResolving(a){return c.has(a)},processBatches(){for(let a of j.keys())F(a);},hasPendingBatches(){for(let a of j.values())if(a.requirements.length>0)return true;return false},registerDefinitions(a){for(let[v,E]of Object.entries(a))n[v]=E;_.clear();},assignDefinition(a,v){if(!n[a])throw new Error(`[Directive] Cannot assign resolver "${a}" \u2014 it does not exist. Use register() to create it.`);n[a]=v,_.clear();},unregisterDefinition(a){if(!n[a])return;for(let[E,$]of c)$.resolverId===a&&($.controller.abort(),c.delete(E),S.set(E,{state:"canceled",requirementId:E,canceledAt:Date.now()}),f?.(a,$.originalRequirement));let v=j.get(a);if(v){v.timer&&clearTimeout(v.timer);for(let E of v.requirements)S.set(E.id,{state:"canceled",requirementId:E.id,canceledAt:Date.now()}),f?.(a,E);j.delete(a);}delete n[a],_.clear(),G();},async callOne(a,v){let E=n[a];if(!E)throw new Error(`[Directive] Cannot call resolver "${a}" \u2014 it does not exist.`);let $=new AbortController,A=g($.signal);if(E.resolve){let z;i.batch(()=>{z=E.resolve(v,A);}),await z;}},destroy(){this.cancelAll(),S.clear(),_.clear();}}}function We(e){let n=Object.create(null),o=Object.create(null),i=Object.create(null),y=Object.create(null),s=Object.create(null),p=Object.create(null),m=new Map;for(let t of e.modules){let r=(h,P)=>{if(h)for(let U of Object.keys(h)){if(Z.has(U))throw new Error(`[Directive] Security: Module "${t.id}" has dangerous key "${U}" in ${P}. This could indicate a prototype pollution attempt.`);if(P==="schema"&&U.startsWith("$"))throw new Error(`[Directive] Module "${t.id}" has schema key "${U}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};if(r(t.schema,"schema"),r(t.events,"events"),r(t.derive,"derive"),r(t.effects,"effects"),r(t.constraints,"constraints"),r(t.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let h of Object.keys(t.schema)){let P=m.get(h);if(P)throw new Error(`[Directive] Schema collision: Fact "${h}" is defined in both module "${P}" and "${t.id}". Use namespacing (e.g., "${t.id}::${h}") or merge into one module.`);m.set(h,t.id);}Object.assign(n,t.schema),t.events&&Object.assign(o,t.events),t.derive&&Object.assign(i,t.derive),t.effects&&Object.assign(y,t.effects),t.constraints&&Object.assign(s,t.constraints),t.resolvers&&Object.assign(p,t.resolvers);}let f=null;if(e.modules.some(t=>t.snapshotEvents)){f=new Set;for(let t of e.modules){let r=t;if(r.snapshotEvents)for(let h of r.snapshotEvents)f.add(h);else if(r.events)for(let h of Object.keys(r.events))f.add(h);}}let c=0,S=false;if(process.env.NODE_ENV!=="production"){let t=new Set(Object.keys(i));for(let r of Object.keys(n))t.has(r)&&console.warn(`[Directive] "${r}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let w=Ye();for(let t of e.plugins??[])w.register(t);let j=Xe({config:e.errorBoundary,onError:t=>w.emitError(t),onRecovery:(t,r)=>w.emitErrorRecovery(t,r)}),_=null,Q=()=>{},G=()=>{},x=null,D=e.debug?.runHistory??false,V=e.debug?.maxRuns??100,O=[],g=new Map,M=0,u=null,k=[],C=new Map,F=new Map,B=new Map,a=null,v=0,E=0,$={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0},{store:A,facts:z}=Ge({schema:n,onChange:(t,r,h)=>{w.emitFactSet(t,r,h),Q(t),D&&k.push({key:String(t),oldValue:h,newValue:r}),!x?.isRestoring&&(c===0&&(S=true),I.changedKeys.add(t),me());},onBatch:t=>{w.emitFactsBatch(t);let r=[];for(let h of t)r.push(h.key);if(D)for(let h of t)h.type==="delete"?k.push({key:h.key,oldValue:h.prev,newValue:void 0}):k.push({key:h.key,oldValue:h.prev,newValue:h.value});if(G(r),!x?.isRestoring){c===0&&(S=true);for(let h of t)I.changedKeys.add(h.key);me();}}}),T=He({definitions:i,facts:z,store:A,onCompute:(t,r,h,P)=>{w.emitDerivationCompute(t,r,P),u&&u.derivationsRecomputed.push({id:t,deps:P?[...P]:[],oldValue:h,newValue:r});},onInvalidate:t=>w.emitDerivationInvalidate(t),onError:(t,r)=>{j.handleError("derivation",t,r)==="retry"&&T.invalidate(t);}});Q=t=>T.invalidate(t),G=t=>T.invalidateMany(t);let W=Je({definitions:y,facts:z,store:A,onRun:(t,r)=>{w.emitEffectRun(t),u&&u.effectsRun.push({id:t,triggeredBy:r});},onError:(t,r)=>{let h=j.handleError("effect",t,r);w.emitEffectError(t,r),u&&u.effectErrors.push({id:t,error:String(r)}),h==="disable"&&W.disable(t),h==="retry"&&(I.changedKeys.add("*"),me());}}),N=Le({definitions:s,facts:z,onEvaluate:(t,r)=>w.emitConstraintEvaluate(t,r),onError:(t,r)=>{let h=j.handleError("constraint",t,r);w.emitConstraintError(t,r),h==="disable"&&N.disable(t);}});function d(t){let r=g.get(t);if(r&&r.status==="pending"){r.status="settled";let h=B.get(t);r.duration=h!==void 0?performance.now()-h:Date.now()-r.timestamp,B.delete(t),F.delete(t),r.causalChain=q(r),K(r),E++,w.emitRunComplete(r);}}function b(t){let r=C.get(t);if(C.delete(t),r!==void 0){let h=(F.get(r)??1)-1;h<=0?d(r):F.set(r,h);}}function R(){let t=O.shift();if(t&&(g.delete(t.id),B.delete(t.id),t.status==="pending")){F.delete(t.id);for(let[r,h]of C)h===t.id&&C.delete(r);}}function q(t){let r=[];for(let h of t.factChanges)r.push(`${h.key} changed`);for(let h of t.derivationsRecomputed)r.push(`${h.id} recomputed`);for(let h of t.constraintsHit)r.push(`${h.id} constraint hit`);for(let h of t.requirementsAdded)r.push(`${h.type} requirement added`);for(let h of t.resolversCompleted)r.push(`${h.resolver} resolved (${h.duration.toFixed(0)}ms)`);for(let h of t.resolversErrored)r.push(`${h.resolver} errored`);for(let h of t.effectsRun)r.push(`${h.id} effect ran`);return r.join(" \u2192 ")}function K(t){$.count++,$.totalDuration+=t.duration,$.avgDuration=$.totalDuration/$.count,t.duration>$.maxDuration&&($.maxDuration=t.duration);let r=t.resolversStarted.length;$.totalResolverCount+=r,$.avgResolverCount=$.totalResolverCount/$.count;let h=t.factChanges.length;$.totalFactChangeCount+=h,$.avgFactChangeCount=$.totalFactChangeCount/$.count;let P=[];$.count>3&&t.duration>$.avgDuration*5&&P.push(`Duration ${t.duration.toFixed(0)}ms is 5x+ above average (${$.avgDuration.toFixed(0)}ms)`),t.resolversErrored.length>0&&P.push(`${t.resolversErrored.length} resolver(s) errored`),P.length>0&&(t.anomalies=P);}let L=Ze({definitions:p,facts:z,store:A,onStart:(t,r)=>w.emitResolverStart(t,r),onComplete:(t,r,h)=>{if(j.clearRetryAttempts(t),w.emitResolverComplete(t,r,h),w.emitRequirementMet(r,t),N.markResolved(r.fromConstraint),D){let P=C.get(r.id);if(P!==void 0){let U=g.get(P);U&&U.resolversCompleted.push({resolver:t,requirementId:r.id,duration:h});}b(r.id);}},onError:(t,r,h)=>{let P=j.handleError("resolver",t,h,r);if(w.emitResolverError(t,r,h),P==="disable"&&N.disable(r.fromConstraint),P==="retry"&&(I.previousRequirements.remove(r.id),me()),P==="retry-later"){let J=j.getRetryLaterManager().getPendingRetries().find(ne=>ne.sourceId===t);J&&!J.callback&&(J.callback=()=>{me();});}if(D){let U=C.get(r.id);if(U!==void 0){let J=g.get(U);J&&J.resolversErrored.push({resolver:t,requirementId:r.id,error:String(h)});}b(r.id);}},onRetry:(t,r,h)=>w.emitResolverRetry(t,r,h),onCancel:(t,r)=>{w.emitResolverCancel(t,r),w.emitRequirementCanceled(r),D&&b(r.id);},onResolutionComplete:()=>{re(),me();}}),ue=new Set;function de(){for(let t of ue)t();}let H=e.debug?.timeTravel?Ve({config:e.debug,facts:z,store:A,onSnapshot:t=>{w.emitSnapshot(t),de();},onTimeTravel:(t,r)=>{w.emitTimeTravel(t,r),de();}}):ze();x=H;let se=new Set;function re(){for(let t of se)t();}let ye=50,pe=0,I={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new De,readyPromise:null,readyResolve:null},Y={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},ve=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]),Ce=[];function Ae(t){if(typeof t!="string"||t.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String(t)}`);if(Z.has(t))throw new Error(`[Directive] Security: Definition ID "${t}" is a blocked property.`);if(t.includes("::"))throw new Error(`[Directive] Definition ID "${t}" cannot contain "::". This separator is reserved for namespacing.`)}function Fe(t,r,h){if(I.isDestroyed)throw new Error(`[Directive] Cannot register ${t} "${r}" on a destroyed system.`);if(Ae(r),I.isReconciling){Ce.push({op:"register",type:t,id:r,def:h});return}nt(t,r,h);}function Oe(t,r,h){if(I.isDestroyed)throw new Error(`[Directive] Cannot assign ${t} "${r}" on a destroyed system.`);if(Ae(r),I.isReconciling){Ce.push({op:"assign",type:t,id:r,def:h});return}rt(t,r,h);}function je(t,r){if(I.isDestroyed)throw new Error(`[Directive] Cannot unregister ${t} "${r}" on a destroyed system.`);if(Ae(r),I.isReconciling){Ce.push({op:"unregister",type:t,id:r});return}st(t,r);}function _e(t,r,h){if(I.isDestroyed)throw new Error(`[Directive] Cannot call ${t} "${r}" on a destroyed system.`);switch(Ae(r),w.emitDefinitionCall(t,r,h),t){case "constraint":return N.callOne(r,h);case "resolver":return L.callOne(r,h);case "derivation":return T.callOne(r);case "effect":return W.callOne(r)}}function nt(t,r,h){switch(t){case "constraint":{if(r in s)throw new Error(`[Directive] Constraint "${r}" already exists. Use assign() to override.`);let P=h;s[r]=P,N.registerDefinitions({[r]:P}),Y.constraints.add(r),w.emitDefinitionRegister(t,r,h),me();break}case "resolver":{if(r in p)throw new Error(`[Directive] Resolver "${r}" already exists. Use assign() to override.`);let P=h;p[r]=P,L.registerDefinitions({[r]:P}),Y.resolvers.add(r),w.emitDefinitionRegister(t,r,h),me();break}case "derivation":{if(ve.has(r))throw new Error(`[Directive] Derivation ID "${r}" conflicts with a reserved derive method name.`);if(r in i)throw new Error(`[Directive] Derivation "${r}" already exists. Use assign() to override.`);i[r]=h,T.registerDefinitions({[r]:h}),Y.derivations.add(r),w.emitDefinitionRegister(t,r,h);break}case "effect":{if(r in y)throw new Error(`[Directive] Effect "${r}" already exists. Use assign() to override.`);let P=h;y[r]=P,W.registerDefinitions({[r]:P}),Y.effects.add(r),w.emitDefinitionRegister(t,r,h);break}}}function rt(t,r,h){switch(t){case "constraint":{if(!(r in s))throw new Error(`[Directive] Constraint "${r}" does not exist. Use register() to create it.`);let P=s[r];N.assignDefinition(r,h),ee.constraints.set(r,P),s[r]=h,w.emitDefinitionAssign(t,r,h,P),me();break}case "resolver":{if(!(r in p))throw new Error(`[Directive] Resolver "${r}" does not exist. Use register() to create it.`);let P=p[r];L.assignDefinition(r,h),ee.resolvers.set(r,P),p[r]=h,w.emitDefinitionAssign(t,r,h,P),me();break}case "derivation":{if(ve.has(r))throw new Error(`[Directive] Derivation ID "${r}" conflicts with a reserved derive method name.`);if(!(r in i))throw new Error(`[Directive] Derivation "${r}" does not exist. Use register() to create it.`);let P=i[r];T.assignDefinition(r,h),ee.derivations.set(r,P),i[r]=h,w.emitDefinitionAssign(t,r,h,P);break}case "effect":{if(!(r in y))throw new Error(`[Directive] Effect "${r}" does not exist. Use register() to create it.`);let P=y[r];W.assignDefinition(r,h),ee.effects.set(r,P),y[r]=h,w.emitDefinitionAssign(t,r,h,P);break}}}function st(t,r){switch(t){case "constraint":{if(!Y.constraints.has(r)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static constraint "${r}". Only dynamically registered constraints can be removed.`);return}N.unregisterDefinition(r),delete s[r],Y.constraints.delete(r),ee.constraints.delete(r),w.emitDefinitionUnregister(t,r),me();break}case "resolver":{if(!Y.resolvers.has(r)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static resolver "${r}". Only dynamically registered resolvers can be removed.`);return}L.unregisterDefinition(r),delete p[r],Y.resolvers.delete(r),ee.resolvers.delete(r),w.emitDefinitionUnregister(t,r);break}case "derivation":{if(!Y.derivations.has(r)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static derivation "${r}". Only dynamically registered derivations can be removed.`);return}T.unregisterDefinition(r),delete i[r],Y.derivations.delete(r),ee.derivations.delete(r),w.emitDefinitionUnregister(t,r);break}case "effect":{if(!Y.effects.has(r)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static effect "${r}". Only dynamically registered effects can be removed.`);return}W.unregisterDefinition(r),delete y[r],Y.effects.delete(r),ee.effects.delete(r),w.emitDefinitionUnregister(t,r);break}}}function xt(){if(Ce.length===0)return;let t=Ce.splice(0);for(let r of t)try{switch(r.op){case "register":nt(r.type,r.id,r.def);break;case "assign":rt(r.type,r.id,r.def);break;case "unregister":st(r.type,r.id);break}}catch(h){process.env.NODE_ENV!=="production"&&console.error(`[Directive] Error in deferred ${r.op} for ${r.type} "${r.id}":`,h);}}function me(){!I.isRunning||I.reconcileScheduled||I.isInitializing||(I.reconcileScheduled=true,re(),queueMicrotask(()=>{I.reconcileScheduled=false,I.isRunning&&!I.isInitializing&&Ct().catch(t=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",t);});}));}async function Ct(){if(I.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.`),D&&(k.length=0),pe=0;return}I.isReconciling=true,re();let t=D?performance.now():0;if(D){let r=++M;B.set(r,t),u={id:r,timestamp:Date.now(),duration:0,status:"pending",factChanges:k.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]};}try{I.changedKeys.size>0&&((f===null||S)&&H.takeSnapshot(`facts-changed:${[...I.changedKeys].join(",")}`),S=!1);let r=z.$snapshot();w.emitReconcileStart(r),await W.runEffects(I.changedKeys);let h=new Set(I.changedKeys);I.changedKeys.clear();let P=await N.evaluate(h),U=new De;for(let te of P)U.add(te),w.emitRequirementCreated(te);if(u){let te=new Set(P.map(oe=>oe.fromConstraint));for(let oe of te){let ie=N.getState(oe);if(ie){let ae=N.getDependencies(oe);u.constraintsHit.push({id:oe,priority:ie.priority,deps:ae?[...ae]:[]});}}}let{added:J,removed:ne}=U.diff(I.previousRequirements);if(u){for(let te of J)u.requirementsAdded.push({id:te.id,type:te.requirement.type,fromConstraint:te.fromConstraint});for(let te of ne)u.requirementsRemoved.push({id:te.id,type:te.requirement.type,fromConstraint:te.fromConstraint});}for(let te of ne)L.cancel(te.id);for(let te of J)L.resolve(te);if(u){let te=L.getInflightInfo(),oe=new Map(te.map(ie=>[ie.id,ie]));for(let ie of J){let ae=oe.get(ie.id);u.resolversStarted.push({resolver:ae?.resolverId??"unknown",requirementId:ie.id}),C.set(ie.id,u.id);}}I.previousRequirements=U;let le=L.getInflightInfo(),fe={unmet:P.filter(te=>!L.isResolving(te.id)),inflight:le,completed:[],canceled:ne.map(te=>({id:te.id,resolverId:le.find(oe=>oe.id===te.id)?.resolverId??"unknown"}))};w.emitReconcileEnd(fe),I.isReady||(I.isReady=!0,I.readyResolve&&(I.readyResolve(),I.readyResolve=null));}finally{if(u){if(u.duration=performance.now()-t,u.factChanges.length>0||u.constraintsHit.length>0||u.requirementsAdded.length>0||u.effectsRun.length>0){let h=u.resolversStarted.length;h===0?(u.status="settled",u.causalChain=q(u),K(u),O.push(u),g.set(u.id,u),O.length>V&&R(),E++,w.emitRunComplete(u)):(u.status="pending",O.push(u),g.set(u.id,u),O.length>V&&R(),E++,F.set(u.id,h));}else B.delete(u.id);u=null;}I.isReconciling=false,xt(),I.changedKeys.size>0?me():I.reconcileScheduled||(pe=0),re();}}let Ne={register:(t,r)=>Fe("derivation",t,r),assign:(t,r)=>Oe("derivation",t,r),unregister:t=>je("derivation",t),call:t=>_e("derivation",t),isDynamic:t=>Y.derivations.has(t),listDynamic:()=>[...Y.derivations]},Tt=new Proxy({},{get(t,r){if(typeof r!="symbol"&&!Z.has(r)){if(r in Ne)return Ne[r];if(r in i)return T.get(r)}},has(t,r){return typeof r=="symbol"||Z.has(r)?false:r in i||r in Ne},ownKeys(){return Object.keys(i)},getOwnPropertyDescriptor(t,r){if(typeof r!="symbol"&&!Z.has(r)&&(r in i||r in Ne))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),$t=new Proxy({},{get(t,r){if(typeof r!="symbol"&&!Z.has(r))return h=>{let P=o[r];if(P){c++,(f===null||f.has(r))&&(S=true);try{A.batch(()=>{P(z,{type:r,...h});});}finally{c--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${r}". No handler is registered for this event. Available events: ${Object.keys(o).join(", ")||"(none)"}`);}},has(t,r){return typeof r=="symbol"||Z.has(r)?false:r in o},ownKeys(){return Object.keys(o)},getOwnPropertyDescriptor(t,r){if(typeof r!="symbol"&&!Z.has(r)&&r in o)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),he={facts:z,debug:H.isEnabled?H:null,derive:Tt,events:$t,constraints:{disable:t=>N.disable(t),enable:t=>N.enable(t),isDisabled:t=>N.isDisabled(t),register:(t,r)=>Fe("constraint",t,r),assign:(t,r)=>Oe("constraint",t,r),unregister:t=>je("constraint",t),call:(t,r)=>_e("constraint",t,r),isDynamic:t=>Y.constraints.has(t),listDynamic:()=>[...Y.constraints]},effects:{disable:t=>W.disable(t),enable:t=>W.enable(t),isEnabled:t=>W.isEnabled(t),register:(t,r)=>Fe("effect",t,r),assign:(t,r)=>Oe("effect",t,r),unregister:t=>je("effect",t),call:t=>_e("effect",t),isDynamic:t=>Y.effects.has(t),listDynamic:()=>[...Y.effects]},resolvers:{register:(t,r)=>Fe("resolver",t,r),assign:(t,r)=>Oe("resolver",t,r),unregister:t=>je("resolver",t),call:(t,r)=>_e("resolver",t,r),isDynamic:t=>Y.resolvers.has(t),listDynamic:()=>[...Y.resolvers]},get runHistory(){return D?((!a||v!==E)&&(a=[...O],v=E),a):null},initialize(){if(!I.isInitialized){I.isInitializing=true;for(let t of e.modules)t.init&&A.batch(()=>{t.init(z);});e.onAfterModuleInit&&A.batch(()=>{e.onAfterModuleInit();}),I.isInitializing=false,I.isInitialized=true;for(let t of Object.keys(i))T.get(t);}},start(){if(!I.isRunning){I.isInitialized||this.initialize(),I.isRunning=true;for(let t of e.modules)t.hooks?.onStart?.(he);if(w.emitStart(he),e.errorBoundary?.retryLater&&!_){let t=Math.max(e.errorBoundary.retryLater.delayMs??1e3,250);_=setInterval(()=>{let r=j.processDueRetries();for(let h of r)h.callback?h.callback():me();},Math.min(t,500));}me();}},stop(){if(I.isRunning){I.isRunning=false,_!==null&&(clearInterval(_),_=null),j.getRetryLaterManager().clearAll(),L.cancelAll(),W.cleanupAll();for(let t of e.modules)t.hooks?.onStop?.(he);w.emitStop(he);}},destroy(){I.isDestroyed||(this.stop(),I.isDestroyed=true,A.destroy?.(),L.destroy(),j.clearErrors(),se.clear(),ue.clear(),Ce.length=0,O.length=0,g.clear(),C.clear(),F.clear(),B.clear(),k.length=0,u=null,a=null,Y.constraints.clear(),Y.resolvers.clear(),Y.derivations.clear(),Y.effects.clear(),ee.constraints.clear(),ee.resolvers.clear(),ee.derivations.clear(),ee.effects.clear(),w.emitDestroy(he));},dispatch(t){if(Z.has(t.type))return;let r=o[t.type];if(r){c++,(f===null||f.has(t.type))&&(S=true);try{A.batch(()=>{r(z,t);});}finally{c--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${t.type}". No handler is registered for this event. Available events: ${Object.keys(o).join(", ")||"(none)"}`);},read(t){return T.get(t)},subscribe(t,r){let h=[],P=[];for(let J of t)J in i?h.push(J):J in n?P.push(J):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${J}"`);let U=[];return h.length>0&&U.push(T.subscribe(h,r)),P.length>0&&U.push(A.subscribe(P,r)),()=>{for(let J of U)J();}},watch(t,r,h){let P=h?.equalityFn?(J,ne)=>h.equalityFn(J,ne):(J,ne)=>Object.is(J,ne);if(t in i){let J=T.get(t);return T.subscribe([t],()=>{let ne=T.get(t);if(!P(ne,J)){let le=J;J=ne,r(ne,le);}})}process.env.NODE_ENV!=="production"&&(t in n||console.warn(`[Directive] watch: unknown key "${t}"`));let U=A.get(t);return A.subscribe([t],()=>{let J=A.get(t);if(!P(J,U)){let ne=U;U=J,r(J,ne);}})},when(t,r){return new Promise((h,P)=>{let U=A.toObject();if(t(U)){h();return}let J,ne,le=()=>{J?.(),ne!==void 0&&clearTimeout(ne);};J=A.subscribeAll(()=>{let fe=A.toObject();t(fe)&&(le(),h());}),r?.timeout!==void 0&&r.timeout>0&&(ne=setTimeout(()=>{le(),P(new Error(`[Directive] when: timed out after ${r.timeout}ms`));},r.timeout));})},inspect(){return {unmet:I.previousRequirements.all(),inflight:L.getInflightInfo(),constraints:N.getAllStates().map(t=>({id:t.id,active:t.lastResult??false,disabled:N.isDisabled(t.id),priority:t.priority,hitCount:t.hitCount,lastActiveAt:t.lastActiveAt})),resolvers:Object.fromEntries(L.getInflight().map(t=>[t,L.getStatus(t)])),resolverDefs:Object.entries(p).map(([t,r])=>({id:t,requirement:typeof r.requirement=="string"?r.requirement:"(predicate)"})),runHistoryEnabled:D,...D?{runHistory:O.map(t=>({...t,factChanges:t.factChanges.map(r=>({...r})),derivationsRecomputed:t.derivationsRecomputed.map(r=>({...r,deps:[...r.deps]})),constraintsHit:t.constraintsHit.map(r=>({...r,deps:[...r.deps]})),requirementsAdded:t.requirementsAdded.map(r=>({...r})),requirementsRemoved:t.requirementsRemoved.map(r=>({...r})),resolversStarted:t.resolversStarted.map(r=>({...r})),resolversCompleted:t.resolversCompleted.map(r=>({...r})),resolversErrored:t.resolversErrored.map(r=>({...r})),effectsRun:t.effectsRun.map(r=>({...r,triggeredBy:[...r.triggeredBy]})),effectErrors:t.effectErrors.map(r=>({...r}))}))}:{}}},explain(t){let h=I.previousRequirements.all().find(oe=>oe.id===t);if(!h)return null;let P=N.getState(h.fromConstraint),U=L.getStatus(t),J={},ne=A.toObject();for(let[oe,ie]of Object.entries(ne))J[oe]=ie;let le=[`Requirement "${h.requirement.type}" (id: ${h.id})`,`\u251C\u2500 Produced by constraint: ${h.fromConstraint}`,`\u251C\u2500 Constraint priority: ${P?.priority??0}`,`\u251C\u2500 Constraint active: ${P?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${U.state}`],fe=Object.entries(h.requirement).filter(([oe])=>oe!=="type").map(([oe,ie])=>`${oe}=${JSON.stringify(ie)}`).join(", ");fe&&le.push(`\u251C\u2500 Requirement payload: { ${fe} }`);let te=Object.entries(J).slice(0,10);return te.length>0&&(le.push("\u2514\u2500 Relevant facts:"),te.forEach(([oe,ie],ae)=>{let be=ae===te.length-1?" \u2514\u2500":" \u251C\u2500",we=typeof ie=="object"?JSON.stringify(ie):String(ie);le.push(`${be} ${oe} = ${we.slice(0,50)}${we.length>50?"...":""}`);})),le.join(`
2
- `)},getOriginal(t,r){let P={constraint:ee.constraints,resolver:ee.resolvers,derivation:ee.derivations,effect:ee.effects}[t];if(P)return P.get(r)},restoreOriginal(t,r){let P={constraint:ee.constraints,resolver:ee.resolvers,derivation:ee.derivations,effect:ee.effects}[t];if(!P||!P.has(r))return false;let U=P.get(r);return Oe(t,r,U),P.delete(r),true},async settle(t=5e3){let r=Date.now();for(;;){L.hasPendingBatches()&&L.processBatches(),await new Promise(U=>setTimeout(U,0));let h=this.inspect();if(h.inflight.length===0&&!I.isReconciling&&!I.reconcileScheduled&&!L.hasPendingBatches())return;if(Date.now()-r>t){let U=[];h.inflight.length>0&&U.push(`${h.inflight.length} resolvers inflight: ${h.inflight.map(ne=>ne.resolverId).join(", ")}`),I.isReconciling&&U.push("reconciliation in progress"),I.reconcileScheduled&&U.push("reconcile scheduled");let J=I.previousRequirements.all();throw J.length>0&&U.push(`${J.length} unmet requirements: ${J.map(ne=>ne.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${t}ms. ${U.join("; ")}`)}await new Promise(U=>setTimeout(U,10));}},getSnapshot(){return {facts:A.toObject(),version:1}},getDistributableSnapshot(t={}){let{includeDerivations:r,excludeDerivations:h,includeFacts:P,ttlSeconds:U,metadata:J,includeVersion:ne}=t,le={},fe=Object.keys(i),te;if(r){if(te=r.filter(ae=>fe.includes(ae)),process.env.NODE_ENV!=="production"){let ae=r.filter(be=>!fe.includes(be));ae.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${ae.join(", ")}. Available: ${fe.join(", ")||"(none)"}`);}}else te=fe;if(h){let ae=new Set(h);te=te.filter(be=>!ae.has(be));}for(let ae of te)try{le[ae]=T.get(ae);}catch(be){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${ae}" due to error:`,be);}if(P&&P.length>0){let ae=A.toObject(),be=Object.keys(ae);if(process.env.NODE_ENV!=="production"){let we=P.filter(Pt=>!(Pt in ae));we.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${we.join(", ")}. Available: ${be.join(", ")||"(none)"}`);}for(let we of P)we in ae&&(le[we]=ae[we]);}let oe=Date.now(),ie={data:le,createdAt:oe};return U!==void 0&&U>0&&(ie.expiresAt=oe+U*1e3),ne&&(ie.version=lt(le)),J&&(ie.metadata=J),ie},watchDistributableSnapshot(t,r){let{includeDerivations:h,excludeDerivations:P}=t,U=Object.keys(i),J;if(h?J=h.filter(fe=>U.includes(fe)):J=U,P){let fe=new Set(P);J=J.filter(te=>!fe.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 le=this.getDistributableSnapshot({...t,includeVersion:true}).version;return T.subscribe(J,()=>{let fe=this.getDistributableSnapshot({...t,includeVersion:true});fe.version!==le&&(le=fe.version,r(fe));})},restore(t){if(!t||typeof t!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!t.facts||typeof t.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!ke(t))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");A.batch(()=>{for(let[r,h]of Object.entries(t.facts))Z.has(r)||A.set(r,h);});},onSettledChange(t){return se.add(t),()=>{se.delete(t);}},onTimeTravelChange(t){return ue.add(t),()=>{ue.delete(t);}},batch(t){A.batch(t);},get isSettled(){return L.getInflight().length===0&&!L.hasPendingBatches()&&!I.isReconciling&&!I.reconcileScheduled},get isRunning(){return I.isRunning},get isInitialized(){return I.isInitialized},get isReady(){return I.isReady},whenReady(){return I.isReady?Promise.resolve():I.isRunning?(I.readyPromise||(I.readyPromise=new Promise(t=>{I.readyResolve=t;})),I.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function qt(t){if(I.isReconciling)throw new Error(`[Directive] Cannot register module "${t.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(I.isDestroyed)throw new Error(`[Directive] Cannot register module "${t.id}" on a destroyed system.`);let r=(h,P)=>{if(h)for(let U of Object.keys(h)){if(Z.has(U))throw new Error(`[Directive] Security: Module "${t.id}" has dangerous key "${U}" in ${P}.`);if(P==="schema"&&U.startsWith("$"))throw new Error(`[Directive] Module "${t.id}" has schema key "${U}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};r(t.schema,"schema"),r(t.events,"events"),r(t.derive,"derive"),r(t.effects,"effects"),r(t.constraints,"constraints"),r(t.resolvers,"resolvers");for(let h of Object.keys(t.schema))if(h in n)throw new Error(`[Directive] Schema collision: Fact "${h}" already exists. Cannot register module "${t.id}".`);if(process.env.NODE_ENV!=="production"&&t.derive){let h=new Set(Object.keys(n));for(let P of Object.keys(t.derive))h.has(P)&&console.warn(`[Directive] "${P}" exists as both a fact and a derivation after registering module "${t.id}".`);}if(t.snapshotEvents){f===null&&(f=new Set(Object.keys(o)));for(let h of t.snapshotEvents)f.add(h);}else if(f!==null&&t.events)for(let h of Object.keys(t.events))f.add(h);Object.assign(n,t.schema),t.events&&Object.assign(o,t.events),t.derive&&(Object.assign(i,t.derive),T.registerDefinitions(t.derive)),t.effects&&(Object.assign(y,t.effects),W.registerDefinitions(t.effects)),t.constraints&&(Object.assign(s,t.constraints),N.registerDefinitions(t.constraints)),t.resolvers&&(Object.assign(p,t.resolvers),L.registerDefinitions(t.resolvers)),A.registerKeys(t.schema),e.modules.push(t),t.init&&A.batch(()=>{t.init(z);}),t.hooks?.onInit?.(he),I.isRunning&&(t.hooks?.onStart?.(he),me());}he.registerModule=qt,w.emitInit(he);for(let t of e.modules)t.hooks?.onInit?.(he);return he}var X="::";function tn(e){let n=Object.keys(e),o=new Set,i=new Set,y=[],s=[];function p(m){if(o.has(m))return;if(i.has(m)){let l=s.indexOf(m),c=[...s.slice(l),m].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${c}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}i.add(m),s.push(m);let f=e[m];if(f?.crossModuleDeps)for(let l of Object.keys(f.crossModuleDeps))n.includes(l)&&p(l);s.pop(),i.delete(m),o.add(m),y.push(m);}for(let m of n)p(m);return y}var wt=new WeakMap,Rt=new WeakMap,kt=new WeakMap,Dt=new WeakMap;function qe(e){if("module"in e){if(!e.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof e.module);return on(e)}let n=e;if(Array.isArray(n.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
1
+ 'use strict';var ye=class extends Error{constructor(c,i,y,s,u=true){super(c);this.source=i;this.sourceId=y;this.context=s;this.recoverable=u;this.name="DirectiveError";}};function Ae(){return {create(n){return n}}}function je(){return {create(n){return n}}}function Fe(n){return n}function _e(n){return n}function gt(n){return n._mode==="single"}function yt(n){return n._mode==="namespaced"}function ve(n=[],t,c,i,y,s){return {_type:void 0,_validators:n,_typeName:t,_default:c,_transform:i,_description:y,_refinements:s,validate(u){return ve([...n,u],t,c,i,y,s)}}}function se(n,t,c,i,y,s){return {...ve(n,t,c,i,y,s),default(h){return se(n,t,h,i,y,s)},transform(h){return se([],t,void 0,f=>{let D=i?i(f):f;return h(D)},y)},brand(){return se(n,`Branded<${t}>`,c,i,y,s)},describe(h){return se(n,t,c,i,h,s)},refine(h,g){let f=[...s??[],{predicate:h,message:g}];return se([...n,h],t,c,i,y,f)},nullable(){return se([h=>h===null||n.every(g=>g(h))],`${t} | null`,c,i,y)},optional(){return se([h=>h===void 0||n.every(g=>g(h))],`${t} | undefined`,c,i,y)}}}var mt={string(){return se([n=>typeof n=="string"],"string")},number(){let n=(t,c,i,y,s)=>({...se(t,"number",c,i,y,s),min(h){return n([...t,g=>g>=h],c,i,y,s)},max(h){return n([...t,g=>g<=h],c,i,y,s)},default(h){return n(t,h,i,y,s)},describe(h){return n(t,c,i,h,s)},refine(h,g){let f=[...s??[],{predicate:h,message:g}];return n([...t,h],c,i,y,f)}});return n([t=>typeof t=="number"])},boolean(){return se([n=>typeof n=="boolean"],"boolean")},array(){let n=(t,c,i,y,s)=>{let u=se(t,"array",i,void 0,y),h=s??{value:-1};return {...u,get _lastFailedIndex(){return h.value},set _lastFailedIndex(f){h.value=f;},of(f){let D={value:-1};return n([...t,m=>{for(let S=0;S<m.length;S++){let C=m[S];if(!f._validators.every(P=>P(C)))return D.value=S,false}return true}],f,i,y,D)},nonEmpty(){return n([...t,f=>f.length>0],c,i,y,h)},maxLength(f){return n([...t,D=>D.length<=f],c,i,y,h)},minLength(f){return n([...t,D=>D.length>=f],c,i,y,h)},default(f){return n(t,c,f,y,h)},describe(f){return n(t,c,i,f,h)}}};return n([t=>Array.isArray(t)])},object(){let n=(t,c,i)=>({...se(t,"object",c,void 0,i),shape(s){return n([...t,u=>{for(let[h,g]of Object.entries(s)){let f=u[h],D=g;if(D&&!D._validators.every(m=>m(f)))return false}return true}],c,i)},nonNull(){return n([...t,s=>s!=null],c,i)},hasKeys(...s){return n([...t,u=>s.every(h=>h in u)],c,i)},default(s){return n(t,s,i)},describe(s){return n(t,c,s)}});return n([t=>typeof t=="object"&&t!==null&&!Array.isArray(t)])},enum(...n){process.env.NODE_ENV!=="production"&&n.length===0&&console.warn("[Directive] t.enum() called with no values - this will reject all strings");let t=new Set(n);return se([c=>typeof c=="string"&&t.has(c)],`enum(${n.join("|")})`)},literal(n){return se([t=>t===n],`literal(${String(n)})`)},nullable(n){let t=n._typeName??"unknown";return ve([c=>c===null?true:n._validators.every(i=>i(c))],`${t} | null`)},optional(n){let t=n._typeName??"unknown";return ve([c=>c===void 0?true:n._validators.every(i=>i(c))],`${t} | undefined`)},union(...n){process.env.NODE_ENV!=="production"&&n.length===0&&console.warn("[Directive] t.union() called with no types - this will reject all values");let t=n.map(c=>c._typeName??"unknown");return se([c=>n.some(i=>i._validators.every(y=>y(c)))],t.join(" | "))},record(n){let t=n._typeName??"unknown";return se([c=>typeof c!="object"||c===null||Array.isArray(c)?false:Object.values(c).every(i=>n._validators.every(y=>y(i)))],`Record<string, ${t}>`)},tuple(...n){process.env.NODE_ENV!=="production"&&n.length===0&&console.warn("[Directive] t.tuple() called with no types - this will only accept empty arrays");let t=n.map(c=>c._typeName??"unknown");return se([c=>!Array.isArray(c)||c.length!==n.length?false:n.every((i,y)=>i._validators.every(s=>s(c[y])))],`[${t.join(", ")}]`)},date(){return se([n=>n instanceof Date&&!Number.isNaN(n.getTime())],"Date")},uuid(){let n=/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;return se([t=>typeof t=="string"&&n.test(t)],"uuid")},email(){let n=/^[^\s@]+@[^\s@]+\.[^\s@]+$/;return se([t=>typeof t=="string"&&n.test(t)],"email")},url(){return se([n=>{if(typeof n!="string")return false;try{return new URL(n),!0}catch{return false}}],"url")},bigint(){return se([n=>typeof n=="bigint"],"bigint")}};function Ne(n,t){if(process.env.NODE_ENV!=="production"){!n||typeof n!="string"?console.warn("[Directive] Module ID must be a non-empty string"):/^(__[a-z][a-z0-9_-]*|[a-z][a-z0-9-]*)$/i.test(n)||console.warn(`[Directive] Module ID "${n}" should follow kebab-case convention (e.g., "my-module")`),t.schema?t.schema.facts||console.warn("[Directive] Module schema.facts is required"):console.warn("[Directive] Module schema is required");let i=t.schema?.derivations??{},y=t.derive??{},s=new Set(Object.keys(i)),u=new Set(Object.keys(y));for(let m of u)s.has(m)||console.warn(`[Directive] Derivation "${m}" not declared in schema.derivations`);for(let m of s)u.has(m)||console.warn(`[Directive] schema.derivations["${m}"] has no matching implementation in derive`);let h=t.schema?.events??{},g=t.events??{},f=new Set(Object.keys(h)),D=new Set(Object.keys(g));for(let m of D)f.has(m)||console.warn(`[Directive] Event "${m}" not declared in schema.events`);for(let m of f)D.has(m)||console.warn(`[Directive] schema.events["${m}"] has no matching handler in events`);if(t.history?.snapshotEvents){t.history.snapshotEvents.length===0&&console.warn("[Directive] history.snapshotEvents is an empty array \u2014 no events will create history snapshots. Omit history.snapshotEvents entirely to snapshot all events, or list specific events.");let m=new Set(Object.keys(t.schema?.events??{}));for(let S of t.history.snapshotEvents)m.has(S)||console.warn(`[Directive] history.snapshotEvents entry "${S}" not declared in schema.events. Available events: ${[...m].join(", ")||"(none)"}`);}if(t.resolvers&&t.schema?.requirements){let m=new Set(Object.keys(t.schema.requirements));for(let[S,C]of Object.entries(t.resolvers)){let P=C;typeof P.requirement=="string"&&!m.has(P.requirement)&&console.warn(`[Directive] Resolver "${S}" references unknown requirement type "${P.requirement}". Available types: ${[...m].join(", ")||"(none)"}`);}}}let c="crossModuleDeps"in t?t.crossModuleDeps:void 0;return {id:n,schema:t.schema,init:t.init,derive:t.derive??{},events:t.events??{},effects:t.effects,constraints:t.constraints,resolvers:t.resolvers,hooks:t.hooks,history:t.history,crossModuleDeps:c}}function pt(n){return t=>Ne(t,n)}async function me(n,t,c){let i,y=new Promise((s,u)=>{i=setTimeout(()=>u(new Error(c)),t);});try{return await Promise.race([n,y])}finally{clearTimeout(i);}}function he(n,t=50){let c=new WeakSet;function i(y,s){if(s>t)return '"[max depth exceeded]"';if(y===null)return "null";if(y===void 0)return "undefined";let u=typeof y;if(u==="string")return JSON.stringify(y);if(u==="number"||u==="boolean")return String(y);if(u==="function")return '"[function]"';if(u==="symbol")return '"[symbol]"';if(Array.isArray(y)){if(c.has(y))return '"[circular]"';c.add(y);let h=`[${y.map(g=>i(g,s+1)).join(",")}]`;return c.delete(y),h}if(u==="object"){let h=y;if(c.has(h))return '"[circular]"';c.add(h);let D=`{${Object.keys(h).sort().map(m=>`${JSON.stringify(m)}:${i(h[m],s+1)}`).join(",")}}`;return c.delete(h),D}return '"[unknown]"'}return i(n,0)}function ae(n,t=50){let c=new Set(["__proto__","constructor","prototype"]),i=new WeakSet;function y(s,u){if(u>t)return false;if(s==null||typeof s!="object")return true;let h=s;if(i.has(h))return true;if(i.add(h),Array.isArray(h)){for(let g of h)if(!y(g,u+1))return i.delete(h),false;return i.delete(h),true}for(let g of Object.keys(h))if(c.has(g)||!y(h[g],u+1))return i.delete(h),false;return i.delete(h),true}return y(n,0)}function ht(n,t){if(n===t)return true;if(!n||!t)return false;let c=Object.keys(n),i=Object.keys(t);if(c.length!==i.length)return false;for(let y of c)if(n[y]!==t[y])return false;return true}function Ke(n){let t=he(n),c=5381;for(let i=0;i<t.length;i++)c=(c<<5)+c^t.charCodeAt(i);return (c>>>0).toString(16)}function Be(n,t=Date.now()){return n.expiresAt!==void 0&&t>n.expiresAt}function vt(n,t=Date.now()){if(!n||typeof n!="object")throw new Error("[Directive] Invalid snapshot: expected an object with 'data' and 'createdAt' properties.");if(!("data"in n))throw new Error("[Directive] Invalid snapshot: missing required 'data' property.");if(!("createdAt"in n)||typeof n.createdAt!="number")throw new Error("[Directive] Invalid snapshot: missing or invalid 'createdAt' property (expected number).");if(Be(n,t)){let c=new Date(n.expiresAt).toISOString();throw new Error(`[Directive] Snapshot expired at ${c}. Obtain a fresh snapshot from the source.`)}return n.data}function St(n,t){let c=[];function i(s,u,h){if(s==null){u!=null&&c.push({path:h,oldValue:s,newValue:u,type:"added"});return}if(u==null){c.push({path:h,oldValue:s,newValue:u,type:"removed"});return}if(typeof s!="object"||typeof u!="object"){Object.is(s,u)||c.push({path:h,oldValue:s,newValue:u,type:"changed"});return}if(Array.isArray(s)&&Array.isArray(u)){if(s.length!==u.length){c.push({path:h,oldValue:s,newValue:u,type:"changed"});return}for(let m=0;m<s.length;m++)i(s[m],u[m],`${h}[${m}]`);return}let g=s,f=u,D=new Set([...Object.keys(g),...Object.keys(f)]);for(let m of D){let S=h?`${h}.${m}`:m;m in g?m in f?i(g[m],f[m],S):c.push({path:S,oldValue:g[m],newValue:void 0,type:"removed"}):c.push({path:S,oldValue:void 0,newValue:f[m],type:"added"});}}i(n.data,t.data,"");let y=n.version!==t.version&&(n.version!==void 0||t.version!==void 0);return {identical:c.length===0,changes:c,versionChanged:y,oldVersion:n.version,newVersion:t.version}}function wt(n){return "signature"in n&&typeof n.signature=="string"}async function bt(n,t){let c=he({data:n.data,createdAt:n.createdAt,expiresAt:n.expiresAt,version:n.version,metadata:n.metadata}),i=await We(c,t);return {...n,signature:i,algorithm:"hmac-sha256"}}async function Rt(n,t){if(!n.signature||n.algorithm!=="hmac-sha256")return false;let c=he({data:n.data,createdAt:n.createdAt,expiresAt:n.expiresAt,version:n.version,metadata:n.metadata}),i=await We(c,t);return Dt(n.signature,i)}async function We(n,t){let c=typeof t=="string"?new TextEncoder().encode(t):t,i={name:"HMAC",hash:{name:"SHA-256"}},y=await crypto.subtle.importKey("raw",c,i,false,["sign"]),s=new TextEncoder().encode(n),u=await crypto.subtle.sign("HMAC",y,s);return Array.from(new Uint8Array(u)).map(h=>h.toString(16).padStart(2,"0")).join("")}function Dt(n,t){if(n.length!==t.length)return false;let c=0;for(let i=0;i<n.length;i++)c|=n.charCodeAt(i)^t.charCodeAt(i);return c===0}function kt(n){return typeof n=="boolean"?{enabled:n,maxSnapshots:100}:{enabled:true,maxSnapshots:n.maxSnapshots??100}}function be(n){let{historyOption:t,facts:c,store:i,onSnapshot:y,onHistoryChange:s}=n,{enabled:u,maxSnapshots:h}=kt(t),g=[],f=-1,D=1,m=false,S=false,C=[],P=null,z=-1;function K(){return i.toObject()}function O(){let $=K();return structuredClone($)}function k($){if(!ae($)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}i.batch(()=>{for(let[j,x]of Object.entries($)){if(j==="__proto__"||j==="constructor"||j==="prototype"){console.warn(`[Directive] Skipping dangerous key "${j}" during fact restoration`);continue}c[j]=x;}});}return {get isEnabled(){return u},get isRestoring(){return S},get isPaused(){return m},get snapshots(){return [...g]},get currentIndex(){return f},takeSnapshot($){if(!u||m)return {id:-1,timestamp:Date.now(),facts:{},trigger:$};let j={id:D++,timestamp:Date.now(),facts:O(),trigger:$};for(f<g.length-1&&g.splice(f+1),g.push(j),f=g.length-1;g.length>h;)g.shift(),f--;return y?.(j),j},restore($){if(u){m=true,S=true;try{k($.facts);}finally{m=false,S=false;}}},goBack($=1){if(!u||g.length===0)return;let j=f,x=f,e=C.find(l=>f>l.startIndex&&f<=l.endIndex);if(e)x=e.startIndex;else if(C.find(E=>f===E.startIndex)){let E=C.find(q=>q.endIndex<f&&f-q.endIndex<=$);x=E?E.startIndex:Math.max(0,f-$);}else x=Math.max(0,f-$);if(j===x)return;f=x;let o=g[f];o&&(this.restore(o),s?.(j,x));},goForward($=1){if(!u||g.length===0)return;let j=f,x=f,e=C.find(l=>f>=l.startIndex&&f<l.endIndex);if(e?x=e.endIndex:x=Math.min(g.length-1,f+$),j===x)return;f=x;let o=g[f];o&&(this.restore(o),s?.(j,x));},goTo($){if(!u)return;let j=g.findIndex(o=>o.id===$);if(j===-1){console.warn(`[Directive] Snapshot ${$} not found`);return}let x=f;f=j;let e=g[f];e&&(this.restore(e),s?.(x,j));},replay(){if(!u||g.length===0)return;f=0;let $=g[0];$&&this.restore($);},export(){return JSON.stringify({version:1,snapshots:g,currentIndex:f})},import($){if(u)try{let j=JSON.parse($);if(typeof j!="object"||j===null)throw new Error("Invalid history data: expected object");if(j.version!==1)throw new Error(`Unsupported history export version: ${j.version}`);if(!Array.isArray(j.snapshots))throw new Error("Invalid history data: snapshots must be an array");if(typeof j.currentIndex!="number")throw new Error("Invalid history data: currentIndex must be a number");for(let e of j.snapshots){if(typeof e!="object"||e===null)throw new Error("Invalid snapshot: expected object");if(typeof e.id!="number"||typeof e.timestamp!="number"||typeof e.trigger!="string"||typeof e.facts!="object")throw new Error("Invalid snapshot structure");if(!ae(e.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}g.length=0,g.push(...j.snapshots),f=j.currentIndex;let x=g[f];x&&this.restore(x);}catch(j){console.error("[Directive] Failed to import history data:",j);}},beginChangeset($){u&&(P=$,z=f);},endChangeset(){!u||P===null||(f>z&&C.push({label:P,startIndex:z,endIndex:f}),P=null,z=-1);},pause(){m=true;},resume(){m=false;}}}function Re(){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=new WeakMap;function He(n,t){if(t)return t(n);let c=Ve.get(n);if(c!==void 0)return c;let{type:i,...y}=n,s=he(y),u=`${i}:${s}`;return Ve.set(n,u),u}function De(n,t,c){return {requirement:n,id:He(n,c),fromConstraint:t}}function Et(n){return t=>({type:n,...t})}function Mt(n,t){return n.type===t}function xt(n){return t=>t.type===n}var de=class n{map=new Map;add(t){this.map.has(t.id)||this.map.set(t.id,t);}remove(t){return this.map.delete(t)}has(t){return this.map.has(t)}get(t){return this.map.get(t)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let t=new n;for(let c of this.map.values())t.add(c);return t}diff(t){let c=[],i=[],y=[];for(let s of this.map.values())t.has(s.id)?y.push(s):c.push(s);for(let s of t.map.values())this.map.has(s.id)||i.push(s);return {added:c,removed:i,unchanged:y}}};var fe=[];function Ct(){let n=new Set;return {get isTracking(){return true},track(t){n.add(t);},getDependencies(){return n}}}var Tt={isTracking:false,track(){},getDependencies(){return new Set}};function ze(){return fe[fe.length-1]??Tt}function Ot(){return fe.length>0}function ge(n){let t=Ct();fe.push(t);try{return {value:n(),deps:t.getDependencies()}}finally{fe.pop();}}function Se(n){let t=fe.splice(0,fe.length);try{return n()}finally{for(let c of t)fe.push(c);}}function pe(n){ze().track(n);}var G=Object.freeze(new Set(["__proto__","constructor","prototype"]));var $t=5e3;function ke(n){let{definitions:t,facts:c,requirementKeys:i={},defaultTimeout:y=$t,onEvaluate:s,onError:u}=n,h=new Map,g=new Set,f=new Set,D=new Map,m=new Map,S=new Set,C=new Map,P=new Map,z=false,K=new Set,O=new Set,k=new Map,N=[],$=new Map;function j(){k.clear();for(let[d,R]of Object.entries(t))if(R.after)for(let w of R.after)t[w]&&(k.has(w)||k.set(w,new Set),k.get(w).add(d));}function x(){let d=new Set,R=new Set,w=[];function M(A,ee){if(d.has(A))return;if(R.has(A)){let p=ee.indexOf(A),b=[...ee.slice(p),A].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${b}. Remove one of the \`after\` dependencies to break the cycle.`)}R.add(A),ee.push(A);let r=t[A];if(r?.after)for(let p of r.after)t[p]&&M(p,ee);ee.pop(),R.delete(A),d.add(A),w.push(A);}for(let A of Object.keys(t))M(A,[]);N=w,$=new Map(N.map((A,ee)=>[A,ee]));}if(x(),j(),process.env.NODE_ENV!=="production"){for(let[d,R]of Object.entries(t))if(R.after)for(let w of R.after)t[w]||console.warn(`[Directive] Constraint "${d}" references unknown constraint "${w}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function e(d,R){return R.async!==void 0?R.async:!!f.has(d)}function o(d){let R=t[d];if(!R)throw new Error(`[Directive] Unknown constraint: ${d}`);let w=e(d,R);w&&f.add(d);let M={id:d,priority:R.priority??0,isAsync:w,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:R.after??[],hitCount:0,lastActiveAt:null};return h.set(d,M),M}function l(d){return h.get(d)??o(d)}function E(d,R){let w=D.get(d)??new Set;if(w.size===R.size&&w.size>0){let M=true;for(let A of R)if(!w.has(A)){M=false;break}if(M)return}for(let M of w){let A=m.get(M);A?.delete(d),A&&A.size===0&&m.delete(M);}for(let M of R)m.has(M)||m.set(M,new Set),m.get(M).add(d);D.set(d,R);}function q(d){let R=t[d];if(!R)return false;let w=l(d);w.isEvaluating=true,w.error=null;try{let M;if(R.deps)M=R.when(c),C.set(d,new Set(R.deps));else {let A=ge(()=>R.when(c));M=A.value,C.set(d,A.deps);}return M instanceof Promise?(f.add(d),w.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${d}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),M.then(A=>(w.lastResult=A,A&&(w.hitCount++,w.lastActiveAt=Date.now()),w.isEvaluating=!1,s?.(d,A),A)).catch(A=>(w.error=A instanceof Error?A:new Error(String(A)),w.lastResult=!1,w.isEvaluating=!1,u?.(d,A),!1))):(w.lastResult=M,M&&(w.hitCount++,w.lastActiveAt=Date.now()),w.isEvaluating=!1,s?.(d,M),M)}catch(M){return w.error=M instanceof Error?M:new Error(String(M)),w.lastResult=false,w.isEvaluating=false,u?.(d,M),false}}async function a(d){let R=t[d];if(!R)return false;let w=l(d),M=R.timeout??y;if(w.isEvaluating=true,w.error=null,R.deps?.length){let A=new Set(R.deps);E(d,A),C.set(d,A);}try{let A=R.when(c),ee=await me(A,M,`Constraint "${d}" timed out after ${M}ms`);return w.lastResult=ee,ee&&(w.hitCount++,w.lastActiveAt=Date.now()),w.isEvaluating=!1,s?.(d,ee),ee}catch(A){return w.error=A instanceof Error?A:new Error(String(A)),w.lastResult=false,w.isEvaluating=false,u?.(d,A),false}}let v=10;function T(d,R){if(d==null)return [];if(Array.isArray(d)){let w=d.filter(M=>M!=null);return process.env.NODE_ENV!=="production"&&w.length>v&&R&&console.warn(`[Directive] Constraint "${R}" produced ${w.length} requirements. Consider splitting into multiple constraints for better performance.`),w}return [d]}function F(d){let R=t[d];if(!R)return {requirements:[],deps:new Set};let w=R.require;if(typeof w=="function"){let{value:A,deps:ee}=ge(()=>w(c));return {requirements:T(A,d),deps:ee}}return {requirements:T(w,d),deps:new Set}}function H(d,R){if(R.size===0)return;let w=D.get(d)??new Set;for(let M of R)w.add(M),m.has(M)||m.set(M,new Set),m.get(M).add(d);D.set(d,w);}let J=null;function I(){return J||(J=Object.keys(t).sort((d,R)=>{let w=l(d),A=l(R).priority-w.priority;if(A!==0)return A;let ee=$.get(d)??0,r=$.get(R)??0;return ee-r})),J}for(let d of Object.keys(t))o(d);if(process.env.NODE_ENV!=="production")for(let[d,R]of Object.entries(t))R.async&&!R.deps&&console.warn(`[Directive] Async constraint "${d}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function L(d){let R=h.get(d);if(!R||R.after.length===0)return true;for(let w of R.after)if(t[w]&&!g.has(w)&&!O.has(w)&&!K.has(w))return false;return true}return {async evaluate(d){let R=new de;O.clear();let w=I().filter(b=>!g.has(b)),M;if(!z||!d||d.size===0)M=w,z=true;else {let b=new Set;for(let W of d){let B=m.get(W);if(B)for(let V of B)g.has(V)||b.add(V);}for(let W of S)g.has(W)||b.add(W);S.clear(),M=[...b];for(let W of w)if(!b.has(W)){let B=P.get(W);if(B)for(let V of B)R.add(V);}}function A(b,W){if(g.has(b))return;let B=C.get(b);if(!W){B!==void 0&&E(b,B),O.add(b),P.set(b,[]);return}O.delete(b);let V,Z;try{let Q=F(b);V=Q.requirements,Z=Q.deps;}catch(Q){u?.(b,Q),B!==void 0&&E(b,B),P.set(b,[]);return}if(B!==void 0){let Q=new Set(B);for(let Y of Z)Q.add(Y);E(b,Q);}else H(b,Z);if(V.length>0){let Q=i[b],Y=V.map(te=>De(te,b,Q));for(let te of Y)R.add(te);P.set(b,Y);}else P.set(b,[]);}async function ee(b){let W=[],B=[];for(let Y of b)if(L(Y))B.push(Y);else {W.push(Y);let te=P.get(Y);if(te)for(let X of te)R.add(X);}if(B.length===0)return W;let V=[],Z=[];for(let Y of B)l(Y).isAsync?Z.push(Y):V.push(Y);let Q=[];for(let Y of V){let te=q(Y);if(te instanceof Promise){Q.push({id:Y,promise:te});continue}A(Y,te);}if(Q.length>0){let Y=await Promise.all(Q.map(async({id:te,promise:X})=>({id:te,active:await X})));for(let{id:te,active:X}of Y)A(te,X);}if(Z.length>0){let Y=await Promise.all(Z.map(async te=>({id:te,active:await a(te)})));for(let{id:te,active:X}of Y)A(te,X);}return W}let r=M,p=M.length+1;for(;r.length>0&&p>0;){let b=r.length;if(r=await ee(r),r.length===b)break;p--;}return R.all()},getState(d){return h.get(d)},getDependencies(d){return D.get(d)},getAllStates(){return [...h.values()]},disable(d){if(!h.has(d)){console.warn(`[Directive] constraints.disable("${d}") \u2014 no such constraint`);return}g.add(d),J=null,P.delete(d);let R=D.get(d);if(R){for(let w of R){let M=m.get(w);M&&(M.delete(d),M.size===0&&m.delete(w));}D.delete(d);}C.delete(d);},enable(d){if(!h.has(d)){console.warn(`[Directive] constraints.enable("${d}") \u2014 no such constraint`);return}g.delete(d),J=null,S.add(d);},isDisabled(d){return g.has(d)},invalidate(d){let R=m.get(d);if(R)for(let w of R)S.add(w);},markResolved(d){K.add(d);let R=h.get(d);R&&(R.lastResolvedAt=Date.now());let w=k.get(d);if(w)for(let M of w)S.add(M);},isResolved(d){return K.has(d)},registerDefinitions(d){let R=false;for(let[w,M]of Object.entries(d))t[w]=M,o(w),S.add(w),M.after?.length&&(R=true);J=null,R&&x(),j();},assignDefinition(d,R){if(!t[d])throw new Error(`[Directive] Cannot assign constraint "${d}" \u2014 it does not exist. Use register() to create it.`);t[d]=R,o(d),S.add(d),J=null,x(),j();},unregisterDefinition(d){if(!t[d])return;delete t[d],h.delete(d),g.delete(d),f.delete(d),S.delete(d),O.delete(d),K.delete(d),P.delete(d),C.delete(d);let R=D.get(d);if(R){for(let w of R){let M=m.get(w);M&&(M.delete(d),M.size===0&&m.delete(w));}D.delete(d);}k.delete(d);for(let w of k.values())w.delete(d);J=null,x(),j();},async callOne(d,R){if(!t[d])throw new Error(`[Directive] Cannot call constraint "${d}" \u2014 it does not exist.`);if(g.has(d))return [];let M=l(d),A;if(M.isAsync)A=await a(d);else {let b=q(d);A=b instanceof Promise?await b:b;}if(!A)return [];let{requirements:ee}=F(d);if(ee.length===0)return [];let r=i[d],p=[];for(let b of ee){let W=R?{...b,...R}:b;p.push(De(W,d,r));}return p}}}function Ee(n){let{definitions:t,facts:c,store:i,onCompute:y,onInvalidate:s,onError:u}=n,h=new Map,g=new Map,f=new Map,D=new Map,m=0,S=new Set,C=false,P=100,z;function K(e){if(!t[e])throw new Error(`[Directive] Unknown derivation: ${e}`);let l={id:e,compute:()=>k(e),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return h.set(e,l),l}function O(e){return h.get(e)??K(e)}function k(e){let o=O(e),l=t[e];if(!l)throw new Error(`[Directive] Unknown derivation: ${e}`);if(o.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${e}`);o.isComputing=true;try{let E=o.cachedValue,{value:q,deps:a}=ge(()=>l(c,z));return o.cachedValue=q,o.isStale=!1,N(e,a),y?.(e,q,E,[...a]),q}catch(E){throw u?.(e,E),E}finally{o.isComputing=false;}}function N(e,o){let l=O(e),E=l.dependencies;if(E.size===o.size){let q=true;for(let a of o)if(!E.has(a)){q=false;break}if(q)return}for(let q of E)if(h.has(q)){let a=D.get(q);a?.delete(e),a&&a.size===0&&D.delete(q);}else {let a=f.get(q);a?.delete(e),a&&a.size===0&&f.delete(q);}for(let q of o)t[q]?(D.has(q)||D.set(q,new Set),D.get(q).add(e)):(f.has(q)||f.set(q,new Set),f.get(q).add(e));l.dependencies=o;}function $(){if(!(m>0||C)){C=true;try{let e=0;for(;S.size>0;){if(++e>P){let l=[...S];throw S.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${P} iterations. Remaining: ${l.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let o=[...S];S.clear();for(let l of o)g.get(l)?.forEach(E=>E());}}finally{C=false;}}}function j(e,o=new Set){let l=[e];for(;l.length>0;){let E=l.pop();if(o.has(E))continue;o.add(E);let q=h.get(E);if(!q||q.isStale)continue;q.isStale=true,s?.(E),S.add(E);let a=D.get(E);if(a)for(let v of a)l.push(v);}}return z=new Proxy({},{get(e,o){if(typeof o=="symbol"||G.has(o)||!t[o])return;pe(o);let l=O(o);return l.isStale&&k(o),l.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(e){let o=O(e);return o.isStale&&k(e),o.cachedValue},isStale(e){return h.get(e)?.isStale??true},invalidate(e){let o=f.get(e);if(!o)return;m++;let l=new Set;try{for(let E of o)j(E,l);}finally{m--,$();}},invalidateMany(e){m++;let o=new Set;try{for(let l of e){let E=f.get(l);if(E)for(let q of E)j(q,o);}}finally{m--,$();}},invalidateAll(){m++;try{for(let e of h.values())e.isStale||(e.isStale=!0,S.add(e.id));}finally{m--,$();}},subscribe(e,o){for(let l of e){let E=l;g.has(E)||g.set(E,new Set),g.get(E).add(o);}return ()=>{for(let l of e){let E=l,q=g.get(E);q?.delete(o),q&&q.size===0&&g.delete(E);}}},getProxy(){return z},getDependencies(e){return O(e).dependencies},registerDefinitions(e){for(let[o,l]of Object.entries(e))t[o]=l,K(o);},assignDefinition(e,o){if(!t[e])throw new Error(`[Directive] Cannot assign derivation "${e}" \u2014 it does not exist. Use register() to create it.`);t[e]=o;let l=h.get(e);l&&(l.isStale=true,S.add(e)),$();},unregisterDefinition(e){if(!t[e])return;let o=h.get(e);if(o)for(let E of o.dependencies)if(h.has(E)){let q=D.get(E);q?.delete(e),q&&q.size===0&&D.delete(E);}else {let q=f.get(E);q?.delete(e),q&&q.size===0&&f.delete(E);}let l=D.get(e);if(l){m++;try{for(let E of l)j(E);}finally{m--;}D.delete(e);}delete t[e],h.delete(e),g.delete(e),S.delete(e),$();},callOne(e){if(!t[e])throw new Error(`[Directive] Cannot call derivation "${e}" \u2014 it does not exist.`);return k(e)}}}var Pt=3;function Me(n){let{definitions:t,facts:c,store:i,onRun:y,onError:s}=n,u=new Map,h=null,g=false;function f(O){let k=t[O];if(!k)throw new Error(`[Directive] Unknown effect: ${O}`);let N={id:O,enabled:true,hasExplicitDeps:!!k.deps,dependencies:k.deps?new Set(k.deps):null,cleanup:null,stableRunCount:0,depsStable:false};return u.set(O,N),N}function D(O){return u.get(O)??f(O)}function m(){return i.toObject()}function S(O,k){let N=D(O);if(!N.enabled)return false;if(N.dependencies){for(let $ of N.dependencies)if(k.has($))return N.depsStable&&(N.depsStable=false,N.stableRunCount=0),true;return false}return true}function C(O){if(O.cleanup){try{O.cleanup();}catch(k){s?.(O.id,k),console.error(`[Directive] Effect "${O.id}" cleanup threw an error:`,k);}O.cleanup=null;}}function P(O,k){if(typeof k=="function")if(g)try{k();}catch(N){s?.(O.id,N),console.error(`[Directive] Effect "${O.id}" cleanup threw an error:`,N);}else O.cleanup=k;}async function z(O){let k=D(O),N=t[O];if(!(!k.enabled||!N)){C(k),y?.(O,k.dependencies?[...k.dependencies]:[]);try{if(k.hasExplicitDeps){let $;if(i.batch(()=>{$=N.run(c,h);}),$ instanceof Promise){let j=await $;P(k,j);}else P(k,$);}else if(k.depsStable&&k.dependencies){let $;if(i.batch(()=>{$=N.run(c,h);}),$ instanceof Promise){let j=await $;P(k,j);}else P(k,$);}else {let $,j=ge(()=>(i.batch(()=>{$=N.run(c,h);}),$)),x=j.deps,e=j.value;if(e instanceof Promise&&(e=await e),P(k,e),k.dependencies&&x.size===k.dependencies.size){let o=!0;for(let l of x)if(!k.dependencies.has(l)){o=!1;break}o?(k.stableRunCount++,k.stableRunCount>=Pt&&(k.depsStable=!0)):(k.stableRunCount=0,k.depsStable=!1);}else k.stableRunCount=0,k.depsStable=!1;k.dependencies=x.size>0?x:null;}}catch($){s?.(O,$),console.error(`[Directive] Effect "${O}" threw an error:`,$),k.hasExplicitDeps||(k.stableRunCount=0,k.depsStable=false);}}}for(let O of Object.keys(t))f(O);return {async runEffects(O){let k=[];for(let N of Object.keys(t))S(N,O)&&k.push(N);await Promise.all(k.map(z)),h=m();},async runAll(){let O=Object.keys(t);await Promise.all(O.map(k=>{let N=D(k);return N.enabled?(N.depsStable=false,N.stableRunCount=0,z(k)):Promise.resolve()})),h=m();},disable(O){let k=D(O);k.enabled=false;},enable(O){let k=D(O);k.enabled=true;},isEnabled(O){return D(O).enabled},cleanupAll(){g=true;for(let O of u.values())C(O);},registerDefinitions(O){for(let[k,N]of Object.entries(O))t[k]=N,f(k);},assignDefinition(O,k){if(!t[O])throw new Error(`[Directive] Cannot assign effect "${O}" \u2014 it does not exist. Use register() to create it.`);let N=u.get(O);N&&C(N),t[O]=k,f(O);},unregisterDefinition(O){if(!t[O])return;let k=u.get(O);k&&C(k),delete t[O],u.delete(O);},async callOne(O){let k=t[O];if(!k)throw new Error(`[Directive] Cannot call effect "${O}" \u2014 it does not exist.`);let N=D(O);if(N.enabled){C(N),y?.(O,N.dependencies?[...N.dependencies]:[]);try{let $;if(i.batch(()=>{$=k.run(c,h);}),$ instanceof Promise){let j=await $;P(N,j);}else P(N,$);}catch($){s?.(O,$),console.error(`[Directive] Effect "${O}" threw an error:`,$);}}}}}function Ue(n){let{mergedDerive:t,getDerivation:c,definitions:i}=n,y={register:(s,u)=>i.register("derivation",s,u),assign:(s,u)=>i.assign("derivation",s,u),unregister:s=>i.unregister("derivation",s),call:s=>i.call("derivation",s),isDynamic:s=>i.isDynamic("derivation",s),listDynamic:()=>i.listDynamic("derivation")};return new Proxy({},{get(s,u){if(typeof u!="symbol"&&!G.has(u)){if(u in y)return y[u];if(u in t)return c(u)}},has(s,u){return typeof u=="symbol"||G.has(u)?false:u in t||u in y},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(s,u){if(typeof u!="symbol"&&!G.has(u)&&(u in t||u in y))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Le(n){let{mergedEvents:t,dispatchEvent:c}=n;return new Proxy({},{get(i,y){if(typeof y!="symbol"&&!G.has(y))return s=>{c(y,s);}},has(i,y){return typeof y=="symbol"||G.has(y)?false:y in t},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(i,y){if(typeof y!="symbol"&&!G.has(y)&&y in t)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}var Je=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]);function Xe(n){let{mergedConstraints:t,mergedResolvers:c,mergedDerive:i,mergedEffects:y,constraintsManager:s,resolversManager:u,derivationsManager:h,effectsManager:g,pluginManager:f,getState:D,scheduleReconcile:m,maxDeferredRegistrations:S}=n,C={constraints:new Set,resolvers:new Set,derivations:new Set,effects:new Set},P={constraints:new Map,resolvers:new Map,derivations:new Map,effects:new Map},z=[];function K(x){if(typeof x!="string"||x.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String(x)}`);if(G.has(x))throw new Error(`[Directive] Security: Definition ID "${x}" is a blocked property.`);if(x.includes("::"))throw new Error(`[Directive] Definition ID "${x}" cannot contain "::". This separator is reserved for namespacing.`)}function O(x,e,o){switch(x){case "constraint":{if(e in t)throw new Error(`[Directive] Constraint "${e}" already exists. Use assign() to override.`);let l=o;t[e]=l,s.registerDefinitions({[e]:l}),C.constraints.add(e),f.emitDefinitionRegister(x,e,o),m();break}case "resolver":{if(e in c)throw new Error(`[Directive] Resolver "${e}" already exists. Use assign() to override.`);let l=o;c[e]=l,u.registerDefinitions({[e]:l}),C.resolvers.add(e),f.emitDefinitionRegister(x,e,o),m();break}case "derivation":{if(Je.has(e))throw new Error(`[Directive] Derivation ID "${e}" conflicts with a reserved derive method name.`);if(e in i)throw new Error(`[Directive] Derivation "${e}" already exists. Use assign() to override.`);i[e]=o,h.registerDefinitions({[e]:o}),C.derivations.add(e),f.emitDefinitionRegister(x,e,o);break}case "effect":{if(e in y)throw new Error(`[Directive] Effect "${e}" already exists. Use assign() to override.`);let l=o;y[e]=l,g.registerDefinitions({[e]:l}),C.effects.add(e),f.emitDefinitionRegister(x,e,o);break}}}function k(x,e,o){switch(x){case "constraint":{if(!(e in t))throw new Error(`[Directive] Constraint "${e}" does not exist. Use register() to create it.`);let l=t[e];s.assignDefinition(e,o),P.constraints.set(e,l),t[e]=o,f.emitDefinitionAssign(x,e,o,l),m();break}case "resolver":{if(!(e in c))throw new Error(`[Directive] Resolver "${e}" does not exist. Use register() to create it.`);let l=c[e];u.assignDefinition(e,o),P.resolvers.set(e,l),c[e]=o,f.emitDefinitionAssign(x,e,o,l),m();break}case "derivation":{if(Je.has(e))throw new Error(`[Directive] Derivation ID "${e}" conflicts with a reserved derive method name.`);if(!(e in i))throw new Error(`[Directive] Derivation "${e}" does not exist. Use register() to create it.`);let l=i[e];h.assignDefinition(e,o),P.derivations.set(e,l),i[e]=o,f.emitDefinitionAssign(x,e,o,l);break}case "effect":{if(!(e in y))throw new Error(`[Directive] Effect "${e}" does not exist. Use register() to create it.`);let l=y[e];g.assignDefinition(e,o),P.effects.set(e,l),y[e]=o,f.emitDefinitionAssign(x,e,o,l);break}}}function N(x,e){switch(x){case "constraint":{if(!C.constraints.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static constraint "${e}". Only dynamically registered constraints can be removed.`);return}s.unregisterDefinition(e),delete t[e],C.constraints.delete(e),P.constraints.delete(e),f.emitDefinitionUnregister(x,e),m();break}case "resolver":{if(!C.resolvers.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static resolver "${e}". Only dynamically registered resolvers can be removed.`);return}u.unregisterDefinition(e),delete c[e],C.resolvers.delete(e),P.resolvers.delete(e),f.emitDefinitionUnregister(x,e);break}case "derivation":{if(!C.derivations.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static derivation "${e}". Only dynamically registered derivations can be removed.`);return}h.unregisterDefinition(e),delete i[e],C.derivations.delete(e),P.derivations.delete(e),f.emitDefinitionUnregister(x,e);break}case "effect":{if(!C.effects.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static effect "${e}". Only dynamically registered effects can be removed.`);return}g.unregisterDefinition(e),delete y[e],C.effects.delete(e),P.effects.delete(e),f.emitDefinitionUnregister(x,e);break}}}function $(){if(z.length===0)return;let x=z.splice(0);for(let e of x)try{switch(e.op){case "register":O(e.type,e.id,e.def);break;case "assign":k(e.type,e.id,e.def);break;case "unregister":N(e.type,e.id);break}}catch(o){process.env.NODE_ENV!=="production"&&console.error(`[Directive] Error in deferred ${e.op} for ${e.type} "${e.id}":`,o);}}function j(x,e,o,l){let{isDestroyed:E,isReconciling:q}=D();if(E)throw new Error(`[Directive] Cannot ${x} ${e} "${o}" on a destroyed system.`);if(K(o),q){if(z.length>=S)throw new Error(`[Directive] Too many deferred registrations (max ${S}). Avoid calling register/assign/unregister in resolver or effect callbacks during reconciliation.`);x==="unregister"?z.push({op:x,type:e,id:o}):z.push({op:x,type:e,id:o,def:l});return}switch(x){case "register":O(e,o,l);break;case "assign":k(e,o,l);break;case "unregister":N(e,o);break}}return {register(x,e,o){j("register",x,e,o);},assign(x,e,o){j("assign",x,e,o);},unregister(x,e){j("unregister",x,e);},call(x,e,o){let{isDestroyed:l}=D();if(l)throw new Error(`[Directive] Cannot call ${x} "${e}" on a destroyed system.`);switch(K(e),f.emitDefinitionCall(x,e,o),x){case "constraint":return s.callOne(e,o);case "resolver":return u.callOne(e,o);case "derivation":return h.callOne(e);case "effect":return g.callOne(e)}},isDynamic(x,e){switch(x){case "constraint":return C.constraints.has(e);case "resolver":return C.resolvers.has(e);case "derivation":return C.derivations.has(e);case "effect":return C.effects.has(e)}},listDynamic(x){switch(x){case "constraint":return [...C.constraints];case "resolver":return [...C.resolvers];case "derivation":return [...C.derivations];case "effect":return [...C.effects]}},flushDeferred:$,getOriginal(x,e){let l={constraint:P.constraints,resolver:P.resolvers,derivation:P.derivations,effect:P.effects}[x];if(l)return l.get(e)},restoreOriginal(x,e){let l={constraint:P.constraints,resolver:P.resolvers,derivation:P.derivations,effect:P.effects}[x];if(!l||!l.has(e))return false;let E=l.get(e);return j("assign",x,e,E),l.delete(e),true},destroy(){z.length=0,C.constraints.clear(),C.resolvers.clear(),C.derivations.clear(),C.effects.clear(),P.constraints.clear(),P.resolvers.clear(),P.derivations.clear(),P.effects.clear();}}}function Ge(n){let{traceConfig:t,pluginManager:c}=n;if(!(t===true||typeof t=="object"&&t!==null))return {enabled:false,recordFactChange(){},startRun(){return 0},currentTrace:null,getEntries(){return null},attributeResolverStart(){},recordResolverComplete(){},recordResolverError(){},decrementInflight(){},finalizeCurrentRun(){},drainPendingChanges(){},destroy(){}};let y=(typeof t=="object"&&t!==null?t.maxRuns:void 0)??100,s=[],u=new Map,h=0,g=null,f=[],D=new Map,m=new Map,S=new Map,C=null,P=0,z=0,K={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0};function O(e){let o=u.get(e);if(o&&o.status==="pending"){o.status="settled";let l=S.get(e);o.duration=l!==void 0?performance.now()-l:Date.now()-o.timestamp,S.delete(e),m.delete(e),o.causalChain=$(o),j(o),z++,c.emitTraceComplete(o);}}function k(e){let o=D.get(e);if(D.delete(e),o!==void 0){let l=(m.get(o)??1)-1;l<=0?O(o):m.set(o,l);}}function N(){let e=s.shift();if(e&&(u.delete(e.id),S.delete(e.id),e.status==="pending")){m.delete(e.id);for(let[o,l]of D)l===e.id&&D.delete(o);}}function $(e){let o=[];for(let l of e.factChanges)o.push(`${l.key} changed`);for(let l of e.derivationsRecomputed)o.push(`${l.id} recomputed`);for(let l of e.constraintsHit)o.push(`${l.id} constraint hit`);for(let l of e.requirementsAdded)o.push(`${l.type} requirement added`);for(let l of e.resolversCompleted)o.push(`${l.resolver} resolved (${l.duration.toFixed(0)}ms)`);for(let l of e.resolversErrored)o.push(`${l.resolver} errored`);for(let l of e.effectsRun)o.push(`${l.id} effect ran`);return o.join(" \u2192 ")}function j(e){K.count++,K.totalDuration+=e.duration,K.avgDuration=K.totalDuration/K.count,e.duration>K.maxDuration&&(K.maxDuration=e.duration);let o=e.resolversStarted.length;K.totalResolverCount+=o,K.avgResolverCount=K.totalResolverCount/K.count;let l=e.factChanges.length;K.totalFactChangeCount+=l,K.avgFactChangeCount=K.totalFactChangeCount/K.count;let E=[];K.count>3&&e.duration>K.avgDuration*5&&E.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${K.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&E.push(`${e.resolversErrored.length} resolver(s) errored`),E.length>0&&(e.anomalies=E);}return {enabled:true,get currentTrace(){return g},set currentTrace(e){g=e;},recordFactChange(e,o,l){f.push({key:e,oldValue:o,newValue:l});},startRun(){let e=performance.now(),o=++h;return S.set(o,e),g={id:o,timestamp:Date.now(),duration:0,status:"pending",factChanges:f.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]},e},getEntries(){return (!C||P!==z)&&(C=[...s],P=z),C},attributeResolverStart(e){g&&D.set(e,g.id);},recordResolverComplete(e,o,l){let E=D.get(e);if(E!==void 0){let q=u.get(E);q&&q.resolversCompleted.push({resolver:o,requirementId:e,duration:l});}},recordResolverError(e,o,l){let E=D.get(e);if(E!==void 0){let q=u.get(E);q&&q.resolversErrored.push({resolver:o,requirementId:e,error:l});}},decrementInflight(e){k(e);},finalizeCurrentRun(e){if(!g)return;if(g.duration=performance.now()-e,g.factChanges.length>0||g.constraintsHit.length>0||g.requirementsAdded.length>0||g.effectsRun.length>0){let l=g.resolversStarted.length;l===0?(g.status="settled",g.causalChain=$(g),j(g),s.push(g),u.set(g.id,g),s.length>y&&N(),z++,c.emitTraceComplete(g)):(g.status="pending",s.push(g),u.set(g.id,g),s.length>y&&N(),z++,m.set(g.id,l));}else S.delete(g.id);g=null;},drainPendingChanges(){f.length=0;},destroy(){s.length=0,u.clear(),D.clear(),m.clear(),S.clear(),f.length=0,g=null,C=null;}}}function Ye(n={}){let{delayMs:t=1e3,maxRetries:c=3,backoffMultiplier:i=2,maxDelayMs:y=3e4}=n,s=new Map;function u(h){let g=t*i**(h-1);return Math.min(g,y)}return {scheduleRetry(h,g,f,D,m){if(D>c)return null;let S=u(D),C={source:h,sourceId:g,context:f,attempt:D,nextRetryTime:Date.now()+S,callback:m};return s.set(g,C),C},getPendingRetries(){return Array.from(s.values())},processDueRetries(){let h=Date.now(),g=[];for(let[f,D]of s)D.nextRetryTime<=h&&(g.push(D),s.delete(f));return g},cancelRetry(h){s.delete(h);},clearAll(){s.clear();}}}var It={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function xe(n={}){let{config:t={},onError:c,onRecovery:i}=n,y=[],s=100,u=Ye(t.retryLater),h=new Map,g=1e3;function f(S,C,P,z){if(P instanceof ye)return P;let K=P instanceof Error?P.message:String(P),O=S!=="system";return new ye(K,S,C,z,O)}function D(S,C,P){let z=(()=>{switch(S){case "constraint":return t.onConstraintError;case "resolver":return t.onResolverError;case "effect":return t.onEffectError;case "derivation":return t.onDerivationError;default:return}})();if(typeof z=="function"){try{let K=z(P,C);if(typeof K=="string")return K}catch(K){console.error("[Directive] Error in error handler callback:",K);}return "skip"}return typeof z=="string"?z:It[S]}return {handleError(S,C,P,z){let K=f(S,C,P,z);y.push(K),y.length>s&&y.shift();try{c?.(K);}catch(k){console.error("[Directive] Error in onError callback:",k);}try{t.onError?.(K);}catch(k){console.error("[Directive] Error in config.onError callback:",k);}let O=D(S,C,P instanceof Error?P:new Error(String(P)));if(O==="retry-later"){let k=(h.get(C)??0)+1;if(h.set(C,k),h.size>g){let $=h.keys().next().value;$!==void 0&&h.delete($);}u.scheduleRetry(S,C,z,k)||(O="skip",h.delete(C),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${S} "${C}" exceeded max retry-later attempts. Skipping.`));}try{i?.(K,O);}catch(k){console.error("[Directive] Error in onRecovery callback:",k);}if(O==="throw")throw K;return O},getLastError(){return y[y.length-1]??null},getAllErrors(){return [...y]},clearErrors(){y.length=0;},getRetryLaterManager(){return u},processDueRetries(){return u.processDueRetries()},clearRetryAttempts(S){h.delete(S),u.cancelRetry(S);}}}function qt(n,t=100){try{return JSON.stringify(n)?.slice(0,t)??String(n)}catch{return "[circular or non-serializable]"}}function Ze(n){let{schema:t,onChange:c,onBatch:i}=n,s=Object.keys(t).length===0,u=n.validate??process.env.NODE_ENV!=="production",h=n.strictKeys??(process.env.NODE_ENV!=="production"&&!s),g=n.redactErrors??false,f=new Map,D=new Set,m=new Map,S=new Set,C=0,P=[],z=new Set,K=false,O=[],k=100;function N(a){return a!==null&&typeof a=="object"&&"safeParse"in a&&typeof a.safeParse=="function"&&"_def"in a&&"parse"in a&&typeof a.parse=="function"}function $(a){let v=a;if(v._typeName)return v._typeName;if(N(a)){let T=a._def;if(T?.typeName)return T.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function j(a){return g?"[redacted]":qt(a)}function x(a,v){if(!u)return;let T=t[a];if(!T){if(h)throw new Error(`[Directive] Unknown fact key: "${a}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${a}"`);return}if(N(T)){let I=T.safeParse(v);if(!I.success){let L=v===null?"null":Array.isArray(v)?"array":typeof v,_=j(v),d=I.error?.message??I.error?.issues?.[0]?.message??"Validation failed",R=$(T);throw new Error(`[Directive] Validation failed for "${a}": expected ${R}, got ${L} ${_}. ${d}`)}return}let F=T,H=F._validators;if(!H||!Array.isArray(H)||H.length===0)return;let J=F._typeName??"unknown";for(let I=0;I<H.length;I++){let L=H[I];if(typeof L=="function"&&!L(v)){let _=v===null?"null":Array.isArray(v)?"array":typeof v,d=j(v),R="";typeof F._lastFailedIndex=="number"&&F._lastFailedIndex>=0&&(R=` (element at index ${F._lastFailedIndex} failed)`,F._lastFailedIndex=-1);let w=I===0?"":` (validator ${I+1} failed)`;throw new Error(`[Directive] Validation failed for "${a}": expected ${J}, got ${_} ${d}${w}${R}`)}}}function e(a){m.get(a)?.forEach(v=>v());}function o(){S.forEach(a=>a());}function l(a,v,T){if(K){O.push({key:a,value:v,prev:T});return}K=true;try{c?.(a,v,T),e(a),o();let F=0;for(;O.length>0;){if(++F>k)throw O.length=0,new Error(`[Directive] Infinite notification loop detected after ${k} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let H=[...O];O.length=0;for(let J of H)c?.(J.key,J.value,J.prev),e(J.key);o();}}finally{K=false;}}function E(){if(!(C>0)){if(i&&P.length>0&&i([...P]),z.size>0){K=true;try{for(let v of z)e(v);o();let a=0;for(;O.length>0;){if(++a>k)throw O.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${k} iterations.`);let v=[...O];O.length=0;for(let T of v)c?.(T.key,T.value,T.prev),e(T.key);o();}}finally{K=false;}}P.length=0,z.clear();}}let q={get(a){return pe(a),f.get(a)},has(a){return pe(a),f.has(a)},set(a,v){x(a,v);let T=f.get(a);Object.is(T,v)||(f.set(a,v),D.add(a),C>0?(P.push({key:a,value:v,prev:T,type:"set"}),z.add(a)):l(a,v,T));},delete(a){let v=f.get(a);f.delete(a),D.delete(a),C>0?(P.push({key:a,value:void 0,prev:v,type:"delete"}),z.add(a)):l(a,void 0,v);},batch(a){C++;try{a();}finally{C--,E();}},subscribe(a,v){for(let T of a){let F=T;m.has(F)||m.set(F,new Set),m.get(F).add(v);}return ()=>{for(let T of a){let F=m.get(T);F&&(F.delete(v),F.size===0&&m.delete(T));}}},subscribeAll(a){return S.add(a),()=>S.delete(a)},toObject(){let a={};for(let v of D)f.has(v)&&(a[v]=f.get(v));return a}};return q.destroy=()=>{m.clear(),S.clear();},q.registerKeys=a=>{for(let v of Object.keys(a))G.has(v)||(t[v]=a[v],D.add(v));},q}function Qe(n,t,c=t){return new Proxy(n,{get(i,y){let s=Reflect.get(i,y);return typeof y=="symbol"||typeof s!="object"||s===null?s:Qe(s,t,`${c}.${String(y)}`)},set(i,y,s){return typeof y!="symbol"&&console.warn(`[Directive] Nested mutation on "facts.${c}.${String(y)}" will not trigger reactivity. Use: facts.${t} = { ...facts.${t}, ... }`),Reflect.set(i,y,s)}})}function et(n,t){let c=()=>({get:y=>Se(()=>n.get(y)),has:y=>Se(()=>n.has(y))});return new Proxy({},{get(y,s){if(s==="$store")return n;if(s==="$snapshot")return c;if(typeof s=="symbol"||G.has(s))return;let u=n.get(s);return process.env.NODE_ENV!=="production"&&u!==null&&typeof u=="object"?Qe(u,s):u},set(y,s,u){return typeof s=="symbol"||s==="$store"||s==="$snapshot"||G.has(s)?false:(n.set(s,u),true)},deleteProperty(y,s){return typeof s=="symbol"||s==="$store"||s==="$snapshot"||G.has(s)?false:(n.delete(s),true)},has(y,s){return s==="$store"||s==="$snapshot"?true:typeof s=="symbol"||G.has(s)?false:n.has(s)},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(y,s){return s==="$store"||s==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Ce(n){let t=Ze(n),c=et(t,n.schema);return {store:t,facts:c}}function Te(){let n=[];function t(s){if(s)try{return s()}catch(u){console.error("[Directive] Plugin error:",u);return}}async function c(s){if(s)try{return await s()}catch(u){console.error("[Directive] Plugin error:",u);return}}function i(s){return (...u)=>{for(let h of n)t(()=>h[s]?.(...u));}}return {register(s){n.some(u=>u.name===s.name)&&(console.warn(`[Directive] Plugin "${s.name}" is already registered, replacing...`),this.unregister(s.name)),n.push(s);},unregister(s){let u=n.findIndex(h=>h.name===s);u!==-1&&n.splice(u,1);},getPlugins(){return [...n]},async emitInit(s){for(let u of n)await c(()=>u.onInit?.(s));},emitStart:i("onStart"),emitStop:i("onStop"),emitDestroy:i("onDestroy"),emitFactSet:i("onFactSet"),emitFactDelete:i("onFactDelete"),emitFactsBatch:i("onFactsBatch"),emitDerivationCompute:i("onDerivationCompute"),emitDerivationInvalidate:i("onDerivationInvalidate"),emitReconcileStart:i("onReconcileStart"),emitReconcileEnd:i("onReconcileEnd"),emitConstraintEvaluate:i("onConstraintEvaluate"),emitConstraintError:i("onConstraintError"),emitRequirementCreated:i("onRequirementCreated"),emitRequirementMet:i("onRequirementMet"),emitRequirementCanceled:i("onRequirementCanceled"),emitResolverStart:i("onResolverStart"),emitResolverComplete:i("onResolverComplete"),emitResolverError:i("onResolverError"),emitResolverRetry:i("onResolverRetry"),emitResolverCancel:i("onResolverCancel"),emitEffectRun:i("onEffectRun"),emitEffectError:i("onEffectError"),emitSnapshot:i("onSnapshot"),emitHistoryNavigate:i("onHistoryNavigate"),emitError:i("onError"),emitErrorRecovery:i("onErrorRecovery"),emitDefinitionRegister:i("onDefinitionRegister"),emitDefinitionAssign:i("onDefinitionAssign"),emitDefinitionUnregister:i("onDefinitionUnregister"),emitDefinitionCall:i("onDefinitionCall"),emitTraceComplete:i("onTraceComplete")}}var tt={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},nt={enabled:false,windowMs:50};function At(n,t){let{backoff:c,initialDelay:i=100,maxDelay:y=3e4}=n,s;switch(c){case "none":s=i;break;case "linear":s=i*t;break;case "exponential":s=i*2**(t-1);break;default:s=i;}return Math.max(1,Math.min(s,y))}function Oe(n){let{definitions:t,facts:c,store:i,onStart:y,onComplete:s,onError:u,onRetry:h,onCancel:g,onResolutionComplete:f}=n;if(process.env.NODE_ENV!=="production")for(let[a,v]of Object.entries(t)){if(!v.resolve&&!v.resolveBatch&&!v.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${a}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(v.batch?.enabled&&!v.resolveBatch&&!v.resolveBatchWithResults)if(v.resolve)console.warn(`[Directive] Resolver "${a}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${a}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let D=new Map,m=new Map,S=1e3,C=new Map,P=new Map,z=1e3;function K(){if(m.size>S){let a=m.size-S,v=m.keys();for(let T=0;T<a;T++){let F=v.next().value;F&&m.delete(F);}}}function O(a){return typeof a=="object"&&a!==null&&"requirement"in a&&typeof a.requirement=="string"}function k(a){return typeof a=="object"&&a!==null&&"requirement"in a&&typeof a.requirement=="function"}function N(a,v){return O(a)?v.type===a.requirement:k(a)?a.requirement(v):false}function $(a){let v=a.type,T=P.get(v);if(T){P.delete(v),P.set(v,T);for(let F of T){let H=t[F];if(H&&N(H,a))return F}}for(let[F,H]of Object.entries(t))if(N(H,a)){if(!P.has(v)){if(P.size>=z){let J=P.keys().next().value;J!==void 0&&P.delete(J);}P.set(v,new Set);}return P.get(v).add(F),F}return null}function j(a){return {facts:c,signal:a,snapshot:()=>c.$snapshot()}}async function x(a,v,T,F){let H=a instanceof Error?a:new Error(String(a));if(F.signal.aborted)return {action:"abort",error:H};if(T.shouldRetry&&!T.shouldRetry(H,v))return {action:"break",error:H};if(v<T.attempts){if(F.signal.aborted)return {action:"abort",error:H};let J=At(T,v);if(await new Promise(I=>{let L=setTimeout(I,J),_=()=>{clearTimeout(L),I();};F.signal.addEventListener("abort",_,{once:true});}),F.signal.aborted)return {action:"abort",error:H}}return {action:"continue",error:H}}async function e(a,v,T){let F=t[a];if(!F)return;let H={...tt,...F.retry},J=null;for(let I=1;I<=H.attempts;I++){if(T.signal.aborted)return;let L=D.get(v.id);L&&(L.attempt=I,L.status={state:"running",requirementId:v.id,startedAt:L.startedAt,attempt:I});try{let _=j(T.signal);if(F.resolve){let R;i.batch(()=>{R=F.resolve(v.requirement,_);});let w=F.timeout;w&&w>0?await me(R,w,`Resolver "${a}" timed out after ${w}ms`):await R;}let d=Date.now()-(L?.startedAt??Date.now());m.set(v.id,{state:"success",requirementId:v.id,completedAt:Date.now(),duration:d}),K(),s?.(a,v,d);return}catch(_){let d=await x(_,I,H,T);if(J=d.error,d.action==="abort")return;if(d.action==="break")break;I<H.attempts&&h?.(a,v,I+1);}}m.set(v.id,{state:"error",requirementId:v.id,error:J,failedAt:Date.now(),attempts:H.attempts}),K(),u?.(a,v,J);}async function o(a,v){let T=t[a];if(!T)return;if(!T.resolveBatch&&!T.resolveBatchWithResults){await Promise.all(v.map(d=>{let R=new AbortController;return e(a,d,R)}));return}let F={...tt,...T.retry},H={...nt,...T.batch},J=new AbortController,I=Date.now(),L=null,_=H.timeoutMs??T.timeout;for(let d=1;d<=F.attempts;d++){if(J.signal.aborted)return;try{let R=j(J.signal),w=v.map(M=>M.requirement);if(T.resolveBatchWithResults){let M,A;if(i.batch(()=>{A=T.resolveBatchWithResults(w,R);}),_&&_>0?M=await me(A,_,`Batch resolver "${a}" timed out after ${_}ms`):M=await A,M.length!==v.length)throw new Error(`[Directive] Batch resolver "${a}" returned ${M.length} results but expected ${v.length}. Results array must match input order.`);let ee=Date.now()-I,r=!1;for(let p=0;p<v.length;p++){let b=v[p],W=M[p];if(W.success)m.set(b.id,{state:"success",requirementId:b.id,completedAt:Date.now(),duration:ee}),s?.(a,b,ee);else {r=!0;let B=W.error??new Error("Batch item failed");m.set(b.id,{state:"error",requirementId:b.id,error:B,failedAt:Date.now(),attempts:d}),u?.(a,b,B);}}if(!r||v.some((p,b)=>M[b]?.success))return}else {let M;i.batch(()=>{M=T.resolveBatch(w,R);}),_&&_>0?await me(M,_,`Batch resolver "${a}" timed out after ${_}ms`):await M;let A=Date.now()-I;for(let ee of v)m.set(ee.id,{state:"success",requirementId:ee.id,completedAt:Date.now(),duration:A}),s?.(a,ee,A);return}}catch(R){let w=await x(R,d,F,J);if(L=w.error,w.action==="abort")return;if(w.action==="break")break;if(d<F.attempts)for(let M of v)h?.(a,M,d+1);}}for(let d of v)m.set(d.id,{state:"error",requirementId:d.id,error:L,failedAt:Date.now(),attempts:F.attempts}),u?.(a,d,L);K();}function l(a,v){let T=t[a];if(!T)return;let F={...nt,...T.batch};C.has(a)||C.set(a,{resolverId:a,requirements:[],timer:null});let H=C.get(a);if(H.requirements.push(v),F.maxSize&&H.requirements.length>=F.maxSize){H.timer&&(clearTimeout(H.timer),H.timer=null),E(a);return}H.timer&&clearTimeout(H.timer),H.timer=setTimeout(()=>{E(a);},F.windowMs);}function E(a){let v=C.get(a);if(!v||v.requirements.length===0)return;let T=[...v.requirements];v.requirements=[],v.timer=null,o(a,T).then(()=>{f?.();});}return {resolve(a){if(D.has(a.id))return;let v=$(a.requirement);if(!v){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] No resolver found for requirement type "${a.requirement.type}" (id: ${a.id})`);return}let T=t[v];if(!T)return;if(T.batch?.enabled){l(v,a);return}let F=new AbortController,H=Date.now(),J={requirementId:a.id,resolverId:v,controller:F,startedAt:H,attempt:1,status:{state:"pending",requirementId:a.id,startedAt:H},originalRequirement:a};D.set(a.id,J),y?.(v,a),e(v,a,F).finally(()=>{D.delete(a.id)&&f?.();});},cancel(a){let v=D.get(a);if(v){v.controller.abort(),D.delete(a),m.set(a,{state:"canceled",requirementId:a,canceledAt:Date.now()}),K(),g?.(v.resolverId,v.originalRequirement);return}for(let T of C.values()){let F=T.requirements.findIndex(H=>H.id===a);if(F!==-1){let[H]=T.requirements.splice(F,1);m.set(a,{state:"canceled",requirementId:a,canceledAt:Date.now()}),K(),H&&g?.(T.resolverId,H);return}}},cancelAll(){let a=[...D.keys()];for(let v of a)this.cancel(v);for(let v of C.values()){v.timer&&clearTimeout(v.timer);for(let T of v.requirements)m.set(T.id,{state:"canceled",requirementId:T.id,canceledAt:Date.now()}),g?.(v.resolverId,T);}C.clear(),K();},getStatus(a){let v=D.get(a);if(v)return v.status;let T=m.get(a);return T||{state:"idle"}},getInflight(){return [...D.keys()]},getInflightInfo(){return [...D.values()].map(a=>({id:a.requirementId,resolverId:a.resolverId,startedAt:a.startedAt}))},isResolving(a){return D.has(a)},processBatches(){for(let a of C.keys())E(a);},hasPendingBatches(){for(let a of C.values())if(a.requirements.length>0)return true;return false},registerDefinitions(a){for(let[v,T]of Object.entries(a))t[v]=T;P.clear();},assignDefinition(a,v){if(!t[a])throw new Error(`[Directive] Cannot assign resolver "${a}" \u2014 it does not exist. Use register() to create it.`);t[a]=v,P.clear();},unregisterDefinition(a){if(!t[a])return;for(let[T,F]of D)F.resolverId===a&&(F.controller.abort(),D.delete(T),m.set(T,{state:"canceled",requirementId:T,canceledAt:Date.now()}),g?.(a,F.originalRequirement));let v=C.get(a);if(v){v.timer&&clearTimeout(v.timer);for(let T of v.requirements)m.set(T.id,{state:"canceled",requirementId:T.id,canceledAt:Date.now()}),g?.(a,T);C.delete(a);}delete t[a],P.clear(),K();},async callOne(a,v){let T=t[a];if(!T)throw new Error(`[Directive] Cannot call resolver "${a}" \u2014 it does not exist.`);let F=new AbortController,H=j(F.signal);if(T.resolve){let J;i.batch(()=>{J=T.resolve(v,H);}),await J;}},destroy(){this.cancelAll(),m.clear(),P.clear();}}}function we(n){let t=Object.create(null),c=Object.create(null),i=Object.create(null),y=Object.create(null),s=Object.create(null),u=Object.create(null),h=new Map;for(let r of n.modules){let p=(b,W)=>{if(b)for(let B of Object.keys(b)){if(G.has(B))throw new Error(`[Directive] Security: Module "${r.id}" has dangerous key "${B}" in ${W}. This could indicate a prototype pollution attempt.`);if(W==="schema"&&B.startsWith("$"))throw new Error(`[Directive] Module "${r.id}" has schema key "${B}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};if(p(r.schema,"schema"),p(r.events,"events"),p(r.derive,"derive"),p(r.effects,"effects"),p(r.constraints,"constraints"),p(r.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let b of Object.keys(r.schema)){let W=h.get(b);if(W)throw new Error(`[Directive] Schema collision: Fact "${b}" is defined in both module "${W}" and "${r.id}". Use namespacing (e.g., "${r.id}::${b}") or merge into one module.`);h.set(b,r.id);}Object.assign(t,r.schema),r.events&&Object.assign(c,r.events),r.derive&&Object.assign(i,r.derive),r.effects&&Object.assign(y,r.effects),r.constraints&&Object.assign(s,r.constraints),r.resolvers&&Object.assign(u,r.resolvers);}let g=null;if(n.modules.some(r=>r.history?.snapshotEvents)){g=new Set;for(let r of n.modules){let p=r;if(p.history?.snapshotEvents)for(let b of p.history.snapshotEvents)g.add(b);else if(p.events)for(let b of Object.keys(p.events))g.add(b);}}let D=0,m=false;if(process.env.NODE_ENV!=="production"){let r=new Set(Object.keys(i));for(let p of Object.keys(t))r.has(p)&&console.warn(`[Directive] "${p}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let S=Te();for(let r of n.plugins??[])S.register(r);let C=xe({config:n.errorBoundary,onError:r=>S.emitError(r),onRecovery:(r,p)=>S.emitErrorRecovery(r,p)}),P=null,z=()=>{},K=()=>{},O=null,k=Ge({traceConfig:n.trace,pluginManager:S}),N=k.enabled,{store:$,facts:j}=Ce({schema:t,onChange:(r,p,b)=>{S.emitFactSet(r,p,b),z(r),N&&k.recordFactChange(String(r),b,p),!O?.isRestoring&&(D===0&&(m=true),I.changedKeys.add(r),_());},onBatch:r=>{S.emitFactsBatch(r);let p=[];for(let b of r)p.push(b.key);if(N)for(let b of r)k.recordFactChange(b.key,b.prev,b.type==="delete"?void 0:b.value);if(K(p),!O?.isRestoring){D===0&&(m=true);for(let b of r)I.changedKeys.add(b.key);_();}}}),x=Ee({definitions:i,facts:j,store:$,onCompute:(r,p,b,W)=>{S.emitDerivationCompute(r,p,W),k.currentTrace&&k.currentTrace.derivationsRecomputed.push({id:r,deps:W?[...W]:[],oldValue:b,newValue:p});},onInvalidate:r=>S.emitDerivationInvalidate(r),onError:(r,p)=>{C.handleError("derivation",r,p)==="retry"&&x.invalidate(r);}});z=r=>x.invalidate(r),K=r=>x.invalidateMany(r);let e=Me({definitions:y,facts:j,store:$,onRun:(r,p)=>{S.emitEffectRun(r),k.currentTrace&&k.currentTrace.effectsRun.push({id:r,triggeredBy:p});},onError:(r,p)=>{let b=C.handleError("effect",r,p);S.emitEffectError(r,p),k.currentTrace&&k.currentTrace.effectErrors.push({id:r,error:String(p)}),b==="disable"&&e.disable(r),b==="retry"&&(I.changedKeys.add("*"),_());}}),o=ke({definitions:s,facts:j,onEvaluate:(r,p)=>S.emitConstraintEvaluate(r,p),onError:(r,p)=>{let b=C.handleError("constraint",r,p);S.emitConstraintError(r,p),b==="disable"&&o.disable(r);}}),l=Oe({definitions:u,facts:j,store:$,onStart:(r,p)=>S.emitResolverStart(r,p),onComplete:(r,p,b)=>{C.clearRetryAttempts(r),S.emitResolverComplete(r,p,b),S.emitRequirementMet(p,r),o.markResolved(p.fromConstraint),N&&(k.recordResolverComplete(p.id,r,b),k.decrementInflight(p.id));},onError:(r,p,b)=>{let W=C.handleError("resolver",r,b,p);if(S.emitResolverError(r,p,b),W==="disable"&&o.disable(p.fromConstraint),W==="retry"&&(I.previousRequirements.remove(p.id),_()),W==="retry-later"){let V=C.getRetryLaterManager().getPendingRetries().find(Z=>Z.sourceId===r);V&&!V.callback&&(V.callback=()=>{_();});}N&&(k.recordResolverError(p.id,r,String(b)),k.decrementInflight(p.id));},onRetry:(r,p,b)=>S.emitResolverRetry(r,p,b),onCancel:(r,p)=>{S.emitResolverCancel(r,p),S.emitRequirementCanceled(p),N&&k.decrementInflight(p.id);},onResolutionComplete:()=>{T(),_();}}),E=new Set;function q(){for(let r of E)r();}let a=n.history?be({historyOption:n.history,facts:j,store:$,onSnapshot:r=>{S.emitSnapshot(r),q();},onHistoryChange:(r,p)=>{S.emitHistoryNavigate(r,p),q();}}):Re();O=a;let v=new Set;function T(){for(let r of v)r();}let F=50,H=100,J=0,I={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new de,readyPromise:null,readyResolve:null},L=Xe({mergedConstraints:s,mergedResolvers:u,mergedDerive:i,mergedEffects:y,constraintsManager:o,resolversManager:l,derivationsManager:x,effectsManager:e,pluginManager:S,getState:()=>I,scheduleReconcile:_,maxDeferredRegistrations:H});function _(){!I.isRunning||I.reconcileScheduled||I.isInitializing||(I.reconcileScheduled=true,T(),queueMicrotask(()=>{I.reconcileScheduled=false,I.isRunning&&!I.isInitializing&&d().catch(r=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",r);});}));}async function d(){if(I.isReconciling)return;if(J++,J>F){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${F} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),N&&k.drainPendingChanges(),J=0;return}I.isReconciling=true,T();let r=N?k.startRun():0,p=k.currentTrace;try{I.changedKeys.size>0&&((g===null||m)&&a.takeSnapshot(`facts-changed:${[...I.changedKeys].join(",")}`),m=!1);let b=j.$snapshot();S.emitReconcileStart(b),await e.runEffects(I.changedKeys);let W=new Set(I.changedKeys);I.changedKeys.clear();let B=await o.evaluate(W),V=new de;for(let X of B)V.add(X),S.emitRequirementCreated(X);if(p){let X=new Set(B.map(re=>re.fromConstraint));for(let re of X){let ne=o.getState(re);if(ne){let ie=o.getDependencies(re);p.constraintsHit.push({id:re,priority:ne.priority,deps:ie?[...ie]:[]});}}}let{added:Z,removed:Q}=V.diff(I.previousRequirements);if(p){for(let X of Z)p.requirementsAdded.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});for(let X of Q)p.requirementsRemoved.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});}for(let X of Q)l.cancel(X.id);for(let X of Z)l.resolve(X);if(p){let X=l.getInflightInfo(),re=new Map(X.map(ne=>[ne.id,ne]));for(let ne of Z){let ie=re.get(ne.id);p.resolversStarted.push({resolver:ie?.resolverId??"unknown",requirementId:ne.id}),k.attributeResolverStart(ne.id);}}I.previousRequirements=V;let Y=l.getInflightInfo(),te={unmet:B.filter(X=>!l.isResolving(X.id)),inflight:Y,completed:[],canceled:Q.map(X=>({id:X.id,resolverId:Y.find(re=>re.id===X.id)?.resolverId??"unknown"}))};S.emitReconcileEnd(te),I.isReady||(I.isReady=!0,I.readyResolve&&(I.readyResolve(),I.readyResolve=null));}finally{N&&k.finalizeCurrentRun(r),I.isReconciling=false,L.flushDeferred(),I.changedKeys.size>0?_():I.reconcileScheduled||(J=0),T();}}function R(r,p){let b=c[r];if(b){D++,(g===null||g.has(r))&&(m=true);try{$.batch(()=>{b(j,{type:r,...p});});}finally{D--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${r}". No handler is registered for this event. Available events: ${Object.keys(c).join(", ")||"(none)"}`);}let w=Ue({mergedDerive:i,getDerivation:r=>x.get(r),definitions:L}),M=Le({mergedEvents:c,dispatchEvent:R}),A={facts:j,history:a.isEnabled?a:null,derive:w,events:M,constraints:{disable:r=>o.disable(r),enable:r=>o.enable(r),isDisabled:r=>o.isDisabled(r),register:(r,p)=>L.register("constraint",r,p),assign:(r,p)=>L.assign("constraint",r,p),unregister:r=>L.unregister("constraint",r),call:(r,p)=>L.call("constraint",r,p),isDynamic:r=>L.isDynamic("constraint",r),listDynamic:()=>L.listDynamic("constraint")},effects:{disable:r=>e.disable(r),enable:r=>e.enable(r),isEnabled:r=>e.isEnabled(r),register:(r,p)=>L.register("effect",r,p),assign:(r,p)=>L.assign("effect",r,p),unregister:r=>L.unregister("effect",r),call:r=>L.call("effect",r),isDynamic:r=>L.isDynamic("effect",r),listDynamic:()=>L.listDynamic("effect")},resolvers:{register:(r,p)=>L.register("resolver",r,p),assign:(r,p)=>L.assign("resolver",r,p),unregister:r=>L.unregister("resolver",r),call:(r,p)=>L.call("resolver",r,p),isDynamic:r=>L.isDynamic("resolver",r),listDynamic:()=>L.listDynamic("resolver")},get trace(){return k.getEntries()},initialize(){if(!I.isInitialized){I.isInitializing=true;for(let r of n.modules)r.init&&$.batch(()=>{r.init(j);});n.onAfterModuleInit&&$.batch(()=>{n.onAfterModuleInit();}),I.isInitializing=false,I.isInitialized=true;for(let r of Object.keys(i))x.get(r);}},start(){if(!I.isRunning){I.isInitialized||this.initialize(),I.isRunning=true;for(let r of n.modules)r.hooks?.onStart?.(A);if(S.emitStart(A),n.errorBoundary?.retryLater&&!P){let r=Math.max(n.errorBoundary.retryLater.delayMs??1e3,250);P=setInterval(()=>{let p=C.processDueRetries();for(let b of p)b.callback?b.callback():_();},Math.min(r,500));}_();}},stop(){if(I.isRunning){I.isRunning=false,P!==null&&(clearInterval(P),P=null),C.getRetryLaterManager().clearAll(),l.cancelAll(),e.cleanupAll();for(let r of n.modules)r.hooks?.onStop?.(A);S.emitStop(A);}},destroy(){I.isDestroyed||(this.stop(),I.isDestroyed=true,$.destroy?.(),l.destroy(),C.clearErrors(),v.clear(),E.clear(),k.destroy(),L.destroy(),S.emitDestroy(A));},dispatch(r){G.has(r.type)||R(r.type,r);},read(r){return x.get(r)},subscribe(r,p){let b=[],W=[];for(let V of r)V in i?b.push(V):V in t?W.push(V):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${V}"`);let B=[];return b.length>0&&B.push(x.subscribe(b,p)),W.length>0&&B.push($.subscribe(W,p)),()=>{for(let V of B)V();}},watch(r,p,b){let W=b?.equalityFn?(V,Z)=>b.equalityFn(V,Z):(V,Z)=>Object.is(V,Z);if(r in i){let V=x.get(r);return x.subscribe([r],()=>{let Z=x.get(r);if(!W(Z,V)){let Q=V;V=Z,p(Z,Q);}})}process.env.NODE_ENV!=="production"&&(r in t||console.warn(`[Directive] watch: unknown key "${r}"`));let B=$.get(r);return $.subscribe([r],()=>{let V=$.get(r);if(!W(V,B)){let Z=B;B=V,p(V,Z);}})},when(r,p){return new Promise((b,W)=>{let B=$.toObject();if(r(B)){b();return}let V,Z,Q=()=>{V?.(),Z!==void 0&&clearTimeout(Z);};V=$.subscribeAll(()=>{let Y=$.toObject();r(Y)&&(Q(),b());}),p?.timeout!==void 0&&p.timeout>0&&(Z=setTimeout(()=>{Q(),W(new Error(`[Directive] when: timed out after ${p.timeout}ms`));},p.timeout));})},inspect(){return {unmet:I.previousRequirements.all(),inflight:l.getInflightInfo(),constraints:o.getAllStates().map(r=>({id:r.id,active:r.lastResult??false,disabled:o.isDisabled(r.id),priority:r.priority,hitCount:r.hitCount,lastActiveAt:r.lastActiveAt})),resolvers:Object.fromEntries(l.getInflight().map(r=>[r,l.getStatus(r)])),resolverDefs:Object.entries(u).map(([r,p])=>({id:r,requirement:typeof p.requirement=="string"?p.requirement:"(predicate)"})),traceEnabled:N,...N?{trace:(k.getEntries()??[]).map(r=>({...r,factChanges:r.factChanges.map(p=>({...p})),derivationsRecomputed:r.derivationsRecomputed.map(p=>({...p,deps:[...p.deps]})),constraintsHit:r.constraintsHit.map(p=>({...p,deps:[...p.deps]})),requirementsAdded:r.requirementsAdded.map(p=>({...p})),requirementsRemoved:r.requirementsRemoved.map(p=>({...p})),resolversStarted:r.resolversStarted.map(p=>({...p})),resolversCompleted:r.resolversCompleted.map(p=>({...p})),resolversErrored:r.resolversErrored.map(p=>({...p})),effectsRun:r.effectsRun.map(p=>({...p,triggeredBy:[...p.triggeredBy]})),effectErrors:r.effectErrors.map(p=>({...p}))}))}:{}}},explain(r){let b=I.previousRequirements.all().find(X=>X.id===r);if(!b)return null;let W=o.getState(b.fromConstraint),B=l.getStatus(r),V={},Z=$.toObject();for(let[X,re]of Object.entries(Z))V[X]=re;let Q=[`Requirement "${b.requirement.type}" (id: ${b.id})`,`\u251C\u2500 Produced by constraint: ${b.fromConstraint}`,`\u251C\u2500 Constraint priority: ${W?.priority??0}`,`\u251C\u2500 Constraint active: ${W?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${B.state}`],Y=Object.entries(b.requirement).filter(([X])=>X!=="type").map(([X,re])=>`${X}=${JSON.stringify(re)}`).join(", ");Y&&Q.push(`\u251C\u2500 Requirement payload: { ${Y} }`);let te=Object.entries(V).slice(0,10);return te.length>0&&(Q.push("\u2514\u2500 Relevant facts:"),te.forEach(([X,re],ne)=>{let ie=ne===te.length-1?" \u2514\u2500":" \u251C\u2500",ue=typeof re=="object"?JSON.stringify(re):String(re);Q.push(`${ie} ${X} = ${ue.slice(0,50)}${ue.length>50?"...":""}`);})),Q.join(`
2
+ `)},getOriginal(r,p){return L.getOriginal(r,p)},restoreOriginal(r,p){return L.restoreOriginal(r,p)},async settle(r=5e3){let p=Date.now();for(;;){l.hasPendingBatches()&&l.processBatches(),await new Promise(B=>setTimeout(B,0));let b=this.inspect();if(b.inflight.length===0&&!I.isReconciling&&!I.reconcileScheduled&&!l.hasPendingBatches())return;if(Date.now()-p>r){let B=[];b.inflight.length>0&&B.push(`${b.inflight.length} resolvers inflight: ${b.inflight.map(Z=>Z.resolverId).join(", ")}`),I.isReconciling&&B.push("reconciliation in progress"),I.reconcileScheduled&&B.push("reconcile scheduled");let V=I.previousRequirements.all();throw V.length>0&&B.push(`${V.length} unmet requirements: ${V.map(Z=>Z.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${r}ms. ${B.join("; ")}`)}await new Promise(B=>setTimeout(B,10));}},getSnapshot(){return {facts:$.toObject(),version:1}},getDistributableSnapshot(r={}){let{includeDerivations:p,excludeDerivations:b,includeFacts:W,ttlSeconds:B,metadata:V,includeVersion:Z}=r,Q={},Y=Object.keys(i),te;if(p){if(te=p.filter(ne=>Y.includes(ne)),process.env.NODE_ENV!=="production"){let ne=p.filter(ie=>!Y.includes(ie));ne.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${ne.join(", ")}. Available: ${Y.join(", ")||"(none)"}`);}}else te=Y;if(b){let ne=new Set(b);te=te.filter(ie=>!ne.has(ie));}for(let ne of te)try{Q[ne]=x.get(ne);}catch(ie){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${ne}" due to error:`,ie);}if(W&&W.length>0){let ne=$.toObject(),ie=Object.keys(ne);if(process.env.NODE_ENV!=="production"){let ue=W.filter(ft=>!(ft in ne));ue.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${ue.join(", ")}. Available: ${ie.join(", ")||"(none)"}`);}for(let ue of W)ue in ne&&(Q[ue]=ne[ue]);}let X=Date.now(),re={data:Q,createdAt:X};return B!==void 0&&B>0&&(re.expiresAt=X+B*1e3),Z&&(re.version=Ke(Q)),V&&(re.metadata=V),re},watchDistributableSnapshot(r,p){let{includeDerivations:b,excludeDerivations:W}=r,B=Object.keys(i),V;if(b?V=b.filter(Y=>B.includes(Y)):V=B,W){let Y=new Set(W);V=V.filter(te=>!Y.has(te));}if(V.length===0)return process.env.NODE_ENV!=="production"&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let Q=this.getDistributableSnapshot({...r,includeVersion:true}).version;return x.subscribe(V,()=>{let Y=this.getDistributableSnapshot({...r,includeVersion:true});Y.version!==Q&&(Q=Y.version,p(Y));})},restore(r){if(!r||typeof r!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!r.facts||typeof r.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!ae(r))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");$.batch(()=>{for(let[p,b]of Object.entries(r.facts))G.has(p)||$.set(p,b);});},onSettledChange(r){return v.add(r),()=>{v.delete(r);}},onHistoryChange(r){return E.add(r),()=>{E.delete(r);}},batch(r){$.batch(r);},get isSettled(){return l.getInflight().length===0&&!l.hasPendingBatches()&&!I.isReconciling&&!I.reconcileScheduled},get isRunning(){return I.isRunning},get isInitialized(){return I.isInitialized},get isReady(){return I.isReady},whenReady(){return I.isReady?Promise.resolve():I.isRunning?(I.readyPromise||(I.readyPromise=new Promise(r=>{I.readyResolve=r;})),I.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function ee(r){if(I.isReconciling)throw new Error(`[Directive] Cannot register module "${r.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(I.isDestroyed)throw new Error(`[Directive] Cannot register module "${r.id}" on a destroyed system.`);let p=(b,W)=>{if(b)for(let B of Object.keys(b)){if(G.has(B))throw new Error(`[Directive] Security: Module "${r.id}" has dangerous key "${B}" in ${W}.`);if(W==="schema"&&B.startsWith("$"))throw new Error(`[Directive] Module "${r.id}" has schema key "${B}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};p(r.schema,"schema"),p(r.events,"events"),p(r.derive,"derive"),p(r.effects,"effects"),p(r.constraints,"constraints"),p(r.resolvers,"resolvers");for(let b of Object.keys(r.schema))if(b in t)throw new Error(`[Directive] Schema collision: Fact "${b}" already exists. Cannot register module "${r.id}".`);if(process.env.NODE_ENV!=="production"&&r.derive){let b=new Set(Object.keys(t));for(let W of Object.keys(r.derive))b.has(W)&&console.warn(`[Directive] "${W}" exists as both a fact and a derivation after registering module "${r.id}".`);}if(r.history?.snapshotEvents){g===null&&(g=new Set(Object.keys(c)));for(let b of r.history.snapshotEvents)g.add(b);}else if(g!==null&&r.events)for(let b of Object.keys(r.events))g.add(b);Object.assign(t,r.schema),r.events&&Object.assign(c,r.events),r.derive&&(Object.assign(i,r.derive),x.registerDefinitions(r.derive)),r.effects&&(Object.assign(y,r.effects),e.registerDefinitions(r.effects)),r.constraints&&(Object.assign(s,r.constraints),o.registerDefinitions(r.constraints)),r.resolvers&&(Object.assign(u,r.resolvers),l.registerDefinitions(r.resolvers)),$.registerKeys(r.schema),n.modules.push(r),r.init&&$.batch(()=>{r.init(j);}),r.hooks?.onInit?.(A),I.isRunning&&(r.hooks?.onStart?.(A),_());}A.registerModule=ee,S.emitInit(A);for(let r of n.modules)r.hooks?.onInit?.(A);return A}var U="::";function jt(n){let t=Object.keys(n),c=new Set,i=new Set,y=[],s=[];function u(h){if(c.has(h))return;if(i.has(h)){let f=s.indexOf(h),D=[...s.slice(f),h].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${D}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}i.add(h),s.push(h);let g=n[h];if(g?.crossModuleDeps)for(let f of Object.keys(g.crossModuleDeps))t.includes(f)&&u(f);s.pop(),i.delete(h),c.add(h),y.push(h);}for(let h of t)u(h);return y}var rt=new WeakMap,st=new WeakMap,ot=new WeakMap,it=new WeakMap;function Ie(n){if("module"in n){if(!n.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof n.module);return Kt(n)}let t=n;if(Array.isArray(t.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,10 +8,10 @@ Use:
8
8
  createSystem({ modules: { auth: authModule, data: dataModule } })
9
9
 
10
10
  Or for a single module:
11
- createSystem({ module: counterModule })`);let o=n.modules;if(o&&typeof o=="object"&&"id"in o&&"schema"in o)throw new Error(`[Directive] A single module was passed to \`modules:\`. For a single module, use \`module:\` instead:
11
+ createSystem({ module: counterModule })`);let c=t.modules;if(c&&typeof c=="object"&&"id"in c&&"schema"in c)throw new Error(`[Directive] A single module was passed to \`modules:\`. For a single module, use \`module:\` instead:
12
12
 
13
13
  createSystem({ module: myModule })
14
14
 
15
15
  For multiple modules, wrap in an object:
16
- createSystem({ modules: { myName: myModule } })`);return nn(n)}function nn(e){let n=e.modules,o=new Set(Object.keys(n)),i=e.debug?.snapshotModules?new Set(e.debug.snapshotModules):null;if(e.tickMs!==void 0&&e.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(process.env.NODE_ENV!=="production"){for(let[g,M]of Object.entries(n))if(M.crossModuleDeps)for(let u of Object.keys(M.crossModuleDeps))u===g?console.warn(`[Directive] Module "${g}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):o.has(u)||console.warn(`[Directive] Module "${g}" declares crossModuleDeps.${u}, but no module with namespace "${u}" exists in the system. Available modules: ${[...o].join(", ")}`);}if(process.env.NODE_ENV!=="production"&&e.debug?.snapshotModules)for(let g of e.debug.snapshotModules)o.has(g)||console.warn(`[Directive] debug.snapshotModules entry "${g}" doesn't match any module. Available modules: ${[...o].join(", ")}`);let y,s=e.initOrder??"auto";if(Array.isArray(s)){let g=s,M=Object.keys(n).filter(u=>!g.includes(u));if(M.length>0)throw new Error(`[Directive] initOrder is missing modules: ${M.join(", ")}. All modules must be included in the explicit order.`);y=g;}else s==="declaration"?y=Object.keys(n):y=tn(n);let p=e.debug,m=e.errorBoundary;e.zeroConfig&&(p={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...e.debug},m={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...e.errorBoundary});for(let g of Object.keys(n)){if(g.includes(X))throw new Error(`[Directive] Module name "${g}" contains the reserved separator "${X}". Module names cannot contain "${X}".`);let M=n[g];if(M){for(let u of Object.keys(M.schema.facts))if(u.includes(X))throw new Error(`[Directive] Schema key "${u}" in module "${g}" contains the reserved separator "${X}". Schema keys cannot contain "${X}".`)}}let f=[];for(let g of y){let M=n[g];if(!M)continue;let u=M.crossModuleDeps&&Object.keys(M.crossModuleDeps).length>0,k=u?Object.keys(M.crossModuleDeps):[],C={};for(let[T,W]of Object.entries(M.schema.facts))C[`${g}${X}${T}`]=W;let F={};if(M.schema.derivations)for(let[T,W]of Object.entries(M.schema.derivations))F[`${g}${X}${T}`]=W;let B={};if(M.schema.events)for(let[T,W]of Object.entries(M.schema.events))B[`${g}${X}${T}`]=W;let a=M.init?T=>{let W=ge(T,g);M.init(W);}:void 0,v={};if(M.derive)for(let[T,W]of Object.entries(M.derive))v[`${g}${X}${T}`]=(N,d)=>{let b=u?Se(N,g,k):ge(N,g),R=et(d,g);return W(b,R)};let E={};if(M.events)for(let[T,W]of Object.entries(M.events))E[`${g}${X}${T}`]=(N,d)=>{let b=ge(N,g);W(b,d);};let $={};if(M.constraints)for(let[T,W]of Object.entries(M.constraints)){let N=W;$[`${g}${X}${T}`]={...N,deps:N.deps?.map(d=>`${g}${X}${d}`),when:d=>{let b=u?Se(d,g,k):ge(d,g);return N.when(b)},require:typeof N.require=="function"?d=>{let b=u?Se(d,g,k):ge(d,g);return N.require(b)}:N.require};}let A={};if(M.resolvers)for(let[T,W]of Object.entries(M.resolvers)){let N=W;A[`${g}${X}${T}`]={...N,resolve:async(d,b)=>{let R=Qe(b.facts,n,()=>Object.keys(n));await N.resolve(d,{facts:R[g],signal:b.signal});}};}let z={};if(M.effects)for(let[T,W]of Object.entries(M.effects)){let N=W;z[`${g}${X}${T}`]={...N,run:(d,b)=>{let R=u?Se(d,g,k):ge(d,g),q=b?u?Se(b,g,k):ge(b,g):void 0;return N.run(R,q)},deps:N.deps?.map(d=>`${g}${X}${d}`)};}f.push({id:M.id,schema:{facts:C,derivations:F,events:B,requirements:M.schema.requirements??{}},init:a,derive:v,events:E,effects:z,constraints:$,resolvers:A,hooks:M.hooks,snapshotEvents:i&&!i.has(g)?[]:M.snapshotEvents?.map(T=>`${g}${X}${T}`)});}process.env.NODE_ENV!=="production"&&e.tickMs&&e.tickMs>0&&(f.some(M=>M.events&&Object.keys(M.events).some(u=>u.endsWith(`${X}tick`)))||console.warn(`[Directive] tickMs is set to ${e.tickMs}ms but no module defines a "tick" event handler.`));let l=null,c=null;function S(g){for(let[M,u]of Object.entries(g)){if(Z.has(M)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${M}". Skipping.`);continue}if(!o.has(M)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${M}". Available modules: ${[...o].join(", ")}`);continue}if(u&&typeof u=="object"&&!ke(u))throw new Error(`[Directive] initialFacts/hydrate for namespace "${M}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[k,C]of Object.entries(u))Z.has(k)||(c.facts[`${M}${X}${k}`]=C);}}c=We({modules:f.map(g=>({id:g.id,schema:g.schema.facts,requirements:g.schema.requirements,init:g.init,derive:g.derive,events:g.events,effects:g.effects,constraints:g.constraints,resolvers:g.resolvers,hooks:g.hooks,snapshotEvents:g.snapshotEvents})),plugins:e.plugins,debug:p,errorBoundary:m,tickMs:e.tickMs,onAfterModuleInit:()=>{e.initialFacts&&S(e.initialFacts),l&&(S(l),l=null);}});let w=new Map;for(let g of Object.keys(n)){let M=n[g];if(!M)continue;let u=[];for(let k of Object.keys(M.schema.facts))u.push(`${g}${X}${k}`);if(M.schema.derivations)for(let k of Object.keys(M.schema.derivations))u.push(`${g}${X}${k}`);w.set(g,u);}let j={names:null};function _(){return j.names===null&&(j.names=Object.keys(n)),j.names}let Q=Qe(c.facts,n,_),G=rn(c.derive,n,_),x=sn(c,n,_),D=null,V=e.tickMs,O={_mode:"namespaced",facts:Q,debug:c.debug,derive:G,events:x,constraints:c.constraints,effects:c.effects,resolvers:c.resolvers,get runHistory(){return c.runHistory},get isRunning(){return c.isRunning},get isSettled(){return c.isSettled},get isInitialized(){return c.isInitialized},get isReady(){return c.isReady},whenReady:c.whenReady.bind(c),async hydrate(g){if(c.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let M=await g();M&&typeof M=="object"&&(l=M);},initialize(){c.initialize();},start(){if(c.start(),V&&V>0){let g=Object.keys(f[0]?.events??{}).find(M=>M.endsWith(`${X}tick`));g&&(D=setInterval(()=>{c.dispatch({type:g});},V));}},stop(){D&&(clearInterval(D),D=null),c.stop();},destroy(){this.stop(),c.destroy();},dispatch(g){c.dispatch(g);},batch:c.batch.bind(c),read(g){return c.read(Re(g))},subscribe(g,M){let u=[];for(let k of g)if(k.endsWith(".*")){let C=k.slice(0,-2),F=w.get(C);F?u.push(...F):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${k}" \u2014 namespace "${C}" not found.`);}else u.push(Re(k));return c.subscribe(u,M)},subscribeModule(g,M){let u=w.get(g);return !u||u.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${g}") \u2014 namespace not found. Available: ${[...w.keys()].join(", ")}`),()=>{}):c.subscribe(u,M)},watch(g,M,u){return c.watch(Re(g),M,u)},when(g,M){return c.when(()=>g(Q),M)},onSettledChange:c.onSettledChange.bind(c),onTimeTravelChange:c.onTimeTravelChange.bind(c),inspect:c.inspect.bind(c),settle:c.settle.bind(c),explain:c.explain.bind(c),getSnapshot:c.getSnapshot.bind(c),restore:c.restore.bind(c),getDistributableSnapshot(g){let M={...g,includeDerivations:g?.includeDerivations?.map(Re),excludeDerivations:g?.excludeDerivations?.map(Re),includeFacts:g?.includeFacts?.map(Re)},u=c.getDistributableSnapshot(M),k={};for(let[C,F]of Object.entries(u.data)){let B=C.indexOf(X);if(B>0){let a=C.slice(0,B),v=C.slice(B+X.length);k[a]||(k[a]={}),k[a][v]=F;}else k._root||(k._root={}),k._root[C]=F;}return {...u,data:k}},watchDistributableSnapshot(g,M){let u={...g,includeDerivations:g?.includeDerivations?.map(Re),excludeDerivations:g?.excludeDerivations?.map(Re),includeFacts:g?.includeFacts?.map(Re)};return c.watchDistributableSnapshot(u,k=>{let C={};for(let[F,B]of Object.entries(k.data)){let a=F.indexOf(X);if(a>0){let v=F.slice(0,a),E=F.slice(a+X.length);C[v]||(C[v]={}),C[v][E]=B;}else C._root||(C._root={}),C._root[F]=B;}M({...k,data:C});})},registerModule(g,M){if(o.has(g))throw new Error(`[Directive] Module namespace "${g}" already exists. Cannot register a duplicate namespace.`);if(g.includes(X))throw new Error(`[Directive] Module name "${g}" contains the reserved separator "${X}".`);if(Z.has(g))throw new Error(`[Directive] Module name "${g}" is a blocked property.`);for(let T of Object.keys(M.schema.facts))if(T.includes(X))throw new Error(`[Directive] Schema key "${T}" in module "${g}" contains the reserved separator "${X}".`);let u=M,k=u.crossModuleDeps&&Object.keys(u.crossModuleDeps).length>0,C=k?Object.keys(u.crossModuleDeps):[],F={};for(let[T,W]of Object.entries(u.schema.facts))F[`${g}${X}${T}`]=W;let B=u.init?T=>{let W=ge(T,g);u.init(W);}:void 0,a={};if(u.derive)for(let[T,W]of Object.entries(u.derive))a[`${g}${X}${T}`]=(N,d)=>{let b=k?Se(N,g,C):ge(N,g),R=et(d,g);return W(b,R)};let v={};if(u.events)for(let[T,W]of Object.entries(u.events))v[`${g}${X}${T}`]=(N,d)=>{let b=ge(N,g);W(b,d);};let E={};if(u.constraints)for(let[T,W]of Object.entries(u.constraints)){let N=W;E[`${g}${X}${T}`]={...N,deps:N.deps?.map(d=>`${g}${X}${d}`),when:d=>{let b=k?Se(d,g,C):ge(d,g);return N.when(b)},require:typeof N.require=="function"?d=>{let b=k?Se(d,g,C):ge(d,g);return N.require(b)}:N.require};}let $={};if(u.resolvers)for(let[T,W]of Object.entries(u.resolvers)){let N=W;$[`${g}${X}${T}`]={...N,resolve:async(d,b)=>{let R=Qe(b.facts,n,_);await N.resolve(d,{facts:R[g],signal:b.signal});}};}let A={};if(u.effects)for(let[T,W]of Object.entries(u.effects)){let N=W;A[`${g}${X}${T}`]={...N,run:(d,b)=>{let R=k?Se(d,g,C):ge(d,g),q=b?k?Se(b,g,C):ge(b,g):void 0;return N.run(R,q)},deps:N.deps?.map(d=>`${g}${X}${d}`)};}o.add(g),n[g]=u,j.names=null;let z=[];for(let T of Object.keys(u.schema.facts))z.push(`${g}${X}${T}`);if(u.schema.derivations)for(let T of Object.keys(u.schema.derivations))z.push(`${g}${X}${T}`);w.set(g,z),c.registerModule({id:u.id,schema:F,requirements:u.schema.requirements??{},init:B,derive:Object.keys(a).length>0?a:void 0,events:Object.keys(v).length>0?v:void 0,effects:Object.keys(A).length>0?A:void 0,constraints:Object.keys(E).length>0?E:void 0,resolvers:Object.keys($).length>0?$:void 0,hooks:u.hooks,snapshotEvents:i&&!i.has(g)?[]:u.snapshotEvents?.map(T=>`${g}${X}${T}`)});}};return process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!O.isRunning&&!O.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0),O}function Re(e){if(e.includes(".")){let[n,...o]=e.split(".");return `${n}${X}${o.join(X)}`}return e}function ge(e,n){let o=wt.get(e);if(o){let y=o.get(n);if(y)return y}else o=new Map,wt.set(e,o);let i=new Proxy({},{get(y,s){if(typeof s!="symbol"&&!Z.has(s))return s==="$store"||s==="$snapshot"?e[s]:e[`${n}${X}${s}`]},set(y,s,p){return typeof s=="symbol"||Z.has(s)?false:(e[`${n}${X}${s}`]=p,true)},has(y,s){return typeof s=="symbol"||Z.has(s)?false:`${n}${X}${s}`in e},deleteProperty(y,s){return typeof s=="symbol"||Z.has(s)?false:(delete e[`${n}${X}${s}`],true)},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return o.set(n,i),i}function Qe(e,n,o){let i=Rt.get(e);if(i)return i;let y=new Proxy({},{get(s,p){if(typeof p!="symbol"&&!Z.has(p)&&Object.hasOwn(n,p))return ge(e,p)},has(s,p){return typeof p=="symbol"||Z.has(p)?false:Object.hasOwn(n,p)},ownKeys(){return o()},getOwnPropertyDescriptor(s,p){if(typeof p!="symbol"&&Object.hasOwn(n,p))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return Rt.set(e,y),y}var Mt=new WeakMap;function Se(e,n,o){let i=`${n}:${JSON.stringify([...o].sort())}`,y=Mt.get(e);if(y){let f=y.get(i);if(f)return f}else y=new Map,Mt.set(e,y);let s=new Set(o),p=["self",...o],m=new Proxy({},{get(f,l){if(typeof l!="symbol"&&!Z.has(l)){if(l==="self")return ge(e,n);if(s.has(l))return ge(e,l);process.env.NODE_ENV!=="production"&&typeof l=="string"&&console.warn(`[Directive] Module "${n}" accessed undeclared cross-module property "${l}". Add it to crossModuleDeps or use "facts.self.${l}" for own module facts.`);}},has(f,l){return typeof l=="symbol"||Z.has(l)?false:l==="self"||s.has(l)},ownKeys(){return p},getOwnPropertyDescriptor(f,l){if(typeof l!="symbol"&&(l==="self"||s.has(l)))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return y.set(i,m),m}function et(e,n){let o=Dt.get(e);if(o){let y=o.get(n);if(y)return y}else o=new Map,Dt.set(e,o);let i=new Proxy({},{get(y,s){if(typeof s!="symbol"&&!Z.has(s))return e[`${n}${X}${s}`]},has(y,s){return typeof s=="symbol"||Z.has(s)?false:`${n}${X}${s}`in e},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return o.set(n,i),i}function rn(e,n,o){let i=kt.get(e);if(i)return i;let y=new Proxy({},{get(s,p){if(typeof p!="symbol"&&!Z.has(p)&&Object.hasOwn(n,p))return et(e,p)},has(s,p){return typeof p=="symbol"||Z.has(p)?false:Object.hasOwn(n,p)},ownKeys(){return o()},getOwnPropertyDescriptor(s,p){if(typeof p!="symbol"&&Object.hasOwn(n,p))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return kt.set(e,y),y}var Et=new WeakMap;function sn(e,n,o){let i=Et.get(e);return i||(i=new Map,Et.set(e,i)),new Proxy({},{get(y,s){if(typeof s=="symbol"||Z.has(s)||!Object.hasOwn(n,s))return;let p=i.get(s);if(p)return p;let m=new Proxy({},{get(f,l){if(typeof l!="symbol"&&!Z.has(l))return c=>{e.dispatch({type:`${s}${X}${l}`,...c});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return i.set(s,m),m},has(y,s){return typeof s=="symbol"||Z.has(s)?false:Object.hasOwn(n,s)},ownKeys(){return o()},getOwnPropertyDescriptor(y,s){if(typeof s!="symbol"&&Object.hasOwn(n,s))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function on(e){let n=e.module;if(!n)throw new Error("[Directive] createSystem requires a module. Got: "+typeof n);if(e.tickMs!==void 0&&e.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(e.initialFacts&&!ke(e.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"&&(n.crossModuleDeps&&Object.keys(n.crossModuleDeps).length>0&&console.warn("[Directive] Single module mode ignores crossModuleDeps. Use multiple modules if cross-module access is needed: createSystem({ modules: { ... } })"),e.tickMs&&e.tickMs>0&&(n.events&&"tick"in n.events||console.warn(`[Directive] tickMs is set to ${e.tickMs}ms but module has no "tick" event handler.`)),e.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 o=e.debug,i=e.errorBoundary;e.zeroConfig&&(o={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...e.debug},i={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...e.errorBoundary});let y=null,s=null;s=We({modules:[{id:n.id,schema:n.schema.facts,requirements:n.schema.requirements,init:n.init,derive:n.derive,events:n.events,effects:n.effects,constraints:n.constraints,resolvers:n.resolvers,hooks:n.hooks,snapshotEvents:n.snapshotEvents}],plugins:e.plugins,debug:o,errorBoundary:i,tickMs:e.tickMs,onAfterModuleInit:()=>{if(e.initialFacts)for(let[c,S]of Object.entries(e.initialFacts))Z.has(c)||(s.facts[c]=S);if(y){for(let[c,S]of Object.entries(y))Z.has(c)||(s.facts[c]=S);y=null;}}});let p=new Proxy({},{get(c,S){if(typeof S!="symbol"&&!Z.has(S))return w=>{s.dispatch({type:S,...w});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),m=null,f=e.tickMs,l={_mode:"single",facts:s.facts,debug:s.debug,derive:s.derive,events:p,constraints:s.constraints,effects:s.effects,resolvers:s.resolvers,get runHistory(){return s.runHistory},get isRunning(){return s.isRunning},get isSettled(){return s.isSettled},get isInitialized(){return s.isInitialized},get isReady(){return s.isReady},whenReady:s.whenReady.bind(s),async hydrate(c){if(s.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let S=await c();S&&typeof S=="object"&&(y=S);},initialize(){s.initialize();},start(){s.start(),f&&f>0&&n.events&&"tick"in n.events&&(m=setInterval(()=>{s.dispatch({type:"tick"});},f));},stop(){m&&(clearInterval(m),m=null),s.stop();},destroy(){this.stop(),s.destroy();},dispatch(c){s.dispatch(c);},batch:s.batch.bind(s),read(c){return s.read(c)},subscribe(c,S){return s.subscribe(c,S)},watch(c,S,w){return s.watch(c,S,w)},when(c,S){return s.when(c,S)},onSettledChange:s.onSettledChange.bind(s),onTimeTravelChange:s.onTimeTravelChange.bind(s),inspect:s.inspect.bind(s),settle:s.settle.bind(s),explain:s.explain.bind(s),getSnapshot:s.getSnapshot.bind(s),restore:s.restore.bind(s),getDistributableSnapshot:s.getDistributableSnapshot.bind(s),watchDistributableSnapshot:s.watchDistributableSnapshot.bind(s),registerModule(c){s.registerModule({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});}};return process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!l.isRunning&&!l.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0),l}function an(e){let n={facts:{},derivations:{},events:{},requirements:{}},o,i,y,s,p,m,f,l={schema(c){return n=c,l},init(c){return o=c,l},derive(c){return y=c,l},events(c){return i=c,l},effects(c){return s=c,l},constraints(c){return p=c,l},resolvers(c){return m=c,l},hooks(c){return f=c,l},build(){if(!n||!n.facts)throw new Error(`[Directive] Module "${e}" requires a schema with at least facts defined. Call .schema({ facts: { ... } }) before .build().`);let c=Object.keys(n.derivations??{}),S=Object.keys(y??{}),w=c.filter(G=>!S.includes(G));if(w.length>0)throw new Error(`[Directive] Module "${e}" is missing derivation implementations: ${w.join(", ")}. All derivations declared in schema.derivations must have implementations in .derive().`);let j=Object.keys(n.events??{}),_=Object.keys(i??{}),Q=j.filter(G=>!_.includes(G));if(Q.length>0)throw new Error(`[Directive] Module "${e}" is missing event handler implementations: ${Q.join(", ")}. All events declared in schema.events must have implementations in .events().`);return {id:e,schema:n,init:o,events:i,derive:y,effects:s,constraints:p,resolvers:m,hooks:f}}};return l}function cn(){return {when(e){return {require(n){let o,i,y,s,p,m={priority(f){return o=f,m},after(...f){return i=i?[...i,...f]:[...f],m},deps(...f){return y=y?[...y,...f]:[...f],m},timeout(f){return s=f,m},async(f){return p=f,m},build(){let f={when:e,require:n};return o!==void 0&&(f.priority=o),i!==void 0&&(f.after=i),y!==void 0&&(f.deps=y),s!==void 0&&(f.timeout=s),p!==void 0&&(f.async=p),f}};return m}}}}}function Pe(e){let n={...e};return n.withPriority=o=>Pe({...e,priority:o}),n.withAfter=(...o)=>Pe({...e,after:e.after?[...e.after,...o]:[...o]}),n.withDeps=(...o)=>Pe({...e,deps:e.deps?[...e.deps,...o]:[...o]}),n.withTimeout=o=>Pe({...e,timeout:o}),n.withAsync=o=>Pe({...e,async:o}),n}function un(e){return {require(n){return Pe({when:e,require:n})}}}function ln(){return {module(e){return dn(e)},modules(e){return fn(e)}}}function dn(e){let n,o,i,y,s,p,m={plugins(f){return n=f,m},debug(f){return o=f,m},errorBoundary(f){return i=f,m},tickMs(f){return y=f,m},zeroConfig(f=true){return s=f,m},initialFacts(f){return p=f,m},build(){return qe({module:e,plugins:n,debug:o,errorBoundary:i,tickMs:y,zeroConfig:s,initialFacts:p})}};return m}function fn(e){let n,o,i,y,s,p,m,f={plugins(l){return n=l,f},debug(l){return o=l,f},errorBoundary(l){return i=l,f},tickMs(l){return y=l,f},zeroConfig(l=true){return s=l,f},initialFacts(l){return p=l,f},initOrder(l){return m=l,f},build(){return qe({modules:e,plugins:n,debug:o,errorBoundary:i,tickMs:y,zeroConfig:s,initialFacts:p,initOrder:m})}};return f}function tt(){let e={pending:new Map,inflight:new Map,failed:new Map,errors:new Map,listeners:new Set};function n(){for(let f of e.listeners)f();}function o(f,l){let c=f.get(l);return c||(c=new Set,f.set(l,c)),c}function i(f){let l=e.pending.get(f)??new Set,c=e.inflight.get(f)??new Set,S=e.failed.get(f)??new Set,w=e.errors.get(f)??null;return {pending:l.size,inflight:c.size,failed:S.size,isLoading:l.size>0||c.size>0,hasError:S.size>0,lastError:w}}function y(){let f=new Set([...e.pending.keys(),...e.inflight.keys(),...e.failed.keys()]),l=new Map;for(let c of f)l.set(c,i(c));return l}function s(f){return e.listeners.add(f),()=>e.listeners.delete(f)}function p(){e.pending.clear(),e.inflight.clear(),e.failed.clear(),e.errors.clear(),n();}return {plugin:{name:"requirement-status",onRequirementCreated(f){let l=f.requirement.type;o(e.pending,l).add(f.id),e.failed.get(l)?.delete(f.id),n();},onResolverStart(f,l){let c=l.requirement.type;e.pending.get(c)?.delete(l.id),o(e.inflight,c).add(l.id),n();},onResolverComplete(f,l){let c=l.requirement.type;e.inflight.get(c)?.delete(l.id),e.pending.get(c)?.delete(l.id),n();},onResolverError(f,l,c){let S=l.requirement.type;e.inflight.get(S)?.delete(l.id),o(e.failed,S).add(l.id),e.errors.set(S,c instanceof Error?c:new Error(String(c))),n();},onResolverCancel(f,l){let c=l.requirement.type;e.pending.get(c)?.delete(l.id),e.inflight.get(c)?.delete(l.id),n();},onRequirementMet(f){let l=f.requirement.type;e.pending.get(l)?.delete(f.id),e.inflight.get(l)?.delete(f.id),n();}},getStatus:i,getAllStatus:y,subscribe:s,reset:p}}function gn(e){return n=>e.getStatus(n)}function mn(e){let n=tt(),i=[...e.plugins??[],n.plugin];return {system:qe({module:e.module,plugins:i,debug:e.debug,errorBoundary:e.errorBoundary,tickMs:e.tickMs,zeroConfig:e.zeroConfig,initialFacts:e.initialFacts}),statusPlugin:n}}var mr={None:"none",Linear:"linear",Exponential:"exponential"};exports.Backoff=mr;exports.DirectiveError=xe;exports.RequirementSet=De;exports.constraint=cn;exports.createConstraintFactory=ot;exports.createConstraintsManager=Le;exports.createDerivationsManager=He;exports.createDisabledTimeTravel=ze;exports.createEffectsManager=Je;exports.createEngine=We;exports.createErrorBoundaryManager=Xe;exports.createFacts=Ge;exports.createFactsProxy=vt;exports.createFactsStore=ht;exports.createModule=ut;exports.createModuleFactory=Ft;exports.createPluginManager=Ye;exports.createRequirementStatusPlugin=tt;exports.createResolverFactory=it;exports.createResolversManager=Ze;exports.createRetryLaterManager=pt;exports.createStatusHook=gn;exports.createSystem=qe;exports.createSystemWithStatus=mn;exports.createTimeTravelManager=Ve;exports.diffSnapshots=Nt;exports.forType=Lt;exports.generateRequirementId=mt;exports.getCurrentTracker=yt;exports.isNamespacedSystem=It;exports.isRequirementType=Ut;exports.isSignedSnapshot=Bt;exports.isSingleModuleSystem=Ot;exports.isSnapshotExpired=dt;exports.isTracking=Xt;exports.module=an;exports.req=zt;exports.shallowEqual=jt;exports.signSnapshot=Kt;exports.system=ln;exports.t=At;exports.trackAccess=$e;exports.typedConstraint=at;exports.typedResolver=ct;exports.validateSnapshot=_t;exports.verifySnapshotSignature=Wt;exports.when=un;exports.withTracking=Ee;exports.withoutTracking=Ke;//# sourceMappingURL=index.cjs.map
16
+ createSystem({ modules: { myName: myModule } })`);return Ft(t)}function Ft(n){let t=n.modules,c=new Set(Object.keys(t)),i=typeof n.history=="object"?n.history:null,y=i?.snapshotModules?new Set(i.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[e,o]of Object.entries(t))if(o.crossModuleDeps)for(let l of Object.keys(o.crossModuleDeps))l===e?console.warn(`[Directive] Module "${e}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):c.has(l)||console.warn(`[Directive] Module "${e}" declares crossModuleDeps.${l}, but no module with namespace "${l}" exists in the system. Available modules: ${[...c].join(", ")}`);}if(process.env.NODE_ENV!=="production"&&i?.snapshotModules)for(let e of i.snapshotModules)c.has(e)||console.warn(`[Directive] history.snapshotModules entry "${e}" doesn't match any module. Available modules: ${[...c].join(", ")}`);let s,u=n.initOrder??"auto";if(Array.isArray(u)){let e=u,o=Object.keys(t).filter(l=>!e.includes(l));if(o.length>0)throw new Error(`[Directive] initOrder is missing modules: ${o.join(", ")}. All modules must be included in the explicit order.`);s=e;}else u==="declaration"?s=Object.keys(t):s=jt(t);let{history:h,trace:g,errorBoundary:f}=ut(n);for(let e of Object.keys(t)){if(e.includes(U))throw new Error(`[Directive] Module name "${e}" contains the reserved separator "${U}". Module names cannot contain "${U}".`);let o=t[e];if(o){for(let l of Object.keys(o.schema.facts))if(l.includes(U))throw new Error(`[Directive] Schema key "${l}" in module "${e}" contains the reserved separator "${U}". Schema keys cannot contain "${U}".`)}}let D=[];for(let e of s){let o=t[e];if(!o)continue;let l=o.crossModuleDeps&&Object.keys(o.crossModuleDeps).length>0,E=l?Object.keys(o.crossModuleDeps):[],q={};for(let[_,d]of Object.entries(o.schema.facts))q[`${e}${U}${_}`]=d;let a={};if(o.schema.derivations)for(let[_,d]of Object.entries(o.schema.derivations))a[`${e}${U}${_}`]=d;let v={};if(o.schema.events)for(let[_,d]of Object.entries(o.schema.events))v[`${e}${U}${_}`]=d;let T=o.init?_=>{let d=oe(_,e);o.init(d);}:void 0,F={};if(o.derive)for(let[_,d]of Object.entries(o.derive))F[`${e}${U}${_}`]=(R,w)=>{let M=l?ce(R,e,E):oe(R,e),A=Pe(w,e);return d(M,A)};let H={};if(o.events)for(let[_,d]of Object.entries(o.events))H[`${e}${U}${_}`]=(R,w)=>{let M=oe(R,e);d(M,w);};let J={};if(o.constraints)for(let[_,d]of Object.entries(o.constraints)){let R=d;J[`${e}${U}${_}`]={...R,deps:R.deps?.map(w=>`${e}${U}${w}`),when:w=>{let M=l?ce(w,e,E):oe(w,e);return R.when(M)},require:typeof R.require=="function"?w=>{let M=l?ce(w,e,E):oe(w,e);return R.require(M)}:R.require};}let I={};if(o.resolvers)for(let[_,d]of Object.entries(o.resolvers)){let R=d;I[`${e}${U}${_}`]={...R,resolve:async(w,M)=>{let A=$e(M.facts,t,()=>Object.keys(t));await R.resolve(w,{facts:A[e],signal:M.signal});}};}let L={};if(o.effects)for(let[_,d]of Object.entries(o.effects)){let R=d;L[`${e}${U}${_}`]={...R,run:(w,M)=>{let A=l?ce(w,e,E):oe(w,e),ee=M?l?ce(M,e,E):oe(M,e):void 0;return R.run(A,ee)},deps:R.deps?.map(w=>`${e}${U}${w}`)};}D.push({id:o.id,schema:{facts:q,derivations:a,events:v,requirements:o.schema.requirements??{}},init:T,derive:F,events:H,effects:L,constraints:J,resolvers:I,hooks:o.hooks,history:{snapshotEvents:y&&!y.has(e)?[]:o.history?.snapshotEvents?.map(_=>`${e}${U}${_}`)}});}process.env.NODE_ENV!=="production"&&n.tickMs&&n.tickMs>0&&(D.some(o=>o.events&&Object.keys(o.events).some(l=>l.endsWith(`${U}tick`)))||console.warn(`[Directive] tickMs is set to ${n.tickMs}ms but no module defines a "tick" event handler.`));let m=null,S=null;function C(e){for(let[o,l]of Object.entries(e)){if(G.has(o)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${o}". Skipping.`);continue}if(!c.has(o)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${o}". Available modules: ${[...c].join(", ")}`);continue}if(l&&typeof l=="object"&&!ae(l))throw new Error(`[Directive] initialFacts/hydrate for namespace "${o}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[E,q]of Object.entries(l))G.has(E)||(S.facts[`${o}${U}${E}`]=q);}}S=we({modules:D.map(e=>({id:e.id,schema:e.schema.facts,requirements:e.schema.requirements,init:e.init,derive:e.derive,events:e.events,effects:e.effects,constraints:e.constraints,resolvers:e.resolvers,hooks:e.hooks,history:e.history})),plugins:n.plugins,history:h,trace:g,errorBoundary:f,tickMs:n.tickMs,onAfterModuleInit:()=>{n.initialFacts&&C(n.initialFacts),m&&(C(m),m=null);}});let P=new Map;for(let e of Object.keys(t)){let o=t[e];if(!o)continue;let l=[];for(let E of Object.keys(o.schema.facts))l.push(`${e}${U}${E}`);if(o.schema.derivations)for(let E of Object.keys(o.schema.derivations))l.push(`${e}${U}${E}`);P.set(e,l);}let z={names:null};function K(){return z.names===null&&(z.names=Object.keys(t)),z.names}let O=$e(S.facts,t,K),k=_t(S.derive,t,K),N=Nt(S,t,K),$=null,j=n.tickMs,x={_mode:"namespaced",facts:O,history:S.history,derive:k,events:N,constraints:S.constraints,effects:S.effects,resolvers:S.resolvers,async hydrate(e){if(S.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let o=await e();o&&typeof o=="object"&&(m=o);},initialize(){S.initialize();},start(){if(S.start(),j&&j>0){let e=Object.keys(D[0]?.events??{}).find(o=>o.endsWith(`${U}tick`));e&&($=setInterval(()=>{S.dispatch({type:e});},j));}},stop(){$&&(clearInterval($),$=null),S.stop();},destroy(){this.stop(),S.destroy();},dispatch(e){S.dispatch(e);},read(e){return S.read(le(e))},subscribe(e,o){let l=[];for(let E of e)if(E.endsWith(".*")){let q=E.slice(0,-2),a=P.get(q);a?l.push(...a):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${E}" \u2014 namespace "${q}" not found.`);}else l.push(le(E));return S.subscribe(l,o)},subscribeModule(e,o){let l=P.get(e);return !l||l.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${e}") \u2014 namespace not found. Available: ${[...P.keys()].join(", ")}`),()=>{}):S.subscribe(l,o)},watch(e,o,l){return S.watch(le(e),o,l)},when(e,o){return S.when(()=>e(O),o)},getDistributableSnapshot(e){let o={...e,includeDerivations:e?.includeDerivations?.map(le),excludeDerivations:e?.excludeDerivations?.map(le),includeFacts:e?.includeFacts?.map(le)},l=S.getDistributableSnapshot(o),E={};for(let[q,a]of Object.entries(l.data)){let v=q.indexOf(U);if(v>0){let T=q.slice(0,v),F=q.slice(v+U.length);E[T]||(E[T]={}),E[T][F]=a;}else E._root||(E._root={}),E._root[q]=a;}return {...l,data:E}},watchDistributableSnapshot(e,o){let l={...e,includeDerivations:e?.includeDerivations?.map(le),excludeDerivations:e?.excludeDerivations?.map(le),includeFacts:e?.includeFacts?.map(le)};return S.watchDistributableSnapshot(l,E=>{let q={};for(let[a,v]of Object.entries(E.data)){let T=a.indexOf(U);if(T>0){let F=a.slice(0,T),H=a.slice(T+U.length);q[F]||(q[F]={}),q[F][H]=v;}else q._root||(q._root={}),q._root[a]=v;}o({...E,data:q});})},registerModule(e,o){if(c.has(e))throw new Error(`[Directive] Module namespace "${e}" already exists. Cannot register a duplicate namespace.`);if(e.includes(U))throw new Error(`[Directive] Module name "${e}" contains the reserved separator "${U}".`);if(G.has(e))throw new Error(`[Directive] Module name "${e}" is a blocked property.`);for(let _ of Object.keys(o.schema.facts))if(_.includes(U))throw new Error(`[Directive] Schema key "${_}" in module "${e}" contains the reserved separator "${U}".`);let l=o,E=l.crossModuleDeps&&Object.keys(l.crossModuleDeps).length>0,q=E?Object.keys(l.crossModuleDeps):[],a={};for(let[_,d]of Object.entries(l.schema.facts))a[`${e}${U}${_}`]=d;let v=l.init?_=>{let d=oe(_,e);l.init(d);}:void 0,T={};if(l.derive)for(let[_,d]of Object.entries(l.derive))T[`${e}${U}${_}`]=(R,w)=>{let M=E?ce(R,e,q):oe(R,e),A=Pe(w,e);return d(M,A)};let F={};if(l.events)for(let[_,d]of Object.entries(l.events))F[`${e}${U}${_}`]=(R,w)=>{let M=oe(R,e);d(M,w);};let H={};if(l.constraints)for(let[_,d]of Object.entries(l.constraints)){let R=d;H[`${e}${U}${_}`]={...R,deps:R.deps?.map(w=>`${e}${U}${w}`),when:w=>{let M=E?ce(w,e,q):oe(w,e);return R.when(M)},require:typeof R.require=="function"?w=>{let M=E?ce(w,e,q):oe(w,e);return R.require(M)}:R.require};}let J={};if(l.resolvers)for(let[_,d]of Object.entries(l.resolvers)){let R=d;J[`${e}${U}${_}`]={...R,resolve:async(w,M)=>{let A=$e(M.facts,t,K);await R.resolve(w,{facts:A[e],signal:M.signal});}};}let I={};if(l.effects)for(let[_,d]of Object.entries(l.effects)){let R=d;I[`${e}${U}${_}`]={...R,run:(w,M)=>{let A=E?ce(w,e,q):oe(w,e),ee=M?E?ce(M,e,q):oe(M,e):void 0;return R.run(A,ee)},deps:R.deps?.map(w=>`${e}${U}${w}`)};}c.add(e),t[e]=l,z.names=null;let L=[];for(let _ of Object.keys(l.schema.facts))L.push(`${e}${U}${_}`);if(l.schema.derivations)for(let _ of Object.keys(l.schema.derivations))L.push(`${e}${U}${_}`);P.set(e,L),S.registerModule({id:l.id,schema:a,requirements:l.schema.requirements??{},init:v,derive:Object.keys(T).length>0?T:void 0,events:Object.keys(F).length>0?F:void 0,effects:Object.keys(I).length>0?I:void 0,constraints:Object.keys(H).length>0?H:void 0,resolvers:Object.keys(J).length>0?J:void 0,hooks:l.hooks,history:{snapshotEvents:y&&!y.has(e)?[]:l.history?.snapshotEvents?.map(_=>`${e}${U}${_}`)}});}};return lt(x,S),dt(x),x}function ut(n){let t=n.history,c=n.trace,i=n.errorBoundary;if(n.zeroConfig){let y=process.env.NODE_ENV!=="production";t=t??y,i={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...n.errorBoundary};}return {history:t,trace:c,errorBoundary:i}}function lt(n,t){Object.defineProperties(n,{trace:{get(){return t.trace},enumerable:true,configurable:true},isRunning:{get(){return t.isRunning},enumerable:true,configurable:true},isSettled:{get(){return t.isSettled},enumerable:true,configurable:true},isInitialized:{get(){return t.isInitialized},enumerable:true,configurable:true},isReady:{get(){return t.isReady},enumerable:true,configurable:true}}),n.whenReady=t.whenReady.bind(t),n.batch=t.batch.bind(t),n.onSettledChange=t.onSettledChange.bind(t),n.onHistoryChange=t.onHistoryChange.bind(t),n.inspect=t.inspect.bind(t),n.settle=t.settle.bind(t),n.explain=t.explain.bind(t),n.getSnapshot=t.getSnapshot.bind(t),n.restore=t.restore.bind(t);}function dt(n){process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!n.isRunning&&!n.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0);}function le(n){if(n.includes(".")){let[t,...c]=n.split(".");return `${t}${U}${c.join(U)}`}return n}function oe(n,t){let c=rt.get(n);if(c){let y=c.get(t);if(y)return y}else c=new Map,rt.set(n,c);let i=new Proxy({},{get(y,s){if(typeof s!="symbol"&&!G.has(s))return s==="$store"||s==="$snapshot"?n[s]:n[`${t}${U}${s}`]},set(y,s,u){return typeof s=="symbol"||G.has(s)?false:(n[`${t}${U}${s}`]=u,true)},has(y,s){return typeof s=="symbol"||G.has(s)?false:`${t}${U}${s}`in n},deleteProperty(y,s){return typeof s=="symbol"||G.has(s)?false:(delete n[`${t}${U}${s}`],true)},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return c.set(t,i),i}function $e(n,t,c){let i=st.get(n);if(i)return i;let y=new Proxy({},{get(s,u){if(typeof u!="symbol"&&!G.has(u)&&Object.hasOwn(t,u))return oe(n,u)},has(s,u){return typeof u=="symbol"||G.has(u)?false:Object.hasOwn(t,u)},ownKeys(){return c()},getOwnPropertyDescriptor(s,u){if(typeof u!="symbol"&&Object.hasOwn(t,u))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return st.set(n,y),y}var at=new WeakMap;function ce(n,t,c){let i=`${t}:${JSON.stringify([...c].sort())}`,y=at.get(n);if(y){let g=y.get(i);if(g)return g}else y=new Map,at.set(n,y);let s=new Set(c),u=["self",...c],h=new Proxy({},{get(g,f){if(typeof f!="symbol"&&!G.has(f)){if(f==="self")return oe(n,t);if(s.has(f))return oe(n,f);process.env.NODE_ENV!=="production"&&typeof f=="string"&&console.warn(`[Directive] Module "${t}" accessed undeclared cross-module property "${f}". Add it to crossModuleDeps or use "facts.self.${f}" for own module facts.`);}},has(g,f){return typeof f=="symbol"||G.has(f)?false:f==="self"||s.has(f)},ownKeys(){return u},getOwnPropertyDescriptor(g,f){if(typeof f!="symbol"&&(f==="self"||s.has(f)))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return y.set(i,h),h}function Pe(n,t){let c=it.get(n);if(c){let y=c.get(t);if(y)return y}else c=new Map,it.set(n,c);let i=new Proxy({},{get(y,s){if(typeof s!="symbol"&&!G.has(s))return n[`${t}${U}${s}`]},has(y,s){return typeof s=="symbol"||G.has(s)?false:`${t}${U}${s}`in n},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return c.set(t,i),i}function _t(n,t,c){let i=ot.get(n);if(i)return i;let y=new Proxy({},{get(s,u){if(typeof u!="symbol"&&!G.has(u)&&Object.hasOwn(t,u))return Pe(n,u)},has(s,u){return typeof u=="symbol"||G.has(u)?false:Object.hasOwn(t,u)},ownKeys(){return c()},getOwnPropertyDescriptor(s,u){if(typeof u!="symbol"&&Object.hasOwn(t,u))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return ot.set(n,y),y}var ct=new WeakMap;function Nt(n,t,c){let i=ct.get(n);return i||(i=new Map,ct.set(n,i)),new Proxy({},{get(y,s){if(typeof s=="symbol"||G.has(s)||!Object.hasOwn(t,s))return;let u=i.get(s);if(u)return u;let h=new Proxy({},{get(g,f){if(typeof f!="symbol"&&!G.has(f))return D=>{n.dispatch({type:`${s}${U}${f}`,...D});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return i.set(s,h),h},has(y,s){return typeof s=="symbol"||G.has(s)?false:Object.hasOwn(t,s)},ownKeys(){return c()},getOwnPropertyDescriptor(y,s){if(typeof s!="symbol"&&Object.hasOwn(t,s))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Kt(n){let t=n.module;if(!t)throw new Error("[Directive] createSystem requires a module. Got: "+typeof t);if(n.tickMs!==void 0&&n.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(n.initialFacts&&!ae(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"&&(t.crossModuleDeps&&Object.keys(t.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&&(t.events&&"tick"in t.events||console.warn(`[Directive] tickMs is set to ${n.tickMs}ms but module has no "tick" event handler.`)),(typeof n.history=="object"?n.history:null)?.snapshotModules&&console.warn("[Directive] history.snapshotModules has no effect in single-module mode. Use history.snapshotEvents on the module definition instead, or switch to createSystem({ modules: { ... } }) for multi-module filtering."));let{history:c,trace:i,errorBoundary:y}=ut(n),s=null,u=null;u=we({modules:[{id:t.id,schema:t.schema.facts,requirements:t.schema.requirements,init:t.init,derive:t.derive,events:t.events,effects:t.effects,constraints:t.constraints,resolvers:t.resolvers,hooks:t.hooks,history:t.history}],plugins:n.plugins,history:c,trace:i,errorBoundary:y,tickMs:n.tickMs,onAfterModuleInit:()=>{if(n.initialFacts)if(!ae(n.initialFacts))process.env.NODE_ENV!=="production"&&console.warn("[Directive] initialFacts contains potentially dangerous keys. Skipping.");else for(let[m,S]of Object.entries(n.initialFacts))G.has(m)||(u.facts[m]=S);if(s){if(!ae(s))process.env.NODE_ENV!=="production"&&console.warn("[Directive] hydrate() data contains potentially dangerous keys. Skipping.");else for(let[m,S]of Object.entries(s))G.has(m)||(u.facts[m]=S);s=null;}}});let h=new Proxy({},{get(m,S){if(typeof S!="symbol"&&!G.has(S))return C=>{u.dispatch({type:S,...C});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),g=null,f=n.tickMs,D={_mode:"single",facts:u.facts,history:u.history,derive:u.derive,events:h,constraints:u.constraints,effects:u.effects,resolvers:u.resolvers,async hydrate(m){if(u.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let S=await m();S&&typeof S=="object"&&(s=S);},initialize(){u.initialize();},start(){u.start(),f&&f>0&&t.events&&"tick"in t.events&&(g=setInterval(()=>{u.dispatch({type:"tick"});},f));},stop(){g&&(clearInterval(g),g=null),u.stop();},destroy(){this.stop(),u.destroy();},dispatch(m){u.dispatch(m);},read(m){return u.read(m)},subscribe(m,S){return u.subscribe(m,S)},watch(m,S,C){return u.watch(m,S,C)},when(m,S){return u.when(m,S)},getDistributableSnapshot:u.getDistributableSnapshot.bind(u),watchDistributableSnapshot:u.watchDistributableSnapshot.bind(u),registerModule(m){u.registerModule({id:m.id,schema:m.schema.facts,requirements:m.schema.requirements,init:m.init,derive:m.derive,events:m.events,effects:m.effects,constraints:m.constraints,resolvers:m.resolvers,hooks:m.hooks,history:m.history});}};return lt(D,u),dt(D),D}function qe(){let n={pending:new Map,inflight:new Map,failed:new Map,errors:new Map,listeners:new Set};function t(){for(let g of n.listeners)g();}function c(g,f){let D=g.get(f);return D||(D=new Set,g.set(f,D)),D}function i(g){let f=n.pending.get(g)??new Set,D=n.inflight.get(g)??new Set,m=n.failed.get(g)??new Set,S=n.errors.get(g)??null;return {pending:f.size,inflight:D.size,failed:m.size,isLoading:f.size>0||D.size>0,hasError:m.size>0,lastError:S}}function y(){let g=new Set([...n.pending.keys(),...n.inflight.keys(),...n.failed.keys()]),f=new Map;for(let D of g)f.set(D,i(D));return f}function s(g){return n.listeners.add(g),()=>n.listeners.delete(g)}function u(){n.pending.clear(),n.inflight.clear(),n.failed.clear(),n.errors.clear(),t();}return {plugin:{name:"requirement-status",onRequirementCreated(g){let f=g.requirement.type;c(n.pending,f).add(g.id),n.failed.get(f)?.delete(g.id),t();},onResolverStart(g,f){let D=f.requirement.type;n.pending.get(D)?.delete(f.id),c(n.inflight,D).add(f.id),t();},onResolverComplete(g,f){let D=f.requirement.type;n.inflight.get(D)?.delete(f.id),n.pending.get(D)?.delete(f.id),t();},onResolverError(g,f,D){let m=f.requirement.type;n.inflight.get(m)?.delete(f.id),c(n.failed,m).add(f.id),n.errors.set(m,D instanceof Error?D:new Error(String(D))),t();},onResolverCancel(g,f){let D=f.requirement.type;n.pending.get(D)?.delete(f.id),n.inflight.get(D)?.delete(f.id),t();},onRequirementMet(g){let f=g.requirement.type;n.pending.get(f)?.delete(g.id),n.inflight.get(f)?.delete(g.id),t();}},getStatus:i,getAllStatus:y,subscribe:s,reset:u}}function Bt(n){return t=>n.getStatus(t)}function Wt(n){let t=qe(),i=[...n.plugins??[],t.plugin];return {system:Ie({module:n.module,plugins:i,trace:n.trace,errorBoundary:n.errorBoundary,tickMs:n.tickMs,zeroConfig:n.zeroConfig,initialFacts:n.initialFacts}),statusPlugin:t}}var Ln={None:"none",Linear:"linear",Exponential:"exponential"};exports.Backoff=Ln;exports.DirectiveError=ye;exports.RequirementSet=de;exports.createConstraintFactory=Ae;exports.createConstraintsManager=ke;exports.createDerivationsManager=Ee;exports.createDisabledHistory=Re;exports.createEffectsManager=Me;exports.createEngine=we;exports.createErrorBoundaryManager=xe;exports.createFacts=Ce;exports.createFactsProxy=et;exports.createFactsStore=Ze;exports.createHistoryManager=be;exports.createModule=Ne;exports.createModuleFactory=pt;exports.createPluginManager=Te;exports.createRequirementStatusPlugin=qe;exports.createResolverFactory=je;exports.createResolversManager=Oe;exports.createRetryLaterManager=Ye;exports.createStatusHook=Bt;exports.createSystem=Ie;exports.createSystemWithStatus=Wt;exports.diffSnapshots=St;exports.forType=xt;exports.generateRequirementId=He;exports.getCurrentTracker=ze;exports.isNamespacedSystem=yt;exports.isRequirementType=Mt;exports.isSignedSnapshot=wt;exports.isSingleModuleSystem=gt;exports.isSnapshotExpired=Be;exports.isTracking=Ot;exports.req=Et;exports.shallowEqual=ht;exports.signSnapshot=bt;exports.t=mt;exports.trackAccess=pe;exports.typedConstraint=Fe;exports.typedResolver=_e;exports.validateSnapshot=vt;exports.verifySnapshotSignature=Rt;exports.withTracking=ge;exports.withoutTracking=Se;//# sourceMappingURL=index.cjs.map
17
17
  //# sourceMappingURL=index.cjs.map