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